

# CSC 411

## Computer Organization (Spring 2022) Lecture 7: Representing instructions

Prof. Marco Alvarez, University of Rhode Island

## Disclaimer

Some of the following slides are adapted from:  
Computer Organization and Design (Patterson and Hennessy)  
The Hardware/Software Interface



| RISC-V operands              |                                                  |                                                                                                                                                                                |  |  |
|------------------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Name                         | Example                                          | Comments                                                                                                                                                                       |  |  |
| 32 registers                 | x0-x31                                           | Fast locations for data. In RISC-V, data must be in registers to perform arithmetic. Register x0 always equals 0.                                                              |  |  |
| 2 <sup>30</sup> memory words | Memory[0], Memory[4], ..., Memory[4,294,967,292] | Accessed only by data transfer instructions. RISC-V uses byte addresses, so sequential word accesses differ by 4. Memory holds data structures, arrays, and spilled registers. |  |  |

| RISC-V assembly language |                                  |                    |                                    |                                            |
|--------------------------|----------------------------------|--------------------|------------------------------------|--------------------------------------------|
| Category                 | Instruction                      | Example            | Meaning                            | Comments                                   |
| Arithmetic               | Add                              | add x5, x6, x7     | $x5 = x6 + x7$                     | Three register operands; add               |
|                          | Subtract                         | sub x5, x6, x7     | $x5 = x6 - x7$                     | Three register operands; subtract          |
|                          | Add immediate                    | addi x5, x6, 20    | $x5 = x6 + 20$                     | Used to add constants                      |
| Data transfer            | Load word                        | lw x5, 40(x6)      | $x5 = \text{Memory}[x6 + 40]$      | Word from memory to register               |
|                          | Load word, unsigned              | lwu x5, 40(x6)     | $x5 = \text{Memory}[x6 + 40]$      | Unsigned word from memory to register      |
|                          | Store word                       | sw x5, 40(x6)      | $\text{Memory}[x6 + 40] = x5$      | Word from register to memory               |
|                          | Load halfword                    | lh x5, 40(x6)      | $x5 = \text{Memory}[x6 + 40]$      | Halfword from memory to register           |
|                          | Load halfword, unsigned          | lhu x5, 40(x6)     | $x5 = \text{Memory}[x6 + 40]$      | Unsigned halfword from memory to register  |
|                          | Store halfword                   | sh x5, 40(x6)      | $\text{Memory}[x6 + 40] = x5$      | Halfword from register to memory           |
|                          | Load byte                        | lb x5, 40(x6)      | $x5 = \text{Memory}[x6 + 40]$      | Byte from memory to register               |
|                          | Load byte, unsigned              | lbu x5, 40(x6)     | $x5 = \text{Memory}[x6 + 40]$      | Byte unsigned from memory to register      |
|                          | Store byte                       | sb x5, 40(x6)      | $\text{Memory}[x6 + 40] = x5$      | Byte from register to memory               |
|                          | Load reserved                    | lr.d x5, (x6)      | $x5 = \text{Memory}[x6]$           | Load; 1st half of atomic swap              |
|                          | Store conditional                | sc.d x7, x5, (x6)  | $\text{Memory}[x6] = x5; x7 = 0/1$ | Store; 2nd half of atomic swap             |
|                          | Load upper immediate             | lui x5, 0x12345000 | $x5 = 0x12345000$                  | Loads 20-bit constant shifted left 12 bits |
| Logical                  | And                              | and x5, x6, x7     | $x5 = x6 \& x7$                    | Three reg. operands; bit-by-bit AND        |
|                          | Inclusive or                     | or x5, x6, x8      | $x5 = x6   x8$                     | Three reg. operands; bit-by-bit OR         |
|                          | Exclusive or                     | xor x5, x6, x9     | $x5 = x6 \wedge x9$                | Three reg. operands; bit-by-bit XOR        |
|                          | And immediate                    | andi x5, x6, 20    | $x5 = x6 \& 20$                    | Bit-by-bit AND reg. with constant          |
|                          | Inclusive or immediate           | ori x5, x6, 20     | $x5 = x6   20$                     | Bit-by-bit OR reg. with constant           |
|                          | Exclusive or immediate           | xori x5, x6, 20    | $x5 = x6 \wedge 20$                | Bit-by-bit XOR reg. with constant          |
| Shift                    | Shift left logical immediate     | sll x5, x6, x7     | $x5 = x6 \ll x7$                   | Shift left by register                     |
|                          | Shift right logical              | srl x5, x6, x7     | $x5 = x6 \gg x7$                   | Shift right by register                    |
|                          | Shift right arithmetic           | sra x5, x6, x7     | $x5 = x6 \gg> x7$                  | Arithmetic shift right by register         |
|                          | Shift left logical immediate     | slli x5, x6, 3     | $x5 = x6 \ll 3$                    | Shift left by immediate                    |
|                          | Shift right logical immediate    | srli x5, x6, 3     | $x5 = x6 \gg 3$                    | Shift right by immediate                   |
|                          | Shift right arithmetic immediate | srai x5, x6, 3     | $x5 = x6 \gg> 3$                   | Arithmetic shift right by immediate        |

## Representing instructions

# Representing instructions

- Instructions are encoded in binary
  - called machine code
- RISC-V instructions
  - encoded as 32-bit instruction words
  - small number of formats encoding operation code (opcode), register numbers, ...
  - regularity !

## RISC-V R-format instructions

- Instruction fields
  - opcode: operation code
  - rd: destination register number
  - funct3: 3-bit function code (additional opcode)
  - rs1: first source register number
  - rs2: second source register number
  - funct7: 7-bit function code (additional opcode)

| funct7 | rs2    | rs1    | funct3 | rd     | opcode |
|--------|--------|--------|--------|--------|--------|
| 7 bits | 5 bits | 5 bits | 3 bits | 5 bits | 7 bits |

## Example

| funct7 | rs2    | rs1    | funct3 | rd     | opcode |
|--------|--------|--------|--------|--------|--------|
| 7 bits | 5 bits | 5 bits | 3 bits | 5 bits | 7 bits |

add x9, x20, x21

|   |    |    |   |   |    |
|---|----|----|---|---|----|
| 0 | 21 | 20 | 0 | 9 | 51 |
|---|----|----|---|---|----|

|         |       |       |     |       |         |
|---------|-------|-------|-----|-------|---------|
| 0000000 | 10101 | 10100 | 000 | 01001 | 0110011 |
|---------|-------|-------|-----|-------|---------|

00000001010110100000010010110011<sub>2</sub> = 015A04B3<sub>16</sub>

## RISC-V I-format instructions

- Immediate arithmetic and load instructions
  - rs1: source or base address register number
  - immediate: constant operand, or offset added to base address
    - two's complement, sign extended
- Different formats complicate decoding, but allow 32-bit instructions uniformly
  - keep formats as similar as possible

| immediate | rs1    | funct3 | rd     | opcode |
|-----------|--------|--------|--------|--------|
| 12 bits   | 5 bits | 3 bits | 5 bits | 7 bits |



## Stored computer programs

- Instructions represented in binary, just like data
  - instructions and data stored in memory
- Binary compatibility allows compiled programs to work on different computers
  - standardized ISAs

## Memory layout

### ▪ Stack/Heap (**stack pointer**)

- space for the run-time stack (local procedures)
- dynamically allocated data

### ▪ Globals (**global pointer**)

- global variables

### ▪ Text (**program counter**)

- instructions



[https://chortle.ccsu.edu/AssemblyTutorial/Chapter-10/ass10\\_3.html](https://chortle.ccsu.edu/AssemblyTutorial/Chapter-10/ass10_3.html)