刘帅嵌入式系统-LDRT用户模式的字数据读取指令

刘帅嵌入式系统-LDRT用户模式的字数据读取指令

LDRT指令用于从内存中将一个32位的字数据读取到指令中的目标寄存器中。如果指令中寻址方式确定的地址不是字对齐的,则从内存中读出的数值要进行循环右移操作,移位的位数为寻址方式确定的地址的bits[1:0]的8倍。这样对于Little-endian的内存模式,指令想要读取的字节数据存放在目标寄存器的低8位;对于Big-endian的内存模式,指令想要读取的字节数据存放在目标寄存器的bits[31:24] ( 寻址方式确定的地址bit[0]为0 )或者bits[15:8] (寻址方式确定的地址bit[0]为1)。

当在特权级的处理器模式下使用本指令时,内存系统将该操作当作一般用户模式下的内存访问操作。

指令的编码格式

刘帅嵌入式系统-LDRT用户模式的字数据读取指令

指令的语法格式

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指令。