

## The ARM Instruction Set



## **Processor Modes**

- \* The ARM has six operating modes:
  - *User* (unprivileged mode under which most tasks run)
  - FIQ (entered when a high priority (fast) interrupt is raised)
  - IRQ (entered when a low priority (normal) interrupt is raised)
  - *Supervisor* (entered on reset and when a Software Interrupt instruction is executed)
  - *Abort* (used to handle memory access violations)
  - *Undef* (used to handle undefined instructions)
- \* ARM Architecture Version 4 adds a seventh mode:
  - System (privileged mode using the same registers as user mode)



# The Registers

- \* ARM has 37 registers in total, all of which are 32-bits long.
  - 1 dedicated program counter
  - 1 dedicated current program status register
  - 5 dedicated saved program status registers
  - 30 general purpose registers
- \* However these are arranged into several banks, with the accessible bank being governed by the processor mode. Each mode can access
  - a particular set of r0-r12 registers
  - a particular r13 (the stack pointer) and r14 (link register)
  - r15 (the program counter)
  - cpsr (the current program status register)

### and privileged modes can also access

• a particular spsr (saved program status register)



# **Register Organisation**

#### **General registers and Program Counter**

| User32 / System | FIQ32    | Supervisor32 | Abort32  | IRQ32    | Undefined32 |
|-----------------|----------|--------------|----------|----------|-------------|
| r0              | r0       | r0           | r0       | r0       | r0          |
| r1              | r1       | r1           | r1       | r1       | r1          |
| r2              | r2       | r2           | r2       | r2       | r2          |
| r3              | r3       | r3           | r3       | r3       | r3          |
| r4              | r4       | r4           | r4       | r4       | r4          |
| r5              | r5       | r5           | r5       | r5       | r5          |
| r6              | r6       | r6           | r6       | r6       | r6          |
| r7              | r7       | r7           | r7       | r7       | r7          |
| r8              | r8_fiq   | r8           | r8       | r8       | r8          |
| r9              | r9_fiq   | r9           | r9       | r9       | r9          |
| r10             | r10_fiq  | r10          | r10      | r10      | r10         |
| r11             | r11_fiq  | r11          | r11      | r11      | r11         |
| r12             | r12_fiq  | r12          | r12      | r12      | r12         |
| r13 (sp)        | r13_fiq  | r13_svc      | r13_abt  | r13_irq  | r13_undef   |
| r14 (lr)        | r14_fiq  | r14_svc      | r14_abt  | r14_irq  | r14_undef   |
| r15 (pc)        | r15 (pc) | r15 (pc)     | r15 (pc) | r15 (pc) | r15 (pc)    |

### **Program Status Registers**

cpsr

cpsr spsr\_fiq cpsr spsr\_svc cpsr spsr\_abt

cpsr spsr\_irq cpsr spsr\_undef