命令セット(めいれいせっと、instruction set)は、プログラマから見たコンピュータ・アーキテクチャを指す言葉で、データ型、命令、レジスタ、アドレッシングモード、メモリアーキテクチャ、割り込みと例外処理、(もしあれば)入出力などから構成される。命令セットアーキテクチャ(instruction set architecture、ISA)とも言う。
ISAは、CPUに実装された命令形式を二進数のコード(オペコード)のセットで表現したものである。オペコードのセットは、機械語とも呼ばれる。
命令セットアーキテクチャは、マイクロアーキテクチャと区別するための用語でもある。マイクロアーキテクチャとは、ある命令セットを実装するためのプロセッサ設計上の技術を意味する(マイクロコード、パイプライン、キャッシュシステム、など)。 マイクロアーキテクチャの異なるコンピュータが同じ命令セットを共有することもある。 例えば、インテルのPentiumとAMDのAthlonは、実装しているx86命令セットはほとんど同じだが内部設計は全く異なる。
この概念を拡大したユニークなISAとしてTIMI (Technology-Independent Machine Interface) があり、これはシステム/38とAS/400で使われている。TIMIは最近では仮想機械として知られるソフトウェアで実現されている。これはプラットフォームとそこで動作するアプリケーションの寿命を延ばすために設計されたもので、プラットフォーム全体を全く異なるハードウェアに移行してもTIMI自身だけを移植すれば、その上のオペレーティングシステムもアプリケーションもそのまま動作する。このためIBMはAS/400のハードウェアを古いCISCからPOWERに移行させたが、OSを含めたソフトウェアは全く変更せずに済んだ。
マイクロアーキテクチャを設計するとき、技術者は Register Transfer Language (RTL) を使って ISA の各命令の処理を定義する。
ISAは、インタプリタによりソフトウェアとしてエミュレートすることもできる。 一般にエミュレーションで動作すると、直接ハードウェアで同じISAを実装したときよりも遅くなる。 今日、新たなISA(あるいはマイクロアーキテクチャ)を開発しようとするベンダーはソフトウェアエミュレータを作って、ハードウェアが完成する前にソフトウェア開発者が開発に取り掛かることができるようにするのが一般的である。
Befehlssatz | Instruction set | Conjunto de instrucciones | Jeu d'instructions | סט פקודות | Utasításkészlet | Instruction set | ISA (procesory) | Система команд | Komut kümesi | Архітектура системи команд