

control

option

command

command

option

control

## Module 5)

2.25.1 srl \$t2, \$t0, 10 # move bits 16-11 down to the very right. Bits we want at the start)  
 srl \$t2, \$t2, 26 # shift \$t2 26 bits to the left, bits 0-25 will be zeros.  
 srl \$t1, \$t1, 6 # cut off \$t1 bits 26-31  
 srl \$t1, \$t1, 6 # shift \$t1 6 bits to the right, so last 6 bits are zeros  
 add \$t1, \$t1, \$t2 # replaces the zeros in \$t1 in bits 26-31 with the 6 bits in \$t2

2.25.1.1 I format to hold on address, and two registers for comparison.

2.25.2 LOOP : ~~addi \$t3, \$t1, \$Zero, \$t2~~ # if ~~\$t1 < 0~~ OR \$t2, \$t1 = 1 / else \$t1 = 0  
 beg. \$t3, \$Zero, EXIT  
 addi ~~add~~ \$t1, \$t1, ~~1~~ - 1 # decrement, no sub!

j Loop # if R[rs] > 0, go to Loop

## EXIT :

| Loop   | \$t1 | \$t2       |
|--------|------|------------|
| Loop 1 | 9    | 2          |
| 2      | 8    | 4          |
| 3      | 7    | 6          |
| 4      | 6    | 8          |
| 5      | 5    | 10         |
| 6      | 4    | 12         |
| 7      | 3    | 14         |
| 8      | 2    | 16         |
| 9      | 1    | 18         |
| 10     | 0    | 20         |
| 11     | fail | go to DONE |

$$\boxed{\$t2 = 20}$$

2.26.1 while (i > 0) {  
 i = i - 1  
 B = B + 2

3

2.26.1.3 if N = 0 = \$t1 then only 2 instructions are executed.  
 LOOP srl \$t2, \$t0, \$t1 ← first  
 beq \$t2, \$0, DONE ← second.

If N = 1, 5 > instructions

N = 2, 12.

so Number of instructions =  $(\$t1 \cdot 5) + 2$  or  $\downarrow N$

control

option

command

⌘ command

⌥ option

### ④ Additional

1) abs \$54,\$51 # absolute value

bgez \$51, LOAD  
nor \$51,\$51,\$200 # NOR will invert \$51  
addi \$51,\$54,1

LOAD: add \$54,\$51,\$200

useful instruction

bgez : A=0, branch on greater than zero  
if rs > 0, branch

nor : rd,rs,rt  
put logical NOR into rd.

basically find the two's complement

2) rol \$+7,\$+3,8 , rotate left      rel: bits off the left end move onto the right  
sll \$+0, \$+3,8      # 31-23 are shifted out so rol of 2 of 011010 → 101001

srl \$+1,\$+3,24      # 31-23 became 7-0 and the new 31-7 are all zeros  
or \$+7,\$+0,\$+1

3) ld \$+5,0(\$+0)

lw \$+2,\$+4

sll \$+0,\$+8,32

srl \$+6,\$+7,32

lw \$+1,0(\$+6)

srl \$+3,\$+8,32

lw \$+0,0(\$+3)

ld: rddest, address

ld: load 64 bit quantity at address in rddest and rddest+1

lui: load upper immediate

loads into upper 16 bits

ori: insert into lower 16 bits

# set lower 32 bits of \$+8 and store in \$+1

# set upper 32 bits of \$+8 and store in \$+0

lw \$+5,0(\$+0)

# \$+0 has the upper immediate

lw \$+6,0(\$+1)

# \$+1 has the lower immediate