ARM r1p3 Computer Hardware User Manual


 
Programmer’s Model
ARM DDI 0363E Copyright © 2009 ARM Limited. All rights reserved. 2-3
ID013010 Non-Confidential, Unrestricted Access
2.2 Instruction set states
The processor has two instruction set states:
ARM state The processor executes 32-bit, word-aligned ARM instructions in this
state.
Thumb state The processor executes 32-bit and 16-bit halfword-aligned Thumb
instructions in this state.
Note
Transition between ARM state and Thumb state does not affect the processor mode or the
register contents.
2.2.1 Switching state
The instruction set state of the processor can be switched between ARM state and Thumb state:
Using the
BX
and
BLX
instructions, by a load to the PC, or with a data-processing instruction
that does not set flags, with the PC as the destination register. Switching state is described
in the ARM Architecture Reference Manual.
Note
When the
BXJ
instruction is used the processor invokes the
BX
instruction.
Automatically on an exception. You can write an exception handler routine in ARM or
Thumb code. For more information, see Exceptions on page 2-16.
2.2.2 Interworking ARM and Thumb state
The processor enables you to mix ARM and Thumb code. For more information about
interworking ARM and Thumb, see the RealView Compilation Tools Developer Guide.