# CO\_Lab4 Report

0511105 李頤

## Architecture

使用題目的架構



# Hardware Module Analysis

這次 lab 主要做的事情就是在各 stage 間加上 pipeline registers 以下是我在 onenote 上每條線名稱及大小的命名及分析 (截圖可能比較模糊但應該還算看得清楚)



### Problems You Met and Solutions

### 1. 剛接完線完全跑不出結果

後來決定把 reg 的結果印出來,發現各種眼殘手殘 總之有些線的大小設錯了

### 2. ALU 的結果不對

發現 bus 接線的順序剛好顛倒了

應該是 .ALU\_op\_o({EX\_id[3], EX\_id[2], EX\_id[1]}), 打成 .ALU\_op\_o({EX\_id[1], EX\_id[2], EX\_id[3]}), 還好有把 reg 印出來不然找到死

### 3. 移植 lab3

有些多的線(Jr, Jal)我就把它晾在那,不影響結果

### 4. 如何解決 data hazard

我把一些沒有 dependency 的指令插進有 hazard 的指令間,有些還需要加bubble (32'b0)

### 5. Mult 指令**實**現

這次兩筆次資都沒有 mult 這個指令我覺得很奇怪,不過我還是加了, ALU\_Ctrl 加個 011000 控制,ALU case 加個相乘的功能

### 6. Reg 大小調整

原本大小都是自己先加起來在填 N 但發現寫錯要改不太方便就寫成

Pipe\_Reg #(.size(2+3+5+32+32+32+32+5+5)) ID\_EX( 這樣哪條寫錯比較好調整

# Result

### CO\_P4\_test\_1.txt

### My result

| Register |                                      |                                   |                  |                |                |                  |          |      |   |
|----------|--------------------------------------|-----------------------------------|------------------|----------------|----------------|------------------|----------|------|---|
| r0=      | 0, r1=                               | 3, r2=                            | 4, r3=           | 1, r4=         | 6, r5=         | 2, r6=           | 7, r7=   | 1    |   |
| r8=      | 1, r9=                               | 0, r10=                           | 3, r11=          | 0, r12=        | 0, r1          | 3= 0, r          | 14= 0, r | 15=  | 0 |
| r16=     | 0, r17=                              | 0, r18=                           | 0, r19=          | 0, r2          | 0= 0,          | r21= 0,          | r22= 0,  | r23= | 1 |
| r24=     | 0, r25=                              | 0, r26=                           | 0, r27=          | 0, r2          | 8= 0,          | r29= 0,          | r30= 0,  | r31= | - |
| Memory== |                                      |                                   |                  |                |                |                  |          |      |   |
| m0=      | 0, m1=                               | 3, m2=                            | 0, m3=           | 0, m4=         | 0, m5=         | Ο, m6=           | 0, m7= 0 |      |   |
| m8=      | 0, m9=                               | 0, m10=                           | O, m11=          | 0, m12=        | O, m13=        | 0, m14=          | 0, m15=  | 0    |   |
| r16=     | O, m17=                              | O, m18=                           | 0, m19=          | O, m2O=        | 0, m21=        | 0, m22=          | 0, m23=  | 0    |   |
| INFO: [U | SF-XSim-96] XSim<br>SF-XSim-97] XSim | completed. Desi<br>simulation ran | for 1000ns       | tBench_behav'  | loaded.        |                  |          | 0    |   |
| launch_s | imulation: Time                      | (s): cpu = UO:00                  | J:UJ ; elapsed = | UU:UU:U6 . Mem | ory (MB): peak | = /92.355 ; gain | = 0.000  |      |   |

0

#### Answer



### CO\_P4\_test\_2.txt

我不想更動原來的檔案,所以我把更動完的指令存在 CO\_P4\_test\_2\_m.txt

### My result

| Register | (======                              |                                                  |                                | ========         |                |                  |            |     |   |
|----------|--------------------------------------|--------------------------------------------------|--------------------------------|------------------|----------------|------------------|------------|-----|---|
| r0=      | 0, r1=                               | 16, r2=                                          | 20, r3=                        | 8, r4=           | 16, r5=        | 8, r6=           | 24, r7=    | 26  |   |
| r8=      | 8, r9=                               | 100, r10=                                        | 0, r11=                        | 0, r12=          | 0, r13         | = 0, r14         | 4= 0, r15: |     | 0 |
| r16=     | 0, r17=                              | 0, r18=                                          | 0, r19=                        | 0, r20=          | 0, r           | 21= 0, 1         | r22= 0, r2 | 23= | 0 |
| r24=     | 0, r25=                              | 0, r26=                                          | 0, r27=                        | 0, r28=          | 0, r           | 29= 0, 1         | :30= 0, r  | 31= | 0 |
| Memory== | 0, m1=                               | 16, m2=                                          |                                |                  | O, m5=         | O, m6= (         | ), m7= O   |     |   |
| m8=      | 0, m9=                               | 0, m10=                                          | O, m11=                        | O, m12=          | O, m13=        | 0, m14=          | 0, m15=    | 0   |   |
| r16=     | 0, m17=                              | 0, m18=                                          | O, m19=                        | 0, m20=          | O, m21=        | 0, m22=          | 0, m23=    | 0   |   |
| INFO: [U | JSF-XSim-96] XSi<br>JSF-XSim-97] XSi | 0, m26=<br>m completed. Desi<br>m simulation ran | gn snapshot 'Tes<br>for 1000ns | tBench_behav' lo | aded.          | ·                | O, m31=    | 0   |   |
| launch_s | simulation: Time                     | (s): cpu = 00:00                                 | ):03 ; elapsed =               | 00:00:07 . Memor | y (MB): peak = | 792.355 ; gain = | = 0.000    |     |   |

#### Answer



### 更動的指令



### Mult 指令

我直接加 mult 指令在第二筆測資後面測試, r12 = r3 \* r8 (= 64) 指令為: 000000001101000011000000011000 跑出來的結果:

| Register= |         |           |         |         |          |         |            |   |
|-----------|---------|-----------|---------|---------|----------|---------|------------|---|
| r0=       | 0, r1=  | 16, r2=   | 20, r3= | 8, r4=  | 16, r5=  | 8, r6=  | 24, r7= 26 |   |
| r8=       | 8, r9=  | 100, r10= | 0, r11= | 0, r12= | 64) r13= | 0, r14= | 0, r15=    | 0 |
| r16=      | 0, r17= | 0, r18=   | 0, r19= | 0, r20= | 0, r21=  | 0, r22= | 0, r23=    | 0 |
| r24=      | 0, r25= | 0, r26=   | 0, r27= | 0, r28= | 0, r29=  | 0, r30= | 0, r31=    | 0 |

# ●心得

剛跑出結果覺得很感動,覺得寫這麼久終於能動了,很有成就感。 但在寫 hardware module analysis 時發現自己做的也只有加個幾個 reg 跟接幾條線而已 突然想不通為什麼搞那麼久 總之寫完還是很開心拉 喔對上次 NewE3 開雷害我壓線失敗,這次有學乖早點開始寫