|            | Instruction |     |       |        | Name                                     | Description                                                                             | Tymo       | Opcod    |      | Funct3 | Eupot7 |      |
|------------|-------------|-----|-------|--------|------------------------------------------|-----------------------------------------------------------------------------------------|------------|----------|------|--------|--------|------|
|            |             |     | rs1   | 2      | ADD                                      | ·                                                                                       | R          | <u> </u> | 0011 |        |        | 0000 |
|            | add         |     |       |        |                                          | rd = rs1 + rs2                                                                          | _          |          |      |        |        |      |
|            | sub         |     | rs1   |        | SUBtract<br>bitwise AND                  | rd = rs1 - rs2                                                                          | R          |          | 0011 |        |        | 0000 |
|            | and         |     | rs1   |        |                                          | rd = rs1 & rs2                                                                          | R          |          | 0011 |        |        | 0000 |
|            | or          |     | rs1   |        | bitwise OR                               | rd = rs1   rs2                                                                          | R          |          | 0011 |        |        | 0000 |
|            | xor         |     | rs1   |        | bitwise XOR                              | rd = rs1 ^ rs2                                                                          | R          |          | 0011 |        |        | 0000 |
|            | sll         |     | rs1   |        | Shift Left Logical                       | rd = rs1 << rs2                                                                         | R          |          | 0011 |        |        | 0000 |
|            | srl         |     | rs1   |        | Shift Right Logical                      | rd = rs1 >> rs2 (Zero-extend)                                                           | R          |          | 0011 |        |        | 0000 |
|            | sra         |     | rs1   |        |                                          | rd = rs1 >> rs2 (Sign-extend)                                                           | R          |          | 0011 |        |        | 0000 |
|            | slt         | rd  | rs1   | rs2    | Set Less Than (signed)                   | rd = (rs1 < rs2) ? 1 : 0                                                                | R          | 011      | 0011 | 010    | 000    | 0000 |
|            | sltu        | rd  | rs1   | rs2    | Set Less Than (Unsigned)                 |                                                                                         | R          | 011      | 0011 | 011    | 000    | 0000 |
| O          | addi        | rd  | rs1   | imm    | ADD Immediate                            | rd = rs1 + imm                                                                          | I          | 001      | 0011 | 000    |        |      |
| Arithmetic | andi        | rd  | rs1   | imm    | bitwise AND<br>Immediate                 | rd = rs1 & imm                                                                          | I          | 001      | 0011 | 111    |        |      |
| Arii       | ori         | rd  | rs1   | imm    | bitwise OR<br>Immediate                  | rd = rs1   imm                                                                          | I          | 001      | 0011 | 110    |        |      |
|            | xori        | rd  | rs1   | imm    | bitwise XOR<br>Immediate                 | rd = rs1 ^ imm                                                                          | I          | 001      | 0011 | 100    |        |      |
|            | slli        | rd  | rs1   | imm    | Shift Left Logical<br>Immediate          | rd = rs1 << imm                                                                         | l*         | 001      | 0011 | 001    | 000    | 0000 |
|            | srli        | rd  | rs1   | imm    | Shift Right Logical<br>Immediate         | rd = rs1 >> imm (Zero-extend)                                                           | <b> </b> * | 001      | 0011 | 101    | 000    | 0000 |
|            | srai        | rd  | rs1   | imm    | Shift Right Arithmetic<br>Immediate      | rd = rs1 >> imm (Sign-extend)                                                           | <b> </b> * | 001      | 0011 | 101    | 010    | 0000 |
|            | slti        | rd  | rs1   | imm    | Set Less Than<br>Immediate (signed)      | rd = (rs1 < imm) ? 1 : 0                                                                | I          | 001      | 0011 | 010    |        |      |
|            | sltiu       | rd  | rs1   | imm    | Set Less Than<br>Immediate<br>(Unsigned) |                                                                                         | I          | 001      | 0011 | 011    |        |      |
|            | 1b          | rd  | imm   | (rs1)  | Load Byte                                | rd = 1 byte of memory at address<br>rs1 + imm, sign-extended                            | I          | 000      | 0011 | 000    |        |      |
|            | lbu         | rd  | imm ( | (rs1)  | Load Byte<br>(Unsigned)                  | rd = 1 byte of memory at address<br>rs1 + imm, zero-extended                            | I          | 000      | 0011 | 100    |        |      |
|            | lh          | rd  | imm   | (rs1)  | Load Half-word                           | rd = 2 bytes of memory starting at address rs1 + imm, sign-extended                     | I          | 000      | 0011 | 001    |        |      |
| ح          | lhu         | rd  | imm ( | (rs1)  | Load Half-word<br>(Unsigned)             | rd = 2 bytes of memory starting at address rs1 + imm, zero-extended                     | I          | 000      | 0011 | 101    |        |      |
| Memory     | lw          | rd  | imm ( | (rs1)  | Load Word                                | rd = 4 bytes of memory starting at address rs1 + imm                                    | I          | 000      | 0011 | 010    |        |      |
| _          | sb          | rs2 | ? imn | n(rs1) | Store Byte                               | Stores least-significant byte of rs2 at the address rs1 + imm in memory                 | S          | 010      | 0011 | 000    |        |      |
|            | sh          | rs2 | ? imn | n(rs1) | Store Half-word                          | Stores the 2 least-significant bytes of rs2 starting at the address rs1 + imm in memory | S          | 010      | 0011 | 001    |        |      |
|            | sw          | rs2 | ? imn | n(rs1) | Store Word                               | Stores rs2 starting at the address rs1 + imm in memory                                  | S          | 010      | 0011 | 010    |        |      |

|         | Instruction        | Name                                  | Description                                 | Туре | Opcode    | Funct3 |
|---------|--------------------|---------------------------------------|---------------------------------------------|------|-----------|--------|
|         | beq rs1 rs2 label  | Branch if EQual                       | if (rs1 == rs2)<br>PC = PC + offset         | В    | 110 0011  | 000    |
|         | bge rs1 rs2 label  | Branch if Greater or Equal (signed)   | if (rs1 >= rs2)                             | В    | 110 0011  | 101    |
|         | bgeu rs1 rs2 label | Branch if Greater or Equal (Unsigned) | PC = PC + offset                            | В    | 110 0011  | 111    |
|         | blt rs1 rs2 label  | Branch if Less Than (signed)          | if (rs1 < rs2)                              | В    | 110 0011  | 100    |
|         | bltu rs1 rs2 label | Branch if Less Than (Unsigned)        | PC = PC + offset                            | В    | 110 0011  | 110    |
| Control | bne rs1 rs2 label  | Branch if Not Equal                   | if (rs1 != rs2)<br>PC = PC + offset         | В    | 110 0011  | 001    |
| ပိ      | jal rd label       | Jump And Link                         | rd = PC + 4<br>PC = PC + offset             | J    | 110 1111  |        |
|         | jalr rd rs1 imm    | Jump And Link Register                | rd = PC + 4<br>PC = rs1 + imm               | I    | 110 0111  | 000    |
|         | auipc rd immu      | Add Upper Immediate to PC             | imm = immu << 12<br>rd = PC + imm           | U    | 001 0111  |        |
|         | lui rd immu        | Load Upper Immediate                  | imm = immu << 12<br>rd = imm                | U    | 011 0111  |        |
| Other   | ebreak             | Environment BREAK                     | Asks the debugger to do something (imm = 0) | I    | 111 0011  | 000    |
|         | ecall              | Environment CALL                      | Asks the OS to do something (imm = 1)       | I    | 111 0011  | 000    |
| Ĕ       | mul rd rs1 rs2     | MULtiply (part of mul ISA extension)  | rd = rs1 * rs2                              |      | (omitted) |        |

| #                      | Name                                       | Description                      | #           | Name | Desc            |  |  |  |  |
|------------------------|--------------------------------------------|----------------------------------|-------------|------|-----------------|--|--|--|--|
| -                      | -                                          | ·                                | I           |      |                 |  |  |  |  |
| <b>x</b> 0             | zero                                       | Constant 0                       | x16         | a6   | Args            |  |  |  |  |
| x1                     | ra                                         | Return<br>Address                | x17         | a7   |                 |  |  |  |  |
| <b>x</b> 2             | sp                                         | Stack<br>Pointer                 | x18         | s2   |                 |  |  |  |  |
| ж3                     | gp                                         | Global<br>Pointer                | x19         | s3   |                 |  |  |  |  |
| x4                     | tp                                         | Thread<br>Pointer                | <b>x</b> 20 | s4   | ers             |  |  |  |  |
| <b>x</b> 5             | t0                                         |                                  | x21         | s5   | gist            |  |  |  |  |
| <b>x</b> 6             | t1                                         | Temporary<br>Registers           | x22         | s6   | Saved Registers |  |  |  |  |
| <b>x</b> 7             | t2                                         | rtogiotoro                       | <b>x</b> 23 | s7   | Nec             |  |  |  |  |
| <b>x</b> 8             | s0                                         | Saved                            | x24         | s8   | Sa              |  |  |  |  |
| <b>x</b> 9             | s1                                         | Registers                        | <b>x</b> 25 | s9   |                 |  |  |  |  |
| <b>x10</b>             | <b>a</b> 0                                 | Function                         | x26         | s10  |                 |  |  |  |  |
| x11                    | a1                                         | Arguments<br>or Return<br>Values | <b>x</b> 27 | s11  |                 |  |  |  |  |
| <b>x12</b>             | a2                                         |                                  | <b>x</b> 28 | t3   | es              |  |  |  |  |
| <b>x</b> 13            | <b>a</b> 3                                 | Function                         | x29         | t4   | orari           |  |  |  |  |
| x14                    | a4                                         | Arguments                        | <b>x</b> 30 | t5   | Temporaries     |  |  |  |  |
| <b>x</b> 15            | <b>a</b> 5                                 |                                  | <b>x</b> 31 | t6   | 7e              |  |  |  |  |
| Caller saved registers |                                            |                                  |             |      |                 |  |  |  |  |
| Calle                  | Callee saved registers (except x0, gp, tp) |                                  |             |      |                 |  |  |  |  |

Immediates are sign-extended to 32 bits, except in I\* type instructions

|                   |                              | 1                                         |                       |  |  |  |
|-------------------|------------------------------|-------------------------------------------|-----------------------|--|--|--|
| Pseudoinstruction | Name                         | Description                               | Translation           |  |  |  |
| beqz rs1 label    | Branch if EQuals Zero        | <pre>if (rs1 == 0) PC = PC + offset</pre> | beq rs1 x0 label      |  |  |  |
| bnez rs1 label    | Branch if Not<br>Equals Zero | <pre>if (rs1 != 0) PC = PC + offset</pre> | bne rs1 x0 label      |  |  |  |
| j label           | Jump                         | PC = PC + offset                          | jal x0 label          |  |  |  |
| jal label         | Jump and Link                | PC = PC + offset<br>ra = PC + 4           | jal ra label          |  |  |  |
| jr rs1            | Jump Register                | PC = rs1                                  | jalr x0 rs1 0         |  |  |  |
| la rd label       | Load absolute<br>Address     | rd = &label                               | auipc, addi           |  |  |  |
| li rd imm         | Load Immediate               | rd = imm                                  | lui (if needed), addi |  |  |  |
| mv rd rs1         | MoVe                         | rd = rs1                                  | addi rd rs1 0         |  |  |  |
| neg rd rs1        | NEGate                       | rd = -rs1                                 | sub rd x0 rs1         |  |  |  |
| nop               | No OPeration                 | do nothing                                | addi x0 x0 0          |  |  |  |
| not rd rs1        | bitwise NOT                  | rd = ~rs1                                 | xori rd rs1 -1        |  |  |  |
| ret               | RETurn                       | PC = ra                                   | jalr x0 x1 0          |  |  |  |

| 3 | 1 25         | 24 20         | 19 15      | 14 12  | 11 7        | 6 0    |
|---|--------------|---------------|------------|--------|-------------|--------|
| R | funct7       | rs2           | rs1        | funct3 | rd          | opcode |
| I | imm[11       | rs1           | funct3     | rd     | opcode      |        |
| * | funct7       | imm[4:0]      | rs1 funct3 |        | rd          | opcode |
| S | imm[11:5]    | rs2           | rs1 funct3 |        | imm[4:0]    | opcode |
| В | imm[12 10:5] | rs2           | rs1        | funct3 | imm[4:1 11] | opcode |
| U |              | rd            | opcode     |        |             |        |
| J | im           | ım[20 10:1 11 | rd         | opcode |             |        |

# Selected ASCII values

| HEX  | DEC | CHAR  | HEX  | DEC | CHAR | HEX  | DEC | CHAR | HEX  | DEC | CHAR | HEX  | DEC | CHAR | HEX  | DEC | CHAR |
|------|-----|-------|------|-----|------|------|-----|------|------|-----|------|------|-----|------|------|-----|------|
| 0x20 | 32  | SPACE | 0x30 | 48  | 0    | 0x40 | 64  | @    | 0x50 | 80  | P    | 0x60 | 96  | `    | 0x70 | 112 | р    |
| 0x21 | 33  | !     | 0x31 | 49  | 1    | 0x41 | 65  | А    | 0x51 | 81  | Q    | 0x61 | 97  | a    | 0x71 | 113 | q    |
| 0x22 | 34  | "     | 0x32 | 50  | 2    | 0x42 | 66  | В    | 0x52 | 82  | R    | 0x62 | 98  | b    | 0x72 | 114 | r    |
| 0x23 | 35  | #     | 0x33 | 51  | 3    | 0x43 | 67  | С    | 0x53 | 83  | S    | 0x63 | 99  | С    | 0x73 | 115 | S    |
| 0x24 | 36  | \$    | 0x34 | 52  | 4    | 0x44 | 68  | D    | 0x54 | 84  | Т    | 0x64 | 100 | d    | 0x74 | 116 | t    |
| 0x25 | 37  | 010   | 0x35 | 53  | 5    | 0x45 | 69  | E    | 0x55 | 85  | U    | 0x65 | 101 | е    | 0x75 | 117 | u    |
| 0x26 | 38  | &     | 0x36 | 54  | 6    | 0x46 | 70  | F    | 0x56 | 86  | V    | 0x66 | 102 | f    | 0x76 | 118 | V    |
| 0x27 | 39  | 1     | 0x37 | 55  | 7    | 0x47 | 71  | G    | 0x57 | 87  | W    | 0x67 | 103 | g    | 0x77 | 119 | W    |
| 0x28 | 40  | (     | 0x38 | 56  | 8    | 0x48 | 72  | Н    | 0x58 | 88  | Х    | 0x68 | 104 | h    | 0x78 | 120 | Х    |
| 0x29 | 41  | )     | 0x39 | 57  | 9    | 0x49 | 73  | I    | 0x59 | 89  | Y    | 0x69 | 105 | i    | 0x79 | 121 | У    |
| 0x2A | 42  | *     | 0x3A | 58  |      | 0x4A | 74  | J    | 0x5A | 90  | Z    | 0x6A | 106 | j    | 0x7A | 122 | Z    |
| 0x2B | 43  | +     | 0x3B | 59  | ;    | 0x4B | 75  | K    | 0x5B | 91  | [    | 0x6B | 107 | k    | 0x7B | 123 | {    |
| 0x2C | 44  | ,     | 0x3C | 60  | <    | 0x4C | 76  | L    | 0x5C | 92  | \    | 0x6C | 108 | 1    | 0x7C | 124 |      |
| 0x2D | 45  | -     | 0x3D | 61  | =    | 0x4D | 77  | М    | 0x5D | 93  | ]    | 0x6D | 109 | m    | 0x7D | 125 | }    |
| 0x2E | 46  |       | 0x3E | 62  | >    | 0x4E | 78  | N    | 0x5E | 94  | ^    | 0x6E | 110 | n    | 0x7E | 126 | ~    |
| 0x2F | 47  | _/    | 0x3F | 63  | ?    | 0x4F | 79  | 0    | 0x5F | 95  |      | 0x6F | 111 | 0    | 0x00 | 0   | NULL |

## C Format String Specifiers

| O I diffiat during opcomers |                                                       |  |  |  |  |  |  |  |  |
|-----------------------------|-------------------------------------------------------|--|--|--|--|--|--|--|--|
| Specifier                   | Output                                                |  |  |  |  |  |  |  |  |
| d <b>or</b> i               | Signed decimal integer                                |  |  |  |  |  |  |  |  |
| u                           | Unsigned decimal integer                              |  |  |  |  |  |  |  |  |
| 0                           | Unsigned octal                                        |  |  |  |  |  |  |  |  |
| X                           | Unsigned hexadecimal integer, lowercase               |  |  |  |  |  |  |  |  |
| X                           | Unsigned hexadecimal integer, uppercase               |  |  |  |  |  |  |  |  |
| f                           | Decimal floating point, lowercase                     |  |  |  |  |  |  |  |  |
| F                           | Decimal floating point, uppercase                     |  |  |  |  |  |  |  |  |
| е                           | Scientific notation (significand/exponent), lowercase |  |  |  |  |  |  |  |  |
| Е                           | Scientific notation (significand/exponent), uppercase |  |  |  |  |  |  |  |  |
| g                           | Use the shortest representation: %e or %f             |  |  |  |  |  |  |  |  |
| G                           | Use the shortest representation: %E or %F             |  |  |  |  |  |  |  |  |
| a                           | Hexadecimal floating point, lowercase                 |  |  |  |  |  |  |  |  |
| A                           | Hexadecimal floating point, uppercase                 |  |  |  |  |  |  |  |  |
| С                           | Character                                             |  |  |  |  |  |  |  |  |
| s                           | String of characters                                  |  |  |  |  |  |  |  |  |
| р                           | Pointer address                                       |  |  |  |  |  |  |  |  |

## IEEE 754 Floating Point Standard

|                  | Sign Exponent |                         | Significand |
|------------------|---------------|-------------------------|-------------|
| Single Precision | 1 bit         | 8 bits (bias = -127)    | 23 bits     |
| Double Precision | 1 bit         | 11 bits (bias = -1023)  | 52 bits     |
| Quad Precision   | 1 bit         | 15 bits (bias = -16383) | 112 bits    |

Standard exponent bias: - (2<sup>E-1</sup>-1) where E is the number of exponent bits

#### SI Prefixes

| Size              | Prefix | Symbol | Size             | Prefix | Symbol | Size            | Prefix | Symbol |
|-------------------|--------|--------|------------------|--------|--------|-----------------|--------|--------|
| 10 <sup>-3</sup>  | milli- | m      | 10 <sup>3</sup>  | kilo-  | k      | 210             | kibi-  | Ki     |
| 10 <sup>-6</sup>  | micro- | μ      | 10 <sup>6</sup>  | mega-  | М      | 2 <sup>20</sup> | mebi-  | Mi     |
| 10 <sup>-9</sup>  | nano-  | n      | 10 <sup>9</sup>  | giga-  | G      | 230             | gibi-  | Gi     |
| 10 <sup>-12</sup> | pico-  | р      | 10 <sup>12</sup> | tera-  | Т      | 240             | tebi-  | Ti     |
| 10 <sup>-15</sup> | femto- | f      | 10 <sup>15</sup> | peta-  | Р      | 2 <sup>50</sup> | pebi-  | Pi     |
| 10 <sup>-18</sup> | atto-  | а      | 10 <sup>18</sup> | еха-   | E      | 2 <sup>60</sup> | exbi-  | Ei     |
| 10 <sup>-21</sup> | zepto- | z      | 10 <sup>21</sup> | zetta- | Z      | 2 <sup>70</sup> | zebi-  | Zi     |
| 10 <sup>-24</sup> | yocto- | у      | 10 <sup>24</sup> | yotta- | Y      | 280             | yobi-  | Yi     |

## Laws of Boolean Algebra

$$egin{array}{lll} x\cdot \overline{x} &= 0 & x+\overline{x} &= 1 & (xy)z &= x\,(yz) \ x\cdot 0 &= 0 & x+1 &= 1 & (x+y)+z &= x+(y+z) \ x\cdot 1 &= x & x+0 &= x & x\,(y+z) &= xy+xz \ x\cdot x &= x & x+x &= x & x+yz &= (x+y)\,(x+z) \ x\cdot y &= y\cdot x & x+y &= y+x & \overline{x\cdot y} &= \overline{x}+\overline{y} \ xy+x &= x & (x+y)x &= x & \overline{(x+y)} &= \overline{x}\cdot \overline{y} \ \end{array}$$



