# 計算機組織期末Project

教授: 朱守禮

組別:15

組員:

11027102仇瀚慶 11027142 林蕙郁 11027144 陳佳音 11027131 李虹昀

# 一、Datapath與詳細資料圖:



#### 二、設計重點說明

使用了5種暫存器(分別為IF ID、ID EX、EX MEM、MEM WB)五種部份。

#### 第一階段: IF

IF\_ID存了PC, INS, INS, reset, clk, enable

這個MUDULE(IF\_ID)存了兩個值: PC(指令位置)及INS(指令數據), 當enable信號為高電位時, PCout輸出的值等於PCin輸入的值, 儲存了指令位置。同樣的, INSout輸出的值就會等於INSin輸入的值, 儲存了指令數據。

#### 第二階段: ID

ID\_EX存了WB, MEMORY, EX, IDEX, RD1, RD2, Extnd, shamt, RT, RD, funct, IDEX\_ctlbrn, jump, jumpaddr, IDEX, RT, functin, reset, clk, enable

這個MODULE會從第一階段(IF\_ID)階段接收PC(指令位置)和INS(指令數據)。如果enable信號為高電位,則將PCin的值傳遞到PCout,保存指令位置。同樣地,將INSin的值傳遞到INSout,保存指令數據。從Register File中讀取第一個RD1的值,並將其傳遞到IDEX\_Rd1out再從Register File中讀取第二個數據寄存器RD2的值,並傳到IDEX\_Rd2out。對立即數進行符號擴展,並將結果傳遞到SignEXTNDout。對它進行無符號擴展,並將結果傳到UNEXTNDout。根據控制單元的信號(control signal),從UNEXTNDout和SignEXTNDout中選擇擴展結果,再將其傳遞到extendmuxout。從IF\_ID做出的動作再把結果進入ID\_EX存起,例如ALU操作類型和分支控制信號。將控制信號傳遞到IDEX\_ctlbrnout,以供後續階段使用。最後檢查是否存在跳躍指令,並根據需要計算跳躍地址。將跳躍信號和跳躍地址傳遞到IDEX\_jump和jumpaddr1,以供後續階段使用。

#### 第三階段: EX

EX\_MEM存了WB, MEMORY, TOTALALU, RD2, WN, ZERO, add, jump, jumpaddr, reset, clk, enable

在執行(Execute)階段,模組會從第一階段(IF\_ID)階段接收指令位置和指令數據。它將這些值保存起來並從REGISTER FILE中讀取數據寄存器的值。同時,它對值進行擴展,選擇擴展結果並傳遞控制信號。這些值和控制信號被傳遞到ID\_EX(指令執行)寄存器中。ID\_EX它保存了從前一階段獲取的數據和控制信號,以供後續階段使用。其中包括了PC和INS從IF\_ID階段接收並保存到ID\_EX寄存器中。數據寄存器值(RD1和RD2)。從REGISTER FILE中讀取的數據寄存器值被傳遞到ID\_EX寄存器的相應字段中。擴展結果,對值進行符號擴展和無符號擴展,然後根據控制信號選擇相應的擴展結果,最終傳遞到ID EX寄存器中。

控制信號,從控制單元獲取的控制信號被傳遞到ID\_EX寄存器中,包括ALU操作類型和分支控制信號等。跳躍指令檢測:在執行階段中檢查是否存在跳躍指令,如果存在,則計算跳躍地址並將跳躍信號和跳躍地址傳遞到ID\_EX寄存器的相應字段中。

#### 第四階段: MEM

MEM/WB存了WB, DM, ADDR, WN, DMin, reset, clk, enable

從前一階段(EX\_MEM)接收數據和控制信號。將接收到的數據和控制信號保存在相應的寄存器中。如果收到重置信號(reset),則將寄存器的值重置為初始狀態。如果(enable)為高電位,就會根據控制信號和數據進行相應的操作。將操作結果保存在寄存器的相應字段中,以供後續階段使用。

將需要寫入的數據、存儲器地址和寫入寄存器編號從寄存器輸出(DMin、ADDRin、WNin)傳遞到寄存器輸出(DMout、ADDRout、WNout)。

根據需要進行寫回操作的控制信號(WBin),將寄存器輸出(DMout、ADDRout、WNout)傳遞到寄存器輸出(WBout)。

#### 第五階段: WB

根據WBin的控制信號決定是否需要寫回。

## 三、驗證結果

```
x] => x
# 18446744073709551615, PC:
# 0, readi:
# 0, reg_f
# 0, reg_f
# 0, wd:
# 0, NOP
# 1, readi:
# 1, reg_f
# 1, reg_f
# 1, reg_f
# 1, reg_f
# 2, readi:
# 2, readi:
# 2, readi:
# 3, readi:
# 3, readi:
# 3, redi:
# 3, redi:
# 3, redi:
# 3, reg_f
# 3, PC:
# 3, wd:
# 3, ADD
# 4, veadi:
# 4, sub
# 5, reg_f
# 4, pc:
# 4, wd:
# 5, reg_f
# 5, pc:
# 5, wd:
# 5, ADD
# 6, readi:
# 6, reg_f
# 7, reg_f
                          0, reading data: Mem[
                                                                                       7, reading data: Mem[
                                                                                                                            28] => 36735008
                                                                                     7, reg_file[18] =>
                                                                                                                           4 (Port 1)
                          0, reading data: Mem[
                                                      0] => 20
0 (Port 2)
0 (Port 1)
                                                            01 => 2385444864
                                                                                     7, reg_file[16] =>
                                                                                                                          1 (Port 2)
                          0, reg_file[ 0] =>
                                                                                      8, reg_file[18] <=
                                                                                                                          2 (Write)
                         0, reg_file[ 0] =>
                                                                                       7, PC: 28
                                                                                       7, wd:
                                                                                       7, OR
                                                           41 => 305201155
                         1, reading data: Mem[
                         1, reading data: Mem[ 4] => 30

1, reg_file[15] => 21 (Port 2)

1, reg_file[17] => 2 (Port 1)
                                                                                       8, reading data: Mem[
                                                                                                                            32] => 38834210
                                                                                                                       32] => :
2 (Port 1)
                                                                                       8, reg file[17] =>
                                                                                       9, reg_file[17] <=
                                                                                                                          3 (Write)
                                                                                       8, PC: 32
                                                                                      8, wd:
                         2, reading data: Mem[
                                                           8] => 38834208
                                                                                      8, ADD
                         2, reg_file[17] =>
                                                          2 (Port 2)
                                                                                       9, reading data: Mem[
                                                                                                                            28] => 36735008
                                                                                      9, reg_file[18] =>
                                                                                                                           2 (Port 1)
                                                                                       9, PC: 28
                         3, reading data: Mem[
                                                          12] => 38834210
                                                                                     9, wd:
                         3, reading data: Mem[
                                                            2] =>
                                                          1 (Port 2)
                                                                                      9, SUB
                         3, reg_file[16] =>
                         3, reg_file[18] =>
                                                          3 (Port 1)
                                   12
                                                                                      10, reading data: Mem[
                                                                                                                            32] => 38834210
                                                                                                                         321 -- 3 (Port 1)
                                                                                      10, reg_file[17] =>
                                                                                                                         5 (Write)
                                                                                      11, reg_file[18] <=
                                                                                      10, PC: 32
                                                       16] => 36735008
                         4, reading data: Mem[
                                                     256 (Write)
                                                                                      10, wd:
                         5, reg_file[15] <=
                         4, PC: 16
                                                                                      10, ADD
                                         256
                                                                                      11, reading data: Mem[
                                                                                                                            36] => 38834213
                                                                                                                         36] => :
5 (Port 1)
                                                                                      11, reg_file[18] =>
                         5, reading data: Mem[
                                                          20] => 134217735
                                                                                      12, reg_file[17] <=
                                                                                                                           3 (Write)
                          5, reg_file[17] =>
                                                          2 (Port 1)
                                                                                      11, PC: 36
                         5, PC: 20
                                                                                      11, wd:
                                          x
                                                                                      11, SUB
                                                          24] => 38834213
                         6, reading data: Mem[
                                                                                      12, reading data: Mem[
                                                                                                                            40] => 2886860824
                                                                                                                         1 (Write)
                          6, reg_file[ 0] =>
                                                    0 (Port 2)
0 (Port 1)
4 (Write)
                                                                                     13, reg_file[18] <=</pre>
                         6, reg_file[ 0] =>
                                                                                     12, PC: 40
                         7, reg file[18] <=
                                                                                      12, wd:
                                                                                                          - 1
                                                                                      12, OR
                                                                                      13, reading data: Mem[
                                                                                                                            441 => 36737060
                                                                                                                         0 (Port 1)
                                                                                      13, reg_file[ 0] =>
                                                                                                                          1 (Port 2)
                                                                                      13, reg_file[18] =>
                                                                                      14, reg_file[17] <=
                                                                                                                           4 (Write)
                                                                                      13, PC: 44
                                                                                      13, SW
```

| 14di d M!                                   | 401 -> 640670007               | 21, PC:  | 76  |
|---------------------------------------------|--------------------------------|----------|-----|
| 4, reading data: Mem[<br>4, reg file[17] => | 48] => 640679937<br>4 (Port 1) | 21, wd:  | x   |
| 4, reg_file[16] =>                          | 1 (Port 2)                     | 21, NOP  |     |
| , reg_file[18] <=                           | 4 (Write)                      |          |     |
| , PC: 48                                    |                                |          |     |
| , wd: 4                                     |                                | 22, PC:  | 80  |
| , AND                                       |                                | 22, wd:  | x   |
|                                             | 501 -> 1151040                 | 22, NOP  |     |
| , reading data: Mem[<br>, reg_file[18] <=   | 52] => 1151042<br>5 (Write)    |          |     |
| , reg_file[10] <- i, writing data: Mem[     | 24] <= 1                       |          |     |
| 5, PC: 52                                   | 2.1                            | 23, PC:  | 84  |
| , ADDIU                                     |                                | 23, wd:  | x   |
|                                             |                                | 23, NOP  |     |
| , reading data: Mem[                        | 56] => 38895658                | ,        |     |
| , reg_file[ 0] =>                           | 0 (Port 1)                     | 0.4 DC-  |     |
| , reg_file[17] =><br>, PC: 56               | 4 (Port 2)                     | 24, PC:  | 88  |
| 6, wd: x                                    |                                | 24, wd:  | x   |
| , SRL                                       |                                | 24, NOP  |     |
|                                             |                                |          |     |
| , reading data: Mem[                        | 60] => 1915879425              | or no.   |     |
| 7, reg_file[18] =>                          | 5 (Port 1)                     | 25, PC:  | 92  |
| 8, reg_file[18] <=                          | 0 (Write)                      | 25, wd:  | x   |
| 7, PC: 60                                   |                                | 25, NOP  |     |
| 7, wd: 0<br>7, SLT                          |                                |          |     |
| , 311                                       |                                | ac pa    | 0.6 |
| , reading data: Mem[                        | 64] => 0                       | 26, PC:  | 96  |
| , reg_file[17] =>                           | 4 (Port 1)                     | 26, wd:  | x   |
| reg_file[18] =>                             | 0 (Port 2)                     | 26, NOP  |     |
| reg_file[16] <=                             | x (Write)                      |          |     |
| , PC: 64                                    |                                | 27 DC:   | 100 |
| , MADDU                                     |                                | 27, PC:  |     |
| , reg_file[ 0] =>                           | 0 (Port 1)                     | 27, wd:  | x   |
| reg_file[ 0] =>                             | 0 (Port 2)                     | 27, NOP  |     |
| , reg_file[18] <=                           | 0 (Write)                      |          |     |
| , PC: 68                                    |                                | 28, PC:  | 104 |
| 9, wd: 0                                    |                                |          |     |
| 9, NOP                                      |                                | 28, wd:  | x   |
| l, reg_file[16] <=                          | 1 (Write)                      | 28, NOP  |     |
| ), PC: 72                                   | I (WIICE)                      |          |     |
| 0, wd: 1                                    |                                | 29, PC:  | 108 |
| O, NOP                                      |                                |          |     |
|                                             |                                | 29, wd:  | x   |
|                                             |                                | 29, NOP  |     |
|                                             |                                | 30, PC:  | 112 |
|                                             |                                | 30, wd:  | x   |
|                                             |                                |          | •   |
|                                             |                                | 30, NOP  |     |
|                                             |                                | 31, PC:  | 116 |
|                                             |                                | 31, wd:  | x   |
|                                             |                                | 31, NOP  | -   |
|                                             |                                | 01, 1101 |     |
|                                             |                                | 32, PC:  | 120 |
|                                             |                                | 32, wd:  | x   |
|                                             |                                | 32, NOP  |     |
|                                             |                                | JZ, HOP  |     |

```
33, PC:
           124
                       45, PC:
                                    172
33, wd:
                       45, wd:
33, NOP
                       45, NOP
34, PC:
            128
                       46, PC:
                                    176
34, wd:
             ×
                       46, wd:
                                     ×
34, NOP
                        46, NOP
35, PC:
            132
                       47, PC:
                                    180
35, wd:
                       47, wd:
                                     X
35, NOP
                       47, NOP
36, PC:
            136
                       48, PC:
                                    184
36, wd:
             ×
                       48, wd:
                                    ×
36, NOP
                        48, NOP
37, PC:
            140
                       49, PC:
                                    188
37, wd:
             X
                       49, wd:
                                     ×
37, NOP
                       49, NOP
38, PC:
            144
                        50, PC:
                                    192
38, wd:
             ×
                       50, wd:
                                    ×
38, NOP
                        50, NOP
39, PC:
            148
                       51, PC:
                                    196
39, wd:
             X
                       51, wd:
                                    X
39, NOP
                       51, NOP
40, PC:
            152
                        52, PC:
                                   200
40, wd:
             ×
                        52, wd:
                                    X
40, NOP
                        52, NOP
41, PC:
            156
                        53, reading data: Mem[ 204] => 17424
41, wd:
             ×
                               204
                        53, PC:
41, NOP
                        53, wd:
                                    X
                        53, NOP
42, PC:
            160
42, wd:
             ×
                        54, reading data: Mem[ 208] => 36882
42, NOP
                               208
                        54, PC:
                        54, wd:
                                    X
43, PC:
            164
                        54, Hi
            x
43, wd:
43, NOP
                       55, reading data: Mem[ 212] => 36831257
                       55, PC:
                                212
44, PC:
            168
                        55, wd:
                                    ×
44, wd:
             ×
                        55, Lo
44, NOP
```

| 56, reg_file[18] => | 0 (Port 2) | 66, PC:   | 256      |
|---------------------|------------|-----------|----------|
| 56, reg_file[17] => | 4 (Port 1) | 66, wd:   | x        |
| 56, PC: 216         |            | 66, NOP   |          |
| 56, wd: x           |            |           |          |
| 56, MULTU           |            | 67, PC:   | 260      |
|                     |            | 67, wd:   | x        |
| 57, reg_file[ 0] => | 0 (Port 2) | 67, NOP   |          |
| 57, reg_file[ 0] => | 0 (Port 1) |           |          |
| 58, reg_file[ 8] <= | 0 (Write)  | 68, PC:   | 264      |
| 57, PC: 220         |            | 68, wd:   | x        |
| 57, wd: 0           |            | 68, NOP   |          |
| 57, NOP             |            | ,         |          |
| •                   |            | 69, PC:   | 268      |
| 59, reg_file[18] <= | 0 (Write)  | 69, wd:   | x        |
| 58, PC: 224         |            | 69, NOP   | -        |
| 58, wd: 0           |            | ,         |          |
| 58, NOP             |            | 70, PC:   | 272      |
| •                   |            | 70, wd:   | x        |
| 59, PC: 228         |            | 70, NOP   | -        |
| 59, wd: x           |            | .0, 1.02  |          |
| 59, NOP             |            | 71, PC:   | 276      |
| •                   |            | 71, wd:   | x        |
| 60, PC: 232         |            | 71, NOP   | -        |
| 60, wd: x           |            | , 2, 1.02 |          |
| 60, NOP             |            | 72, PC:   | 280      |
| •                   |            | 72, wd:   | x        |
| 61, PC: 236         |            | 72, NOP   | -        |
| 61, wd: x           |            | ,         |          |
| 61, NOP             |            | 73, PC:   | 284      |
| ,                   |            | 73, wd:   | x        |
| 62, PC: 240         |            | 73, NOP   | -        |
| 62, wd: x           |            | ,0, 1.02  |          |
| 62, NOP             |            | 74, PC:   | 288      |
|                     |            | 74, wd:   | x        |
| 63, PC: 244         |            | 74, NOP   | -        |
| 63, wd: x           |            | 71, 1101  |          |
| 63, NOP             |            | 75, PC:   | 292      |
|                     |            | 75, wd:   | x        |
| 64, PC: 248         |            | 75, NOP   | •        |
| 64, wd: x           |            | .07 1101  |          |
| 64, NOP             |            | 76, PC:   | 296      |
| ,                   |            | 76, wd:   | 250<br>X |
| 65, PC: 252         |            | 76, NOP   | ^        |
| 65, wd: x           |            | 70, NOE   |          |
| 65, NOP             |            | 77, PC:   | 300      |
| 55, 252             |            | 77, wd:   |          |
|                     |            |           | x        |
|                     |            | 77. NOP   |          |

```
78, PC:
               304
                                            90, PC:
                                                      352
78, wd:
                                            90, wd:
78, NOP
                                            90, NOP
79, PC:
               308
79, wd:
                                            91, reading data: Mem[
                                                                356] =>
                                                                                17424
79, NOP
                                                        356
                                            91, PC:
                                            91, wd:
                                                       X
80, PC:
               312
                                            91, NOP
80, wd:
                ×
80, NOP
                                            92, reading data: Mem[ 360] =>
                                                                                36882
                                            92, PC:
                                                    360
81, PC:
               316
81, wd:
                                            92, wd:
81, NOP
                                            92, Hi
82, PC:
               320
                                            93, reading data: Mem[
                                                                    364] =>
82, wd:
                                            93, PC:
                                                        364
82, NOP
                                            93, wd:
83, PC:
               324
                                            93, Lo
83, wd:
83, NOP
                                            94, reg_file[ x] =>
                                                                    x (Port 2)
                                            94, reg_file[ x] =>
                                                                     x (Port 1)
84, PC:
               328
                          # control_pipelined unimplemented opcode x
84, wd:
                X
                                            94, PC:
                                                        368
84, NOP
                                            96, reg_file[ 8] <=
                                                                     0 (Write)
85, PC:
               332
                                            95, PC:
                                                        372
85, wd:
                                            97, reg_file[18] <=
                                                                     0 (Write)
85, NOP
                                            96, PC:
                                                     376
                                            97, PC:
86, PC:
               336
                                            98, PC:
86, wd:
                                            99, End of Simulation
86, NOP
87, PC:
               340
87, wd:
87, NOP
88, PC:
               344
88, wd:
88, NOP
89, PC:
               348
89, wd:
89, NOP
```

## 四、waveform







#### 五、心得:

#### 1027102仇瀚慶:

在這次的PROJECT中,我認為比期中的難度差了好多,在期中project時做出來的東西,結果現在只是變成一個架構圖的一小部分而已,而且趕在期中PROJECT完就要寫期末了,一開始我們還沒有接流水線的時候都以為會順利的做完,結果其實最難的地方就是接線了,我們一開始就在PIPELINE花了不少的時間,看了課本,聽老師上課,回去複習,再到實作出來。在流水線寫出來的時候,以為可以快快結束了,並沒有。直接COMPILE ERROR一整行,讓我們頭非常痛,有夠麻煩。之後底霸個也讓我們戰了好幾個夜晚,不過雖然做這件事的過程很煎熬,但最後有弄出一些小成果出現,讓我也很開心。不過我以後應該不會想碰硬體了哈哈哈哈。

## 11027131李虹昀:

我們一開始還沒做pipeline的時候,感覺做起來很順,但碰到了pipeline的時候,error就跳出一大堆,各種的問題==,幾乎每一個模組都有毛病,連compile都過不

了。印出來答案時wd都是xx, 跑wave的時候一堆都是紅線, 我們在要交作業前每天都meeting超過了5個小時, 有時候甚至沒吃晚餐, 就為了抵出bug。

在交前一個禮拜睡的時數都不超過6小時,很常不知道不覺看到天亮,有種壽命又減10歲的感覺,但在學習的過程中也默默的學到了許多東西,從一開始不知道怎麼接到了解整個架構圖,雖然學習過程是辛苦的,但也學到了不少,對CPU的架構又更加了解。

## 11027142林蕙郁:

這次的期末PROJECT我覺得感覺和期中的難度真的差很多,在我們期中的時候至少課本翻一翻也能有大概的想法可以寫出來或者是網路上可以參考,但到期末PROJECT之後發覺,除了了解他的流程,在實現程式碼又是另外一回事了,寫PIPELINE,新指令,一開始還用HAZARD都遇到了一堆困難(但在聽老師說用NOP就得救了因為HAZARD不用寫,耶),我們在交前一整個禮拜每天都MEETIING了不知道有幾個小時,感覺每天都快要天亮的時候才跑去休息,而且還不小心引來了壞習慣,在半夜一看著螢幕底霸個,手就會很癢想要吃零食。不過雖然真的很辛苦,但也學到了許多。

## 11027144陳佳音:

在寫程式碼的過程中,遇到各種錯誤和困難真的是一段煎熬的旅程。然而,我們通過堅持和持續的努力,我們最終成功還是克服了這些問題,真的非常開心。在寫程式碼的時候常常感覺快好了,但後來發覺問題越來越多,好不容易debug結束,結果跑模擬又出現其他問題,每天花超多的時間在討論新出現的bug是因為什麼原因造成的,還好每一次問題最後都有被解決。

我們在實作pipelining的時候真的超挫折,因為常常搞不清楚問題出在哪裡, pipelining引入了時序和數據相依的複雜性都有可能導致各種錯誤,所以要對每 個module仔細的檢查和調整,才能夠確保數據和控制信號的正確傳輸,但我們在 逐行看程式的時候還是常常會看到迷路。 雖然在接的時候過得很不順, 但在我們堅持與努力之下, 東西最後還是有看起來還ok的結果, 雖然不敢確定答案一定是正確的, 但我們在寫得過程中也學習到許多的知識。

## 六、負責項目

報告、繪製、程式撰寫: 一起完成