gpt4 book ai didi

linux - 解释基本的 ARM 指令

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:33:36 24 4
gpt4 key购买 nike

我有几个问题,其中一个是:

Which of these ARM instructions clears register r5, so that all of it's bits are set to ’0’?

and r5, r5, #0
eor r5, r5, r5
lsr r5, #32
sub r5, r5, r5

根据我的理解,sub r5, r5, r5 清除寄存器,因为它从自身中减去数字。 andeor 显然看起来不对。

lsr r5, #32 是否也清除寄存器?它将 r5 寄存器移动 32 位,对吗?因此,该指令如果清除寄存器也是有意义的。


与此相关,我还需要解读这段代码:

What is the relationship between the contents of register r0 and register r1 when the following sequence of ARM instructions is executed?

    mov r0, #12
mov r1, #1
start:
cmp r0, #0
ble end
mul r1, r0, r1
sub r0, r0, #1
b start
end:

我不完全确定 cmp r0, #0 做了什么,以及它最终是否改变了 r0 的值。我知道它比较值。

因此,根据我的理解,运行此代码后,mul r1, r0, r1 表示 r1 设置为等于 12,即 1 * 12 = 12(如果 cmp r0, #0不影响 r0 的值,我不知道)。

因此,r1 设置为 12 - 1 = 11。

任何人都可以澄清在运行此代码后我是否获得了 r0 (12) 和 r1 (11) 的正确值,以及 cmp r0, #0ble end 在这里做什么以及它如何影响寄存器 r0(如果有的话)?

最佳答案

第一部分:

Which of these ARM instructions clears register r5, so that all of its bits are set to ’0’?

全部!

and r5, r5, #0

这相当于 r5 = r5 & 0,将所有位与零相与将清除寄存器。

eor r5, r5, r5

这是 r5 = r5 ^ r5,“异或”运算。与自身进行异或也会得到零,因为 1 ^ 1 也是 0

lsr r5, #32

正如您提到的,将所有 32 位右移会将它们全部清零。 ARM specification甚至对 LSR 说:

if the shift is 32, Rd is cleared, and the last bit shifted out remains in the C flag

sub r5, r5, r5

同样,r5 = r5 - r5 会将其清零。


第二部分的代码是这样做的(在 C 代码中):

int r0 = 12;
int r1 = 1;
while (r0 > 0)
r1 *= r0--;

因此,在循环结束时,r1 会将数字 12、11、10... 的乘积降为 1。换句话说,这是计算 r0 的阶乘并将其存储在 r1 上。

cmp 指令只是将 r0 与常量 0 进行比较并设置标志,以便 ble(如果小于或等于则分支)可以对其执行操作. cmp 指令不修改其操作数。两条指令一起可以读作:

if (r0 <= 0)
goto end;

关于linux - 解释基本的 ARM 指令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53445840/

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