刘帅嵌入式系统-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指令。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值