## Chapter 2-3

## Exercise1:

$[5]<\S \S 2.3,2.6,2.9>$ Add comments to the following MIPS code and de-
scribe in one sentence what it computes. Assume that $\$ a 0$ and $\$ a 1$ are used for the input and both initially contain the integers $a$ and $b$, respectively. Assume that $\$ \mathrm{v} 0$ is used for the output.

|  | add | \$t0, \$zero, \$zero |
| :---: | :---: | :---: |
| 10op: | beq | \$a1, \$zero, finish |
|  | add | \$t0, \$t0, \$a0 |
|  | sub | \$a1, \$a1, 1 |
|  | j | 100p |
| finish: | addi | \$t0, \$t0, 100 |
|  | add | \$v0, \$t0, \$zero |

## Exercise 2:

$[12]<\S \S 2.3,2.6,2.9>$ The following code fragment processes two arrays and produces an important value in register $\$ \mathrm{v} 0$. Assume that each array consists of 2500 words indexed 0 through 2499 , that the base addresses of the arrays are stored in $\$ a 0$ and $\$ a 1$ respectively, and their sizes (2500) are stored in $\$ a 2$ and $\$ a 3$, respectively. Add comments to the code and describe in one sentence what this code does. Specifically, what will be returned in $\$ \mathrm{v} 0$ ?

|  | outer: | s 11 <br> s11 <br> add <br> add <br> add | ```$a2, $a2, 2 $a3, $a3, 2 $v0, $zero, $zero $t0, $zero, $zero $t4, $a0, $t0``` |
| :---: | :---: | :---: | :---: |
|  | 1 w |  | \$t4, 0 (\$t4) |
|  | add |  | \$t1, \$zero, \$z |
| inner: | add |  | \$t3, \$a1, \$t1 |
|  | 1 w |  | \$t3, 0(\$t3) |
|  | bne |  | \$t3, \$t4, skip |
|  | addi |  | \$v0, \$v0, 1 |
| skip: | addi\$ |  | t1, \$t1, 4 |
|  | bne |  | \$t1, \$a3, inner |
|  | addi |  | \$t0, \$t0, 4 |
|  | bne |  | \$t0, \$a2, outer |

## Exercise 2.16

For these problems, the table holds various binary values for register \$t0. Given the value of $\$ \mathrm{t0}$, you will be asked to evaluate the outcome of different branches.

2.16.1 [5] <2.7> Suppose that register $\$$ t0 contains a value from above and $\$$ t1 has the value

$$
0011111111111000000000000000 \quad 0000_{\text {two }}
$$

Note the result of executing these instructions on particular registers. What is the value of $\$ \mathrm{t} 2$ after the following instructions?

```
    slt $t2, $t0, $t1
    beq $t2, $0, ELSE
    j DONE
ELSE: addi $t2, $0, 2
DONE:
```

2.16.2 [5] <2.7> Suppose that register $\$ \mathrm{t} 0$ contains a value from the table above and is compared against the value $X$, as used in the MIPS instruction below. Note the format of the slti instruction. For what values of $X$, if any, will $\$$ t2 be equal to 1 ?

```
slti $t2, $t0, X
```

2.16.3 [5] <2.7> Suppose the program counter (PC) is set to $0 \times 00000020$. Is it possible to use the jump MIPS assembly instruction to get set the PC to the address as shown in the data table above? Is it possible to use the branch-on-equal MIPS assembly instruction to get set the PC to the address as shown in the data table above?

For these problems, the table holds various binary values for register $\$$ t0. Given the value of $\$ t 0$, you will be asked to evaluate the outcome of different branches.

| a. | $0 \times 00101000$ |
| :--- | :--- |
| b. | $0 \times 80001000$ |

2.16.4 [5] <2.7> Suppose that register $\$$ t0 contains a value from above. What is the value of $\$ \mathrm{t} 2$ after the following instructions?

```
    slt $t2, $0, $t0
    bne $t2, $0, ELSE
    j DONE
ELSE: addi $t2, $t2, 2
DONE:
```

2.16.5 [5] <2.6, 2.7> Suppose that register \$t0 contains a value from above. What is the value of $\$$ t2 after the following instructions?

```
sll $t0, $t0, 2
slt $t2, $t0, $0
```

2.16.6 [5] <2.7> Suppose the program counter (PC) is set to $0 \times 20000000$. Is it possible to use the jump (j) MIPS assembly instruction to get set the PC to the
address as shown in the data table above? Is it possible to use the branch-on-equal (beq) MIPS assembly instruction to set the PC to the address as shown in the data table above? Note the format of the J-type instruction.

## Exercise 2.17

For these problems, there are several instructions that are not included in the MIPS instruction set are shown.

| a. | subi $\$ t 2, \$ t 3,5$ | 非 $R[r t]=R[r s]-$ SignExtImm |
| :--- | :--- | :--- |
| b. | $r p t ~ \$ t 2,100 p$ | 非 $i f(R[r s]>0) R[r s]=R[r s]-1, P C=P C+4+B r a n c h A d d r$ |

2.17.1 [5] <2.7> The table above contains some instructions not included in the MIPS instruction set and the description of each instruction. Why are these instructions not included in the MIPS instruction set?
2.17.2 [5] <2.7> The table above contains some instructions not included in the MIPS instruction set and the description of each instruction. If these instructions were to be implemented in the MIPS instruction set, what is the most appropriate instruction format?
2.17.3 [5] <2.7> For each instruction in the table above, find the shortest sequence of MIPS instructions that performs the same operation.

For these problems, the table holds MIPS assembly code fragments. You will be asked to evaluate each of the code fragments, familiarizing you with the different MIPS branch instructions.

2.17.4 [5] <2.7> For the loops written in MIPS assembly above, assume that the register $\$$ t1 is initialized to the value 10 . What is the value in register $\$ s 2$ assuming the $\$ s 2$ is initially zero?
2.17.5 [5] <2.7> For each of the loops above, write the equivalent $C$ code routine. Assume that the registers $\$ \mathrm{~s} 1, \$ \mathrm{~s} 2, \$ \mathrm{t} 1$, and $\$ \mathrm{t} 2$ are integers $\mathrm{A}, \mathrm{B}, \mathrm{i}$, and temp, respectively.
2.17.6 [5] <2.7> For the loops written in MIPS assembly above, assume that the register $\$$ t1 is initialized to the value N. How many MIPS instructions are executed?

## Exercise 2.18

For these problems, the table holds some C code. You will be asked to evaluate these C code statements in MIPS assembly code.

```
a. for(i=0; i<a; i++)
    d += b;
b. for(i-0; i<a; i++)
    for(j=0;j<b; j++)
```

2.18.1 [5] <2.7> For the table above, draw a control-flow graph of the C code.
2.18.2 [5] <2.7> For the table above, translate the C code to MIPS assembly code. Use a minimum number of instructions. Assume that the values of $a, b, i$, and $j$ are in registers $\$ \mathrm{~s} 0, \$ \mathrm{~s} 1, \$ \mathrm{t0}$, and $\$ \mathrm{t} 1$, respectively. Also, assume that register $\$ \mathrm{~s} 2$ holds the base address of the array D .
2.18.3 [5] <2.7> How many MIPS instructions does it take to implement the C code? If the variables $a$ and $b$ are initialized to 10 and 1 and all elements of D are initially 0 , what is the total number of MIPS instructions that is executed to complete the loop?

For these problems, the table holds MIPS assembly code fragments. You will be asked to evaluate each of the code fragments, familiarizing you with the different MIPS branch instructions.

| a. |  |
| :---: | :---: |
| b. |  |

2.18.4 [5] <2.7> What is the total number of MIPS instructions executed?
2.18.5 [5] <2.7> Translate the loops above into C. Assume that the C-level integer $i$ is held in register $\$ t 1, \$ s 2$ holds the C-level integer called result, and $\$ s 0$ holds the base address of the integer MemArray.
2.18.6 [5] <2.7> Rewrite the loop to reduce the number of MIPS instructions executed.

