# Computer Organization COLab4 report

## Architecture diagrams:



## Hardware module analysis:

主要是把Pipe\_CPU.v的線給接對, module多為助教提供或是沿用上次作業, 特別注意在做lw 時WriteRegister的值是由instr\_20\_16或是instr\_15\_11打包送回才會正確 (講義ch4 p62)。

#### Problems You Met and Solutions:

這次要接的東西有點多,要想一下,小心的接。

### Result:

# CO\_P4\_test\_data1.txt

| : Register= |         |         |         |         |          |                              |           |   |
|-------------|---------|---------|---------|---------|----------|------------------------------|-----------|---|
| r0=         | 0, rl=  | 3, r2=  | 4, r3=  | 1, r4=  | 6, r5=   | 2, r6=                       | 7, r7= 1  |   |
| r8=         | 1, r9=  | 0, r10= | 3, r11= | 0, r12= | 0, 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 |
| Memory===   |         |         |         |         |          |                              |           |   |
| m0=         | 0, m1=  | 3, m2=  | 0, m3=  | 0, m4=  | 0, m5= 0 | , m6= 0, m                   | 7= 0      |   |
| m8=         | 0, m9=  | 0, m10= | 0, m11= | 0, m12= | 0, m13=  | 0, m14=                      | 0, m15= 0 |   |
| r16=        | 0, m17= | 0, m18= | 0, m19= | 0, m20= | 0, m21=  | 0, m22=                      | 0, m23=   | ı |
| 1           |         |         |         |         |          | 0, m30=<br>TestBench.v" Line |           | 1 |

## CO\_P4\_test\_data2.txt

# Modify the machine code:

| I1: addi <b>\$1</b> ,\$0,16       | 001000000000010000000000010000          |
|-----------------------------------|-----------------------------------------|
| l3: addi \$3,\$0,8                | 00100000000011000000000001000           |
| NOP                               | 000000000000000000000000000000000000000 |
| NOP                               | 000000000000000000000000000000000000000 |
| I4: sw \$1,4(\$0)                 | 10101100000000100000000000000100        |
| I2: addi \$2, <mark>\$1</mark> ,4 | 00100000010001000000000000000100        |
| I7: add \$6,\$3,\$1               | 0000000011000010011000000100000         |
| I5: lw \$4,4(\$0)                 | 100011000000010000000000000000100       |
| l8: addi <b>\$7</b> ,\$1,10       | 0010000001001110000000000001010         |
| I10: addi \$9,\$0,100             | 0010000000010010000000001100100         |
| l6: sub \$5, <b>\$4</b> ,\$3      | 0000000100000110010100000100010         |
| 19: and \$8, <b>\$7</b> ,\$3      | 000000011100011010000000100100          |

## 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=                      | 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 |
| Memory=== |         |           |         | ======= |           |                              |            |   |
| m0=       | 0, m1=  | 16, m2=   | 0, m3=  | 0, m4=  | 0, m5= 0, | , m6= 0, m                   | 7= 0       |   |
| m8=       | 0, m9=  | 0, m10=   | 0, m11= | 0, m12= | 0, m13=   | 0, m14=                      | 0, m15= 0  |   |
| r16=      | 0, m17= | 0, m18=   | 0, m19= | 0, m20= | 0, m21=   | 0, m22=                      | 0, m23= 0  |   |
| 1         |         |           |         |         |           | 0, m30=<br>ΓestBench.v" Line |            |   |

## Summary:

這此作業主要是要把圖片中的每一條線看清楚,每一條線都要接對,不然會一直錯,module 大多由助教提供或是沿用之前作業,比較不是問題。