## **Feather ISA**

This custom ISA is designed based on RV32I.

32-bit Instructions, 32 General Registers of 32-bit width.

Some signed instructions beyond RV32I are implemented in this ISA.

ebreak interruption implementation

#### **Instruction Format**

| 31 30 25          | 24 21    | 20     | 19  | 15 14    | 12 | 11 8     | 7       | 6 (    | )      |
|-------------------|----------|--------|-----|----------|----|----------|---------|--------|--------|
| funct7            | rs2      |        | rs1 | func     | t3 | ro       | 1       | opcode | R-type |
|                   |          |        |     |          |    |          |         |        | _      |
| imm[1:            | L:0]     |        | rs1 | func     | t3 | ro       | 1       | opcode | l-type |
|                   |          |        |     | •        | •  |          |         |        | _      |
| imm[11:5]         | rs2      |        | rs1 | func     | t3 | imm      | [4:0]   | opcode | S-type |
|                   |          |        |     |          |    |          |         |        | _      |
| imm[12] imm[10:5] | rs2      |        | rs1 | func     | t3 | imm[4:1] | imm[11] | opcode | B-type |
|                   |          |        |     |          |    |          |         |        |        |
|                   | imm[31:1 | .2]    |     |          |    | ro       | d       | opcode | U-type |
|                   |          |        |     |          |    |          |         |        |        |
| imm[20] imm[10    | D:1] in  | nm[11] | imr | n[19:12] |    | ro       | d       | opcode | J-type |

Instructions with \* are custom instructions beyond RV32I.

## R type

| Inst  | Name                      | Opcode  | funct3 | funct7 | Description        | Note               |
|-------|---------------------------|---------|--------|--------|--------------------|--------------------|
| add   | Add                       | 0110011 | 000    | 0x00   | rd = rs1 +<br>rs2  |                    |
| mul   | Mul                       | 0110011 | 000    | 0x01   | rd = rs1 *<br>rs2  | low 32<br>bits     |
| *addu | Unsigned Add              | 0110011 | 000    | 0x10   | rd = rs1 +<br>rs2  | ignore<br>overflow |
| sub   | Sub                       | 0110011 | 000    | 0x20   | rd = rs1 -<br>rs2  |                    |
| *subu | Unsigned Sub              | 0110011 | 000    | 0x30   | rd = rs1 -<br>rs2  | ignore<br>overflow |
| sll   | Shift Left Logical        | 0110011 | 001    | 0x00   | rd = rs1 <<<br>rs2 |                    |
| slt   | Set Less Than             | 0110011 | 010    | 0x00   | rd = rs1 <<br>rs2  |                    |
| sltu  | Unsigned Set<br>Less Than | 0110011 | 011    | 0x00   | rd = rs1 <<br>rs2  | zero-<br>extends   |
| xor   | Xor                       | 0110011 | 100    | 0x00   | rd = rs1 ^<br>rs2  |                    |
| div   | Div                       | 0110011 | 100    | 0x01   | rs = rs1 /<br>rs2  |                    |
| srl   | Shift Right<br>Logical    | 0110011 | 101    | 0x00   | rd = rs1 >><br>rs2 |                    |
| sra   | Shift Right<br>Arithmetic | 0110011 | 101    | 0x20   | rd = rs1 >><br>rs2 | msb-<br>extends    |
| or    | Or                        | 0110011 | 110    | 0x00   | rd = rs1  <br>rs2  | rs2                |
| rem   | Remainder                 | 0110011 | 110    | 0x01   | rd = rs1 %<br>rs2  |                    |
| and   | And                       | 0110011 | 111    | 0x00   | rd = rs1 &<br>rs2  |                    |

# I type

| Inst  | Name                             | Opcode  | funct3 | imm[11:5] | Description                  | Note             |
|-------|----------------------------------|---------|--------|-----------|------------------------------|------------------|
| addi  | Add Imm                          | 0010011 | 000    |           | rd = rs1 +<br>imm            |                  |
| slli  | Shift Left<br>Logical Imm        | 0010011 | 001    | 0x00      | rd = rs1 <<<br>imm           |                  |
| slti  | Set Less<br>Than Imm             | 0010011 | 010    |           | rd = rs1 <<br>imm            |                  |
| sltiu | Unsigned<br>Set Less<br>Than Imm | 0010011 | 011    |           | rd = rs1 <<br>imm            | zero-<br>extends |
| xori  | Xor Imm                          | 0010011 | 100    |           | rd = rs1 ^<br>imm            |                  |
| srli  | Shift Right<br>Logical Imm       | 0010011 | 101    | 0x00      | rd = rs1 >><br>imm           |                  |
| srai  | Shift Right<br>Arithmetic<br>Imm | 0010011 | 101    | 0x20      | rd = rs1 >><br>imm           | msb-<br>extends  |
| ori   | Or Imm                           | 0010011 | 110    |           | rd = rs1 \ <br>imm           |                  |
| andi  | And Imm                          | 0010011 | 111    |           | rd = rs1 &<br>imm            |                  |
| lb    | Load Byte                        | 0000011 | 000    |           | rd =<br>M[rs1+imm]<br>[0:7]  |                  |
| lh    | Load Half                        | 0000011 | 001    |           | rd =<br>M[rs1+imm]<br>[0:15] |                  |
| lw    | Load Word                        | 0000011 | 010    |           | rd =<br>M[rs1+imm]<br>[0:31] |                  |
| lbu   | Load Byte<br>(U)                 | 0000011 | 100    |           | rd =<br>M[rs1+imm]<br>[0:7]  | zero-<br>extends |
| lhu   | Load Half (U)                    | 0000011 | 101    |           | rd =<br>M[rs1+imm]<br>[0:15] | zero-<br>extends |
| ecall | Environment<br>Call              | 1110011 | 000    |           | Transfer<br>control to<br>OS |                  |

| ebreak | Environment<br>Break | 1110011 | 000 | Transfer control to debugger |
|--------|----------------------|---------|-----|------------------------------|
|--------|----------------------|---------|-----|------------------------------|

## S type

| Inst | Name       | Opcode  | funct3 | Description                |
|------|------------|---------|--------|----------------------------|
| sb   | Store Byte | 0100011 | 000    | M[rs1+imm][0:7]=rs2[0:7]   |
| sh   | Store Half | 0100011 | 001    | M[rs1+imm][0:15]=rs2[0:15] |
| SW   | Store Word | 0100011 | 010    | M[rs1+imm][0:31]=rs2[0:31] |

# **B** type

| Inst | Name                 | Opcode  | funct3 | Description               | Note             |
|------|----------------------|---------|--------|---------------------------|------------------|
| beq  | Branch ==            | 1100011 | 000    | if(rs1 == rs2)<br>PC+=imm |                  |
| bne  | Branch !=            | 1100011 | 001    | if(rs1 != rs2)<br>PC+=imm |                  |
| blt  | Branch <             | 1100011 | 100    | if(rs1 < rs2)<br>PC+=imm  |                  |
| bge  | Branch≥              | 1100011 | 101    | if(rs1 >= rs2)<br>PC+=imm |                  |
| bltu | Unsigned Branch      | 1100011 | 110    | if(rs1 < rs2)<br>PC+=imm  | zero-<br>extends |
| bgeu | Unsigned Branch<br>≥ | 1100011 | 111    | if(rs1 >= rs2)<br>PC+=imm | zero-<br>extends |

# J type

| Inst | Name              | Opcode  | funct3 | Description                 |
|------|-------------------|---------|--------|-----------------------------|
| jal  | Jump And Link     | 1101111 |        | rd = PC + 4, PC += imm      |
| jalr | Jump And Link Reg | 1100111 | 000    | rd = PC + 4, PC = rs1 + imm |

# U type

| Inst  | Name                | Opcode  | Description           |
|-------|---------------------|---------|-----------------------|
| lui   | Load Upper Imm      | 0110111 | rd = imm << 12        |
| auipc | Add Upper Imm to PC | 0010111 | rd = PC + (imm << 12) |