CS378: Machine Organization and Assembly Language

Lecture 2 – Spring 2010

What is an instruction? And a register?
What does register-to-register mean?
In what order is a program executed?

Why do we need memory?
Where are the instructions stored?

What is the C equivalent to: sub $t0, $t1, $t2?

A more complete assembly example

- How would you write in MIPS assembly to compute:
  
  \[-1 \times 2 + 3 \times 4\]

  add $s0, $t0, 1
  add $s1, $t1, 3
  mul $s2, $t0, $t1
  add $s0, $s0, $s2

Memory review

- Memory sizes are specified much like register files; here is a 2\(\times\)8 RAM

- A chip select CS enables or “disables” the RAM
- ADRS specifies the memory location to access
- WR selects between reading from or writing to the memory
  - To read from memory, WR should be set to 1. OUT will be the n-bit value stored at ADRS.
  - To write to memory, we set WR = 1. DATA is the n-bit value to store in memory.

MIPS memory

- MIPS memory is byte-addressable, which means that each memory address references an 8-bit quantity.
- The MIPS architecture can support up to 32 address lines.
  - This results in a 2\(^{32}\) x 8 RAM, which would be 4 GB of memory.
  - Not all actual MIPS machines will have this much!

Loading and storing bytes

- The MIPS instruction set includes dedicated load and store instructions for accessing memory
- MIPS uses indexed addressing to reference memory
  - The address operand specifies a signed constant and a register
  - These values are added to generate the effective address
- The MIPS “load byte” instruction moves one byte of data from RAM memory to a register

- The “store byte” instruction transfers the lowest byte of data from a register into main memory

Announcements

- Homework 0 posted – not graded, just for your benefit
  - On your own, explore SPIM
- Homework 1 (a grade, to be done individually) will be posted Monday.
  - Write a couple of functions in MIPS assembly
  - Due about a week later
- Lab 1 (to be done in partners) posted
  - Please find a lab partner soon
  - Or we will find one for you.
Computing with memory

- So, to compute with memory-based data, you must:
  1. Load the data from memory to the register file.
  2. Do the computation, leaving the result in a register.
  3. Store that value back to memory if needed.
- For example, let's say that you wanted to do the same addition, but the values were in memory. How can we do the following using MIPS assembly language? (A's address is in $s0, result's address is in $s1)

```mips
li $a0, 1234
la $a1, result
add $t0, $a0, $a1
sw $t0, 0($s1)
```

Computing with memory words

- Same example, but with 4-byte ints instead of 1-byte chars. What changes? (As before, A's address is in $s0, result's address is in $s1)

```mips
li $a0, 1234
la $a1, result
add $t0, $a0, $a1
sw $t0, 0($s1)
```

An Array of Words From Memory of Bytes

Use care with memory addresses when accessing words.
For instance, assume an array of words begins at address 2000.
- The first word is at address 2000.
- The second word is at address 2001.
Example, if $s0 contains 2000, then

```mips
lw $s0, 0($s0)
```
would access the first word of the array, but

```mips
lw $s0, 4($s0)
```

would access the third word of the array, at address 2008.

Memory is byte addressed but usually word referenced

Memory Alignment

- Picture words of data stored in byte-addressable memory as follows

<table>
<thead>
<tr>
<th>Address</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
</tr>
</thead>
<tbody>
<tr>
<td>Word 1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Word 2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Word 3</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

- The MIPS architecture requires words to be aligned in memory: 32-bit words must start at an address that is divisible by 4.
  - 0, 4, 8 and 12 are valid word addresses
  - 1, 2, 3, 5, 6, 7, 9, 10 and 11 are not valid word addresses
- Unaligned memory accesses result in a bus error, which you may have unfortunately seen before.
- This restriction has relatively little effect on high-level languages and compilers, but it makes things easier and faster for the processor.

Pseudo Instructions

- MIPS assemblers support pseudo-instructions giving the illusion of a more expressive instruction set by translating into one or more simpler, “real” instructions.
- For example, li and move are pseudo-instructions:
  ```mips
  li $a0, 2000
  move $s1, $0
  ```
  - They are probably clearer than their corresponding MIPS instructions:
    ```mips
    move $s1, 2000
    ```
- We’ll see more pseudo-instructions this semester.
  - A complete list of instructions is given in Appendix B.
  - Unless otherwise stated, you can always use pseudo-instructions in your assignments and on exams.
- But remember that these do not really exist in the hardware—they are conveniences provided by the assembler.