article

命令セット(めいれいせっと、instruction set)は、プログラマから見たコンピュータ・アーキテクチャを指す言葉で、データ型、命令、レジスタアドレッシングモード、メモリアーキテクチャ、割り込み例外処理、(もしあれば)入出力などから構成される。命令セットアーキテクチャ(instruction set architectureISA)とも言う。

ISAは、CPUに実装された命令形式を二進数のコード(オペコード)のセットで表現したものである。オペコードのセットは、機械語とも呼ばれる。

命令セットアーキテクチャは、マイクロアーキテクチャと区別するための用語でもある。マイクロアーキテクチャとは、ある命令セットを実装するためのプロセッサ設計上の技術を意味する(マイクロコードパイプラインキャッシュシステム、など)。 マイクロアーキテクチャの異なるコンピュータが同じ命令セットを共有することもある。 例えば、インテルPentiumAMDAthlonは、実装しているx86命令セットはほとんど同じだが内部設計は全く異なる。

この概念を拡大したユニークなISAとしてTIMI (Technology-Independent Machine Interface) があり、これはシステム/38AS/400で使われている。TIMIは最近では仮想機械として知られるソフトウェアで実現されている。これはプラットフォームとそこで動作するアプリケーションの寿命を延ばすために設計されたもので、プラットフォーム全体を全く異なるハードウェアに移行してもTIMI自身だけを移植すれば、その上のオペレーティングシステムもアプリケーションもそのまま動作する。このためIBMはAS/400のハードウェアを古いCISCからPOWERに移行させたが、OSを含めたソフトウェアは全く変更せずに済んだ。

マイクロアーキテクチャを設計するとき、技術者は Register Transfer Language (RTL) を使って ISA の各命令の処理を定義する。

ISAは、インタプリタによりソフトウェアとしてエミュレートすることもできる。 一般にエミュレーションで動作すると、直接ハードウェアで同じISAを実装したときよりも遅くなる。 今日、新たなISA(あるいはマイクロアーキテクチャ)を開発しようとするベンダーはソフトウェアエミュレータを作って、ハードウェアが完成する前にソフトウェア開発者が開発に取り掛かることができるようにするのが一般的である。

ISA一覧


この一覧は完全ではない。古いものは省かれていて、新しいものはこれからも出てくるだろう。 商用のマイクロプロセッサマイクロコントローラは様々なISAを実装している。 ISAのカスタマイズも非常によく見られる。

ハードウェアで実装されたISA

ハードウェアでも実装されたが一般にはソフトウェアで実装されているISA

ハードウェアに実装されていないISA

  • SECD machine
  • ALGOL Object Code

関連項目


ISAのカテゴリー

商用の使用可能なISA

その他

コンピュータアーキテクチャ

Befehlssatz | Instruction set | Conjunto de instrucciones | Jeu d'instructions | סט פקודות | Utasításkészlet | Instruction set | ISA (procesory) | Система команд | Komut kümesi | Архітектура системи команд

 

This article is licensed under the GNU Free Documentation License. It uses material from the "命令セット".

Home Pageartsbusinesscomputersgameshealthhospitalshomekids & teensnewsphysiciansrecreationreferenceregionalscienceshoppingsocietysportsworld