# **AVR and RISC-V Instructions**

Erik Engheim <erik.engheim@ma.com>

### Arithmetic Operation

|      | Mnemonic        | Instruction               | AVR            | AVR Description |
|------|-----------------|---------------------------|----------------|-----------------|
| ADD  | rd, rs1, rs2    | Add                       | ADD rd, rs     | rd ← rd + rs    |
| SUB  | rd, rs1, rs2    | Subtract                  | SUB rd, rs     | rd ← rd - rs    |
| ADDI | rd, rs1, imm12  | Add immediate             | SUBI rd, -imm8 | rd ← rd - (-rs) |
| ADDI | rd, rs1, -imm12 | Subtract immediate        | SUBI rd, imm8  | rd ← rd - imm8  |
| LUI  | rd, imm20       | Load upper immediate      | LDI rd, imm8   | rd ← imm8       |
| AUIP | rd, imm20       | Add upper immediate to PC | LDI rd, imm8   | rd ← imm8       |

### **Logical Operations**

| Mnemonic            | Instruction                | AVR                        | AVR Description                       |
|---------------------|----------------------------|----------------------------|---------------------------------------|
| AND rd, rs1, rs2    | AND                        | AND rd, rs                 | rd ← rd & rs                          |
| OR rd, rs1, rs2     | OR                         | OR rd, rs                  | rd ← rd   rs                          |
| XOR rd, rs1, rs2    | XOR                        | EOR rd, rs                 | rd ← rd ^ rs                          |
| ANDI rd, rs1, imm12 | AND immediate              | ANDI rd, imm8              | rd ← rd & imm8                        |
| ORI rd, rs1, imm12  | OR immediate               | ORI rd, imm8               | rd ← rd   imm8                        |
| XORI rd, rs1, imm12 | XOR immediate              | LDI rs, imm8<br>EOR rd, rs |                                       |
| SLL rd, rs1, rs2    | Shift left logical         | LSL rd                     | rd ← rd << 1                          |
| SRL rd, rs1, rs2    | Shift right logical        | LSR rd                     | rd ← rd >> 1                          |
| SRA rd, rs1, rs2    | Shift right arithmetic     | ASR rd                     | rd ← rd >> 1                          |
|                     | Rotate Left through carry  | ROL rd                     | rd ← rd  << 1<br>rd[0] ← C, C ← rd[7] |
|                     | Rotate Right through carry | ROR rd                     | rd ← rd >> 1<br>rd[7] ← C, C ← rd[0]  |
|                     | Swap nibbles               | SWAP rd                    | rd[30] ↔ rd[74]                       |

### AVR Register File

| ۲0  | Ր1  | r2  | r3  | r4  | r5  | r6  | r7  |
|-----|-----|-----|-----|-----|-----|-----|-----|
| r8  | ۲9  | r10 | r11 | r12 | r13 | r14 | r15 |
| r16 | r17 | r18 | r19 | r20 | r21 | r22 | r23 |
| r24 | r25 | r26 | r27 | r28 | r29 | r30 | r31 |

### Register Aliases

| ٥٦  | r1  | r2                                    | r3  | r4                                    | r5  | г6  | r7  |
|-----|-----|---------------------------------------|-----|---------------------------------------|-----|-----|-----|
| r8  | ۲9  | r10                                   | r11 | r12                                   | r13 | r14 | r15 |
| r16 | r17 | r18                                   | r19 | r20                                   | r21 | r22 | r23 |
| r24 | r25 | XL                                    | ХН  | YL                                    | YH  | ZL  | ZH  |
|     |     | · · · · · · · · · · · · · · · · · · · |     | · · · · · · · · · · · · · · · · · · · |     |     | 7   |

Callee saved registers (subroutine must save)

Used for indirect addressing

## Load / Store Operations

| Mnemonic                              | Instruction                          | AVR             | AVR Description         |  |
|---------------------------------------|--------------------------------------|-----------------|-------------------------|--|
| LB rd, imm12(rs1)                     | Load byte                            | LDD rd, rs+imm6 | rd ← mem[rs + imm6]     |  |
| LB rd, 0(rs1)                         | Load Indirect                        | LD rd, rs       | rd ← mem[rs]            |  |
| LB rd, 0(r1)<br>ADDI r1, r1, 1        | Load Indirect and post-increment     | LD rd, rs+      | rd ← mem[rs], rs ← rs+1 |  |
| ADDI r1, r1, -1<br>LB rd, 0(r1)       | Load Indirect and pre-decrement      | LD rd, -rs      | rs ← rs-1, rd ← mem[rs] |  |
| LI rd, imm12                          | Load Immediate                       | LDI rd, imm8    | rd ← imm8               |  |
| LUI r1, r1, imm20<br>LB rd, imm12(r1) | Load Direct from data space (32-bit) | LDS rd, imm16   | rd ← mem[imm16]         |  |
| SB rs2, imm12(rs1)                    | Store byte                           | STD rd+imm6, rs | mem[rd + imm6] ← rs     |  |
| SB rs2, 0(rs1)                        | Store Indirect                       | ST rd, rs       | mem[rd] ← rs            |  |
| SB r2, 0(r1)<br>ADDI r1, r1, 1        | Store Indirect and post-increment    | ST rd+, rs      | mem[rd] ← rs, rd ← rd+1 |  |
| ADDI r1, r1, -1<br>SB r2, 0(r1)       | Store Indirect and pre-decrement     | ST -rd, rs      | rd ← rd-1, mem[rd] ← rs |  |
| LUI r1, r1, imm20<br>SB r2, imm12(r1) | Store Direct to data space (32-bit)  | STS imm16, rs   | mem[imm16] ← rs         |  |

### Branching

| Mnemonic               | Instruction                           | AVR         | AVR Description                      |
|------------------------|---------------------------------------|-------------|--------------------------------------|
| BEQ rs1, rs2, imm12    | Branch equal                          | BREQ imm7   | if Z == 1<br>Pc ← Pc + imm7          |
| BNE rs1, rs2, imm12    | Branch not equal                      | BRNE imm7   | if Z == 0<br>pc ← pc + imm7          |
| BGE rs1, rs2, imm12    | Branch greater than or equal          | BRGE imm7   | if N ^ V == 0<br>Pc ← Pc + imm7      |
| BGEU rs1, rs2, imm12   | Branch greater than or equal unsigned | BRSH imm7   | if C == 0<br>pc ← pc + imm12         |
| BLT rs1, rs2, imm12    | Branch less than                      | BRLT imm7   | if rs1 < rs2<br>pc ← pc + imm12      |
| BLTU rs1, rs2, imm12   | Branch less than unsigned             | BRLO imm7   | if rs1 < rs2<br>pc ← pc + imm12 << 1 |
| JALR zero, imm12(zero) | Jump                                  | JMP imm16   | pc ← imm16                           |
| JAL zero, imm20        | Relative jump                         | RJMP imm12  | PC ← PC + imm12                      |
| JALR zero, imm12(rs1)  | Indirect jump                         | IJMP        | pc ← r31:r30                         |
| JAL rd, imm20          | Jump and link                         | RCALL imm12 | stack ← pc + 2<br>pc ← pc + imm12    |
| JALR rd, imm12(zero)   | Long call                             | CALL imm16  | stack ← pc + 2<br>pc ← imm16         |
| JALR rd, imm12(rs1)    | Jump and link register                | RET         | pc ← stack                           |
| JALR rd, imm12(rs1)    | Jump and link register                | ICALL       | stack ← pc + 2<br>pc ← r31:r30       |