Processing math: 100%

コンピュータ・アーキテクチャ 第8回


電子計算機とマイクロコンピュータ

電子計算機は以下の要素から構成されています(図8.1参照)

処理装置の基本的構成

一度に取り扱うデータの単位は、4, 8, 16, 32, 64 bit などがあります。 今回の例では 8bit のものを示します(図8.2参照)。


アドレスバッファ (address buffer) からアドレスを与えると、 記憶装置はそのアドレスで指定された番地(記憶位置)から 8ビットのデータを取り出し、データバッファ (data buffer) に入れます。

アドレスバッファの容量を 16 bit とすると、最大で 64Kbyte (= 216)のデータを記憶することができます。 記憶装置にデータを書き込むときは、データバッファにデータを 与え、アドレスバッファからアドレスを与えます。

直接アドレス指定命令

直接アドレス指定 (direct addressing) 命令では、メモリのアドレスを 1つ指定して、そのアドレス位置に記憶されているデータ(1byte)を操作 (たとえばAレジスタにコピー)します。

直接アドレス指定命令は3バイトで表現され、 第1バイトが命令の種類、第2,3バイトがアドレスを 表しています(図8.3参照)。


[例題] 50番地と51番地のデータをそれぞれ1000番地と1001番地へ移動する プログラムを作りなさい。
[解答]

    LDA     50        ← 50番地の内容をAレジスタにコピーします
    STA   1000        ← Aレジスタの内容を1000番地にコピーします
    LDA     51        ← 51番地の内容をAレジスタにコピーします
    STA   1001        ← Aレジスタの内容を1001番地にコピーします

LDA命令を実行するときの内部動作 (図8.4参照)
LDA命令は3バイト(命令の種類を表すのに1バイト、アドレスを表すのに2バイト) の大きさで、たとえばメモリ中の 2000〜2002番地に格納されています。 プログラム・カウンタがこの2000番地を指した時に命令が実行されます。

  1. プログラムカウンタの内容がアドレスバッファに与えられます。
  2. これにより LDA を示す命令情報がデータバッファを通して
  3. 命令レジスタに与えられます。 命令レジスタはこれを解読し、続く2バイトを必要とする命令で あることを知ります。
  4. (PCは既に1加算されているので)PCの内容をアドレスバッファに送り
  5. 第2バイトを取り出します。
  6. このバイトは W レジスタに入れられます。
  7. (PCはさらに1加算されているので)再びアドレスバッファを通して 記憶装置に与え
  8. データバッファを通して第3バイトが取り出され
  9. Zレジスタに入れられます。
  10. WZレジスタの内容をアドレスバッファに送れば LDA 命令の アドレス部で指定された記憶装置の内容が取り出され、
  11. データバッファに入ります。
  12. 次にIRの制御によりこのデータはAレジスタに入れられます。

命令は、各レジスタの間で適切なタイミングで適切なバスを通して データを転送することで実行されます。各レジスタの間にはゲート回路 が設けられていて、IRの内容を解読することによってこの転送用ゲート が開閉されます。 計算機はレジスタ間の情報の転送を制御することで動作します。


8080 マイクロプロセッサ

インテルの8bitマイクロプロセッサ。 比較的初期のもので、構造がシンプルで理解しやすいプロセッサです。

レジスタ構成(図8.5参照)


Aレジスタ (アキュムレータ)以外に 8 個 (B, C, D, E, H, L, W, Z) の レジスタを持ちます。 Aレジスタと関連したフラグレジスタ(5bit)の意味は次の通りです。

BC, DE, HL, WZ のレジスタ対をまとめて1つの 16ビットレジスタとして 扱うこともあります。 他のレジスタとしては、命令レジスタ(IR)、プログラムカウンタ (PC)、 スタックポインタ (SP) があります。

Tレジスタは演算するデータを一時的に記憶しておくレジスタで、 外部から命令で直接指定することはできません(W,Zレジスタも同様です)。

アドレスやデータを指定する方法としては、以下のものがあります。

命令

i8080CPUの命令の抜粋を表に示す。 ( 命令全体に関しては 8080命令説明書 などを参照して下さい。)

表中で、 r1, r2, r はレジスタを表す。 Mは H,Lレジスタのペアで表される番地のメモリを表す。 B2, B3は命令コードに続く2バイト目、3バイト目のデータを表す。 (X)は矢印の右に現れたときは X から内容をコピーすることを表わし、 矢印の左に現れたときは X の内容を書き換えることを表す。 [X]は矢印の右に現れたときは X が指すメモリ位置からデータをコピーすることを表わし、 矢印の左に現れたときは X が指すメモリ位置の内容を書き換えることを表す。

ニーモニック
(記号命令)
命令コード命令長
(byte)
動作
MOV r1, r2 01DDDSSS 1 (r1) (r2)
MOV r, M 01DDD110 1 (r) [ (H)(L) ]
MOV M, r 01110SSS 1 [ (H)(L) ] (r)
MVI r, B2 00DDD110 2 (r) B2
LDA B3B2 00111010 3 (A) [ B3B2 ]
STA B3B2 00110010 3 [ B3B2 ] (A)
LHLD B3B2 00101010 3 (L) [ B3B2 ]
(H) [ B3B2+1 ]
SHLD B3B2 00100010 3 [ B3B2 ] (L)
[ B3B2+1 ] (H)
ADD r 10000SSS 1 (A) (A) + (r)
ADD M 10000110 1 (A) (A) + [ (H)(L) ]
ADI B2 11000110 2 (A) (A) + B2
SUB r 10010SSS 1 (A) (A) (r)
SUB M 10010110 1 (A) (A) [ (H)(L) ]
SUI B2 11010110 2 (A) (A) B2
CMP r 10111SSS 1 (A) (r) を計算してフラグに反映。Aレジスタは変更されない。
CMP M 10111110 1 (A) [ (H)(L) ] を計算してフラグに反映。Aレジスタは変更されない。
CPI B2 11111110 2 (A) B2 を計算してフラグに反映。Aレジスタは変更されない。
INR r 00DDD100 1 (r) (r) +1
DCR r 00DDD101 1 (r) (r) 1
INX rp 00RP0011 1 (rp) (rp) +1rp={BC, DE, HL, SP}。
DCX rp 00RP1011 1 (rp) (rp) 1rp={BC, DE, HL, SP}。
JMP B3B2 11000011 3 B3B2 番地にジャンプする。(PC) B3B2
JNZ B3B2 11000010 3 zeroフラグがセットされていなければB3B2 番地にジャンプする。
JZ B3B2 11001010 3 zeroフラグがセットされていたらB3B2 番地にジャンプする。
PUSH rp 11RP0101 1 [ (SP)1 ] (rp1)
[ (SP)2 ] (rp2)
(SP) (SP)2,
rp={BC,DE,HL,PSW} のとき(rp1,rp2)={(B,C), (D,E), (H,L), (A, Flags)}。
POP rp 11RP0001 1 (rp2) [ (SP) ]
(rp1) [ (SP)+1 ]
(SP) (SP)+2
rp={BC,DE,HL,PSW} のとき(rp1,rp2)={(B,C), (D,E), (H,L), (A, Flags)}。
CALL B3B2 11001101 3 [ (SP)1 ] (PChigh)
[ (SP)2 ] (PClow)
(SP) (SP) 2
(PC) B3B2
RET 11001001 1 (PClow) [ (SP) ]
(PChigh) [ (SP)+1 ]
(SP) (SP) +2
HLT 01110110 1 割込みかリセットがかかるまでCPUの実行を停止する。
NOP 00000000 1 何も実行しないで次の命令に進む。
レジスタ SSS DDD
A 111
B 000
C 001
D 010
E 011
H 100
L 101
レジスタ RP
BC 00
DE 01
HL 10
SP 11

8080マイクロプロセッサにおける命令の実行

マイクロプロセッサの命令は、命令のバイト数もいろいろで、 アドレス方式も多岐に渡ります。 これらの命令がどのように実行されるかを説明します。

マイクロプロセッサは記憶装置、入出力装置などと組合されて コンピュータを構成する(図8.8参照)。


マイクロプロセッサの制御バスには ~MEMR, ~MEMW, ~IOR, ~IOW の4本があり、 CPU ←→ 記憶装置、 CPU ←→ 入出力装置 の間の 読み出し(R) / 書き込み(W) を制御します(図8.5参照)。

クロック周波数を 2MHz とし、記憶装置の読み出し、書き込みに それぞれ3クロックが必要であるとします。 この3クロックの期間をサイクルと呼びます(図8.9参照)。

読み出しの場合:
    T1: アドレスバスにアドレスを与えます。
    T2: ~MEMR に信号を与えます。
    T3: データを得ます。
書き込みの場合:
    T1: アドレスバスにアドレスを与えます。
    T2: ~MEMW に信号を与えつつ、データバスにデータを与えます。
    T3:    々


いろいろな命令を実行するときの動作タイミングを示します。 8080では命令の実行に要する時間は命令毎に異なっていて、 それぞれの命令毎に製造会社から提供されているマニュアルに 記載されています。

上記のように、命令の実行に必要な時間(クロック数)は命令により 異なります。各命令の取り得るアドレス指定、実行に必要なクロック数は CPUのマニュアルに記載されています。

マイクロプロセッサのプログラミング

表8.1に示される機械語のビットパターンを直接人間が書くことは通常なく、

  1. 機械語に対応する記号命令(アセンブリ言語)によってプログラムを書く
  2. CやC++などの高級言語によってプログラムを書く
という方法を取ります。

アセンブリ言語では、表8.1のような記号命令を使い、命令や変数を 記憶するアドレスを記号(ラベル)で参照できます。