LDRT指令用于从内存中将一个32位的字数据读取到指令中的目标寄存器中。如果指令中寻址方式确定的地址不是字对齐的,则从内存中读出的数值要进行循环右移操作,移位的位数为寻址方式确定的地址的bits[1:0]的8倍。这样对于Little-endian的内存模式,指令想要读取的字节数据存放在目标寄存器的低8位;对于Big-endian的内存模式,指令想要读取的字节数据存放在目标寄存器的bits[31:24] ( 寻址方式确定的地址bit[0]为0 )或者bits[15:8] (寻址方式确定的地址bit[0]为1)。
当在特权级的处理器模式下使用本指令时,内存系统将该操作当作一般用户模式下的内存访问操作。
LDR{< cond >}T < Rd >, < post_indexed_addressing_mode >
其中:
< cond >为指令执行的条件码。当< cond >忽略时,指令为无条件执行。
< Rd >为目标寄存器。
< addressing_mode >为指令的寻址方式。
异常中断程序是在特权级的处理器模式下执行的,这时,如果需要按照用户模式的权限访问内存,可以使用LDRT指令。