## Notes for 9/11/09

MIPS addressing types:

| Addressing              | Example                      | Bits                                              | Range                                                                                                                                                        |
|-------------------------|------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Immediate Addressing    | addiu sp, sp, -32            | 16                                                | -2 <sup>15</sup> 2 <sup>15</sup> - 1                                                                                                                         |
| Register Addressing     | jalr <i>t9</i>               | 5                                                 | 0 31 (32 registers)                                                                                                                                          |
| Base Addressing         | sw 16(sp)                    | Immediate offset: 16<br>Register: 5 (contains 32) | Can point to anywhere in<br>memory, since register can<br>contain any 32-bit value                                                                           |
| PC-relative Addressing  | bne \$t0, \$t1, <i>Label</i> | 16                                                | Since the lowest two bits of<br>address are assumed zero,<br>label gets shifted left by two,<br>and effective range is:<br>$PC \pm -2^{17} \dots 2^{17} - 1$ |
| Pseudodirect Addressing | j Label                      | 26                                                | Anywhere in current 256MB chunk                                                                                                                              |

In the PC-relative and pseudodirect addressing cases, it is safe to assume that the lower two bits are zero because, in MIPS, all instructions are word aligned.

Life cycle of code:

C Program  $\downarrow$  Compiling Assembly  $\downarrow$  Assembling

Machine Code

MIPS has no microcode, since it is already a simple enough of an architecture. Other architectures, especially CISC architectures like the wretched x86, tend to convert machine code to microcode in the processor. Microcode tends to be processor-specific, even within the same architecture, and most processors, such as Intel's x86 processors, do not expose the microcode to software, so you cannot see the microcode or program it yourself.