gpt4 book ai didi

assembly - 具有 2 个或 3 个操作数的 ARM ADD 之间的区别?

转载 作者:行者123 更新时间:2023-12-05 02:59:09 24 4
gpt4 key购买 nike

查看 armkeil 的文档 http://www.keil.com/support/man/docs/armasm/armasm_dom1361289861747.htm当你执行 ADD 函数时,你总是需要 3 个变量,例如:

"MOV r2,#4 \n\t"
"ADD r2,r2,#3 \n\t"

寄存器 2 中的结果为 7。但是当我尝试以下操作时:

"MOV r2,#4 \n\t"
"ADD r2,#3 \n\t"

结果是一样的,那两者之间的根本区别是什么?是否允许使用第二个?

最佳答案

ARM 语法允许在与目标相同时省略中间操作数(第一个源)。(至少在 GAS“统一”语法中;最初 ARM Thumb 语法仅在机器编码时允许它实际上有一个单独的目的地,或者其他东西。GAS 有不同的语法;GCC 通常将其置于 .syntax unified 模式 IIRC,所以这是内联 asm 的上下文)

ADD r2,r2,#3ADD r2,#3 完全相同,适用于接受两者的汇编器。 Keil 的汇编程序可能不会,IDK。

Keil 与 GAS/GCC 使用不同的指令,但我认为大多数指令的语法相同。


一些 thumb 指令编码只有空间来编码 2 个操作数,所以它们在机器代码级别类似于 dst += immediate 而不是 dst = src + immediate。在 asm 源代码级别,Keil 将其记录为 ADDS Rd, Rd, #imm(在您链接的页面中)。

adds 的另一个 16 位编码只有一个 3 位立即数(0..7),但使用这些位允许编码一个单独的目的地, 添加 Rd、Rn、#imm

(请注意,add 而不是 adds 通常需要 32 位指令,因此除非您需要保留标志,否则不要这样做。)

我提到这个是因为您之前的问题是关于 Cortex-M 的。在 ARM 模式下组装时,GAS 可能仍然接受 add r2, #3。第一个源只是隐含的目的地。

关于assembly - 具有 2 个或 3 个操作数的 ARM ADD 之间的区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58293330/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com