

ECE 281

# Lesson 21:

# RV32I Registers

Digital Design and Computer Architecture Lecture Notes

© 2021 Sarah Harris and David Harris

These notes may be used and modified for educational and/or  
non-commercial purposes so long as the source is attributed.

Modified for use by USAF Academy, 2025

# Introduction

- **Architecture:** programmer's view of computer
    - Defined by instructions & operand locations
  - **Microarchitecture:** how to implement an architecture in hardware
  - **Instructions :** commands in a computer's language
    - **Assembly language:** human-readable format of instructions
    - **Machine language:** computer-readable format (1's and 0's)
- 2: [Instructions](#)  
• 3: [Operands](#)  
• 15: [Machine Language: R-Type Instruction Formats](#)  
• 16: [Machine Language: I, S/B, U/J-Type Instr. Formats](#)



# Operands

- **Operand location:** physical location in computer
  - Registers
    - RV32I has thirty-two 32-bit registers
  - Memory
  - Constants (also called *immediates*)

# RISC-V Register Set

| Name    | Register Number | Usage                              |
|---------|-----------------|------------------------------------|
| zero    | x0              | Constant value 0                   |
| ra      | x1              | Return address                     |
| sp      | x2              | Stack pointer                      |
| gp      | x3              | Global pointer                     |
| tp      | x4              | Thread pointer                     |
| t0-2    | x5-7            | Temporaries                        |
| s0 / fp | x8              | Saved register / Frame pointer     |
| s1      | x9              | Saved register                     |
| a0-1    | x10-11          | Function arguments / return values |
| a2-7    | x12-17          | Function arguments                 |
| s2-11   | x18-27          | Saved registers                    |
| t3-6    | x28-31          | Temporaries                        |

## Chapter 6: Architecture

# Machine Language

# Machine Language

- Binary representation of instructions
- Computers only understand 1's and 0's
- 32-bit instructions
  - Simplicity favors regularity: 32-bit data & instructions
- **4 Types of Instruction Formats:**

- R-Type
- I-Type
- S/B-Type
- U/J-Type

# Review: Instruction Formats

| 7 bits                 | 5 bits                          | 5 bits | 3 bits | 5 bits                | 7 bits |        |
|------------------------|---------------------------------|--------|--------|-----------------------|--------|--------|
| funct7                 | rs2                             | rs1    | funct3 | rd                    | op     | R-Type |
| imm <sub>11:0</sub>    |                                 | rs1    | funct3 | rd                    | op     | I-Type |
| imm <sub>11:5</sub>    | rs2                             | rs1    | funct3 | imm <sub>4:0</sub>    | op     | S-Type |
| imm <sub>12,10:5</sub> | rs2                             | rs1    | funct3 | imm <sub>4:1,11</sub> | op     | B-Type |
|                        | imm <sub>31:12</sub>            |        |        | rd                    | op     | U-Type |
|                        | imm <sub>20,10:1,11,19:12</sub> |        |        | rd                    | op     | J-Type |
| 20 bits                |                                 | 5 bits |        | 7 bits                |        |        |

# R-Type Examples

## Assembly

```
add s2, s3, s4  
add x18, x19, x20  
sub t0, t1, t2  
sub x5, x6, x7
```

## Field Values

| funct7 | rs2 | rs1 | funct3 | rd | op |
|--------|-----|-----|--------|----|----|
| 0      | 20  | 19  | 0      | 18 | 51 |
| 32     | 7   | 6   | 0      | 5  | 51 |

## Machine Code

|          |       |       |        |       |          |              |
|----------|-------|-------|--------|-------|----------|--------------|
| funct7   | rs2   | rs1   | funct3 | rd    | op       |              |
| 0000 000 | 10100 | 10011 | 000    | 10010 | 011 0011 | (0x01498933) |
| 0100 000 | 00111 | 00110 | 000    | 00101 | 011 0011 | (0x407302B3) |

Assembly = add x18, x19, x20

Binary = 0000 0001 0100 1001 1000 1001 0011 0011

Assembly = sub x5, x6, x7



Binary = 0100 0000 0111 0011 0000 0010 1011 0011



[rvcodec.js · RISC-V Instruction Encoder/Decoder](#)

# I-Type Examples

| Assembly         | Field Values        |     |        |    |    | Machine Code        |       |        |       |          |              |
|------------------|---------------------|-----|--------|----|----|---------------------|-------|--------|-------|----------|--------------|
|                  | imm <sub>11:0</sub> | rs1 | funct3 | rd | op | imm <sub>11:0</sub> | rs1   | funct3 | rd    | op       |              |
| addi s0, s1, 12  | 12                  | 9   | 0      | 8  | 19 | 0000 0000 1100      | 01001 | 000    | 01000 | 001 0011 | (0x00C48413) |
| addi x8, x9, 12  | -14                 | 6   | 0      | 18 | 19 | 1111 1111 0010      | 00110 | 000    | 10010 | 001 0011 | (0xFF230913) |
| addi s2, t1, -14 | -6                  | 19  | 2      | 7  | 3  | 1111 1111 1010      | 10011 | 010    | 00111 | 000 0011 | (0xFFA9A383) |
| lw t2, -6(\$s3)  | 27                  | 0   | 1      | 9  | 3  | 0000 0001 1011      | 00000 | 001    | 01001 | 000 0011 | (0x01B01483) |
| lw x7, -6(\$x19) | 0x1F                | 20  | 0      | 20 | 3  | 0000 0001 1111      | 10100 | 000    | 10100 | 000 0011 | (0x01FA0A03) |

Assembly = addi x18, x19, 20

Binary = 0000 0001 0100 1001 1000 1001 0001 0011

Assembly = add x18, x19, x20

← R-Type

Binary = 0000 0001 0100 1001 1000 1001 0011 0011

# Interpreting Machine Code

- Write in binary
- Start with **op**: tells how to parse rest
- Extract fields
- **op, funct3, and funct7** fields tell operation
- Ex: 0x41FE83B3 and 0xFDA48393

0x41FE83B3: 0100 0001 1111 1110 1000 0011 1011 0011  
                    x31                  x7  
                    op = 51, funct3 = 0: add or sub (R-type)  
                    funct7 = 0100000: sub

0xFDA48393: 1111 1101 1010 0100 1000 0011 1001 0011  
                    op = 19, funct3 = 0: addi (I-type)

# Interpreting Machine Code

- Write in binary
- Start with **op**: tells how to parse rest
- Extract fields
- **op, funct3, and funct7** fields tell operation
- **Ex:** 0x41FE83B3 and 0xFDA48393

| Machine Code        |                |        |        |        |          |                     | Field Values |        |        |        |        |        |  | Assembly                             |  |
|---------------------|----------------|--------|--------|--------|----------|---------------------|--------------|--------|--------|--------|--------|--------|--|--------------------------------------|--|
| funct7              | rs2            | rs1    | funct3 | rd     | op       |                     | funct7       | rs2    | rs1    | funct3 | rd     | op     |  |                                      |  |
| (0x41FE83B3)        | 0100 000       | 11111  | 11101  | 000    | 00111    | 011 0011            | 32           | 31     | 29     | 0      | 7      | 51     |  | sub x7, x29, x31<br>sub t2, t4, t6   |  |
| 7 bits              | 5 bits         | 5 bits | 3 bits | 5 bits | 7 bits   |                     | 7 bits       | 5 bits | 5 bits | 3 bits | 5 bits | 7 bits |  |                                      |  |
| imm <sub>11:0</sub> | rs1            | funct3 | rd     | op     |          | imm <sub>11:0</sub> | rs1          | funct3 | rd     | op     |        |        |  |                                      |  |
| (0xFDA48393)        | 1111 1101 1010 | 01001  | 000    | 00111  | 001 0011 | -38                 | 9            | 0      | 7      | 19     |        |        |  | addi x7, x9, -38<br>addi t2, s1, -38 |  |
| 12 bits             | 5 bits         | 3 bits | 5 bits | 7 bits |          | 12 bits             | 5 bits       | 3 bits | 5 bits | 7 bits |        |        |  |                                      |  |

# Chapter 6: Architecture

## Microarchitecture

# RISC-V Architectural State Elements



# RV32I Single Cycle Processor (Partial)



| Address | Instruction | Type | Fields            |              |              |                  |             | Machine Language          |
|---------|-------------|------|-------------------|--------------|--------------|------------------|-------------|---------------------------|
| 0x1008  | x4, x5, x6  | R    | funct7<br>0000000 | rs2<br>00110 | rs1<br>00101 | f3<br>110<br>000 | rd<br>00100 | op<br>0110011<br>0062E233 |

Figure 7.10 Datapath enhancements for R-type instructions

# Single-Cycle Control

## High-Level View



## Low-Level View



# Single-Cycle Control

How does I-Type vs. R-Type influence Main decoder?

| 7 bits | 5 bits | 5 bits | 3 bits | 5 bits | 7 bits |        |
|--------|--------|--------|--------|--------|--------|--------|
| funct7 | rs2    | rs1    | funct3 | rd     | op     | R-Type |
| imm    | imm    | rs1    | funct3 | rd     | op     | I-Type |

or x4, x5, x6 0000 0000 0110 0010 1110 0010 0011 0011

ori x4, x5, 6 0000 0000 0110 0010 1110 0010 0001 0011



# Single-Cycle Control: ALU Decoder

| <i>ALUOp</i> | <i>funct3</i> | <i>op<sub>5</sub>, funct<sub>7</sub><sub>5</sub></i> | <i>Instruction</i> | <i>ALUControl<sub>2:0</sub></i> |
|--------------|---------------|------------------------------------------------------|--------------------|---------------------------------|
| 00           | x             | x                                                    | <b>lw, sw</b>      | 000 (add)                       |
| 01           | x             | x                                                    | <b>beq</b>         | 001 (subtract)                  |
| 10           | 000           | 00, 01, 10                                           | <b>add</b>         | 000 (add)                       |
|              | 000           | 11                                                   | <b>sub</b>         | 001 (subtract)                  |
|              | 010           | x                                                    | <b>slt</b>         | 101 (set less than)             |
|              | 110           | x                                                    | <b>or</b>          | 011 (or)                        |
|              | 111           | x                                                    | <b>and</b>         | 010 (and)                       |



# RV32I Single Cycle Processor (Partial)



| Address | Instruction   | Type | Fields                                 | Machine Language                               |
|---------|---------------|------|----------------------------------------|------------------------------------------------|
| 0x1008  | or x4, x5, x6 | R    | funct7<br>rs2<br>rs1<br>f3<br>rd<br>op | 0000000 00110 00101 110 00100 0110011 0062E233 |

Figure 7.10 Datapath enhancements for R-type instructions

# Chapter 6: Architecture

# Practice

# Machine decoding

Write the assembly code from this machine code: **0x00b54533**

[Check your work at rvcodec.js](#)

0000 0000 1011 0101 0100 0101 0011 0011  
  +-----+-----+-----+-----+-----+-----+  
  | 0000 | xB  | xA  | 100 | xA  | 10  | 51  |  
  | 0000 | 11  | 10  |     | 10  | 11  |  
  +-----+-----+-----+-----+-----+-----+

xor x10 x10 x11

| 7 bits              | 5 bits | 5 bits | 3 bits | 5 bits | 7 bits | R-Type | I-Type |
|---------------------|--------|--------|--------|--------|--------|--------|--------|
| funct7              | rs2    | rs1    | funct3 | rd     | op     |        |        |
| imm <sub>11:0</sub> | rs1    | funct3 |        | rd     | op     |        |        |

# Constant initialization

Write the machine code (in hexadecimal) for placing **-58** into register **t7**



| Instruction | op           | funct3  | Funct7 | Type   |
|-------------|--------------|---------|--------|--------|
| <b>addi</b> | 0010011 (19) | 000 (0) | -      | I-Type |