1



#### LEGv8 Reference Data CORE INSTRUCTION SET in Alphabetical Order by Mnemonic

| CORE INSTRUCT                        | ION SET    |            |                    |                                                                        |         |
|--------------------------------------|------------|------------|--------------------|------------------------------------------------------------------------|---------|
| NAME, MNEM                           | 4ONIC      | MAT        | OPCODE (9<br>(Hex) | OPERATION (in Verilog)                                                 | Notes   |
| ADD                                  | ADD        | R          | 458                | R[Rd] = R[Rn] + R[Rm]                                                  |         |
| ADD Immediate                        | ADDI       | I          | 488-489            | R[Rd] = R[Rn] + ALUImm                                                 | (2,9)   |
| ADD Immediate &                      |            |            |                    | R[Rd], $FLAGS = R[Rn] +$                                               |         |
| Set flags                            | ADDIS      | Ι          | 588-589            | ALUImm                                                                 | (1,2,9) |
| ADD & Set flags                      | ADDS       | R          | 558                | R[Rd], $FLAGS = R[Rn] + R[Rm]$                                         | (1)     |
| AND                                  | AND        | R          | 450                | R[Rd] = R[Rn] & R[Rm]                                                  |         |
| AND Immediate                        | ANDI       | I          | 490-491            | R[Rd] = R[Rn] & ALUImm                                                 | (2,9)   |
| AND Immediate &<br>Set flags         | ANDIS      | I          | 790-791            | R[Rd], FLAGS = R[Rn] & ALUImm                                          | (1,2,9) |
| AND & Set flags                      | ANDS       | R          | 750                | R[Rd], $FLAGS = R[Rn] & R[Rm]$                                         | (1)     |
| Branch                               | В          | В          | 0A0-0BF            | PC = PC + BranchAddr                                                   | (3,9)   |
| Branch<br>conditionally              | B.cond     | СВ         | 2A0-2A7            | if(FLAGS==cond)<br>PC = PC + CondBranchAddr                            | (4,9)   |
| Branch with Link                     | BL         | В          | 4A0-4BF            | R[30] = PC + 4;<br>PC = PC + BranchAddr                                | (3,9)   |
| Branch to Register                   | BR         | R          | 6B0                | PC = R[Rt]                                                             |         |
| Compare & Branch<br>if Not Zero      | CBNZ       | СВ         | 5A8-5AF            | if(R[Rt]!=0)<br>PC = PC + CondBranchAddr                               | (4,9)   |
| Compare & Branch<br>if Zero          | CBZ        | СВ         | 5A0-5A7            | if(R[Rt]==0)<br>PC = PC + CondBranchAddr                               | (4,9)   |
| Exclusive OR                         | EOR        | R          | 650                | $R[Rd] = R[Rn] ^ R[Rm]$                                                |         |
| Exclusive OR<br>Immediate            | EORI       | I          | 690-691            | $R[Rd] = R[Rn] ^ALUImm$                                                | (2,9)   |
| LoaD Register<br>Unscaled offset     | LDUR       | D          | 7C2                | R[Rt] = M[R[Rn] + DTAddr]                                              | (5)     |
| LoaD Byte<br>Unscaled offset         | LDURB      | D          | 1C2                | R[Rt]={56'b0,<br>M[R[Rn] + DTAddr](7:0)}                               | (5)     |
| LoaD Half<br>Unscaled offset         | LDURH      | D          | 3C2                | R[Rt]={48'b0,<br>M[R[Rn] + DTAddr] (15:0)}                             | (5)     |
| LoaD Signed Word<br>Unscaled offset  | LDURSW     | D          | 5C4                | R[Rt] = { 32{ M[R[Rn] + DTAddr]<br>[31]},<br>M[R[Rn] + DTAddr] (31:0)} | (5)     |
| LoaD eXclusive<br>Register           | LDXR       | D          | 642                | R[Rd] = M[R[Rn] + DTAddr]                                              | (5,7)   |
| Logical Shift Left                   | LSL        | R          | 69B                | $R[Rd] = R[Rn] \ll shamt$                                              |         |
| Logical Shift Right                  | LSR        | R          | 69A                | R[Rd] = R[Rn] >>> shamt                                                |         |
| MOVe wide with<br>Keep               | MOVK       | IM         | 794-797            | R[Rd] (Instruction[22:21]*16:<br>Instruction[22:21]*16-15) =<br>MOVImm | (6,9)   |
| MOVe wide with<br>Zero               | MOVZ       | IM         | 694-697            | $R[Rd] = \{ MOVImm \le$                                                | (6,9)   |
| Zero<br>Inclusive OR                 | ORR        | R          | 550                | (Instruction[22:21]*16) }<br>R[Rd] = R[Rn]   R[Rm]                     |         |
| Inclusive OR<br>Immediate            | ORRI       | I          | 590-591            | $R[Rd] = R[Rn] \mid ALUImm$                                            | (2,9)   |
| STore Register<br>Unscaled offset    | STUR       | D          | 7C0                | M[R[Rn] + DTAddr] = R[Rt]                                              | (5)     |
| STore Byte<br>Unscaled offset        | STURB      | D          | 1C0                | M[R[Rn] + DTAddr](7:0) = $R[Rt](7:0)$                                  | (5)     |
| STore Half<br>Unscaled offset        | STURH      | D          | 3C0                | M[R[Rn] + DTAddr](15:0) = R[Rt](15:0)                                  | (5)     |
| STore Word<br>Unscaled offset        | STURW      | D          | 5C0                | M[R[Rn] + DTAddr](31:0) = R[Rt](31:0)                                  | (5)     |
| STore eXclusive<br>Register          | STXR       | D          | 640                | M[R[Rn] + DTAddr] = R[Rt];<br>R[Rm] = (atomic) ? 0 : 1                 | (5,7)   |
| SUBtract                             | SUB        | R          | 658                | R[Rd] = R[Rn] - R[Rm]                                                  |         |
| SUBtract<br>Immediate                | SUBI       | I          | 688-689            | R[Rd] = R[Rn] - ALUImm                                                 | (2,9)   |
| SUBtract<br>Immediate & Set<br>flags | SUBIS      | I          | 788-789            | R[Rd], $FLAGS = R[Rn] - ALUImm$                                        | (1,2,9) |
| SUBtract & Set<br>flags              | SUBS       | R          | 758                | R[Rd], $FLAGS = R[Rn] - R[Rm]$                                         | (1)     |
| (1) FLAGS are                        | 4 conditio | n codes se | et by the ALI      | J operation: Negative, Zero, oVerflow                                  | , Carry |

- FLAGS are 4 condition codes set by the ALU operation: Negative, Zero, oVerflow, Carry ALUImm = {52'b0, ALU immediate }
  BranchAddr = {36'RB, address [25]}, BR address, 2'b0 }
  CondBranchAddr = {43'(COND, BR, address [25]}, COND\_BR\_address, 2'b0 }
  DTAddr = {55'(DT\_address [8]), DT\_address }
  MOVImme = {48'b0, MOV\_immediate }
  Atomic test&set pair, R[Rm] = 0 if pair atomic, 1 if not atomic
  Operands considered unsigned numbers (vs. 2's complement)
  Since I, B, and CB instruction formats have opcodes narrower than 11 bits, they occupy a range of 11-bit opcodes

(10) If neither is operand a NaN and Value1 == Value2, FLAGS = 4'b0110; If neither is operand a NaN and Value1 < Value2, FLAGS = 4'b1000; If neither is operand a NaN and Value1 > Value2, FLAGS = 4'b0010; If an operand is a Nan, operands are unordered

2

# ARITHMETIC CORE INSTRUCTION SET

|                                   |       | FOR-  | OPCODE/<br>SHAMT       |                                  |        |
|-----------------------------------|-------|-------|------------------------|----------------------------------|--------|
| NAME, MNEMONI                     | MAT   | (Hex) | OPERATION (in Verilog) | Notes                            |        |
| Floating-point ADD Single         | FADDS | R     | 0F1 / 0A               | S[Rd] = S[Rn] + S[Rm]            |        |
| Floating-point ADD Double         | FADDD | R     | 0F3 / 0A               | D[Rd] = D[Rn] + D[Rm]            |        |
| Floating-point CoMPare<br>Single  | FCMPS | R     | 0F1 / 08               | FLAGS = (S[Rn] vs S[Rm])         | (1,10) |
| Floating-point CoMPare<br>Double  | FCMPD | R     | 0F3 / 08               | FLAGS = (D[Rn]  vs  D[Rm])       | (1,10) |
| Floating-point DIVide Single      | FDIVS | R     | 0F1/06                 | S[Rd] = S[Rn] / S[Rm]            |        |
| Floating-point DIVide Double      | FDIVD | R     | 0F3 / 06               | D[Rd] = D[Rn] / D[Rm]            |        |
| Floating-point MULtiply<br>Single | FMULS | R     | 0F1 / 02               | S[Rd] = S[Rn] * S[Rm]            |        |
| Floating-point MULtiply<br>Double | FMULD | R     | 0F3 / 02               | D[Rd] = D[Rn] * D[Rm]            |        |
| Floating-point SUBtract<br>Single | FSUBS | R     | 0F1 / 0E               | S[Rd] = S[Rn] - S[Rm]            |        |
| Floating-point SUBtract<br>Double | FSUBD | R     | 0F3 / 0E               | D[Rd] = D[Rn] - D[Rm]            |        |
| LoaD Single floating-point        | LDURS | R     | 7C2                    | S[Rt] = M[R[Rn] + DTAddr]        | (5)    |
| LoaD Double floating-point        | LDURD | R     | 7C0                    | D[Rt] = M[R[Rn] + DTAddr]        | (5)    |
| MULtiply                          | MUL   | R     | 4D8 / 1F               | R[Rd] = (R[Rn] * R[Rm]) (63:0)   |        |
| Signed DIVide                     | SDIV  | R     | 4D6 / 02               | R[Rd] = R[Rn] / R[Rm]            |        |
| Signed MULtiply High              | SMULH | R     | 4DA                    | R[Rd] = (R[Rn] * R[Rm]) (127:64) |        |
| STore Single floating-point       | STURS | R     | 7E2                    | M[R[Rn] + DTAddr] = S[Rt]        | (5)    |
| STore Double floating-point       | STURD | R     | 7E0                    | M[R[Rn] + DTAddr] = D[Rt]        | (5)    |
| Unsigned DIVide                   | UDIV  | R     | 4D6 / 03               | R[Rd] = R[Rn] / R[Rm]            | (8)    |
| Unsigned MULtiply High            | UMULH | R     | 4DE                    | R[Rd] = (R[Rn] * R[Rm]) (127:64) | (8)    |

| R     | opcode   |       | R  | m     | shamt    |        | Rn |     | Rd |   |
|-------|----------|-------|----|-------|----------|--------|----|-----|----|---|
|       | 31       | 21    | 20 | 16    | 15       | 10     | 9  | 5 4 |    | 0 |
| I     | opcode   |       | Α  | LU_ir | nmediate |        | Rn |     | Rd |   |
|       | 31       | 22 21 |    |       |          | 10     | 9  | 5 4 |    | 0 |
| D     | opcode   |       |    | DT_ac | ldress   | op     | Rn |     | Rt |   |
|       | 31       | 21    | 20 |       | 12       | 11 10  | 9  | 5 4 |    | 0 |
| В     | opcode   |       |    |       | BR_ad    | ldress |    |     |    |   |
|       | 31 26 25 |       |    |       |          |        |    |     |    | 0 |
| CB    | Opcode   |       |    | COND  | BR_addre | SS     |    |     | Rt |   |
|       | 31 24 23 |       |    |       |          |        |    | 5 4 |    | 0 |
| IW    | opcode   |       |    |       | MOV imn  | nediat | e  |     | Rd |   |
| 1 *** |          |       |    |       |          |        |    |     |    |   |

| PSEUDOINSTRUCTION SET |          |                        |
|-----------------------|----------|------------------------|
| NAME                  | MNEMONIC | OPERATION              |
| CoMPare               | CMP      | FLAGS = R[Rn] - R[Rm]  |
| CoMPare Immediate     | CMPI     | FLAGS = R[Rn] - ALUImm |
| LoaD Address          | LDA      | R[Rd] = R[Rn] + DTAddr |
| MOVe                  | MOV      | R[Rd] = R[Rn]          |

### REGISTER NAME, NUMBER, USE, CALL CONVENTION

| NAME      | NUMBER | USE                                                                                       | PRESERVED      |
|-----------|--------|-------------------------------------------------------------------------------------------|----------------|
| NAME      |        |                                                                                           | ACROSS A CALLS |
| X0 - X7   | 0-7    | Arguments / Results                                                                       | No             |
| X8        | 8      | Indirect result location register                                                         | No             |
| X9 - X15  | 9-15   | Temporaries                                                                               | No             |
| X16 (IP0) | 16     | May be used by linker as a<br>scratch register; other times<br>used as temporary register | No             |
| X17 (IP1) | 17     | May be used by linker as a<br>scratch register; other times<br>used as temporary register | No             |
| X18       | 18     | Platform register for platform<br>independent code; otherwise a<br>temporary register     | No             |
| X19-X27   | 19-27  | Saved                                                                                     | Yes            |
| X28 (SP)  | 28     | Stack Pointer                                                                             | Yes            |
| X29 (FP)  | 29     | Frame Pointer                                                                             | Yes            |
| X30 (LR)  | 30     | Return Address                                                                            | Yes            |
| XZR       | 31     | The Constant Value 0                                                                      | N.A.           |

4

0

### OPCODES IN NUMERICAL ORDER BY OPCODE

| OPCODES:    | IN NUMI | ERICAL ORI   | DER BY OPCO  | DE     |               |     |  |
|-------------|---------|--------------|--------------|--------|---------------|-----|--|
|             |         |              |              |        | 11-bit Opcode |     |  |
| Instruc     |         |              | code         | Shamt  | Range         |     |  |
| Mnemonic    | Format  | Width (bits) | Binary       | Binary | Start (Hex) I |     |  |
| В           | В       | 6            | 000101       |        | 0A0           | 0BF |  |
| FMULS       | R       | 11           | 00011110001  | 000010 | 0F1           |     |  |
| FDIVS       | R       | 11           | 00011110001  | 000110 | 0F1           |     |  |
| FCMPS       | R       | 11           | 00011110001  | 001000 | 0F1           |     |  |
| FADDS       | R       | 11           | 00011110001  | 001010 | 0F1           |     |  |
| FSUBS       | R       | 11           | 00011110001  | 001110 | 0F1           |     |  |
| FMULD       | R       | 11           | 00011110011  | 000010 | 0F3           |     |  |
| FDIVD       | R       | 11           | 00011110011  | 000110 | 0F3           |     |  |
| FCMPD       | R       | 11           | 00011110011  | 001000 | 0F3           |     |  |
| FADDD       | R       | 11           | 00011110011  | 001010 | 0F3           |     |  |
| FSUBD       | R       | 11           | 00011110011  | 001110 | 0F3           |     |  |
| STURB       | D       | 11           | 00111000000  |        | 1C0           | 1   |  |
| LDURB       | D       | 11           | 00111000010  |        | 1C2           |     |  |
| B.cond      | CB      | 8            | 01010100     |        | 2A0           | 2A7 |  |
| STURH       | D       | 11           | 01111000000  |        | 3C0           |     |  |
| LDURH       | D       | 11           | 01111000010  |        | 3C2           |     |  |
| AND         | R       | 11           | 10001010000  |        | 450           |     |  |
| ADD         | R       | 11           | 10001011000  |        | 458           |     |  |
| ADDI        | I       | 10           | 1001000100   |        | 488           | 489 |  |
| ANDI        | I       | 10           | 1001001000   |        | 490           | 491 |  |
| BL          | В       | 6            | 100101       |        | 4A0           | 4BF |  |
| SDIV        | R       | 11           | 100101       | 000010 | 4D6           |     |  |
| UDIV        | R       | 11           | 10011010110  | 000011 | 4D6           |     |  |
| MUL         | R       | 11           | 10011010110  | 011111 | 4D8           |     |  |
| SMULH       | R       | 11           | 10011011010  | 011111 | 4DA           |     |  |
| UMULH       | R       | 11           | 10011011010  |        | 4DF           |     |  |
|             | R       | 11           | 101010101000 |        | 550           | ·   |  |
| ORR<br>ADDS | R       | 11           | 10101010000  |        | 558           |     |  |
|             | I       | 10           | 10101011000  |        | 588           | 589 |  |
| ADDIS       |         | 10           | 1011000100   |        | 590           | 591 |  |
| ORRI        | CB      |              |              |        |               |     |  |
| CBZ         |         | 8            | 10110100     |        | 5A0           | 5A7 |  |
| CBNZ        | CB      |              | 10110101     |        | 5A8           | 5AF |  |
| STURW       | D       | 11           | 101111000000 |        | 5C0           |     |  |
| LDURSW      | D       | 11           | 10111000100  |        | 5C4           |     |  |
| STURS       | R       | 11           | 101111100000 |        | 5E0           |     |  |
| LDURS       | R       | 11           | 101111100010 |        | 5E2           |     |  |
| STXR        | D       | 11           | 11001000000  |        | 640           |     |  |
| LDXR        | D       | 11           | 11001000010  |        | 642           |     |  |
| EOR         | R       | 11           | 11001010000  |        | 650           |     |  |
| SUB         | R       | 11           | 11001011000  |        | 658           |     |  |
| SUBI        | I       | 10           | 1101000100   |        | 688           | 689 |  |
| EORI        | I       | 10           | 1101001000   |        | 690           | 691 |  |
| MOVZ        | IM      | 9            | 110100101    |        | 694           | 697 |  |
| LSR         | R       | 11           | 11010011010  |        | 69A           |     |  |
| LSL         | R       | 11           | 11010011011  |        | 69B           |     |  |
| BR          | R       | 11           | 11010110000  |        | 6B0           |     |  |
| ANDS        | R       | 11           | 11101010000  |        | 750           |     |  |
| SUBS        | R       | 11           | 11101011000  |        | 758           |     |  |
| SUBIS       | I       | 10           | 1111000100   |        | 788           | 789 |  |
| ANDIS       | Ī       | 10           | 1111001000   |        | 790           | 791 |  |
| MOVK        | IM      | 9            | 111100101    |        | 794           | 797 |  |
| STUR        | D       | 11           | 11111000000  |        | 7C0           |     |  |
| LDUR        | D       | 11           | 11111000000  |        | 7C2           |     |  |
| STURD       | R       | 11           | 111111000010 |        | 7E2           |     |  |
| LDURD       | R       | 11           | 11111100000  |        | 7E0           |     |  |
| משטחת       | ı.      | 1.1          | 11111100010  |        | /E2           |     |  |

(1) Since I, B, and CB instruction formats have opcodes narrower than 11 bits, they occupy a range of 11-bit opcodes, e.g., the 6-bit B format occupies 32 (2<sup>5</sup>) 11-bit opcodes.

# IEEE 754 FLOATING-POINT STANDARD

62

3

IEEE 754 Symbols Object Exponent Fraction  $(-1)^s \times (1 + Fraction) \times 2^{(Exponent - Bias)}$ 0  $\pm 0$ where Single Precision Bias = 127,  $\neq 0$ ± Denorm Double Precision Bias = 1023 1 to MAX - 1 anything ± F1. Pt. Num. MAX 0

52 51



### DATA ALIGNMENT

|   | Double Word |      |          |      |          |      |          |      |
|---|-------------|------|----------|------|----------|------|----------|------|
| Г | Word        |      |          |      | Word     |      |          |      |
|   | Halfword    |      | Halfword |      | Halfword |      | Halfword |      |
| Γ | Byte        | Byte | Byte     | Byte | Byte     | Byte | Byte     | Byte |
| ( | )           | 1    | 2        | 3    | 4        | 5    | 6        | 7    |

Value of three least significant bits of byte address (Big Endian)

## EXCEPTION SYNDROME REGISTER (ESR)

| DIRCEI LIGHT            | TINDICONIE I               | REGISTER (ESR)                            |   |
|-------------------------|----------------------------|-------------------------------------------|---|
| Exception<br>Class (EC) | Instruction<br>Length (IL) | Instruction Specific Syndrome field (ISS) |   |
| 31 26                   | 25                         | 24                                        | 0 |

# EXCEPTION CLASS

| Εž | EXCEPTION CLASS |         |                               |        |      |                              |  |  |  |  |
|----|-----------------|---------|-------------------------------|--------|------|------------------------------|--|--|--|--|
|    | EC              | Class   | Cause of Exception            | Number | Name | Cause of Exception           |  |  |  |  |
|    | 0               | Unknown | Unknown                       | 34     | PC   | Misaligned PC<br>exception   |  |  |  |  |
|    | 7               | SIMD    | SIMD/FP registers<br>disabled | 36     | Data | Data Abort                   |  |  |  |  |
|    | 14              | FPE     | Illegal Execution<br>State    | 40     | FPE  | Floating-point exception     |  |  |  |  |
|    | 17              | Sys     | Supervisor Call<br>Exception  | 52     | WPT  | Data Breakpoint<br>exception |  |  |  |  |
|    | 32              | Instr   | Instruction Abort             | 56     | BKPT | SW Breakpoint<br>Exception   |  |  |  |  |

### SIZE PREFIXES AND SYMBOLS

| 1. | ZE PKEFI         | ALS AND S | IMBULS |                 |        |        |
|----|------------------|-----------|--------|-----------------|--------|--------|
|    | SIZE             | PREFIX    | SYMBOL | SIZE            | PREFIX | SYMBOL |
|    | $10^{3}$         | Kilo-     | K      | 210             | Kibi-  | Ki     |
|    | $10^{6}$         | Mega-     | M      | 2 <sup>20</sup> | Mebi-  | Mi     |
|    | 10 <sup>9</sup>  | Giga-     | G      | 230             | Gibi-  | Gi     |
|    | 10 <sup>12</sup> | Tera-     | T      | 2 <sup>40</sup> | Tebi-  | Ti     |
|    | 10 <sup>15</sup> | Peta-     | P      | 250             | Pebi-  | Pi     |
|    | 10 <sup>18</sup> | Exa-      | Е      | 260             | Exbi-  | Ei     |
|    | $10^{21}$        | Zetta-    | Z      | 2 <sup>70</sup> | Zebi-  | Zi     |
|    | $10^{24}$        | Yotta-    | Y      | 280             | Yobi-  | Yi     |
|    | 10 <sup>-3</sup> | milli-    | m      | 10-15           | femto- | f      |
|    | 10 <sup>-6</sup> | micro-    | μ      | 10-18           | atto-  | a      |
|    | 10 <sup>-9</sup> | nano-     | n      | 10-21           | zepto- | z      |
|    | 10-12            | nico-     | n      | 10-24           | vocto- | v      |