## KGP-RISC ISA

Group: 024

Members: Parth Jindal, Pranav Rajput

## **Instruction formats:**

There are 3 types of instruction formats:

1. R-format (Register format)

2. I-format (Immediate format)

3. J-format (Jump format)

#### R-format

| Field size | 6  | 5  | 5  | 5     | 6    | 5  | Instructions                               |
|------------|----|----|----|-------|------|----|--------------------------------------------|
| R-format   | ор | rs | rt | shamt | func | dc | add, cmp, and, xor, all-shift instructions |

Currently, all R-format instructions are kept under the same Op-Code.

op-code: 000000

| Instruction | func-code |
|-------------|-----------|
| add         | 000001    |
| стр         | 000101    |
| and         | 000010    |
| xor         | 000011    |
| shll        | 001100    |
| shrl        | 001110    |
| shllv       | 001000    |
| shrlv       | 001010    |
| shra        | 001111    |
| shrav       | 001011    |

### **I-format**

| Field-size | 6  | 5  | 5     | 16                | Instructions        |
|------------|----|----|-------|-------------------|---------------------|
| I-format   | ор | rs | rt/dc | address/immediate | lw, sw, addi, cmpi, |

The following table enlists the op-code for all the above instructions

| Instruction | op-code |
|-------------|---------|
| lw          | 010000  |
| SW          | 011000  |
| addi        | 001000  |
| cmpi        | 001001  |

### J-format

| Field size | 6  | 26             | Instructions         |
|------------|----|----------------|----------------------|
| J-format   | ор | target address | b, br, bl, bcy, bncy |

The following table enlists the op-code for all the above instructions

| Instruction | op-code | fmt                  |
|-------------|---------|----------------------|
| br          | 100000  | op   rs   xxxxxxxx   |
| b           | 101000  | op   label           |
| bcy         | 101001  | op   label           |
| bncy        | 101010  | op   label           |
| bl          | 101011  | op   label           |
| bltz        | 110000  | op   rs   xx   label |
| bz          | 110001  | op   rs   xx   label |
| bnz         | 110010  | op   rs   xx   label |

# The following table summarizes all the instructions and the associated op-codes

| LSB<br>MSB | 000      | 001  | 010  | 011 | 100 | 101 | 110 | 111 |
|------------|----------|------|------|-----|-----|-----|-----|-----|
| 000        | R-format |      |      |     |     |     |     |     |
| 001        | addi     | cmpi |      |     |     |     |     |     |
| 010        | lw       |      |      |     |     |     |     |     |
| 011        | sw       |      |      |     |     |     |     |     |
| 100        | br       |      |      |     |     |     |     |     |
| 101        | b        | bcy  | bncy | bl  |     |     |     |     |
| 110        | bltz     | bz   | bnz  |     |     |     |     |     |
| 111        |          |      |      |     |     |     |     |     |

## Register convention:

The architectural design is suggested to be used in a similar manner to the MIPS convention of register use as mentioned:

| Symbolic name | Number      | use                    |
|---------------|-------------|------------------------|
| zero          | 0           | Constant 0             |
| at            | 1           | Reserved for assembler |
| v0-v1         | 2-3         | Result registers       |
| a0-a3         | 4-7         | Argument register      |
| t0-t9         | 8-15, 24-25 | Temporary register     |
| s0-s7         | 16-23       | Saved register         |
| k0-k1         | 26-27       | Kernel register        |
| gp            | 28          | Global Data pointer    |
| sp            | 29          | Stack pointer          |
| fp            | 30          | Frame pointer          |
| ra            | 31          | Return Address         |

#### Arithmetic Logic Unit Design

The proposed ALU has an internal adder module, and xor modules and a barrel shifter with lines for direction and type(logical/arithmetic).

A separate input bus is also present for shift-amount to be passed as input to shift module. The shift input can either come directly from the shift input bus or from the 5 LSB's of the register specified in the <u>shift-variable instructions</u>. A 2-1 Mux is hence used to select either of these inputs.

For simplicity, since the ISA doesn't have the subtract command natively, no carry-in has been provided; rather for the complement instruction, a 2-1 MUX is used to switch input-1 with 32'd1 and the adder module is used to compute the complement.

#### Flags from ALU:

- 1. Carry
- 2. Zero result
- 3. Sign of result (0 for +, 1 for -)

ALL ALU-operations are embedded directly into the funcode or in the operation-code passed on from the ALU-controller module

The ALU design has been included in the documentation and also embedded here:

| ALU-operation | funcode[3] | funcode[2]      | funcode[1] | funcode[0] |
|---------------|------------|-----------------|------------|------------|
| forward       | 0          | 0               | 0          | 0          |
| add           | 0          | compl/not-compl | 0          | 1          |
| and           | 0          | 0               | 1          | 0          |
| xor           | 0          | 0               | 1          | 1          |
| shift         | 1          | shamt/reg       | right/left | log/arithm |

# <u>Truth table for ALU-control signals with associated op-codes and func-codes</u>

| Operation | Opcode | funcode | alucode[3] | alucode[2] | alucode[1] | alucode[0]1 |
|-----------|--------|---------|------------|------------|------------|-------------|
| add       | 000000 | 000001  | 0          | 0          | 0          | 1           |
| comp      | 000000 | 000101  | 0          | 1          | 0          | 1           |
| addi      | 001000 | -       | 0          | 0          | 0          | 1           |
| compi     | 001001 | -       | 0          | 1          | 0          | 1           |
| and       | 000000 | 000010  | 0          | 0          | 1          | 0           |
| xor       | 000000 | 000011  | 0          | 0          | 1          | 1           |
| shll      | 000000 | 001100  | 1          | 1          | 0          | 0           |
| shrl      | 000000 | 001110  | 1          | 1          | 1          | 0           |
| shllv     | 000000 | 001000  | 1          | 0          | 0          | 0           |
| shrlv     | 000000 | 001010  | 1          | 0          | 1          | 0           |
| shra      | 000000 | 001111  | 1          | 1          | 1          | 1           |
| shrav     | 000000 | 001011  | 1          | 0          | 1          | 1           |
| lw        | 010000 | -       | 0          | 0          | 0          | 1           |
| sw        | 011000 | -       | 0          | 0          | 0          | 1           |
| b         | 101000 |         | 0          | 0          | 0          | 0           |
| br        | 100000 | -       | 0          | 0          | 0          | 0           |
| bltz      | 110000 | -       | 0          | 0          | 0          | 0           |
| bz        | 110001 | -       | 0          | 0          | 0          | 0           |
| bnz       | 110010 | -       | 0          | 0          | 0          | 0           |
| bl        | 101011 | -       | 0          | 0          | 0          | 0           |
| bcy       | 101001 | -       | 0          | 0          | 0          | 0           |
| bncy      | 101010 | -       | 0          | 0          | 0          | 0           |

## Datapath and control signals for the ISA

The given document (separate and embedded) shows the complete data paths and control signals for the Instruction set. The data-paths are shown using black

lines and the control signals using the red lines. For simplicity the controller lines have not been joined to the modules themselves rather left open for better visual clarity.

The ISA contains 3 primary control modules:

- 1. Controller: handles the primary signals to all modules
- 2. ALU-Controller: handles the ALU-specific control signals
- 3. Branch-Controller: handles the logic for branch on flag-signals and produces the output if it has to branch or not

There are 3 standard ways in which instruction memory can be referenced in the Instruction set:

- 1. Direct PC addressing
- 2. PC-relative addressing
- 3. (Pseudo)Direct jump addressing

#### **Direct addressing:**

This addressing takes place in case of `br` instruction in which case the argument register contains the exact address to jump to.

#### PC-relative addressing:

This addressing takes in case of any 16-bit Label instruction such as bz, bnz, bltz in which case the absolute address is calculated using this formula:

Address = (PC + 4) + SignExtended(Label)

#### Pseudo Direct addressing:

This addressing takes in case of any 26-bit label instruction such as b, bl, bcy, bncy in which case the absolute address is calculated using this formula:

Address = {(PC+4)[31:28] , {Label, 2b'00}}

#### Control signals:

- 1. Regwrite: whether to write into the register file or not
- 2. RegDst[1:0]: destination register for the write-register (can be \$ra, rs, rt)
- 3. ALUSrc: Source for the 2nd input to the ALU (can be rt, sgn-extend(imm))
- 4. MemRead: whether to read from Data-memory or not
- 5. MemWrite: whether to write into the Data-memory or not
- 6. *Mem2Reg[1:0]:* write-data for the register files (can be PC+4, mem[], result ALU)
- 7. LblSel: select type of addressing for PC-relative and PseudoDirect
- 8. *JumpAddr*: whether the jump address comes from a source reg (rs) or from a label

#### <u>Truth table for control signals with associated op-codes and func-codes</u>

| Ор    | Opcode | RegDst | RegWrite | ALUSrc | MemRead | MemWrite | Mem2Reg | LbISel | JumpSel |
|-------|--------|--------|----------|--------|---------|----------|---------|--------|---------|
| add   | 000000 | 00     | 1        | 0      | 0       | 0        | 00      | х      | х       |
| comp  | 000000 | 00     | 1        | 0      | 0       | 0        | 00      | х      | х       |
| addi  | 001000 | 00     | 1        | 1      | 0       | 0        | 00      | х      | х       |
| compi | 001001 | 00     | 1        | 1      | 0       | 0        | 00      | х      | х       |
| and   | 000000 | 00     | 1        | 0      | 0       | 0        | 00      | х      | х       |
| xor   | 000000 | 00     | 1        | 0      | 0       | 0        | 00      | х      | х       |
| shll  | 000000 | 00     | 1        | 0      | 0       | 0        | 00      | х      | х       |
| shrl  | 000000 | 00     | 1        | 0      | 0       | 0        | 00      | х      | х       |
| shllv | 000000 | 00     | 1        | 0      | 0       | 0        | 00      | х      | х       |
| shrlv | 000000 | 00     | 1        | 0      | 0       | 0        | 00      | х      | х       |
| shra  | 000000 | 00     | 1        | 0      | 0       | 0        | 00      | х      | х       |
| shrav | 000000 | 00     | 1        | 0      | 0       | 0        | 00      | х      | х       |
| lw    | 010000 | 01     | 1        | 1      | 1       | 0        | 01      | х      | х       |
| sw    | 011000 | х      | 0        | 1      | 0       | 1        | х       | Х      | х       |
| b     | 101000 | х      | 0        | х      | 0       | 0        | х       | 0      | 0       |
| br    | 100000 | х      | 0        | х      | 0       | 0        | х       | х      | 1       |

| bltz | 110000 | х  | 0 | х | 0 | 0 | х  | 1 | 0 |
|------|--------|----|---|---|---|---|----|---|---|
| bz   | 110001 | х  | 0 | х | 0 | 0 | х  | 1 | 0 |
| bnz  | 110010 | х  | 0 | х | 0 | 0 | х  | 1 | 0 |
| bl   | 101011 | 10 | 1 | х | 0 | 0 | 10 | 0 | 0 |
| bcy  | 101001 | х  | 0 | х | 0 | 0 | х  | 0 | 0 |
| bncy | 101010 | х  | 0 | х | 0 | 0 | х  | 0 | 0 |

#### Key Points:

- An assembler has been provided with the verilog files for creating binaries compatible with the KGP-RISC architecture.
- Except the Datamemory and Instruction-memory modules all read operations are asynchronous and any write operation on a DFF is synchronized to the clock.
- The data-memory works on the negative edge of the clock to cope up with the delays from the instruction memory and combinational logic with respect to the driving clock

## Recursive Fibonacci as a test bench

As a test bench for the given architecture, Recursive fibonacci is used to compute the Fib(6). The semantics for functional call and stack remain the same from MIPS with similar register convention mentioned in the source assembly code. The stack is simulated using the Data-memory with a \$sp register used for referencing the base address of the current stack frame.

#### Pseudo code:

```
int Fib(int n):
    if (n < 2):
        return n
    return Fib(n-1) + Fib(n-2)</pre>
```

#### MIPS code:

```
main:
  xor $29, $29 # sp = 0
  xor $1, $1 # flag set to 0
  xor $4, $4 # n = 6
  addi $4, 6
  bl fib
  addi $1, 1 # flag set to 1 on completion
fib:
  addi $29, 12
                 # (sp -> sp + 12 : make space for stack)
  sw $31, -12($29) # store ra on stack
  sw $4, -8($29) # store n onto stack
  compi $10, 2
                 # t2 = -2
  add $10, $4  # t2 = n-2
  bltz $10, endfib # if n-2 < 0: jump to endfib
  addi $4, -1 # n-1
  bl fib
  sw \$2, -4(\$29) # store fib(n-1) in memory
  lw $4, -8($29) # load n from memory into $a0
  addi $4, -2
  bl fib
  lw $8, -4($29)  # load fib(n-1) into $t0
  add \$2, \$8 # \$v0 = fib(n-1) + fib(n-2)
  b end
endfib:
  xor $2, $2
               # v0 = 0
  add \$2, \$4  # v0 = n (if n == 0 \mid \mid n == 1)
end:
  lw $31 -12($29)
  addi $29, -12  # move stack pointer back to original place
  br $31
```

The \$1 register reserved for assembler is used to check when the program is to be halted in MIPS and has no other purpose. Firstly 12 Bytes of memory is used for every function stack to store the return address, the argument n and one more computational result.

#### The Byte code:

```
memory initialization radix=2;
memory_initialization_vector=
00000011101111010000000001100000,
0000000001000010000000001100000,
0000000100001000000000001100000,
0010000010000000000000000000000110,
1010110000000000000000000000000110,
0010001110100000000000000000001100,
011000111011111111111111111110100,
0110001110100100111111111111111000,
0000001010001000000000000100000,
1100000101000000000000000000001001,
1010110000000000000000000000000110,
011000111010001011111111111111100,
0100001110100100111111111111111000,
1010110000000000000000000000000110,
010000111010100011111111111111100,
0000000010010000000000000100000,
1010000000000000000000000000010111,
0000000010000100000000001100000,
00000000100010000000000000100000,
010000111011111111111111111110100,
001000111010000011111111111110100,
```

## Results:



Content of return value register \$v0: 8

Stopped at time: 3655 ns: File "/home/parth/5th-Sem/Computer-Organization-and-Architecture-Laboratory/KGP-RISC/RISC tb.v" Line 53

ISim>



## **ALU DESIGN KGP-RISC**



