首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >理解ARM中的uxth指令

理解ARM中的uxth指令
EN

Stack Overflow用户
提问于 2022-06-20 15:32:50
回答 1查看 316关注 0票数 0

分析了一个反编译的ARM二进制文件,我看到了这些指令。

代码语言:javascript
运行
复制
...
mov r7, #0
uxth r0, r7
...
add r7, r7, #1
uxth r4, r7
...

来自ARM的医生:

UXTH{cond} {Rd}, Rm {,rotation}将16位值扩展为32位值.它这样做的方法是:

从Rm向右旋转0、8、16或24 bits.

  • Extracting位的
  1. 与所获得的值15:0。
  2. 0扩展到32位。

这使我很困惑,并提出了许多问题:

  • 没有在32位寄存器上运行?
  • 使用uxth
  • 将零扩展为零的目的是什么?为什么不直接将值加载到r0 ?

中?

EN

回答 1

Stack Overflow用户

发布于 2022-06-20 20:08:40

此指令旨在帮助处理16位变量。您的即时操作没有多大意义,但是如果我在地址0x1001有一个16位变量呢?为了避免未对齐的访问,您需要执行32位加载,然后右移8并使用0x0000FFFF (它会自动为您提供符号扩展。要做到这一点,通常您需要另一个寄存器,和几个指令。现在,它的两个指令,不一定需要另一个登记册。在这之前你看到的是左移16,然后右移以避免寄存器给出掩码和零垫,但这是两个指令。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72689539

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档