

# RISC-V RV32I Processor

Anika Mahesh, Henry Tejada Deras

Code: [GitHub - H-TejadaDeras/32-bit-RISC-V-Processor: 32-bit RISC-V Processor Integer Microprocessor with a Harvard Architecture for Computer Architecture Course \(ENGR3410-01.25FA\) in the 2025 Fall Semester.](https://github.com/H-TejadaDeras/32-bit-RISC-V-Processor)

## Processor Design Overview

This report details our design for an unpipelined, multicycle (i.e., the processor executes only one instruction at a time), 32-bit RISC-V integer microprocessor with a Harvard architecture. This design is contained within the top.sv, alu.sv, decoder.sv, and the memory.sv files, and the testbench is in test\_bench\_top.sv. In top.sv, all the registers are defined (x0-x31, pc, and current\_instruction), the processor state machine is defined (this is how we keep track of which state the processor is currently in), data memory operations, and register memory operations. In decoder.sv, the decoder is defined along with all the logic used to sign-extend all the immediates. alu.sv defines all the logic related to all logic and arithmetic operations performed by instructions. Note: we do have various arithmetic operations sprinkled around in the top module, this is implemented as very tiny ALUs that perform a limited set of operations to reduce timing complexities. In terms of instructions, the ALU implements the addi, slti, sltiu, xori, ori, andi, slli, srli, srai, add, sub, sll, slt, sltu, zor, srl, sra, or, and and instructions. All the other instructions are implemented in top.sv.

In terms of memories, we have a few registers. The x0-x31 registers are for storing data that is going to be accessed frequently or soon. The pc register is for storing the address in data memory for the next instruction, and the current\_instruction register is for storing the current instruction that is being executed by the processor.

The processor has 4 different states. Fetch Instruction is the first state, and it executes when the previous instruction is finished running. It reads the next instruction from the instruction memory (defined by the address stored on the pc register) and changes the state to Fetch Registers. The Fetch Registers state stores the instruction in the current\_instruction register and changes the state to Execute instruction, which executes the instruction defined by the current instruction. During the fetch registers stage, the decoder simultaneously decodes the new instruction saved to the current\_instruction register. In the Execute Instruction state, the processor uses the decoded values from decoder.sv to execute it. Since all values from the decoder are properly sign-extended, the top module just decides where to route the data. After the instruction is executed, the state is Write Back, which signals the instruction is completed, and the value of the program counter changes depending on the instruction that has been executed to get the next instruction, and switches the state back to Fetch instruction. This process repeats to process all the given instructions in the instruction memory.

The processor states can be seen here, where 0 is the Fetch Instruction state, 1 is Fetch Registers, 2 is Execute Instruction, and 3 is Write Back.



## Instruction Functionality Validation Tests

## ALU Instructions (rv32i\_test.s)

Testing addi, srlti, srai, xori, add, sub, sll, ori, slt, and sltu instructions.

**addi x1, x1, 0xA98    x1 = 0xFEDCBA98**



The result is correct (alu\_output); alu and registers are updated correctly; and the program counter increments by 4.

**srl x2, x1, 4      pc = 0x08, x2 = 0xFEDCBA9**



Result is correct and alu and registers are updated and program counter updates by 4

**srai x3, x1, 4      pc = 0x0C, x3 = 0xFFEDCBA9**



Result is correct and alu and registers are updated and program counter updates by 4

**xori x4, x3, -1      pc = 0x10, x4 = 0x00123456**



Result is correct and program counter updates by 4

**add x6, x5, x4      pc = 0x18, x6 = 0x00123458**



Result is correct and program counter updates by 4

**sub x7, x6, x4      pc = 0x1C, x7 = 0x00000000**



Result is correct and alu and registers are updated and program counter updates by 4

**sll x8, x4, x5      pc = 0x20, x8 = 0x0048D158**



Result is correct and alu and registers are updated and program counter updates by 4

**ori x9, x8, 7      pc = 0x24, x9 = 0x0048D15F**



Result is correct and alu and registers are updated and program counter updates by 4

**slt x11, x3, x4      pc = 0x2C, x11 = 0x00000001**



Result is correct and alu and registers are updated and program counter updates by 4

**sltu x12, x3, x4      pc = 0x30, x12 = 0x00000000**



Result is correct and alu and registers are updated and program counter updates by 4

### Branch Instructions (branch\_instruct\_test.s + tester\_dmem.hex)

Testing bne and blt instructions. Note: This test makes use of tester\_dmem.hex.

#### tester\_dmem.hex

01234567

76543210

11223344

55667788

99101011

12346548

15975346

26489173

16AF2345

0316497D

00001010

00000000

...

#### branch\_instruct\_test.s

add x2, x0, x0 # Set stack pointer

lw x5, 0(x2) # 01234567 -> x5

lw x6, 4(x2) # 76543210 -> x6

bne x5, x6, 8

sw x6, 1000(x2) # x6 -> 00002000 (address)

blt x6, x5, 24

#### Processor Status (when running the above program)

|                               |                               |                               |
|-------------------------------|-------------------------------|-------------------------------|
| Program Counter: 00001000     | Program Counter: 00001004     | Program Counter: 00001008     |
| Current Instruction: 00000133 | Current Instruction: 00012283 | Current Instruction: 00412303 |
| [add x2, x0, x0]              | [lw x5, 0(x2)]                | [lw x6, 4(x2)]                |
| Register x0: 00000000         | Register x0: 00000000         | Register x0: 00000000         |
| Register x1: 00000000         | Register x1: 00000000         | Register x1: 00000000         |
| Register x2: 00000000         | Register x2: 00000000         | Register x2: 00000000         |
| Register x3: 00000000         | Register x3: 00000000         | Register x3: 00000000         |
| Register x4: 00000000         | Register x4: 00000000         | Register x4: 00000000         |
| Register x5: 00000000         | Register x5: 01234567         | Register x5: 01234567         |
| Register x6: 00000000         | Register x6: 00000000         | Register x6: 76543210         |
| Register x7: 00000000         | Register x7: 00000000         | Register x7: 00000000         |
| Register x8: 00000000         | Register x8: 00000000         | Register x8: 00000000         |
| Register x9: 00000000         | Register x9: 00000000         | Register x9: 00000000         |
| Register x10: 00000000        | Register x10: 00000000        | Register x10: 00000000        |
| Register x11: 00000000        | Register x11: 00000000        | Register x11: 00000000        |
| Register x12: 00000000        | Register x12: 00000000        | Register x12: 00000000        |
| Register x13: 00000000        | Register x13: 00000000        | Register x13: 00000000        |
| Register x14: 00000000        | Register x14: 00000000        | Register x14: 00000000        |
| Register x15: 00000000        | Register x15: 00000000        | Register x15: 00000000        |
| Register x16: 00000000        | Register x16: 00000000        | Register x16: 00000000        |
| Register x17: 00000000        | Register x17: 00000000        | Register x17: 00000000        |
| Register x18: 00000000        | Register x18: 00000000        | Register x18: 00000000        |
| Register x19: 00000000        | Register x19: 00000000        | Register x19: 00000000        |



|                                                                                                                                                                                    |                                                                                                                                                                                    |                                                                                                                                                                                    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register x25: 00000000<br>Register x26: 00000000<br>Register x27: 00000000<br>Register x28: 00000000<br>Register x29: 00000000<br>Register x30: 00000000<br>Register x31: 00000000 | Register x25: 00000000<br>Register x26: 00000000<br>Register x27: 00000000<br>Register x28: 00000000<br>Register x29: 00000000<br>Register x30: 00000000<br>Register x31: 00000000 | Register x25: 00000000<br>Register x26: 00000000<br>Register x27: 00000000<br>Register x28: 00000000<br>Register x29: 00000000<br>Register x30: 00000000<br>Register x31: 00000000 |
| Note: bne instruction properly increments the pc by 8 and arrives at the correct answer from the comparison.                                                                       | Note: blt instruction properly updates pc by incrementing it by 4 (and not 24) and arrives at the correct answer from the comparison.                                              | Note: There are no instructions past this.                                                                                                                                         |

### Misc. Instructions (misc\_instruct\_test.s + tester\_dmem.hex)

Testing lui, auipc, jal, and jalr instructions. Note: This test makes use of tester\_dmem.hex.

#### tester\_dmem.hex

```
01234567
76543210
11223344
55667788
99101011
12346548
15975346
26489173
16AF2345
0316497D
00001010
00000000
...
```

#### misc\_instruct\_test.s

```
add x2, x0, x0 # Set stack pointer
lw x5, 0(x2) # 01234567 -> x5
lw x6, 4(x2) # 76543210 -> x6
lw x28, 40(x2) # 00000010 -> x28
auipc x8, 16
addi x9, x9, 10 # 00000000 -> 0000000A
addi x9, x9, 1 # 0000000A -> 0000000B
jal x10, 8 # Move to 2nd instruction down (lui)
addi x29, x0, x0 # Filler instruction; not meant to do
anything
lui x9, 400000
jalr x10, 4002(x28) # Move to auipc instruction
addi x9, x9, 1 # 0000000B -> 0000000C
```

### Processor Status (when running the above program)

|                                                                                                                                                                                                             |                                                                                                                                                                                                           |                                                                                                                                                                                                           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Program Counter: 00001000<br>Current Instruction: 00000133<br>[add x2, x0, x0]<br>Register x0: 00000000<br>Register x1: 00000000<br>Register x2: 00000000<br>Register x3: 00000000<br>Register x4: 00000000 | Program Counter: 00001004<br>Current Instruction: 00012283<br>[lw x5, 0(x2)]<br>Register x0: 00000000<br>Register x1: 00000000<br>Register x2: 00000000<br>Register x3: 00000000<br>Register x4: 00000000 | Program Counter: 00001008<br>Current Instruction: 00412303<br>[lw x6, 4(x2)]<br>Register x0: 00000000<br>Register x1: 00000000<br>Register x2: 00000000<br>Register x3: 00000000<br>Register x4: 00000000 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

|                               |                               |                               |
|-------------------------------|-------------------------------|-------------------------------|
| Register x5: 00000000         | Register x5: 01234567         | Register x5: 01234567         |
| Register x6: 00000000         | Register x6: 00000000         | Register x6: 76543210         |
| Register x7: 00000000         | Register x7: 00000000         | Register x7: 00000000         |
| Register x8: 00000000         | Register x8: 00000000         | Register x8: 00000000         |
| Register x9: 00000000         | Register x9: 00000000         | Register x9: 00000000         |
| Register x10: 00000000        | Register x10: 00000000        | Register x10: 00000000        |
| Register x11: 00000000        | Register x11: 00000000        | Register x11: 00000000        |
| Register x12: 00000000        | Register x12: 00000000        | Register x12: 00000000        |
| Register x13: 00000000        | Register x13: 00000000        | Register x13: 00000000        |
| Register x14: 00000000        | Register x14: 00000000        | Register x14: 00000000        |
| Register x15: 00000000        | Register x15: 00000000        | Register x15: 00000000        |
| Register x16: 00000000        | Register x16: 00000000        | Register x16: 00000000        |
| Register x17: 00000000        | Register x17: 00000000        | Register x17: 00000000        |
| Register x18: 00000000        | Register x18: 00000000        | Register x18: 00000000        |
| Register x19: 00000000        | Register x19: 00000000        | Register x19: 00000000        |
| Register x20: 00000000        | Register x20: 00000000        | Register x20: 00000000        |
| Register x21: 00000000        | Register x21: 00000000        | Register x21: 00000000        |
| Register x22: 00000000        | Register x22: 00000000        | Register x22: 00000000        |
| Register x23: 00000000        | Register x23: 00000000        | Register x23: 00000000        |
| Register x24: 00000000        | Register x24: 00000000        | Register x24: 00000000        |
| Register x25: 00000000        | Register x25: 00000000        | Register x25: 00000000        |
| Register x26: 00000000        | Register x26: 00000000        | Register x26: 00000000        |
| Register x27: 00000000        | Register x27: 00000000        | Register x27: 00000000        |
| Register x28: 00000000        | Register x28: 00000000        | Register x28: 00000000        |
| Register x29: 00000000        | Register x29: 00000000        | Register x29: 00000000        |
| Register x30: 00000000        | Register x30: 00000000        | Register x30: 00000000        |
| Register x31: 00000000        | Register x31: 00000000        | Register x31: 00000000        |
| Program Counter: 0000100c     | Program Counter: 00001010     | Program Counter: 00001014     |
| Current Instruction: 02812e03 | Current Instruction: 00010417 | Current Instruction: 00a48493 |
| [lw x28, 40(x2)]              | [auipc x8, 16]                | [addi x9, x9, 10]             |
| Register x0: 00000000         | Register x0: 00000000         | Register x0: 00000000         |
| Register x1: 00000000         | Register x1: 00000000         | Register x1: 00000000         |
| Register x2: 00000000         | Register x2: 00000000         | Register x2: 00000000         |
| Register x3: 00000000         | Register x3: 00000000         | Register x3: 00000000         |
| Register x4: 00000000         | Register x4: 00000000         | Register x4: 00000000         |
| Register x5: 01234567         | Register x5: 01234567         | Register x5: 01234567         |
| Register x6: 76543210         | Register x6: 76543210         | Register x6: 76543210         |
| Register x7: 00000000         | Register x7: 00000000         | Register x7: 00000000         |
| Register x8: 00000000         | Register x8: 00011010         | Register x8: 00011010         |
| Register x9: 00000000         | Register x9: 00000000         | Register x9: 0000000a         |



|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register x12: 00000000<br>Register x13: 00000000<br>Register x14: 00000000<br>Register x15: 00000000<br>Register x16: 00000000<br>Register x17: 00000000<br>Register x18: 00000000<br>Register x19: 00000000<br>Register x20: 00000000<br>Register x21: 00000000<br>Register x22: 00000000<br>Register x23: 00000000<br>Register x24: 00000000<br>Register x25: 00000000<br>Register x26: 00000000<br>Register x27: 00000000<br>Register x28: 00001010<br>Register x29: 00000000<br>Register x30: 00000000<br>Register x31: 00000000 | Register x12: 00000000<br>Register x13: 00000000<br>Register x14: 00000000<br>Register x15: 00000000<br>Register x16: 00000000<br>Register x17: 00000000<br>Register x18: 00000000<br>Register x19: 00000000<br>Register x20: 00000000<br>Register x21: 00000000<br>Register x22: 00000000<br>Register x23: 00000000<br>Register x24: 00000000<br>Register x25: 00000000<br>Register x26: 00000000<br>Register x27: 00000000<br>Register x28: 00001010<br>Register x29: 00000000<br>Register x30: 00000000<br>Register x31: 00000000 | Register x12: 00000000<br>Register x13: 00000000<br>Register x14: 00000000<br>Register x15: 00000000<br>Register x16: 00000000<br>Register x17: 00000000<br>Register x18: 00000000<br>Register x19: 00000000<br>Register x20: 00000000<br>Register x21: 00000000<br>Register x22: 00000000<br>Register x23: 00000000<br>Register x24: 00000000<br>Register x25: 00000000<br>Register x26: 00000000<br>Register x27: 00000000<br>Register x28: 00001010<br>Register x29: 00000000<br>Register x30: 00000000<br>Register x31: 00000000 |
| Program Counter: 00001028<br>Current Instruction: 002e0567<br>[jalr x10, 4002(x28)]<br>Register x0: 00000000<br>Register x1: 00000000<br>Register x2: 00000000<br>Register x3: 00000000<br>Register x4: 00000000<br>Register x5: 01234567<br>Register x6: 76543210<br>Register x7: 00000000<br>Register x8: 00011010<br>Register x9: 61a80000<br>Register x10: 0000102c<br>Register x11: 00000000                                                                                                                                    | Program Counter: 00001012<br>Current Instruction: 00010417<br>[Not a real instruction, was moved to half an instruction]<br>Register x0: 00000000<br>Register x1: 00000000<br>Register x2: 00000000<br>Register x3: 00000000<br>Register x4: 00000000<br>Register x5: 01234567<br>Register x6: 76543210<br>Register x7: 00000000<br>Register x8: 00011012<br>Register x9: 61a80000<br>Register x10: 0000102c                                                                                                                         | The rest of the processor cycles were omitted due to the pc value being at a half-word.                                                                                                                                                                                                                                                                                                                                                                                                                                              |

|                                                                           |                        |  |
|---------------------------------------------------------------------------|------------------------|--|
| Register x12: 00000000                                                    | Register x11: 00000000 |  |
| Register x13: 00000000                                                    | Register x12: 00000000 |  |
| Register x14: 00000000                                                    | Register x13: 00000000 |  |
| Register x15: 00000000                                                    | Register x14: 00000000 |  |
| Register x16: 00000000                                                    | Register x15: 00000000 |  |
| Register x17: 00000000                                                    | Register x16: 00000000 |  |
| Register x18: 00000000                                                    | Register x17: 00000000 |  |
| Register x19: 00000000                                                    | Register x18: 00000000 |  |
| Register x20: 00000000                                                    | Register x19: 00000000 |  |
| Register x21: 00000000                                                    | Register x20: 00000000 |  |
| Register x22: 00000000                                                    | Register x21: 00000000 |  |
| Register x23: 00000000                                                    | Register x22: 00000000 |  |
| Register x24: 00000000                                                    | Register x23: 00000000 |  |
| Register x25: 00000000                                                    | Register x24: 00000000 |  |
| Register x26: 00000000                                                    | Register x25: 00000000 |  |
| Register x27: 00000000                                                    | Register x26: 00000000 |  |
| Register x28: 00001010                                                    | Register x27: 00000000 |  |
| Register x29: 00000000                                                    | Register x28: 00001010 |  |
| Register x30: 00000000                                                    | Register x29: 00000000 |  |
| Register x31: 00000000                                                    | Register x30: 00000000 |  |
| Note: jalr instruction properly<br>updates pc and updated register<br>x10 | Register x31: 00000000 |  |

### Memory Instructions (mem\_instruct\_test\_complete.s + tester\_dmem.hex)

Testing lw, lh, lhu, lb, lbu, and sb instructions. Note: This test makes use of tester\_dmem.hex.

#### tester\_dmem.hex

```
01234567
76543210
11223344
55667788
99101011
12346548
15975346
26489173
16AF2345
0316497D
00001010
00000000
...
```

#### mem\_instruct\_test\_complete.s

```
lw x5, 0(x3)
lh x6, 4(x3)
lhu x7, 4(x3)
lb x28, 5(x3)
lbu x29, 5(x3)
sb x28, 250(x3)
lb x30, 250(x3) # verify byte was stored by previous
instruction
sh x6, 300(x3)
lh x31, 300(x3) # verify half word was stored by
previous instruction
sw x5, 100(x3)
lw x8, 100(x3) # verify word was stored by previous
instruction
```

| Processor Status (when running the above program) |                                                    |                                                             |
|---------------------------------------------------|----------------------------------------------------|-------------------------------------------------------------|
| Program Counter: 00001000                         | Program Counter: 00001004                          | Program Counter: 00001008                                   |
| Current Instruction: 0001a283                     | Current Instruction: 00419303                      | Current Instruction: 0041d383                               |
| [lw x5, 0(x3)]                                    | [lh x6, 4(x3)]                                     | [lhu x7, 4(x3)]                                             |
| Register x0: 00000000                             | Register x0: 00000000                              | Register x0: 00000000                                       |
| Register x1: 00000000                             | Register x1: 00000000                              | Register x1: 00000000                                       |
| Register x2: 00000000                             | Register x2: 00000000                              | Register x2: 00000000                                       |
| Register x3: 00000000                             | Register x3: 00000000                              | Register x3: 00000000                                       |
| Register x4: 00000000                             | Register x4: 00000000                              | Register x4: 00000000                                       |
| Register x5: 01234567                             | Register x5: 01234567                              | Register x5: 01234567                                       |
| Register x6: 00000000                             | Register x6: 00003210                              | Register x6: 00003210                                       |
| Register x7: 00000000                             | Register x7: 00000000                              | Register x7: 00003210                                       |
| Register x8: 00000000                             | Register x8: 00000000                              | Register x8: 00000000                                       |
| Register x9: 00000000                             | Register x9: 00000000                              | Register x9: 00000000                                       |
| Register x10: 00000000                            | Register x10: 00000000                             | Register x10: 00000000                                      |
| Register x11: 00000000                            | Register x11: 00000000                             | Register x11: 00000000                                      |
| Register x12: 00000000                            | Register x12: 00000000                             | Register x12: 00000000                                      |
| Register x13: 00000000                            | Register x13: 00000000                             | Register x13: 00000000                                      |
| Register x14: 00000000                            | Register x14: 00000000                             | Register x14: 00000000                                      |
| Register x15: 00000000                            | Register x15: 00000000                             | Register x15: 00000000                                      |
| Register x16: 00000000                            | Register x16: 00000000                             | Register x16: 00000000                                      |
| Register x17: 00000000                            | Register x17: 00000000                             | Register x17: 00000000                                      |
| Register x18: 00000000                            | Register x18: 00000000                             | Register x18: 00000000                                      |
| Register x19: 00000000                            | Register x19: 00000000                             | Register x19: 00000000                                      |
| Register x20: 00000000                            | Register x20: 00000000                             | Register x20: 00000000                                      |
| Register x21: 00000000                            | Register x21: 00000000                             | Register x21: 00000000                                      |
| Register x22: 00000000                            | Register x22: 00000000                             | Register x22: 00000000                                      |
| Register x23: 00000000                            | Register x23: 00000000                             | Register x23: 00000000                                      |
| Register x24: 00000000                            | Register x24: 00000000                             | Register x24: 00000000                                      |
| Register x25: 00000000                            | Register x25: 00000000                             | Register x25: 00000000                                      |
| Register x26: 00000000                            | Register x26: 00000000                             | Register x26: 00000000                                      |
| Register x27: 00000000                            | Register x27: 00000000                             | Register x27: 00000000                                      |
| Register x28: 00000000                            | Register x28: 00000000                             | Register x28: 00000000                                      |
| Register x29: 00000000                            | Register x29: 00000000                             | Register x29: 00000000                                      |
| Register x30: 00000000                            | Register x30: 00000000                             | Register x30: 00000000                                      |
| Register x31: 00000000                            | Register x31: 00000000                             | Register x31: 00000000                                      |
| Note: Word is properly loaded to register x5.     | Note: Half word is properly loaded to register x6. | Note: Unsigned half word is properly loaded to register x7. |





|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                              |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Program Counter: 00001024<br>Current Instruction: 0651a223<br>[sw x5, 100(x3)]<br>Register x0: 00000000<br>Register x1: 00000000<br>Register x2: 00000000<br>Register x3: 00000000<br>Register x4: 00000000<br>Register x5: 01234567<br>Register x6: 00003210<br>Register x7: 00003210<br>Register x8: 00000000<br>Register x9: 00000000<br>Register x10: 00000000<br>Register x11: 00000000<br>Register x12: 00000000<br>Register x13: 00000000<br>Register x14: 00000000<br>Register x15: 00000000<br>Register x16: 00000000<br>Register x17: 00000000<br>Register x18: 00000000<br>Register x19: 00000000<br>Register x20: 00000000<br>Register x21: 00000000<br>Register x22: 00000000<br>Register x23: 00000000<br>Register x24: 00000000<br>Register x25: 00000000<br>Register x26: 00000000<br>Register x27: 00000000<br>Register x28: 00000032<br>Register x29: 00000032<br>Register x30: 00000032<br>Register x31: 00003210 | Program Counter: 00001028<br>Current Instruction: 0641a403<br>[lw x8, 100(x3)]<br>Register x0: 00000000<br>Register x1: 00000000<br>Register x2: 00000000<br>Register x3: 00000000<br>Register x4: 00000000<br>Register x5: 01234567<br>Register x6: 00003210<br>Register x7: 00003210<br>Register x8: 01234567<br>Register x9: 00000000<br>Register x10: 00000000<br>Register x11: 00000000<br>Register x12: 00000000<br>Register x13: 00000000<br>Register x14: 00000000<br>Register x15: 00000000<br>Register x16: 00000000<br>Register x17: 00000000<br>Register x18: 00000000<br>Register x19: 00000000<br>Register x20: 00000000<br>Register x21: 00000000<br>Register x22: 00000000<br>Register x23: 00000000<br>Register x24: 00000000<br>Register x25: 00000000<br>Register x26: 00000000<br>Register x27: 00000000<br>Register x28: 00000032<br>Register x29: 00000032<br>Register x30: 00000032<br>Register x31: 00003210 | The rest of the processor cycles were omitted due to there being no more instructions.<br><br>Note: Word was properly stored; this load instruction shows that it was properly stored to the given location. |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|