

## ARM Assembly Cheat Sheet

Registers (cont) LR -

Link

Register

R14

by Syshella via cheatography.com/128892/cs/26951/

When a function call is

made, LR gets pdated

with a memory address

referencing the next

## Code Layout

.data

@variables

.text

.global main

@code

## @ - Comments

| Data Types |          |            |
|------------|----------|------------|
| Туре       | Mnemonic | Bytes size |
| Word       |          | 4          |
| Half word  | h        | 2          |
| Byte       | b        | 1          |

| Registers      |                          |                                                                                                                                   |
|----------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| #              | Purpose                  | Description                                                                                                                       |
| R0<br>-<br>R12 | General<br>Purpose       | Stores temporary values, pointers                                                                                                 |
| R13            | SP -<br>Stack<br>Pointer | Top of the stack. Allocate space to the stack by substracting the value in bytes that we want to allocate from the stack pointer. |

|        |                            | instruction where the function was initiated from                 |
|--------|----------------------------|-------------------------------------------------------------------|
| R15    | PC -<br>Program<br>Counter | Automatically incremented by the size of the instruction executed |
| CPSR   | - Current P                | rogram Status Register                                            |
| Flag   | Meaning                    | Enable if result of the                                           |
|        |                            | instruction yields a                                              |
| N      | Negative                   | instruction yields a Negative number                              |
| N<br>Z | Negative<br>Zero           |                                                                   |
|        |                            | Negative number                                                   |

|            |                | represented                                                 |
|------------|----------------|-------------------------------------------------------------|
| V          | Overflow       | Value that cannot be represented in 32 bit two's complement |
|            |                |                                                             |
| Flexi      | ble operand    |                                                             |
| #123       | Inmedi         | ate value                                                   |
| Rx         | Registe        | er x                                                        |
| Rx,<br>LSL | J              | er x with logical shift left<br>ts                          |
|            |                |                                                             |
| Dbl:       | - h - d 104h M | arab 2024                                                   |

MNEMONIC(S){condition} {Rd}, Operand1, Operand2 **Mnemonics MNEMONIC** Description An optional suffix. If S is {S} specified, the condition flags are updated on the result of the operation {condition} Condition that is needed to be met in order for the instruction to be executed {Rd} Register destination for storing the result of the instruction Operand1 First operand. Either a register or an inmediate value Operand2 Second (flexible) operand. Either an inmediate value (number) or a register with an optional shift {} - Optional

Flexible operand (cont)

by n bits

Register x with logical shift right

Rx,

LSR n

Syntax



By Syshella cheatography.com/syshella/ Published 10th March, 2021. Last updated 10th March, 2021. Page 1 of 2.

Sponsored by CrosswordCheats.com Learn to solve cryptic crosswords! http://crosswordcheats.com



## ARM Assembly Cheat Sheet

by Syshella via cheatography.com/128892/cs/26951/

| Common Instructions |                               |  |
|---------------------|-------------------------------|--|
| Instru-<br>ction    | Description                   |  |
| MOV                 | Move data                     |  |
| MVN                 | Move and negate               |  |
| ADD                 | Addition                      |  |
| SUB                 | Substraction                  |  |
| MUL                 | Multiplication                |  |
| LSL                 | Logical Shift Left            |  |
| LSR                 | Logical Shift Right           |  |
| ASR                 | Arithmetic Shift Right        |  |
| CMP                 | Compare                       |  |
| CMN                 | Compare and negate            |  |
| AND                 | Bitwise AND                   |  |
| ORR                 | Bitwise OR                    |  |
| EOR                 | Bitwise XOR                   |  |
| LDR                 | Load                          |  |
| STR                 | Store                         |  |
| LDM                 | Load Multiple                 |  |
| STM                 | Store Multiple                |  |
| В                   | Branch                        |  |
| BL                  | Branch with Link              |  |
| ВХ                  | Branch and eXchange           |  |
| BLX                 | Branch with Link and eXchange |  |
| BIC                 | Bit Clear                     |  |

| Address modes                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset                                                                                                                                                                                                                                                                                                                              |
| str r2, [r1, #2] Store the value found in R2 to the memory address found in R1 plus 2. Base register unmodified.                                                                                                                                                                                                                    |
| Pre-indexed                                                                                                                                                                                                                                                                                                                         |
| str r2, [r1, #4]!  Store the value found in R2 to the memory address found in R1 plus 4.  Base register (R1) modified: R1= R1+4                                                                                                                                                                                                     |
| Post-indexed                                                                                                                                                                                                                                                                                                                        |
| ldr r3, [r1], r2, LSL#2  Load the value at memory address found in R1 to the register R3. Then modify base register: R1 = R1+R2<<2                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                     |
| Syntax:                                                                                                                                                                                                                                                                                                                             |
| 1 3                                                                                                                                                                                                                                                                                                                                 |
| Syntax:                                                                                                                                                                                                                                                                                                                             |
| Syntax: STR Ra, [Rb, imm]                                                                                                                                                                                                                                                                                                           |
| Syntax: STR Ra, [Rb, imm] LDR Ra, [Rc, imm]                                                                                                                                                                                                                                                                                         |
| Syntax:  STR Ra, [Rb, imm]  LDR Ra, [Rc, imm]  If there is a !, its prefix address mode                                                                                                                                                                                                                                             |
| Syntax:  STR Ra, [Rb, imm]  LDR Ra, [Rc, imm]  If there is a!, its prefix address mode  ldr r3, [r1, #4]!                                                                                                                                                                                                                           |
| Syntax:  STR Ra, [Rb, imm]  LDR Ra, [Rc, imm]  If there is a!, its prefix address mode  ldr r3, [r1, #4]!  ldr r3, [r1, r2]!                                                                                                                                                                                                        |
| Syntax:  STR Ra, [Rb, imm]  LDR Ra, [Rc, imm]  If there is a!, its prefix address mode  ldr r3, [r1, #4]!  ldr r3, [r1, r2]!  ldr r3, [r1, r2, LSL#2]!                                                                                                                                                                              |
| Syntax:  STR Ra, [Rb, imm]  LDR Ra, [Rc, imm]  If there is a !, its prefix address mode  ldr r3, [r1, #4]!  ldr r3, [r1, r2]!  ldr r3, [r1, r2, LSL#2]!  If the base register is in brackets by itself,                                                                                                                             |
| Syntax:  STR Ra, [Rb, imm]  LDR Ra, [Rc, imm]  If there is a !, its prefix address mode  ldr r3, [r1, #4]!  ldr r3, [r1, r2]!  ldr r3, [r1, r2, LSL#2]!  If the base register is in brackets by itself, it's postfix address mode                                                                                                   |
| Syntax:  STR Ra, [Rb, imm]  LDR Ra, [Rc, imm]  If there is a !, its prefix address mode  ldr r3, [r1, #4]!  ldr r3, [r1, r2]!  ldr r3, [r1, r2, LSL#2]!  If the base register is in brackets by itself, it's postfix address mode  ldr r3, [r1], #4                                                                                 |
| Syntax:  STR Ra, [Rb, imm]  LDR Ra, [Rc, imm]  If there is a !, its prefix address mode  ldr r3, [r1, #4]!  ldr r3, [r1, r2]!  ldr r3, [r1, r2, LSL#2]!  If the base register is in brackets by itself, it's postfix address mode  ldr r3, [r1], #4  ldr r3, [r1], r2                                                               |
| Syntax:  STR Ra, [Rb, imm]  LDR Ra, [Rc, imm]  If there is a !, its prefix address mode  ldr r3, [r1, #4]!  ldr r3, [r1, r2]!  ldr r3, [r1, r2, LSL#2]!  If the base register is in brackets by itself, it's postfix address mode  ldr r3, [r1], #4  ldr r3, [r1], r2  ldr r3, [r1], r2, LSL#2                                      |
| Syntax:  STR Ra, [Rb, imm]  LDR Ra, [Rc, imm]  If there is a !, its prefix address mode  ldr r3, [r1, #4]!  ldr r3, [r1, r2]!  ldr r3, [r1, r2, LSL#2]!  If the base register is in brackets by itself, it's postfix address mode  ldr r3, [r1], #4  ldr r3, [r1], r2  ldr r3, [r1], r2, LSL#2  Anything else, offset address mode: |

| Conditionals                                                |                          |               |
|-------------------------------------------------------------|--------------------------|---------------|
| Mnemonic                                                    | Description              | Flags         |
| EQ                                                          | Equals                   | Z=1           |
| NE                                                          | Non equals               | Z=0           |
| HI                                                          | Higher than (NS)         | C=1 &<br>Z=0  |
| LS                                                          | Less than (NS)           | C=0  <br>Z=1  |
| GE                                                          | Greater or equals (WS)   | N=V           |
| LT                                                          | Less than (WS)           | N!=V          |
| GT                                                          | Greater than (WS)        | Z=0 &<br>N=V  |
| LE                                                          | Less or equals than (WS) | Z=1  <br>N!=V |
| (empty)                                                     | Always (non condition    | onal)         |
| NS - No sign<br>WS - With sign                              |                          |               |
| Most of intructions can be executed using conditionals. le: |                          |               |



By Syshella

cheatography.com/syshella/

Published 10th March, 2021. Last updated 10th March, 2021. Page 2 of 2. Sponsored by CrosswordCheats.com Learn to solve cryptic crosswords! http://crosswordcheats.com

`movle r2, r1