## Bilkent University CS Department

## CS 224 - Digital Design and Computer Architecture



Preliminary Design Report Lab 04

Section 04

Okan Şen 21202377

28/11/2019

| hex          | assembly              | location   |
|--------------|-----------------------|------------|
|              |                       | _          |
| 32'h20020005 | addi \$v0, \$zero, 5  | 0x00000000 |
| 32'h2003000c |                       | 0x0000004  |
|              | addi \$v1, \$zero, 12 |            |
| 32'h2067fff7 |                       | 0x0000008  |
|              | addi \$a3, \$v1, -9   |            |
| 32'h00e22025 |                       | 0x000000C  |
|              | or \$a0, \$a3, \$v0   |            |
| 32'h00642824 |                       | 0x0000010  |
|              | and \$a1, \$v1, \$a0  |            |

| 32'h00a42820 |                      | 0x0000014  |
|--------------|----------------------|------------|
|              | add \$a1, \$a1, \$a0 |            |
| 32'h10a7000a |                      | 0x0000018  |
|              | beq \$a1, \$a3, 10   |            |
| 32'h0064202a |                      | 0x000001C  |
|              | slt \$a0, \$v1, \$a0 |            |
| 32'h10800001 |                      | 0x00000020 |
|              | beq \$a0, \$zero, 1  |            |
| 32'h20050000 |                      | 0x00000024 |
|              | addi \$a1, \$zero, 0 |            |

| 32'h00e2202a |                         | 0x00000028 |
|--------------|-------------------------|------------|
|              | slt \$a0, \$a3, \$v0    |            |
| 32'h00853820 |                         | 0x0000002C |
|              | add \$a3, \$a0, \$a1    |            |
| 32'h00e23822 |                         | 0x0000030  |
|              | sub \$a3, \$a3, \$v0    |            |
| 32'hac670044 |                         | 0x00000034 |
|              | sw \$a3, 0x0044, \$v1   |            |
| 32'h8c020050 |                         | 0x0000038  |
|              | lw \$v0, 0x0050, \$zero |            |

| 32'h08000011 |                           | 0x000003C  |
|--------------|---------------------------|------------|
|              | j 0x0000011               |            |
| 32'h20020001 |                           | 0x0000040  |
|              | addi \$v0, \$zero, 0x0001 |            |
| 32'hac020054 |                           | 0x00000044 |
|              | sw \$v0, 54(\$zero)       |            |
| 32'h08000012 |                           | 0x00000048 |
|              | j 0x0000012               |            |

d) sw+ is in blue. MemtoReg and RegDst are increased to 2 bits to handle mux3's that are converted from mux2's. They are the selection inputs.

Bge is in red. Bgpcmux is the name of the new added mux2 on the top left are, selection input is named bge2.



e)
Only main decoder truth table was edited, the alu decoder truth table stays the same.

| Instruc-<br>tion | Op <sub>5:0</sub> | Reg<br>Write<br>1:0 | Reg<br>Dst | Alu<br>Src | Branc<br>h | Me<br>m<br>Writ<br>e 1:0 | Me<br>m<br>toRe | ALU<br>Op <sub>1:0</sub> | Jum<br>p | bge1 | bge2 |
|------------------|-------------------|---------------------|------------|------------|------------|--------------------------|-----------------|--------------------------|----------|------|------|
| R-type           | 0000              | 01                  | 1          | 0          | 0          | 00                       | 0               | 1x                       | 0        | 0    | 0    |
| lw               | 1000<br>11        | 01                  | 0          | 1          | 0          | 00                       | 1               | 00                       | 0        | 0    | 0    |

| SW   | 1010<br>11 | 00 | Х | 1 | 0 | 01 | Х | 00 | 0 | 0 | 0 |
|------|------------|----|---|---|---|----|---|----|---|---|---|
| beq  | 0001<br>00 | 00 | Х | 0 | 1 | 00 | Х | 01 | 0 | 0 | 0 |
| j    | 0000<br>10 | 00 | Х | Х | Х | 00 | Х | XX | 1 | 0 | 0 |
| addi | 0010<br>00 | 01 | 0 | 1 | 0 | 00 | 0 | 00 | 0 | 0 | 0 |

| Instru<br>c-tion | Op <sub>5:0</sub> | Re<br>g<br>Wri<br>te | Reg<br>Dst<br>1:0 | Alu<br>Src | Branc<br>h | Mem<br>Write | Mem<br>toReg<br>1:0 | ALU<br>Op <sub>1:0</sub> | Jump | bge1 | bge2 |
|------------------|-------------------|----------------------|-------------------|------------|------------|--------------|---------------------|--------------------------|------|------|------|
| sw+              | 11111<br>0        | 1                    | 10                | 1          | 0          | 1            | 10                  | 00                       | 0    | 0    | 0    |
| bge              | 11111             | 0                    | 00                | 0          | 0          | 0            | 00                  | 01                       | 0    | 1    | 1    |

```
f)
Hexes of sw+ and bge, respectively;
0 x FA 08 00 00
0 x FD 09 00 04

Mips code, from hex conversions:

.text
.globl __start

__start:
__sdc2 $t0, 0($s0)
__sd $t1, $t0, label
```

add \$t5, \$t5, \$zero

label:

li \$v0,10 syscall