在 x86 汇编中交换 2 个整数

Dee*_*Dee 2 c assembly swap x86-64

我有一个指向整数数组开头的整数指针,并且我正在尝试交换程序集 x86 中的两个值。这是我的代码:

movq (%rdi,%rcx,4),%r8     # SWAP
movq 4(%rdi,%rcx,4),%r9   
movq %r9,(%rdi,%rcx,4)
movq %r8,4(%rdi,%rcx,4)
Run Code Online (Sandbox Code Playgroud)

rdi包含指针,并且两个值的地址计算是正确的(rcx第一次迭代中只是 0),但是,这是我进行交换时发生的情况:

(gdb) x/5wd $rdi
0x602010:    31    1    2    3
0x602020:    0
(gdb) x/5wd $rdi
0x602010:    1     2    2    3
0x602020:    0
(gdb) x/5wd $rdi
0x602010:    1     31    2    3
0x602020:    0
Run Code Online (Sandbox Code Playgroud)

正如您所看到的,第三个值被第一个和第二个值的交换所替换,我不明白为什么。关于我应该在哪里寻找错误的任何建议?

Dan*_*ani 5

movq移动 8 个字节,而您希望它移动 4 个字节。
请使用and (r8 和 r9 的低 32 位)movl代替。r8dr9d

或者相反,将内存访问彼此偏移 8 个字节而不是 4 个字节来交换 qword。

  • 或者使用 qword 旋转交换内存中的一对双字,例如“rorq $32, (%rdi,%rcx,4)”,但这可能会导致存储转发停顿。 (3认同)