| What is a pseudo-instructio<br>What true MIPS instruction                                | n?<br>is ec | quivalent to: |
|------------------------------------------------------------------------------------------|-------------|---------------|
| * move \$t0, \$s1?                                                                       | 0           | 0             |
| Assume Registers:                                                                        | 1           | 1             |
|                                                                                          | 2           | 2000          |
| xplain what the following in<br>sb \$t0, 4(\$1)<br>lw \$t1, 2(\$2)<br>sh \$t2, -500(\$2) | nstru       | uctions do    |
| ad Byte: Ib req.addr                                                                     | ?           | ?? M[addr]    |





 The MIPS processor only supports two branch instructions, beq and bne, but to simplify your life the assembler provides the following other branches:

| blt \$t0, \$t1, Lab1 | # Branch if \$t0 < \$t1  |
|----------------------|--------------------------|
| ble \$t0, \$t1, Lab2 | # Branch if \$t0 <= \$t1 |
| bgt \$t0, \$t1, Lab3 | # Branch if \$t0 > \$t1  |
| bge \$t0, \$t1, Lab4 | # Branch if \$t0 >= \$t1 |

- There are also immediate versions of these branches, where the *second* source is a constant instead of a register
- Later this quarter we'll see how supporting just beq and bne simplifies the processor design

3



| \$zero    | \$0     | Zero                    |       |
|-----------|---------|-------------------------|-------|
| \$at      | \$1     | Assembler temp          |       |
| \$v0-\$v1 | \$2-3   | Value (return from fcn) |       |
| \$a0-\$a3 | \$4-7   | Argument (to fcn)       |       |
| \$t0-\$t7 | \$8-15  | Temporaries             |       |
| \$s0-\$s7 | \$16-23 | Saved Temporaries       | Saved |
| \$t8-\$t9 | \$24-25 | Temporaries             |       |
| \$k0-\$k1 | \$26-27 | Kernel (OS) Registers   |       |
| \$gp      | \$28    | Global Pointer          | Saved |
| \$sp      | \$29    | Stack Pointer           | Saved |
| \$fp      | \$30    | Frame Pointer           | Saved |
| \$ra      | \$31    | Return Address          | Saved |









|                                   |                       | 1-                          |
|-----------------------------------|-----------------------|-----------------------------|
| Let's write a program             | to count the 1 bits i | n a 32-bit word             |
| int count = 0;                    | .text main:           | ## arg in \$a0              |
| for (int i = 0 ; i < 32 ; i ++) { |                       |                             |
| int bit = input & 1;              | li \$t0, 0            | ## int count = 0;           |
| if (bit != 0) {                   | li \$t1, 0            | ## for (int i = 0           |
| count ++;                         | main_loop:            |                             |
| }                                 | bge \$t1, 32, main_   | exit ## exit loop if i >= 3 |
| input = input >> 1;               | andi \$t2, \$a0, 1    | ## bit = input & 1          |
| }                                 | beq \$t2, \$0, main_  | _skip ## skip if bit == 0   |
|                                   | addi \$t0, \$t0, 1    | ## count ++                 |
|                                   | main_skip:            |                             |
|                                   | srl \$a0, \$a0, 1     | ## input = input >>         |
|                                   | add \$t1, \$t1, 1     | ## i ++                     |
|                                   | j main_loop           |                             |
|                                   | main exit:            |                             |







|                                                                                                                          |                                                                                                       | l-tvp                                                                          | be forr                                                                            | nat                                                                                                                                  |
|--------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Load, s</li> <li>type</li> </ul>                                                                                | tore, bra                                                                                             | anch, &                                                                        | immedia                                                                            | ate instructions are I-                                                                                                              |
| <b>J</b> 1                                                                                                               | ор                                                                                                    | rs                                                                             | rt                                                                                 | address                                                                                                                              |
|                                                                                                                          | 6 bits                                                                                                | 5 bits                                                                         | 5 bits                                                                             | 16 bits                                                                                                                              |
|                                                                                                                          |                                                                                                       | 141                                                                            |                                                                                    |                                                                                                                                      |
| The me instruct                                                                                                          | aning of<br>ion                                                                                       | the reg                                                                        | lister fie                                                                         | lds depends on                                                                                                                       |
| <ul> <li>The me<br/>instruct         <ul> <li>rs is a<br/>operation</li> </ul> </li> </ul>                               | aning of<br>ion<br>a source r<br>and for bra                                                          | egister—a                                                                      | lister fie<br>an addres<br>immedia                                                 | lds depends on<br>ss for loads and stores, or an<br>te arithmetic instructions                                                       |
| <ul> <li>The me<br/>instruct         <ul> <li>rs is a<br/>opera</li> <li>rt is a<br/>for the</li> </ul> </li> </ul>      | aning of<br>ion<br>a source re<br>and for bra<br>source re<br>e other I-1                             | egister—a<br>anch and<br>egister for<br>type instr                             | IISTER TIE<br>an addres<br>immedia<br>r branche<br>uctions                         | lds depends on<br>as for loads and stores, or an<br>te arithmetic instructions<br>s, but a destination register                      |
| <ul> <li>The me instruct</li> <li>rs is a opera</li> <li>rt is a for the</li> <li>The addr</li> </ul>                    | aning of<br>ion<br>a source r<br>and for bra<br>source re<br>e other I-1<br>ess is a 1                | egister—a<br>anch and<br>egister for<br>type instr<br>6-bit sign               | IISTER TIE<br>an addres<br>immedia<br>r branche<br>uctions<br>ned two's-           | lds depends on<br>as for loads and stores, or an<br>te arithmetic instructions<br>s, but a destination register<br>-complement value |
| <ul> <li>The me instruct</li> <li>rs is a opera</li> <li>rt is a for the</li> <li>The addr</li> <li>* Its rar</li> </ul> | aning of<br>ion<br>a source r<br>and for bra<br>source re<br>e other I-1<br>ess is a 1<br>nge is [-32 | egister—a<br>anch and<br>egister for<br>type instr<br>6-bit sign<br>2,768, +3: | Inster fie<br>an addres<br>immedia<br>r branche<br>uctions<br>ned two's-<br>2,767] | lds depends on<br>as for loads and stores, or an<br>te arithmetic instructions<br>s, but a destination register<br>-complement value |

