17.29 LDP

Load Pair of Registers.

Syntax

LDP Wt1, Wt2, [Xn|SP], #imm ; 32-bit

LDP Xt1, Xt2, [Xn|SP], #imm ; 64-bit

LDP Wt1, Wt2, [Xn|SP, #imm]! ; 32-bit

LDP Xt1, Xt2, [Xn|SP, #imm]! ; 64-bit

LDP Wt1, Wt2, [Xn|SP{, #imm}] ; 32-bit

LDP Xt1, Xt2, [Xn|SP{, #imm}] ; 64-bit

Where:

Wt1
Is the 32-bit name of the first general-purpose register to be transferred.
Wt2
Is the 32-bit name of the second general-purpose register to be transferred.
imm

Depends on the instruction variant:

32-bit general registers
Is the signed immediate byte offset, a multiple of 4 in the range -256 to 252.
64-bit general registers
Is the signed immediate byte offset, a multiple of 8 in the range -512 to 504.
Xt1
Is the 64-bit name of the first general-purpose register to be transferred.
Xt2
Is the 64-bit name of the second general-purpose register to be transferred.
Xn|SP
Is the 64-bit name of the general-purpose base register or stack pointer.

Usage

Load Pair of Registers calculates an address from a base register value and an immediate offset, loads two 32-bit words or two 64-bit doublewords from memory, and writes them to two registers. For information about memory accesses, see Load/Store addressing modes in the ARM Architecture Reference Manual ARMv8, for ARMv8-A architecture profile.

Note:

For information about the constrained unpredictable behavior of this instruction, see Architectural Constraints on UNPREDICTABLE behaviors in the ARM Architecture Reference Manual ARMv8, for ARMv8-A architecture profile, and particularly LDP.
Non-ConfidentialPDF file icon PDF versionARM 100069_0608_00_en
Copyright © 2014–2017 ARM Limited or its affiliates. All rights reserved.