首页 > 解决方案 > 使用基于堆栈的调用约定的汇编函数调用

问题描述

我很困惑。我正在查看页面以了解如何使用堆栈将参数传递给函数。但是,我的代码没有按预期工作。鉴于我将计算结果放入 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

标签: macosfunctionassemblyx86-64callstack

解决方案


您使用的是 64 位的 x86-64,而不是 32 位 x86。您知道这一点是因为您能够使用 64 位寄存器,例如rax. 因此,pushcall推送 8 个字节,而不是 4 个,因此您的参数将位于[rbp + 24]and [rbp + 16],而不是[rbp + 12]and [rbp + 8]


推荐阅读