

# CS 520 Computer Architecture

Project #3



### Programming for CPU simulator



















set R0 #200



#### Hardware pipeline





#### Hardware pipeline



| RO  |
|-----|
| R1  |
| R2  |
| R3  |
| R4  |
| R5  |
|     |
| R15 |
|     |







#### Hardware pipeline



| R0<br>R1<br>R2<br>R3<br>R4<br>R5 |
|----------------------------------|
| R2<br>R3<br>R4<br>R5             |
| R3<br>R4<br>R5                   |
| R4<br>R5                         |
| R5                               |
| •••••                            |
|                                  |
|                                  |
| R15                              |



### **Instructions**



| Туре    | Opcode          | Operand 1         | Operand 2           | Operand 3           |
|---------|-----------------|-------------------|---------------------|---------------------|
| Inst-3B | Opcode (1 byte) | Register (1 byte) | Register (1 byte)   | -                   |
| Inch 4D | Opcode (1 byte) | Register (1 byte) | Register (1 byte)   | Register (1 byte)   |
| Inst-4B | Opcode (1 byte) | Register (1 byte) | Immediate (2 bytes) |                     |
| Inst-5B | Opcode (1 byte) | Register (1 byte) | Register (1 byte)   | Immediate (2 bytes) |
| Inst-6B | Opcode (1 byte) | Register (1 byte) | Immediate (2 bytes) | Immediate (2 bytes) |

- Instructions have varied lengths
- Instructions are in a binary code format
- Instructions located in memory address range from 0 to 3999



### Memory Map – mmap#.in





### Logs – test#.log

```
Cycle: 22 (stalls: 12)
MEM2:
MEM1:
EX1:subl R7 R23 R1
IA:set R31 44288
ID:add2 R18 R31 191
IF:set R27 63232
Cycle: 23 (stalls: 13)
MEM2:
MEM1:
EX2:subl R7 R23 R1
EX1:set R31 44288
IA:add2 R18 R31 191 (stall)
ID:set R27 63232
IF:sub2 R26 R27 235
Cycle: 24 (stalls: 14)
MEM2:
MEM1:sub1 R7 R23 R1
EX2:set R31 44288
EX1:
IA:add2 R18 R31 191 (stall)
ID:set R27 63232
IF:sub2 R26 R27 235
```

- test#.log shows the execution process during the simulation.
- This file is for debugging.
- Your simulator does not need to produce this file.



### Output – output#.txt (sample)

```
R1 : 6144
                R5 : -59351
                R7 : 16330
                R9 : 6359
 R8 : 40960
 R10 : 12244
                R11 : -21157
 R12 : -21337
 R14 : 106661
                | R17 : 26619
 R16: -32406
                R19: 33056
 R20 : 37888
                | R23 : -21365
 R24 : 2329
                R25 : 3840
 R26 : -19008
 R28 : 26412
                R29: 8448
 R30 : -41253
Stalled cycles due to data hazard: 96
umber of instruction SET: 42
umber of instruction ADD: 59
umber of instruction SUB: 49
umber of instruction MUL: 0
umber of instruction DIV: 0
 umber of instruction LD: 0
umber of instruction SD: 0
Number of instruction RET: 1
Total execution cycles: 254
otal instruction simulated: 151
```

- output#.txt shows the final results that your simulator produces.
- Your simulator prints these results on a terminal (standard output).