使用基于堆栈的调用约定的汇编函数调用
Assembly function call using stack-based calling conventions
我很困惑。我正在查看 this 页面以了解如何使用堆栈将参数传递给函数。但是,我的代码没有按预期工作。鉴于我将计算结果放入 rax,我希望退出代码为 9,但事实并非如此;相反,我的退出代码是 150。了解 x86 中堆栈调用约定的人是否知道我做错了什么,以及如何实现我要解决的问题?我在 Mac 上使用 GAS 进行组装,如下所示:gcc -masm=intel stack_frames.asm
.global _main
.text
_main:
push 4 # arg 2
push 5 # arg 1
call plus
mov rdi, rax # exit code = result in rax, which I'm expecting to be 9
mov rax, 0x2000001
syscall
plus:
push rbp
mov rbp, rsp
mov rsi, [rbp + 12] # param 1
mov rdi, [rbp + 8] # param 2
add rdi, rsi # sum in rdi
mov rax, rdi # move sum to rax
mov rsp, rbp
pop rbp
ret
您使用的是 x86-64,即 64 位,而不是 32 位 x86。你知道这一点是因为你能够使用像 rax
这样的 64 位寄存器。因此,push
和 call
推送 8 个字节,而不是 4 个,因此您的参数将位于 [rbp + 24]
和 [rbp + 16]
,而不是 [rbp + 12]
和 [rbp + 8]
.
我很困惑。我正在查看 this 页面以了解如何使用堆栈将参数传递给函数。但是,我的代码没有按预期工作。鉴于我将计算结果放入 rax,我希望退出代码为 9,但事实并非如此;相反,我的退出代码是 150。了解 x86 中堆栈调用约定的人是否知道我做错了什么,以及如何实现我要解决的问题?我在 Mac 上使用 GAS 进行组装,如下所示:gcc -masm=intel stack_frames.asm
.global _main
.text
_main:
push 4 # arg 2
push 5 # arg 1
call plus
mov rdi, rax # exit code = result in rax, which I'm expecting to be 9
mov rax, 0x2000001
syscall
plus:
push rbp
mov rbp, rsp
mov rsi, [rbp + 12] # param 1
mov rdi, [rbp + 8] # param 2
add rdi, rsi # sum in rdi
mov rax, rdi # move sum to rax
mov rsp, rbp
pop rbp
ret
您使用的是 x86-64,即 64 位,而不是 32 位 x86。你知道这一点是因为你能够使用像 rax
这样的 64 位寄存器。因此,push
和 call
推送 8 个字节,而不是 4 个,因此您的参数将位于 [rbp + 24]
和 [rbp + 16]
,而不是 [rbp + 12]
和 [rbp + 8]
.