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

    xiaoxiao2023-11-22  159

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

    最新回复(0)