刘帅嵌入式系统-LDRT用户模式的字数据读取指令
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 >为指令的寻址方式。
指令操作的伪代码
if ConditionPassed(cond) then if address[1:0] == 0b00 then Rd=Memory[address,4] else if address[1:0] == 0b01 then Rd=Memory[address,4] Rotate_Right 8 else if address[1:0] == 0b10 then Rd=Memory[address,4] Rotate_Right 16 else /* address[1:0] == 0b11*/ Rd=Memory[address,4] Rotate_Right 24
指令的使用
异常中断程序是在特权级的处理器模式下执行的,这时,如果需要按照用户模式的权限访问内存,可以使用LDRT指令。