使用基于堆栈的调用约定的汇编函数调用

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 位寄存器。因此,pushcall 推送 8 个字节,而不是 4 个,因此您的参数将位于 [rbp + 24][rbp + 16],而不是 [rbp + 12][rbp + 8].