# Architecture diagram:



# Module description:

## Adder1:

執行 pc+=4

## Mux\_Write\_Reg:

由 reg\_dst 決定 write\_reg 的位置

## Decoder:

將 opcode 轉換至對應的{RegWrite , ALU\_op , ALU\_src , Reg\_dst , Branch} AC(ALU\_Crtl):

由 ALU\_op , function(instructions[5:0])決定 alu\_ctrl

## SE(Sign Extend):

將 instructions[15:0]變更為 32bits,並用 alu\_op 判斷是 sign ext./zero ext.

## Mux\_ALUsrc:

用 ALU\_src 決定 ALU 的 src2,0 為 rt 輸入,1 為 sign\_ex 輸入 ALU:

32bits ALU,原則上沿用 lab1 的架構,運算結果由 alu\_ctrl 控制,

alu\_ctrl[3]=>A\_invert,alu\_ctrl[2]=>B\_invert,alu\_ctrl[1:0]=00 為 and、01 為 or、10 為 add、11 為 slt。另外利用 alu\_op 判斷 sltiu 的情形,當遇到 sltiu 運算,取第 32 個 bit 的 cout 跟 1 再做一次 add 運算才是真正的 less\_set 結果。

#### shifter32:

以 shift\_ctrl(alu\_ctrl)決定 shift 的型態,shift\_ctrl=1000 為 lui,1001 為 sra、1010 為 srav

## Shifter\_1\_2:

執行 (n << 2)

### Adder2:

### equal confirm:

比較 bne、beq 的 opcode,在 opcode[0](instruction[26])會有差異,所以用 opcode[0]作為 select,用 zero\_result 作為 alu\_src1 與 alu\_src2 是否相同的依據。

### and\_gate to pointer:

以 branch 控制要不要輸出 equal\_confirm 的結果

# Mux\_PC\_Source:

當 pointer 結果輸入會辨別要不要以 adder2 的結果回傳給 PC result confirm:

用 alu\_ctrl[3]控制,1 為回傳 shifter\_result 到 write\_data、0 為回傳 alu\_result 到 write\_data

## Waveform:

### addi

|   | Signals        | Waves    |          |          |          |     |          |     |          |     |
|---|----------------|----------|----------|----------|----------|-----|----------|-----|----------|-----|
| _ | Time           | )        | 10       | sec      | 20       | sec | 30       | sec | 40       | sec |
| П | pc_out_o[31:0] | XXXXXXXX | 00000000 |          | 00000004 |     | 80000000 |     | 0000000C |     |
|   | RDaddr_i[4:0]  | xx       | 00       |          | 02       |     | 06       |     | 00       |     |
|   | RDdata_i[31:0] | XXXXXXXX | FFFF9489 |          | FFFFADAB |     | FFFFA6BD |     | FFFF2912 |     |
|   | RSaddr_i[4:0]  | ××       | 02       |          | 00       |     |          |     |          |     |
|   | RSdata_o[31:0] | XXXXXXXX | 00000002 |          | FFFF9489 |     |          |     |          |     |
|   | RTaddr_i[4:0]  | xx       | 00       |          | 02       |     | 06       |     | 00       |     |
|   | RTdata_0[31:0] | XXXXXXXX | 00000000 | FFFF9489 | 00000002 |     | 0000000€ |     | FFFF9489 |     |
|   |                |          |          |          |          |     |          |     |          |     |
| 1 |                |          |          |          |          |     |          |     |          |     |

#### Addu

| Sign | nals         | Waves    |          |     |          |     |          |     |          |     |  |
|------|--------------|----------|----------|-----|----------|-----|----------|-----|----------|-----|--|
| Ti   | me           |          | 10       | sec | 20       | sec | 30       | sec | 40       | sec |  |
| pc   | _out_o[31:0] | XXXXXXXX | 00000000 |     | 00000004 |     | 80000000 |     | 000000C  |     |  |
| R    | Daddr_i[4:0] | M.M.     | 00       |     | 01       |     | 06       |     | 00       |     |  |
| RD   | data_i[31:0] | XXXXXXXX | 00000005 |     | 00000009 |     | 00000007 |     | A0000000 |     |  |
| R    | Saddr_i[4:0] | MM       | 02       |     | 04       |     | 0A       |     | 00       |     |  |
| RS   | data_o[31:0] | XXXXXXXX | 00000002 |     | 00000004 |     | FFFFFFFF |     | 00000005 | (   |  |
| R'   | Taddr_i[4:0] | xx       | 03       |     | 05       |     | 08       |     | 00       |     |  |
| RT   | data_0[31:0] | жжжжж    | 00000003 |     | 00000005 |     | 00000008 |     | 00000005 | )   |  |
|      |              |          |          |     |          |     |          |     |          |     |  |

# and

| Time           |          |          |          |          |           |
|----------------|----------|----------|----------|----------|-----------|
| pc_out_o[31:0] | XXXXXXXX | 00000000 | 00000004 | 0000008  | 0000000C  |
| RDaddr_i[4:0]  | жж       | 00       | 06       | 01       | X00       |
| RDdata_i[31:0] | xxxxxxxx | 00000006 | 00000002 | 00000000 | \00000006 |
| RSaddr_i[4:0]  | жж       | 0B       | 00       | 08       | 00        |
| RSdata_o[31:0] | XXXXXXXX | FFFFFFFE | 00000006 | 00000008 | 00000006  |
| RTaddr_i[4:0]  | жж       | 07       | 02       | 07       | X00       |
| RTdata_0[31:0] | XXXXXXXX | 00000007 | 00000002 | 0000007  | 00000006  |
|                |          |          |          |          |           |

# Beq

| Time           | )        | 10 sec   | 20 sec   | 30 sec   | 40 sec   |
|----------------|----------|----------|----------|----------|----------|
| pc_out_o[31:0] | xxxxxxx  | 00000000 | 00000008 | 0000000C | 00000010 |
| RDaddr_i[4:0]  | жx       | 00       | 07       | 00       |          |
| RDdata_i[31:0] | XXXXXXXX | 00000000 | 00000001 | 00000000 |          |
| RSaddr_i[4:0]  | ж        | 00       | 02       | 00       |          |
| RSdata_o[31:0] | XXXXXXXX | 00000000 | 00000002 | 00000000 |          |
| RTaddr_i[4:0]  | жx       | 00       | 07       | 00       |          |
| RTdata o[31:0] | xxxxxxx  | 00000000 | 00000007 | 00000000 |          |

# Bne

| Signais        | waves    |          |     |          |     |          |     |          |     |
|----------------|----------|----------|-----|----------|-----|----------|-----|----------|-----|
| Time           | )<br>    | 10       | sec | 20       | sec | 30       | sec | 40       | sec |
| pc_out_o[31:0] | XXXXXXXX | 00000000 | )   | 80000000 |     | 0000000C |     | 00000010 |     |
| RDaddr_i[4:0]  | жж       | 00       | )   | 07       |     | 00       |     |          |     |
| RDdata_i[31:0] | XXXXXXXX | 00000001 |     |          |     | 00000000 |     |          |     |
| RSaddr_i[4:0]  | жж       | 01       | )   | 02       |     | 00       |     |          |     |
| RSdata_o[31:0] | XXXXXXXX | 00000001 | )   | 00000002 |     | 00000000 |     |          |     |
| RTaddr_i[4:0]  | жж       | 00       | )   | 07       |     | 00       |     |          |     |
| RTdata_o[31:0] | XXXXXXXX | 00000000 | )   | 00000007 |     | 00000000 |     |          |     |
|                |          |          |     |          |     |          |     |          |     |

# Lui

| Signals        | Waves    |          |          |          |     |          |     |          |     |
|----------------|----------|----------|----------|----------|-----|----------|-----|----------|-----|
| Time           | )        | 10       | sec      | 20       | sec | 30       | sec | 40       | sec |
| pc_out_o[31:0] | XXXXXXXX | 00000000 |          | 00000004 |     | 00000008 |     | 0000000C |     |
| RDaddr_i[4:0]  | жж       | 00       |          | 04       |     | 08       |     | 00       |     |
| RDdata_i[31:0] | хххххххх | DEAD0000 |          | BEEF0000 |     | 2EDA0000 |     | 00000000 |     |
| RSaddr_i[4:0]  | жж       | 00       |          |          |     |          |     |          |     |
| RSdata_o[31:0] | XXXXXXXX | 00000000 | DEAD0000 |          |     |          |     |          |     |
| RTaddr_i[4:0]  | жж       | 00       |          | 04       |     | 08       |     | 00       |     |
| RTdata_o[31:0] | хххххххх | 00000000 | DEAD0000 | 00000004 |     | 00000008 |     | DEAD0000 |     |
|                |          |          |          |          |     |          |     |          |     |

## or

| Signals        | Waves    |          |          |     |          |     |          |     |
|----------------|----------|----------|----------|-----|----------|-----|----------|-----|
| Time           | )        | 10 sec   | 20       | sec | 30       | sec | 40       | sec |
| pc_out_o[31:0] | XXXXXXXX | 00000000 | 00000004 |     | 80000000 |     | 000000C  |     |
| RDaddr_i[4:0]  | xx       | 00       | 0€       |     | 01       |     | 00       |     |
| RDdata_i[31:0] | XXXXXXXX | FFFFFFFF |          |     | 0000000A |     | FFFFFFFF |     |
| RSaddr_i[4:0]  | жж       | 0B       | 00       |     | 08       |     | 00       |     |
| RSdata_o[31:0] | XXXXXXXX | FFFFFFFE | FFFFFFFF |     | 00000008 |     | FFFFFFFF |     |
| RTaddr_i[4:0]  | xx       | 07       | 02       |     |          |     | 00       |     |
| RTdata_0[31:0] | XXXXXXXX | 00000007 | 00000002 |     |          |     | FFFFFFF  |     |
|                |          |          |          |     |          |     |          |     |
|                |          |          |          |     |          |     |          |     |

# Ori

| Time           | )        | 10       | sec      | 20       | sec | 30       | sec | 40       | sec |
|----------------|----------|----------|----------|----------|-----|----------|-----|----------|-----|
| pc_out_o[31:0] | XXXXXXXX | 00000000 |          | 00000004 |     | 80000000 |     | 0000000C |     |
| RDaddr_i[4:0]  | xx       | 00       |          | 04       |     | os       |     | 00       |     |
| RDdata_i[31:0] | XXXXXXX  | 0000DEAD |          | FFFFFFF  |     | 00002EDE |     | 0000DEAD |     |
| RSaddr_i[4:0]  | жж       | 00       |          | OB       |     | 06       |     | 00       |     |
| RSdata_0[31:0] | XXXXXXXX | 00000000 | 0000DEAD | FFFFFFF  |     | 0000000€ |     | 0000DEAD |     |
| RTaddr_i[4:0]  | XX       | 00       |          | 04       |     | 08       |     | 00       |     |
| RTdata_o[31:0] | XXXXXXXX | 00000000 | 0000DEAD | 00000004 |     | 00000008 |     | OOOODEAD |     |
|                |          |          |          |          |     |          |     |          |     |

#### Slt

| Time           | <u> </u> | 10 sec   | 20 sec   | 30 sec   | 40 sec   |
|----------------|----------|----------|----------|----------|----------|
| pc_out_o[31:0] | XXXXXXXX | 00000000 | 00000004 | 00000008 | 0000000C |
| RDaddr_i[4:0]  | xx       | 00       | 01       | 02       | 00       |
| RDdata_i[31:0] | XXXXXXXX | 00000001 | 00000000 | 00000001 | 0000000  |
| RSaddr_i[4:0]  | xx       | 02       | 08       | 0A       | 00       |
| RSdata_o[31:0] | XXXXXXXX | 00000002 | 00000008 | FFFFFFF  | 00000001 |
| RTaddr_i[4:0]  | xx       | 04       | 06       | 04       | 00       |
| RTdata o[31:0] | XXXXXXX  | 00000004 | 0000000€ | 0000004  | 00000001 |

### Sltiu



#### Sra

|   | Signals        | Waves    |          |     |          |     |          |     |          |     |
|---|----------------|----------|----------|-----|----------|-----|----------|-----|----------|-----|
| _ | Time           | )        | 10       | sec | 20       | sec | 30       | sec | 40       | sec |
|   | pc_out_o[31:0] | xxxxxxxx | 00000000 |     | 00000004 |     | 80000000 |     | 0000000C |     |
|   | RDaddr_i[4:0]  | жx       | 02       |     | 08       |     | 06       |     | 00       |     |
|   | RDdata_i[31:0] | XXXXXXXX | 00000000 |     | 0000003  |     | FFFFFFF  |     | 00000000 |     |
|   | RSaddr_i[4:0]  | жж       | 00       |     |          |     |          |     |          |     |
|   | RSdata_o[31:0] | XXXXXXXX | 00000000 |     |          |     |          |     |          |     |
|   | RTaddr_i[4:0]  | жж       | 03       |     | 07       |     | 0B       |     | 00       |     |
|   | RTdata_o[31:0] | XXXXXXXX | 00000003 |     | 00000007 |     | FFFFFFE  |     | 00000000 |     |
|   |                |          |          |     |          |     |          |     |          |     |

#### Srav

| Time           |          | 10       | sec 20   | sec 30   | sec 40 s | ec |
|----------------|----------|----------|----------|----------|----------|----|
| pc_out_o[31:0] | xxxxxxx  | 00000000 | 0000004  | 00000008 | 00000000 | Х  |
| RDaddr_i[4:0]  | xx       | 02       | 08       | 0€       | 00       |    |
| RDdata_i[31:0] | XXXXXXXX | 00000000 | 00000003 | FFFFFFF  | 00000000 |    |
| RSaddr_i[4:0]  | xx       | 03       | 01       | 03       | 00       |    |
| RSdata_0[31:0] | XXXXXXXX | 00000003 | 00000001 | 00000003 | 00000000 |    |
| RTaddr_i[4:0]  | xx       | 03       | 07       | ОВ       | 00       |    |
| RTdata_o[31:0] | XXXXXXXX | 00000003 | 00000007 | FFFFFFE  | 00000000 |    |
|                |          |          |          |          |          |    |

#### Subu

| Signals        | Waves    |          |     |         |     |          |     |          |     |
|----------------|----------|----------|-----|---------|-----|----------|-----|----------|-----|
| Time           |          | 10       | sec | 20      | sec | 30       | sec | 40       | sec |
| pc_out_o[31:0] | xxxxxxx  | 00000000 | λο  | 0000004 |     | 00000008 |     | 0000000C | X   |
| RDaddr_i[4:0]  | xx       | 00       | Χα  | 1       |     | 0B       |     | 00       |     |
| RDdata_i[31:0] | xxxxxxx  | FFFFFFFF | Χα  | 0000004 |     | 00000005 |     | 00000000 |     |
| RSaddr_i[4:0]  | xx       | 02       | )(α | 19      |     | 01       |     | 00       |     |
| RSdata_o[31:0] | XXXXXXX  | 00000002 | )(α | 0000009 |     | 00000004 |     | FFFFFFFF | Х   |
| RTaddr_i[4:0]  | жж       | 03       | χο  | 5       |     | 00       |     |          |     |
| RTdata_0[31:0] | XXXXXXXX | 00000003 | λα  | 0000005 |     | FFFFFFFF |     |          | Х   |
|                |          |          |     |         |     |          |     |          |     |

## Questions:

1. What is the difference between "input [15:0] input\_0" and "input [0:15] input\_0" inside the module? 若是前者 input\_0[0] 會是最右邊的位數,而後者 input\_0[0]會最左邊的位數

2. What is the meaning of "always" block in Verilog? 當指定參數條件符合或是設定任何在always block的參數改變,即執行一次always block裡的程序

3. What are the advantages and disadvantages of port connection by order and port connection by name in Verilog?

Port connection by order:

Advantage: 較簡潔,當module的參數與外部參數命名一樣時,可 直接套用

Disadvantage: 容易混淆,debug時可能會造成不便

Port connection by name:

Advantage: 架構清楚,且不用對應原先module設定的順序,在 trace和debug上較有優勢。

Disadvantage: 若module參數名稱與原先建立的不相符(錯字),執行程序就會出錯。

## Contribution:

Most of architecture , debug

Anything to share:

這次lab我發現自己有個壞毛病,在實行alu\_ctrl之類的功能時,我會習慣直接輸入數字代碼,而非利用localparam之類的狀態機參數定義,導致後面在debug的時候,trace不易,要看數字去對應到功能花了不少時間。