# Lecture 3

# Review: Signed Binary Representation

|             |                         | 2'sc binary | decimal |
|-------------|-------------------------|-------------|---------|
|             | $-2^3 =$                | 1000        | -8      |
|             | -(2 <sup>3</sup> - 1) = | 1001        | -7      |
|             |                         | - 1010      | -6      |
| complement  | all the bits            | + 1011      | -5      |
|             | 1011                    | 1100        | -4      |
| 0101        |                         | 1101        | -3      |
| and add a 1 | and add a 1             | 1110        | -2      |
| 0440        | 1010                    | 1111        | -1      |
| 0110        | 1010                    | 0000        | 0       |
|             | complement all the bits | 0001        | 1       |
|             |                         | 0010        | 2       |
|             |                         | 0011        | 3       |
|             |                         | 0100        | 4       |
|             | 2~1=                    | 0101        | 5       |
|             |                         |             | ~ I     |

## **Review: MIPS Number Representations**

□ 32-bit signed numbers (2's complement):

 $MSB \begin{array}{c} 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000 \ 0000$ 

### Converting <32 bit values into 32 bit values</p>

 copy the most significant bit (the sign bit) into the "empty" bits

0010 -> 0000 0010 1010 -> 1111 1010

sign extend versus zero extend

### **Review: MIPS Organization**

Arithmetic instructions – to/from the register file



# **Review: MIPS Instructions, so far**

| Category                 | Instr            | OpCode  | Example              | Meaning                    |
|--------------------------|------------------|---------|----------------------|----------------------------|
| Arithmetic               | add              | 0 & 20  | add \$s1, \$s2, \$s3 | \$s1 = \$s2 + \$s3         |
| (R format)               | subtract         | 0 & 22  | sub \$s1, \$s2, \$s3 | \$s1 = \$s2 - \$s3         |
| Arithmetic<br>(I format) | add<br>immediate | 8       | addi \$s1, \$s2, 4   | \$s1 = \$s2 + 4            |
| Data<br>transfer         | load word        | 23      | lw \$s1, 100(\$s2)   | \$s1 =<br>Memory(\$s2+100) |
| (I format)               | store word       | 2b<br>↑ | sw \$s1, 100(\$s2)   | Memory(\$s2+100) =<br>\$s1 |

hex

### Instructions for Making Decisions

- Decision making instructions
  - alter the control flow
  - i.e., change the "next" instruction to be executed

### MIPS conditional branch instructions:

```
bne $s0, $s1, Lb1 #go to Lb1 if $s0≠$s1
beq $s0, $s1, Lb1 #go to Lb1 if $s0=$s1

    Example:if (i==j) h = i + j;

    bne $s0, $s1, Lb11
add $s3, $s0, $s1
Lb11: ...
```

# **Assembling Branches**

#### Instructions:

| bne \$s0, | \$s1, | Lbl | #go | to | Lbl | if | \$s0≠\$s1 |
|-----------|-------|-----|-----|----|-----|----|-----------|
| beq \$s0, | \$s1, | Lbl | #go | to | Lbl | if | \$s0=\$s1 |

### Machine Formats:



□ How is the branch destination address specified?

#### **Specifying Branch Destinations** Could specify the memory address - but that would require a 32 bit field Could use a "base" register and add to it the 16-bit offset which register? - Instruction Address Register (PC = program counter) - its use is $PC \rightarrow bne $s0,$s1,Lb11$ automatically implied by branch add \$s3,\$s0,\$<del>s</del> - PC gets updated (PC+4) during the Fetch cycle so that it holds the Lbl1: . . . address of the next instruction limits the branch distance to -2<sup>15</sup> to +2<sup>15</sup>-1 instr's from the (instruction after the) branch - but most branches are local anyway

# **Disassembling Branch Destinations**

The contents of the updated PC (PC+4) is added to the 16 bit branch offset which is converted into a 32 bit value by

 concatenating two low-order zeros to make it a word address and then sign-extending those 18 bits

The result is written into the PC if the branch condition is true - before the next Fetch cycle



# **Assembling Branches Example**



 The offset (plus 2 low-order zeros) is sign-extended and added to the (updated) PC

### Another Instruction for Changing Flow

MIPS also has an unconditional branch instruction or jump instruction:

| j       | Lbl      |                                 | #go                  | to         | Lbl |
|---------|----------|---------------------------------|----------------------|------------|-----|
| Example | ə:       | else                            | i!=j<br>h=i+<br>h=i- | ;          |     |
| Else:   | add<br>j | \$s0,<br>\$s3,<br>Exit<br>\$s3, | \$s0                 | <b>,</b> 1 | Ss1 |
| Exit:   | •••      |                                 |                      |            |     |

# Assembling Jumps

□ Instruction: j Lbl

Lbl #go

- #go to Lbl
- Machine Format:



How is the jump destination address specified?

- As an absolute address formed by
  - concatenating 00 as the 2 low-order bits to make it a word address
  - concatenating the upper 4 bits of the current PC (now PC+4)

### **Disassembling Jump Destinations**

The low order 26 bits of the jump instr converted into a 32 bit jump destination address by

 concatenating two low-order zeros to create an 28 bit (word) address and then concatenating the upper 4 bits of the current PC (now PC+4) to create a 32 bit (word) address

that is put into the PC prior to the next Fetch cycle

)ecc



### Assembling Branches and Jumps

Assemble the MIPS machine code (in decimal is fine) for the following code sequence. Assume that the addr of the beg instr is 0x00400020<sub>hex</sub>

|            | beq<br>add<br>i |         | \$s1,<br>\$s0, |                |         |                               |                |
|------------|-----------------|---------|----------------|----------------|---------|-------------------------------|----------------|
| Else:      | sub             |         | \$s0,          | \$s1           |         |                               |                |
| Exit:      | •••             |         |                |                |         |                               |                |
| 0x00400020 |                 | 4       | 16             | 5 17           |         | 2                             |                |
| 0x00400024 |                 | 0       | 16             | 5 17           | 19      | 0                             | 0x20           |
| 0x00400028 |                 | 2       | 0 0            | 00 0100        | 0 (     | 0 0 0                         | 11 002         |
|            |                 | jmp dst | : = (02        | <0) 0x04       | 0003 00 | <sub>2</sub> (00 <sub>2</sub> | <sub>2</sub> ) |
|            |                 |         |                | $= 0 \times 0$ | 0400030 |                               |                |
| 0x0040002c |                 | 0       | 16             | 5 17           | 19      | 0                             | 0x22           |
| 0x00400030 |                 |         |                |                |         |                               |                |

Branching Far Away

- What if the branch destination is further away than can be captured in 16 bits?
- The assembler comes to the rescue it inserts an unconditional jump to the branch target and inverts the condition

beq \$s0, \$s1, L1

becomes

bne \$s0, \$s1, L2 j L1 L2:

# **Compiling While Loops**

Compile the assembly code for the C while loop where i is in \$s0, j is in \$s1, and k is in \$s2 while (i!=k) i=i+j; Loop: beq \$s0, \$s2, Exit add \$s0, \$s0, \$s1 j Loop Exit: ...

Basic block – A sequence of instructions without branches (except at the end) and without branch targets (except at the beginning)

# **More Instructions for Making Decisions**

We have beq, bne, but what about branch-ifless-than?

### New instruction:

slt \$t0, \$s0, \$s1 # if \$s0 < \$s1
 # then
 # \$t0 = 1
 # else
 # \$t0 = 0</pre>

Machine format:



### Yet More Instructions for Making Decisions

- Since constant operands are popular in comparisons, also have slti
- New instruction:

slti \$t0, \$s0, 10 # if \$s0 < 10
 # then
 # \$t0 = 1
 # else
 # \$t0 = 0</pre>

#### Machine format:



2

### **Other Branch Instructions**

Can use slt, beq, bne, and the fixed value of 0 in \$zero to create all relative conditions

| less   | than                | blt   | \$s1, \$s2, Lbl |
|--------|---------------------|-------|-----------------|
| slt    | \$at, \$s1, \$s2    | #\$at | set to 1 if     |
| bne    | \$at, \$zero, Lbl   | . #   | \$s1 < \$s2     |
| less   | than or equal to    | ble   | \$s1, \$s2, Lbl |
| • grea | ater than           | bgt   | \$s1, \$s2, Lbl |
| • grea | at than or equal to | bge   | \$s1, \$s2, Lbl |

As pseudo instructions they are recognized (and expanded) by the assembler

The assembler needs a reserved register (\$at)

• so there are policy of use conventions for registers

# Another Instruction for Changing Flow

- Most higher level languages have case or switch statements allowing the code to select one of many alternatives depending on a single value
- Instruction:
  - jr \$t1 #go to address in \$t1
- Machine format:



| Category               | Instr                         | OpCd   | Example               | Meaning                               |
|------------------------|-------------------------------|--------|-----------------------|---------------------------------------|
| Arithmetic             | add                           | 0 & 20 | add \$s1, \$s2, \$s3  | \$s1 = \$s2 + \$s3                    |
| (R & I                 | subtract                      | 0 & 22 | sub \$s1, \$s2, \$s3  | \$s1 = \$s2 - \$s3                    |
| format)                | add immediate                 | 8      | addi \$s1, \$s2, 4    | \$s1 = \$s2 + 4                       |
| Data                   | load word                     | 23     | lw \$s1, 100(\$s2)    | \$s1 = Memory(\$s2+100)               |
| transfer<br>(I format) | store word                    | 2b     | sw \$s1, 100(\$s2)    | Memory(\$s2+100) = \$s1               |
| Cond.                  | br on equal                   | 4      | beq \$s1, \$s2, L     | if (\$s1==\$s2) go to L               |
| branch                 | br on not equal               | 5      | bne \$s1, \$s2, L     | if (\$s1 !=\$s2) go to L              |
| (I format)             | set on less<br>than immediate | а      | slt \$s1, \$s2, 100   | if (\$s2<100) \$s1=1;<br>else         |
| (R format)             | set on less<br>than           | 0 & 2a | slti \$s1, \$s2, \$s3 | if (\$s2<\$s3) \$s1=1;<br>else \$s1=0 |
| Uncond.                | jump                          | 2      | j 2500                | go to 10000                           |
| jump                   | jump register                 | 0 & 08 | jr \$t1               | go to \$t1                            |

# Review: MIPS Instructions, so far

# **MIPS Organization**



### **MIPS Data Types**

<u>Bit</u>: 0, 1

Bit String: sequence of bits of a particular length

4 bits is a nibble 8 bits is a byte 16 bits is a half-word 32 bits is a word 64 bits is a double-word

#### Character:

ASCII 7 bit code

#### Decimal:

digits 0-9 encoded as  $0000_2$  thru  $1001_2$  two decimal digits packed per 8 bit byte

Integers: 2's complement

**Floating Point** 

### **Beyond Numbers**

Most computers use 8-bit bytes to represent characters with the American Std Code for Info Interchange (ASCII)

| ASCII | Char | ASCII | Char  | ASCII | Char | ASCII | Char | ASCII | Char | ASCII | Char |
|-------|------|-------|-------|-------|------|-------|------|-------|------|-------|------|
| 0     | Null | 32    | space | 48    | 0    | 64    | @    | 96    | `    | 112   | р    |
| 1     |      | 33    | !     | 49    | 1    | 65    | Α    | 97    | а    | 113   | q    |
| 2     |      | 34    | "     | 50    | 2    | 66    | В    | 98    | b    | 114   | r    |
| 3     |      | 35    | #     | 51    | 3    | 67    | С    | 99    | с    | 115   | s    |
| 4     | EOT  | 36    | \$    | 52    | 4    | 68    | D    | 100   | d    | 116   | t    |
| 5     |      | 37    | %     | 53    | 5    | 69    | Е    | 101   | е    | 117   | u    |
| 6     | ACK  | 38    | &     | 54    | 6    | 70    | F    | 102   | f    | 118   | v    |
| 7     |      | 39    | ć     | 55    | 7    | 71    | G    | 103   | g    | 119   | w    |
| 8     | bksp | 40    | (     | 56    | 8    | 72    | Н    | 104   | h    | 120   | x    |
| 9     | tab  | 41    | )     | 57    | 9    | 73    | Ι    | 105   | i    | 121   | у    |
| 10    | LF   | 42    | *     | 58    | :    | 74    | J    | 106   | j    | 122   | z    |
| 11    |      | 43    | +     | 59    | ;    | 75    | К    | 107   | k    | 123   | {    |
| 12    | FF   | 44    | ,     | 60    | <    | 76    | L    | 108   | I    | 124   |      |
|       |      |       |       |       |      |       |      |       |      |       |      |
| 15    |      | 47    | /     | 63    | ?    | 79    | 0    | 111   | 0    | 127   | DEL  |

So, we need instructions to move bytes around

### **Byte Addresses**

- Since bytes (8 bits) are so useful, most ISAs support addressing individual bytes in memory
- Therefore, the memory address of a word must be a multiple of 4 (alignment restriction)

| Big Endian:<br>MIPS | leftmost byte is word address  |
|---------------------|--------------------------------|
| Little Endian:      | rightmost byte is word address |

### Addressing Objects: Endianess and Alignment



# **Loading and Storing Bytes**

### MIPS provides special instructions to move bytes

| lb | \$t0, 1 | (\$s3) | <pre>#load byte from memory</pre> |
|----|---------|--------|-----------------------------------|
| sb | \$t0, 6 | (\$s3) | #store byte to memory             |
|    |         |        |                                   |

| ор | rs | rt | 16 bit number |
|----|----|----|---------------|
|    |    |    |               |

### What 8 bits get loaded and stored?

- load byte places the byte from memory in the rightmost 8 bits of the destination register
  - what happens to the other bits in the register?
- store byte takes the byte from the rightmost 8 bits of a register and writes it to the byte in memory
  - leaving the other bytes in the memory word unchanged

# **Example of Loading and Storing Bytes**

Given following code sequence and memory state what is the state of the memory after executing the code?

| add            |       | •            | zero,            | \$zeı    | 0                   |                 |
|----------------|-------|--------------|------------------|----------|---------------------|-----------------|
| lb<br>sb       |       | •            | (\$s3)<br>(\$s3) |          | What value is       | s left in \$t0? |
| Memory         | '     |              |                  |          | t0 = 0x0000         | 00090           |
| 0x 0 0 0 0 0   | 000   | 24           |                  |          | ••••                |                 |
| 0x 0 0 0 0 0   | 000   | 20           |                  |          |                     | ed in Memory    |
| 0x 0 0 0 0 0   | 000   | 16           | an               | d to w   | /nat?               |                 |
| 0x 1 0 0 0 0   | 010   | 12           | m                | em(4)    | $= 0 \times FFFF90$ | OFF             |
| 0x 0 1 0 0 0 4 | 402   | 8            | 🗅 Wh             | at if th | ne machine v        | was little      |
| 0x F F F F F   | FFF   | 4            | End              | dian?    | <b>•</b> •••        |                 |
| 0x009012       | 2 A 0 | 0            |                  |          | t0 = 0x000          | 00012           |
| Data           |       | Word<br>Addr | d<br>ess (Decir  | mal)     | mem(4) = 0          | xFF12FFFF       |

# Loading and Storing Half Words

# MIPS also provides special instructions to move half words



What 16 bits get loaded and stored?

- load half word places the half word from memory in the rightmost 16 bits of the destination register
  - what happens to the other bits in the register?
- store half word takes the half word from the rightmost 16 bits of the register and writes it to the half word in memory
  - leaving the other half word in the memory word unchanged

# **Shift Operations**

- Need operations to pack and unpack 8-bit characters into 32-bit words
- Shifts move all the bits in a word left or right



- Such shifts are called logical because they fill with zeros
  - Notice that a 5-bit shamt field is enough to shift a 32-bit value 2<sup>5</sup> – 1 or 31 bit positions

# **More Shift Operations**

sra \$t2, \$s0, 8

- An arithmetic shift (sra) maintain the arithmetic correctness of the shifted value (i.e., a number shifted right one bit should be ½ of its original value; a number shifted left should be 2 times its original value)
  - sra uses the most significant bit (sign bit) as the bit shifted in
  - sll works for arithmetic left shifts for 2's compl. (so there is no need for a sla)



#\$t2 = \$s0 >> 8 bits

 Give a specific numerical example (e.g., 6 and -6) illustrating the difference between sll, srl, and sra (and how 6 becomes 3, etc.)

### Compiling Another While Loop

Compile the assembly code for the C while loop where i is in \$s3, k is in \$s5, and the base address of the array save is in \$s6

```
while (save[i] == k)
    i += 1;
Loop: sll $t1, $s3, 2
    add $t1, $t1, $s6
    lw $t0, 0($t1)
    bne $t0, $s5, Exit
    addi $s3, $s3, 1
    j Loop
Exit: ...
```

### **Logical Operations**

There are a number of bit-wise logical operations in the MIPS ISA

and \$t0, \$t1, \$t2 #\$t0 = \$t1 & \$t2
or \$t0, \$t1, \$t2 #\$t0 = \$t1 | \$t2
nor \$t0, \$t1, \$t2 #\$t0 = not(\$t1 | \$t2)



### **Logic Operations**

Logic operations operate on individual bits of the operand.

\$t2 = 0...0 0000 1101 0000 \$t1 = 0...0 0011 1100 0000 and \$t0, \$t1, \$t2 \$t0 = 0...0 0000 1100 0000 or \$t0, \$t1 \$t2 \$t0 = 0...0 0011 1101 0000 nor \$t0, \$t1, \$t2 \$t0 = 1...1 1100 0010 1111

### How About Larger Constants?

- We'd also like to be able to load a 32-bit constant into a register
- Must use two instructions, new "load upper immediate" instruction

```
lui $t0, Oxaaaa
```

f 0 8 10101010101010

Then must get the lower order bits right, i.e.,

| ori \$t0, \$t0,                         | Oxaaaa                                  |
|-----------------------------------------|-----------------------------------------|
| 1010101010101010                        | 000000000000000000000000000000000000000 |
| 000000000000000000000000000000000000000 | 1010101010101010                        |
|                                         |                                         |

1010101010101010 10101010101010

| Category          | Instr                     | ОрС    | Example              | Meaning                               |
|-------------------|---------------------------|--------|----------------------|---------------------------------------|
| Arithmetic        | add                       | 0 & 20 | add \$s1, \$s2, \$s3 | \$s1 = \$s2 + \$s3                    |
| (R & I<br>format) | subtract                  | 0 & 22 | sub \$s1, \$s2, \$s3 | \$s1 = \$s2 - \$s3                    |
|                   | add immediate             | 8      | addi \$s1, \$s2, 4   | \$s1 = \$s2 + 4                       |
|                   | shift left logical        | 0 & 00 | sll \$s1, \$s2, 4    | \$s1 = \$s2 << 4                      |
|                   | shift right<br>logical    | 0 & 02 | srl \$s1, \$s2, 4    | \$s1 = \$s2 >> 4 (fill with zeros)    |
|                   | shift right<br>arithmetic | 0 & 03 | sra \$s1, \$s2, 4    | \$s1 = \$s2 >> 4 (fill with sign bit) |
|                   | and                       | 0 & 24 | and \$s1, \$s2, \$s3 | \$s1 = \$s2 & \$s3                    |
|                   | or                        | 0 & 25 | or \$s1, \$s2, \$s3  | \$s1 = \$s2   \$s3                    |
|                   | nor                       | 0 & 27 | nor \$s1, \$s2, \$s3 | \$s1 = not (\$s2   \$s3)              |
|                   | and immediate             | с      | and \$s1, \$s2, ff00 | \$s1 = \$s2 & 0xff00                  |
|                   | or immediate              | d      | or \$s1, \$s2, ff00  | \$s1 = \$s2   0xff00                  |
|                   | load upper<br>immediate   | f      | lui \$s1, 0xffff     | \$s1 = 0xffff0000                     |

# Review: MIPS Instructions, so far

# Review: MIPS Instructions, so far

| Category                             | Instr                         | ОрС    | Example              | Meaning                        |
|--------------------------------------|-------------------------------|--------|----------------------|--------------------------------|
| Data<br>transfer<br>(I format)       | load word                     | 23     | lw \$s1, 100(\$s2)   | \$s1 = Memory(\$s2+100)        |
|                                      | store word                    | 2b     | sw \$s1, 100(\$s2)   | Memory(\$s2+100) = \$s1        |
|                                      | load byte                     | 20     | lb \$s1, 101(\$s2)   | \$s1 = Memory(\$s2+101)        |
|                                      | store byte                    | 28     | sb \$s1, 101(\$s2)   | Memory(\$s2+101) = \$s1        |
|                                      | load half                     | 21     | lh \$s1, 101(\$s2)   | \$s1 = Memory(\$s2+102)        |
|                                      | store half                    | 29     | sh \$s1, 101(\$s2)   | Memory(\$s2+102) = \$s1        |
| Cond.<br>branch<br>(I & R<br>format) | br on equal                   | 4      | beq \$s1, \$s2, L    | if (\$s1==\$s2) go to L        |
|                                      | br on not equal               | 5      | bne \$s1, \$s2, L    | if (\$s1 !=\$s2) go to L       |
|                                      | set on less<br>than immediate | а      | slti \$s1, \$s2, 100 | if (\$s2<100) \$s1=1;<br>else  |
|                                      | set on less<br>than           | 0 & 2a | slt \$s1, \$s2, \$s3 | if (\$s2<\$s3) \$s1=1;<br>else |
| Uncond.<br>jump                      | jump                          | 2      | j 2500               | go to 10000                    |
|                                      | jump register                 | 0 & 08 | jr \$t1              | go to \$t1                     |