

In the RV32I instruction set, "Register-type" instructions (often called **R-type** instructions) are a fundamental category for operations that primarily involve values stored in registers. These instructions perform arithmetic and logical computations using two source registers and write the result to a destination register.

Here's a breakdown of R-type instructions in RV32I:

**1. Purpose:** R-type instructions are used for common arithmetic and logical operations such as:

- Addition and Subtraction
- Bitwise logical operations (AND, OR, XOR)
- Shift operations (logical left, logical right, arithmetic right)
- Comparison operations (set if less than, signed and unsigned)

### Common R-type Instructions in RV32I:

Here are some examples of R-type instructions in RV32I, along with their general syntax and operation:

- **ADD rd, rs1, rs2:** Adds the contents of rs1 and rs2, stores the result in rd.
  - Example: add x10, x11, x12 ( $x10 = x11 + x12$ )
- **SUB rd, rs1, rs2:** Subtracts the contents of rs2 from rs1, stores the result in rd.
  - Example: sub x10, x11, x12 ( $x10 = x11 - x12$ )
- **AND rd, rs1, rs2:** Performs a bitwise AND operation on rs1 and rs2, stores the result in rd.
  - Example: and x10, x11, x12 ( $x10 = x11 \& x12$ )
- **OR rd, rs1, rs2:** Performs a bitwise OR operation on rs1 and rs2, stores the result in rd.
  - Example: or x10, x11, x12 ( $x10 = x11 | x12$ )
- **XOR rd, rs1, rs2:** Performs a bitwise XOR operation on rs1 and rs2, stores the result in rd.
  - Example: xor x10, x11, x12 ( $x10 = x11 ^ x12$ )
- **SLL rd, rs1, rs2:** Logically shifts rs1 left by the amount specified in the lower 5 bits of rs2, stores the result in rd.
  - Example: sll x10, x11, x12 ( $x10 = x11 << x12$ )
- **SRL rd, rs1, rs2:** Logically shifts rs1 right by the amount specified in the lower 5 bits of rs2, stores the result in rd.
  - Example: srl x10, x11, x12 ( $x10 = x11 >> x12$ )
- **SRA rd, rs1, rs2:** Arithmetically shifts rs1 right by the amount specified in the lower 5 bits of rs2, stores the result in rd. (Preserves the sign bit).
  - Example: sra x10, x11, x12 ( $x10 = x11 >> x12$ )
- **SLT rd, rs1, rs2:** Sets rd to 1 if rs1 (signed) is less than rs2 (signed), otherwise sets rd to 0.
  - Example: slt x10, x11, x12
- **SLTU rd, rs1, rs2:** Sets rd to 1 if rs1 (unsigned) is less than rs2 (unsigned), otherwise sets rd to 0.
  - Example: sltu x10, x11, x12

R-type instructions are foundational to integer computation in RV32I, performing the core register-to-register operations that are essential for almost any program.