[PDF] [PDF] ARM® and Thumb®-2 Instruction Set Quick Reference Card

ARM® and Thumb®-2 Instruction Set Quick Reference Card Key to Tables Rm { , } See Table Register, optionally shifted by constant



Previous PDF Next PDF





[PDF] ARM® Instruction Set Quick Reference Card - Cs Wisc

ARM® Instruction Set Quick Reference Card Key to Tables {endianness} Can be BE (Big Endian) or LE (Little Endian) {cond} Refer to Table Condition Field



[PDF] ARM Architecture Reference Manual

The purpose of this manual is to describe the ARM instruction set architecture, including its high code density Thumb subset, and two of its standard coprocessor 



[PDF] ARM Architecture Reference Manual - Intel

The purpose of this manual is to describe the ARM instruction set architecture, including its high code density Thumb subset, and two of its standard coprocessor 



[PDF] ARM® and Thumb®-2 Instruction Set Quick Reference Card

ARM® and Thumb®-2 Instruction Set Quick Reference Card Key to Tables Rm { , } See Table Register, optionally shifted by constant



[PDF] ARM Instruction Set

The various conditions are defined Table 4-2: Condition code summary on page 4-5 The instruction encoding is shown in Figure 4-3: Branch instructions, below



[PDF] ARM7TDMI Instruction Set Reference

The Thumb instruction set is a subset of the ARM instruction set, and is intended to permit a higher code density (smaller memory requirement) than the ARM 



[PDF] ARM® Instruction Set Quick Reference Card

ARM® Instruction Set Refer to Table Addressing Mode 4 (Block load or Stack pop) {S} Updates Refer to Table ARM architecture versions



[PDF] ARMv7-M Architecture Reference Manual

Thumb instruction set encoding A5-2 A5 2 16-bit Thumb instruction encoding Encoding of modified immediates in Thumb data-processing instructions



[PDF] ARM Instruction Set Quick Reference Card

ARM Instruction Set Quick Reference Flag is unpredictable after these instructions in Architecture v4 and earlier Refer to Table ARM architecture versions

[PDF] arm instruction set tutorial

[PDF] arm opcodes hex

[PDF] arm opcodes reference

[PDF] arm programming tutorial pdf

[PDF] arm thumb opcodes

[PDF] arm7 assembly language programming 100+ examples

[PDF] armed forces service medal

[PDF] armed response companies in johannesburg cbd

[PDF] armed response companies in pretoria west

[PDF] armoury crate service download

[PDF] arms alms in a sentence

[PDF] arms and alms in one sentence

[PDF] arms and alms in same sentence

[PDF] arms and equipment guide 35 e pdf download

[PDF] arms/alms homophones

ARM and Thumb -2 Instruction Set

Quick Reference Card

Key to Tables

Rm {, }See Table Register, optionally shifted by constant

See Table Flexible Operand 2. Shift and rotate are only available as part of Operand2.A comma-separated list of registers, enclosed in braces { and }.

See Table PSR fields.As , must not include the PC.

Either CPSR (Current Processor Status Register) or SPSR (Saved Processor Status Register)As , including the PC.

C*, V*Flag is unpredictable in Architecture v4 and earlier, unchanged in Architecture v5 and later.+/-+ or -. (+ may be omitted.)

Can be Rs or an immediate shift value. The values allowed for each shift type are the same as those § See Table ARM architecture versions.

shown in Table Register, optionally shifted by constant.Interrupt flags. One or more of a, i, f (abort, interrupt, fast interrupt).

x,yB meaning half-register [15:0], or T meaning [31:16].See Table Processor Modes

ARM: a 32-bit constant, formed by right-rotating an 8-bit value by an even number of bits.SPmSP for the processor mode specified by

Thumb: a 32-bit constant, formed by left-shifting an 8-bit value by any number of bits, or a bitLeast significant bit of bitfield.

pattern of one of the forms 0xXYXYXYXY, 0x00XY00XY or 0xXY00XY00.Width of bitfield. + must be <= 32.

See Table Prefixes for Parallel instructions{X}RsX is Rs rotated 16 bits if X present. Otherwise, RsX is Rs.

{IA|IB|DA|DB}Increment After, Increment Before, Decrement After, or Decrement Before. {!}Updates base register after data transfer if ! present (pre-indexed).

IB and DA are not available in Thumb state. If omitted, defaults to IA.{S}Updates condition flags if S present.

B, SB, H, or SH, meaning Byte, Signed Byte, Halfword, and Signed Halfword respectively.{T}User mode privilege if T present.

SB and SH are not available in STR instructions.{R}Rounds result to nearest if R present, otherwise truncates result.

Operation § Assembler S updates Action Notes

AddAddADD{S} Rd, Rn, N Z C V Rd := Rn + Operand2 N with carryADC{S} Rd, Rn, N Z C V Rd := Rn + Operand2 + Carry N wide T2ADD Rd, Rn, #Rd := Rn + imm12, imm12 range 0-4095 T, P saturating {doubled} 5EQ{D}ADD Rd, Rm, RnRd := SAT(Rm + Rn) doubled: Rd := SAT(Rm + SAT(Rn * 2)) Q

AddressForm PC-relative addressADR Rd,

SubtractSubtractSUB{S} Rd, Rn, N Z C V Rd := Rn - Operand2 N with carrySBC{S} Rd, Rn, N Z C V Rd := Rn - Operand2 - NOT(Carry) N wide T2SUB Rd, Rn, #N Z C V Rd := Rn - imm12, imm12 range 0-4095 T, P reverse subtractRSB{S} Rd, Rn, N Z C V Rd := Operand2 - Rn N reverse subtract with carryRSC{S} Rd, Rn, N Z C V Rd := Operand2 - Rn - NOT(Carry) A saturating {doubled} 5EQ{D}SUB Rd, Rm, RnRd := SAT(Rm - Rn) doubled: Rd := SAT(Rm - SAT(Rn * 2)) Q

Exception return without stackSUBS PC, LR, #PC = LR - imm8, CPSR = SPSR(current mode), imm8 range 0-255. T

Parallel

arithmeticHalfword-wise addition 6ADD16 Rd, Rn, RmRd[31:16] := Rn[31:16] + Rm[31:16], Rd[15:0] := Rn[15:0] + Rm[15:0] G

Halfword-wise subtraction 6SUB16 Rd, Rn, RmRd[31:16] := Rn[31:16] - Rm[31:16], Rd[15:0] := Rn[15:0] - Rm[15:0] G

B y te w is e a d d iti on

6ADD8 Rd, Rn, RmRd[31:24] := Rn[31:24] + Rm[31:24], Rd[23:16] := Rn[23:16] + Rm[23:16],

Rd[15:8] := Rn[15:8] + Rm[15:8], Rd[7:0] := Rn[7:0] + Rm[7:0]G

Byte-wise subtraction 6SUB8 Rd, Rn, RmRd[31:24] := Rn[31:24] - Rm[31:24], Rd[23:16] := Rn[23:16] - Rm[23:16],

Rd[15:8] := Rn[15:8] - Rm[15:8], Rd[7:0] := Rn[7:0] - Rm[7:0]G

Halfword-wise exchange, add, subtract 6ASX Rd, Rn, RmRd[31:16] := Rn[31:16] + Rm[15:0], Rd[15:0] := Rn[15:0] - Rm[31:16] G

Halfword-wise exchange, subtract, add 6SAX Rd, Rn, RmRd[31:16] := Rn[31:16] - Rm[15:0], Rd[15:0] := Rn[15:0] + Rm[31:16] G

Unsigned sum of absolute differences 6USAD8 Rd, Rm, RsRd := Abs(Rm[31:24] - Rs[31:24]) + Abs(Rm[23:16] - Rs[23:16])+ Abs(Rm[15:8] - Rs[15:8]) + Abs(Rm[7:0] - Rs[7:0])

and accumulate 6USADA8 Rd, Rm, Rs, RnRd := Rn + Abs(Rm[31:24] - Rs[31:24]) + Abs(Rm[23:16] - Rs[23:16])+ Abs(Rm[15:8] - Rs[15:8]) + Abs(Rm[7:0] - Rs[7:0])

SaturateSigned saturate word, right shift 6SSAT Rd, #, Rm{, ASR }Rd := SignedSat((Rm ASR sh), sat). range 1-32, range 1-31. Q, R

Signed saturate word, left shift 6SSAT Rd, #, Rm{, LSL }Rd := SignedSat((Rm LSL sh), sat). range 1-32, range 0-31. Q

Signed saturate two halfwords 6SSAT16 Rd, #, RmRd[31:16] := SignedSat(Rm[31:16], sat), Rd[15:0] := SignedSat(Rm[15:0], sat). range 1-16.Q

Unsigned saturate word, right shift 6USAT Rd, #, Rm{, ASR }Rd := UnsignedSat((Rm ASR sh), sat).

range 0-31, range 1-31. Q, R

Unsigned saturate word, left shift 6USAT Rd, #, Rm{, LSL }Rd := UnsignedSat((Rm LSL sh), sat). range 0-31, range 0-31. Q

Unsigned saturate two halfwords 6USAT16 Rd, #, RmRd[31:16] := UnsignedSat(Rm[31:16], sat), Rd[15:0] := UnsignedSat(Rm[15:0], sat). range 0-15.Q

ARM and Thumb-2 Instruction Set

Quick Reference Card

Operation § Assembler S updates Action Notes

MultiplyMultiplyMUL{S} Rd, Rm, RsN Z C* Rd := (Rm * Rs)[31:0] (If Rm is Rd, S can be used in Thumb-2) N, S

and accumulateMLA{S} Rd, Rm, Rs, RnN Z C* Rd := (Rn + (Rm * Rs))[31:0] S and subtract T2MLS Rd, Rm, Rs, RnRd := (Rn - (Rm * Rs))[31:0] unsigned longUMULL{S} RdLo, RdHi, Rm, RsN Z C* V* RdHi,RdLo := unsigned(Rm * Rs) S

unsigned accumulate longUMLAL{S} RdLo, RdHi, Rm, RsN Z C* V* RdHi,RdLo := unsigned(RdHi,RdLo + Rm * Rs) S

unsigned double accumulate long 6UMAAL RdLo, RdHi, Rm, RsRdHi,RdLo := unsigned(RdHi + RdLo + Rm * Rs)

Signed multiply longSMULL{S} RdLo, RdHi, Rm, RsN Z C* V* RdHi,RdLo := signed(Rm * Rs) S and accumulate longSMLAL{S} RdLo, RdHi, Rm, RsN Z C* V* RdHi,RdLo := signed(RdHi,RdLo + Rm * Rs) S

16 * 16 bit 5ESMULxy Rd, Rm, RsRd := Rm[x] * Rs[y]

32 * 16 bit 5ESMULWy Rd, Rm, RsRd := (Rm * Rs[y])[47:16]

16 * 16 bit and accumulate 5ESMLAxy Rd, Rm, Rs, RnRd := Rn + Rm[x] * Rs[y] Q

32 * 16 bit and accumulate 5ESMLAWy Rd, Rm, Rs, RnRd := Rn + (Rm * Rs[y])[47:16] Q

16 * 16 bit and accumulate long 5ESMLALxy RdLo, RdHi, Rm, RsRdHi,RdLo := RdHi,RdLo + Rm[x] * Rs[y]

Dual signed multiply, add 6SMUAD{X} Rd, Rm, RsRd := Rm[15:0] * RsX[15:0] + Rm[31:16] * RsX[31:16] Q and accumulate 6SMLAD{X} Rd, Rm, Rs, RnRd := Rn + Rm[15:0] * RsX[15:0] + Rm[31:16] * RsX[31:16] Q

and accumulate long 6SMLALD{X} RdLo, RdHi, Rm, RsRdHi,RdLo := RdHi,RdLo + Rm[15:0] * RsX[15:0] + Rm[31:16] * RsX[31:16]

Dual signed multiply, subtract 6SMUSD{X} Rd, Rm, RsRd := Rm[15:0] * RsX[15:0] - Rm[31:16] * RsX[31:16] Q

and accumulate 6SMLSD{X} Rd, Rm, Rs, RnRd := Rn + Rm[15:0] * RsX[15:0] - Rm[31:16] * RsX[31:16] Q

and accumulate long 6SMLSLD{X} RdLo, RdHi, Rm, RsRdHi,RdLo := RdHi,RdLo + Rm[15:0] * RsX[15:0] - Rm[31:16] * RsX[31:16]

Signed top word multiply 6SMMUL{R} Rd, Rm, RsRd := (Rm * Rs)[63:32] and accumulate 6SMMLA{R} Rd, Rm, Rs, RnRd := Rn + (Rm * Rs)[63:32] and subtract 6SMMLS{R} Rd, Rm, Rs, RnRd := Rn - (Rm * Rs)[63:32] with internal 40-bit accumulate XSMIA Ac, Rm, RsAc := Ac + Rm * Rs packed halfword XSMIAPH Ac, Rm, RsAc := Ac + Rm[15:0] * Rs[15:0] + Rm[31:16] * Rs[31:16] halfword XSMIAxy Ac, Rm, RsAc := Ac + Rm[x] * Rs[y] DivideSigned or Unsigned RM Rd, Rn, RmRd := Rn / Rm is SDIV (signed) or UDIV (unsigned) Move dataMoveMOV{S} Rd, N Z C Rd := Operand2 See also Shift instructions N NOTMVN{S} Rd, N Z C Rd := 0xFFFFFFFF EOR Operand2 N top T2MOVT Rd, #Rd[31:16] := imm16, Rd[15:0] unaffected, imm16 range 0-65535 wide T2MOV Rd, #Rd[15:0] := imm16, Rd[31:16] = 0, imm16 range 0-65535

40-bit accumulator to register XS

MRA RdLo, RdHi, AcRdLo := Ac[31:0], RdHi := Ac[39:32] register to 40-bit accumulator XSMAR Ac, RdLo, RdHiAc[31:0] := RdLo, Ac[39:32] := RdHi

ShiftArithmetic shift rightASR{S} Rd, Rm, N Z C Rd := ASR(Rm, Rs|sh) Same as MOV{S} Rd, Rm, ASR N

Logical shift leftLSL{S} Rd, Rm, N Z C Rd := LSL(Rm, Rs|sh) Same as MOV{S} Rd, Rm, LSL N

Logical shift rightLSR{S} Rd, Rm, N Z C Rd := LSR(Rm, Rs|sh) Same as MOV{S} Rd, Rm, LSR N

Rotate rightROR{S} Rd, Rm, N Z C Rd := ROR(Rm, Rs|sh) Same as MOV{S} Rd, Rm, ROR N Rotate right with extendRRX{S} Rd, RmN Z C Rd := RRX(Rm) Same as MOV{S} Rd, Rm, RRX Count leading zeros5CLZ Rd, RmRd := number of leading zeros in Rm CompareCompareCMP Rn, N Z C V Update CPSR flags on Rn - Operand2 N negativeCMN Rn, N Z C V Update CPSR flags on Rn + Operand2 N LogicalTestTST Rn, N Z C Update CPSR flags on Rn AND Operand2 N Test equivalenceTEQ Rn, N Z C Update CPSR flags on Rn EOR Operand2 ANDAND{S} Rd, Rn, N Z C Rd := Rn AND Operand2 N EOREOR{S} Rd, Rn, N Z C Rd := Rn EOR Operand2 N ORRORR{S} Rd, Rn, N Z C Rd := Rn OR Operand2 N ORN T2ORN{S} Rd, Rn, N Z C Rd := Rn OR NOT Operand2 T Bit ClearBIC{S} Rd, Rn, N Z C Rd := Rn AND NOT Operand2 N

ARM and Thumb-2 Instruction Set

Quick Reference Card

Operation § Assembler ActionNotes

Bit fieldBit Field Clear T2BFC Rd, #, #Rd[(width+lsb-1):lsb] := 0, other bits of Rd unaffected

Bit Field Insert T2BFI Rd, Rn, #, #Rd[(width+lsb-1):lsb] := Rn[(width-1):0], other bits of Rd unaffected

Signed Bit Field Extract T2SBFX Rd, Rn, #, #Rd[(width-1):0] = Rn[(width+lsb-1):lsb], Rd[31:width] = Replicate( Rn[width+lsb-1] )

Unsigned Bit Field Extract T2UBFX Rd, Rn, #, #Rd[(width-1):0] = Rn[(width+lsb-1):lsb], Rd[31:width] = Replicate( 0 )

PackPack halfword bottom + top 6PKHBT Rd, Rn, Rm{, LSL #}Rd[15:0] := Rn[15:0], Rd[31:16] := (Rm LSL sh)[31:16]. sh 0-31.

Pack halfword top + bottom 6PKHTB Rd, Rn, Rm{, ASR #}Rd[31:16] := Rn[31:16], Rd[15:0] := (Rm ASR sh)[15:0]. sh 1-32.

Signed

extendHalfword to word 6SXTH Rd, Rm{, ROR #}Rd[31:0] := SignExtend((Rm ROR (8 * sh))[15:0]). sh 0-3. N

Two bytes to halfwords 6SXTB16 Rd, Rm{, ROR #}Rd[31:16] := SignExtend((Rm ROR (8 * sh))[23:16]),Rd[15:0] := SignExtend((Rm ROR (8 * sh))[7:0]). sh 0-3.

Byte to word 6SXTB Rd, Rm{, ROR #}Rd[31:0] := SignExtend((Rm ROR (8 * sh))[7:0]). sh 0-3. N

Unsigned

extendHalfword to word 6UXTH Rd, Rm{, ROR #}Rd[31:0] := ZeroExtend((Rm ROR (8 * sh))[15:0]). sh 0-3. N

Two bytes to halfwords 6UXTB16 Rd, Rm{, ROR #}Rd[31:16] := ZeroExtend((Rm ROR (8 * sh))[23:16]), Rd[15:0] := ZeroExtend((Rm ROR (8 * sh))[7:0]). sh 0-3. Byte to word 6UXTB Rd, Rm{, ROR #}Rd[31:0] := ZeroExtend((Rm ROR (8 * sh))[7:0]). sh 0-3. N

Signed

extend

with addHalfword to word, add 6SXTAH Rd, Rn, Rm{, ROR #}Rd[31:0] := Rn[31:0] + SignExtend((Rm ROR (8 * sh))[15:0]). sh 0-3.

Two bytes to halfwords, add 6SXTAB16 Rd, Rn, Rm{, ROR #}Rd[31:16] := Rn[31:16] + SignExtend((Rm ROR (8 * sh))[23:16]),

Rd[15:0] := Rn[15:0] + SignExtend((Rm ROR (8 * sh))[7:0]). sh 0-3.

Byte to word, add 6SXTAB Rd, Rn, Rm{, ROR #}Rd[31:0] := Rn[31:0] + SignExtend((Rm ROR (8 * sh))[7:0]). sh 0-3.

Unsigned

extend

with addHalfword to word, add 6UXTAH Rd, Rn, Rm{, ROR #}Rd[31:0] := Rn[31:0] + ZeroExtend((Rm ROR (8 * sh))[15:0]). sh 0-3.

Two bytes to halfwords, add 6UXTAB16 Rd, Rn, Rm{, ROR #}Rd[31:16] := Rn[31:16] + ZeroExtend((Rm ROR (8 * sh))[23:16]),Rd[15:0] := Rn[15:0] + ZeroExtend((Rm ROR (8 * sh))[7:0]). sh 0-3.

Byte to word, add 6UXTAB Rd, Rn, Rm{, ROR #}Rd[31:0] := Rn[31:0] + ZeroExtend((Rm ROR (8 * sh))[7:0]). sh 0-3.

ReverseBits in word T2RBIT Rd, RmFor (i = 0; i < 32; i++) : Rd[i] = Rm[31- i]

Bytes in word 6REV Rd, RmRd[31:24] := Rm[7:0], Rd[23:16] := Rm[15:8], Rd[15:8] := Rm[23:16], Rd[7:0] := Rm[31:24] N

Bytes in both halfwords 6REV16 Rd, RmRd[15:8] := Rm[7:0], Rd[7:0] := Rm[15:8], Rd[31:24] := Rm[23:16], Rd[23:16] := Rm[31:24] N

Bytes in low halfword,

sign extend6REVSH Rd, RmRd[15:8] := Rm[7:0], Rd[7:0] := Rm[15:8], Rd[31:16] := Rm[7] * &FFFF N SelectSelect bytes 6SEL Rd, Rn, RmRd[7:0] := Rn[7:0] if GE[0] = 1, else Rd[7:0] := Rm[7:0] Bits[15:8], [23:16], [31:24] selected similarly by GE[1], GE[2], GE[3]

If-ThenIf-Then T2IT{pattern} {cond}Makes up to four following instructions conditional, according to pattern. pattern is a string of up to three

letters. Each letter can be T (Then) or E (Else).

The first instruction after IT has condition cond. The following instructions have condition cond if the

corresponding letter is T, or the inverse of cond if the corresponding letter is E. See Table Condition Field for available condition codes.T U

BranchBranchB

with linkBL

and exchange 4TBX RmPC := Rm. Target is Thumb if Rm[0] is 1, ARM if Rm[0] is 0. N

with link and exchange (1) 5TBLX

label is this instruction ±32MB (T2: ±16MB).C

with link and exchange (2) 5BLX RmLR := address of next instruction, PC := Rm[31:1]. Change to Thumb if Rm[0] is 1, to ARM if Rm[0] is 0. N

and change to Jazelle state 5JBXJ RmChange to Jazelle state if available

Compare, branch if (non) zero T2CB{N}Z Rn,

Table Branch Byte T2TBB [Rn, Rm]PC = PC + ZeroExtend( Memory( Rn + Rm, 1) << 1). Branch range 4-512. Rn can be PC. T U

Table Branch Halfword T2TBH [Rn, Rm, LSL #1]PC = PC + ZeroExtend( Memory( Rn + Rm << 1, 2) << 1). Branch range 4-131072. Rn can be PC. T U

Move to or

from PSRPSR to registerMRS Rd, Rd := PSR register to PSRMSR _, RmPSR := Rm (selected bytes only) immediate to PSRMSR _, #PSR := immed_8r (selected bytes only)

Processor

state

changeChange processor state 6CPSID {, #}Disable specified interrupts, optional change mode. U, N

6CPSIE {, #}Enable specified interrupts, optional change mode. U, N

Change processor mode 6CPS #U

Set endianness 6SETEND Sets endianness for loads and saves. can be BE (Big Endian) or LE (Little Endian). U, N

ARM Instruction Set

Quick Reference Card

Single data item loads and stores § Assembler Action if is LDR Action if is STR Notes Load or store word, byte

or halfwordImmediate offset{size}{T} Rd, [Rn {, #}]{!}Rd := [address, size] [address, size] := Rd 1, N

Post-indexed, immediate{size}{T} Rd, [Rn], #Rd := [address, size] [address, size] := Rd 2

Register offset{size} Rd, [Rn, +/-Rm {, }]{!}Rd := [address, size] [address, size] := Rd 3, N

Post-indexed, register{size}{T} Rd, [Rn], +/-Rm {, }Rd := [address, size] [address, size] := Rd 4

PC-relative{size} Rd,