AArch64
It was first introduced with the Armv8-A architecture. ARMv8-A represents a fundamental change to the ARM architecture. It adds an optional 64-bit architecture, named AArch64, and the associated new A64 instruction set.
Registers
The architecture provides 31 general purpose registers. Each register can be used as a 64-bit X
register, or as a 32-bit W
register.
When a w
register is written, the top 32 bits of the 64-bit register are zeroed.
- The zero registers,
xzr
andwzr
, always read as 0 and ignore writes. - You can use the stack pointer (
sp
) as the base address for loads and stores. - The Program Counter (
pc
) is not a general-purpose register in A64.
Register(s) | Size | Description |
---|---|---|
Rn |
64 | General register (0-30 ) |
Xn |
64 | General register (0-30 ) |
Wn |
32 | General register (0-30 ) |
XZR |
64 | Zero register |
WZR |
32 | Zero register |
SP |
64 | Stack register |
PC |
64 | Program counter; incremented by four bytes |
There is a separate set of 32 registers (v0-v31
) used for floating point and vector operations. These registers are 128-bit, and like the general-purpose registers, can be accessed in several ways. When the V
form is used, the register is treated as being a vector.
Register(s) | Size | Description |
---|---|---|
Vx |
128 | |
Qx |
128 | |
Dx |
64 | |
Sx |
32 | |
Hx |
16 | |
Bx |
8 |
Procedure Call Standard
- The first seven argments are passed into the
X
registers, with any further arguments are passed on the stack. - In C++,
X0
is used to pass the implicit this pointer that points to the called function.
Register(s) | Significance | Description |
---|---|---|
R0-R7 |
Parameter and result | |
R8 |
XR |
Indirect result |
R9-R15 |
Corruptible | |
R16 |
IP0 |
Intra-procedure-call corruptible |
R17 |
IP1 |
Intra-procedure-call corruptible |
R18 |
PR |
Platform |
R19-R23 |
Callee-saved | |
R24-R28 |
Callee-saved | |
R29 |
FP |
Frame |
R30 |
LR |
Link |
In Arch64 state, the PC is not a general purpose register and you cannot access it explicitly. The following types of instructions read it implicitly:
- Instructions that compute a PC-relative address.
- PC-relative literal loads.
- Direct branches to a PC-relative label.
- Branch and link instructions, which store it in the procedure link register.
The only types of instructions that can write to the PC are:
- Conditional and unconditional branches.
- Exception generation and exception returns.
System Calls
There are special instructions for making such system calls. These instructions cause an exception, which allows controlled entry into a more privileged Exception level.
SVC
Supervisor call - Causes an exception targetingEL1
.HVC
Hypervisor call - Causes an exception targetingEL2
.SMC
Secure monitor call - Causes an exception targetingEL3
.
Linux
Windows
Branch
Instruction | Description |
---|---|
B |
An unconditional branch to a label. |
B.cc |
A conditionally branch. (see condition code suffixes) |
BL |
Branch with Link to a PC-relative offset, setting the register X30 to PC+4 . |
BLR |
Branch with Link to Register calls a subroutine at an address in a register, setting register X30 to PC+4 . |
BR |
Branch to Register branches unconditionally to an address in a register. |
BLRAA , BLRAAZ , BLRAB , BLRABZ |
|
BRAA , BRAAZ , BRAB , BRABZ |
Condition code suffixes
Instructions that can be conditional have an optional two character condition code suffix.
Suffix | Description | Identical to |
---|---|---|
EQ |
Equal | |
NE |
Not equal | |
CS |
Carry set | HS |
HS |
Unsigned higher or same | CS |
CC |
Carry clear | LO |
LO |
Unsigned lower | CC |
MI |
Minus or negative result | |
PL |
Positive or zero result | |
VS |
Overflow | |
VC |
No overflow | |
HI |
Unsigned higher | |
LS |
Unsigned lower or same | |
GE |
Signed greater than or equal | |
LT |
Signed less than | |
GT |
Signed greater than | |
LE |
Signed less than or equal | |
AL |
Always (default) |