

# CSE 112: Computer Organization

---

Instructor: Sujay Deb

## Lecture 11



INDRAPRASTHA INSTITUTE of  
INFORMATION TECHNOLOGY  
**DELHI**



# **Single-Cycle RISC-V Processor**

# Example Program

- Design datapath
- View example program executing

## Example Program:

| Address | Instruction       | Type | Fields                              |              |              |             |                                | Machine Language |          |
|---------|-------------------|------|-------------------------------------|--------------|--------------|-------------|--------------------------------|------------------|----------|
| 0x1000  | l7: lw x6, -4(x9) | I    | imm <sub>11:0</sub><br>111111111100 | rs1<br>01001 | f3<br>010    | rd<br>00110 | op<br>0000011                  | FFC4A303         |          |
| 0x1004  | sw x6, 8(x9)      | S    | imm <sub>11:5</sub><br>0000000      | rs2<br>00110 | rs1<br>01001 | f3<br>010   | imm <sub>4:0</sub><br>01000    | op<br>0100011    | 0064A423 |
| 0x1008  | or x4, x5, x6     | R    | funct7<br>0000000                   | rs2<br>00110 | rs1<br>00101 | f3<br>110   | rd<br>00100                    | op<br>0110011    | 0062E233 |
| 0x100C  | beq x4, x4, l7    | B    | imm <sub>12,10:5</sub><br>1111111   | rs2<br>00100 | rs1<br>00100 | f3<br>000   | imm <sub>4:1,11</sub><br>10101 | op<br>1100011    | FE420AE3 |

# Single-Cycle RISC-V Processor

- **Datapath:** start with `lw` instruction
- **Example:** `lw x6, -4(x9)`  
`lw rd, imm(rs1)`



# Single-Cycle Datapath: lw fetch

## STEP 1: Fetch instruction



| Address | Instruction        | Type | Fields                                           | Machine Language                                     |
|---------|--------------------|------|--------------------------------------------------|------------------------------------------------------|
| 0x1000  | l7: lw x6, -4 (x9) | I    | $\text{imm}_{11:0}$<br>rs1<br>f3<br>rd<br><br>op | 1111111111100<br>01001 010 00110<br>0000011 FFC4A303 |

# Single-Cycle Datapath: lw Reg Read

**STEP 2:** Read source operand (**rs1**) from RF



| Address | Instruction        | Type | Fields                                                                                           | Machine Language |
|---------|--------------------|------|--------------------------------------------------------------------------------------------------|------------------|
| 0x1000  | L7: lw x6, -4 (x9) | I    | $\text{imm}_{11:0}$ 111111111100<br>$\text{rs1}$ 01001<br>$f3$ 010<br>$rd$ 00110<br>$op$ 0000011 | FFC4A303         |

# Single-Cycle Datapath: lw Immediate

## STEP 3: Extend the immediate



| Address             | Instruction                     | Type           | Fields                                                                                                                                   | Machine Language      |
|---------------------|---------------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| <code>0x1000</code> | <code>I7: lw x6, -4 (x9)</code> | <code>I</code> | <code>imm<sub>11:0</sub></code><br>111111111110 <code>rs1</code> 01001 <code>f3</code> 010 <code>rd</code> 00110 <code>op</code> 0000011 | <code>FFC4A303</code> |

# Single-Cycle Datapath: lw Address

**STEP 4:** Compute the memory address

| ALUControl <sub>2:0</sub> | Function |
|---------------------------|----------|
| 000                       | add      |
| 001                       | subtract |
| 010                       | and      |
| 011                       | or       |
| 101                       | SLT      |



| Address | Instruction                    | Type | Fields                                                                                                                                                                | Machine Language |
|---------|--------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 0x1000  | L7: <code>lw x6, -4(x9)</code> | I    | <code>imm<sub>11:0</sub></code><br>111111111100<br><code>rs1</code><br>01001 <code>f3</code><br>010 <code>rd</code><br>00110<br><code>op</code><br>0000011   FFC4A303 |                  |

# Single-Cycle Datapath: lw Mem Read

**STEP 5:** Read data from memory and write it back to register file



| Address | Instruction        | Type | Fields                                       | Machine Language                              |
|---------|--------------------|------|----------------------------------------------|-----------------------------------------------|
| 0x1000  | I7: lw x6, -4 (x9) | I    | imm <sub>11:0</sub><br>rs1<br>f3<br>rd<br>op | 111111111100 01001 010 00110 0000011 FFC4A303 |

# Single-Cycle Datapath: PC Increment

**STEP 6:** Determine address of next instruction



| Address | Instruction       | Type | Fields                                                                                  | Machine Language |
|---------|-------------------|------|-----------------------------------------------------------------------------------------|------------------|
| 0x1000  | L7: lw x6, -4(x9) | I    | imm <sub>11:0</sub> : 111111111100<br>rs1: 01001<br>f3: 010<br>rd: 00110<br>op: 0000011 | FFC4A303         |

# **Single-Cycle Datapath: Other Instructions**

# Single-Cycle Datapath: sw

- **Immediate:** now in {instr[31:25], instr[11:7]}
- **Add control signals:** ImmSrc, MemWrite



| Address | Instruction   | Type | Fields                         |              |              |           |                             | Machine Language          |
|---------|---------------|------|--------------------------------|--------------|--------------|-----------|-----------------------------|---------------------------|
| 0x1004  | sw x6, 8 (x9) | S    | imm <sub>11:5</sub><br>0000000 | rs2<br>00110 | rs1<br>01001 | f3<br>010 | imm <sub>4:0</sub><br>01000 | op<br>0100011    0064A423 |

# Single-Cycle Datapath: Immediate

| ImmSrc | ImmExt                                                           | Instruction Type |
|--------|------------------------------------------------------------------|------------------|
| 0      | $\{{20\{instr[31]\}}, \text{instr}[31:20]\}$                     | I-Type           |
| 1      | $\{{20\{instr[31]\}}, \text{instr}[31:25], \text{instr}[11:7]\}$ | S-Type           |

## I-Type



## S-Type



# Single-Cycle Datapath: R-type

- Read from **rs1** and **rs2** (instead of imm)
- Write *ALUResult* to **rd**



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

# Single-Cycle Datapath: beq

Calculate **target address**: PCTarget = PC + imm



| Address | Instruction    | Type | Fields                                                     | Machine Language                               |
|---------|----------------|------|------------------------------------------------------------|------------------------------------------------|
| 0x100C  | beq x4, x4, L7 | B    | imm <sub>12,10:5</sub> rs2 rs1 f3 imm <sub>4,1,11</sub> op | 1111111 00100 00100 000 10101 1100011 FE420AE3 |

# Single-Cycle Datapath: ImmExt

| ImmSrc <sub>1:0</sub> | ImmExt                                                                                                       | Instruction Type |
|-----------------------|--------------------------------------------------------------------------------------------------------------|------------------|
| 00                    | $\{{\{20\{instr[31]\}}}, \text{instr[31:20]}$                                                                | I-Type           |
| 01                    | $\{{\{20\{instr[31]\}}}, \text{instr[31:25]}, \text{instr[11:7]}$                                            | S-Type           |
| 10                    | $\{{\{19\{instr[31]\}}}, \text{instr[31]}, \text{instr[7]}, \text{instr[30:25]}, \text{instr[11:8]}, 1'b0\}$ | B-Type           |

I-Type



S-Type



B-Type



# Single-Cycle RISC-V Processor



# **Single-Cycle Control**

# Single-Cycle Control

High-Level View



Low-Level View



# Single-Cycle Control: Main Decoder

| op | Instr.     | RegWrite | ImmSrc | ALUSrc | MemWrite | ResultSrc | Branch | ALUOp |
|----|------------|----------|--------|--------|----------|-----------|--------|-------|
| 3  | <b>lw</b>  |          |        |        |          |           |        |       |
| 35 | <b>sw</b>  |          |        |        |          |           |        |       |
| 51 | R-type     |          |        |        |          |           |        |       |
| 99 | <b>beq</b> |          |        |        |          |           |        |       |



# Class Interaction # 13

---



# Review: ALU

| ALUControl <sub>2:0</sub> | Function |
|---------------------------|----------|
| 000                       | add      |
| 001                       | subtract |
| 010                       | and      |
| 011                       | or       |
| 101                       | SLT      |



# Review: ALU

| $ALUControl_{2:0}$ | Function |
|--------------------|----------|
| 000                | add      |
| 001                | subtract |
| 010                | and      |
| 011                | or       |
| 101                | SLT      |

