### 5段パイプラインプロセッサのブロックダイアグラム ADD **Execution Complex** pc[31:0] jaddr[31:0] Instruction Decoder branch Register Instruction Memory File a[31:0] ra\_name[4:0] ra[31:0] addr[31:0] instr[31:0] rb\_name[4:0] rb[31:0] **→** b[31:0] result[31:0] CLK rd\_name[5:0] rd[31:0] ▶ imm[19:0] imm[19:0] rd\_name[4:0] inst[11:0] Fetch Stage Decode Stage Register-Fetch Stage **Execution Stage** Write-Back Stage

### 命令デコーダの入出力

#### 入力

•命令列(32bit): instr

#### 出力

- •ソースレジスタAの名前(5bit): ra\_name
- •ソースレジスタBの名前(5bit): rb\_name
- ・デスティネーションレジスタの名前(5bit): rd\_name
- •即值(20bit): imm
- •制御信号(14bit): inst
- 実行ステージにおける使用ユニット(4bit)
- ALU
- シフタ
- ロード・ストアユニット
- ジャンプユニット
- ALU、コンパレータのオペコード (4bit)
- NOP, ADD, SUB, AND, OR, XOR
- ==, !=, <, >=
- 命令の種類 (6bit)
- R-type
- I-type
- S-type
- B-type
- U-type
- J-type



制御信号のビットパターン

## **Execution Complex (Jump Unit)**



# Execution Complex (Load/Store Unit)

