强制GCC在寄存器中传递参数

时间:2014-06-28 22:27:16

标签: c++ gcc inline-assembly cpu-registers

我开始试图在C ++中乱用内联ASM,所以我写了这个小片段:

#include <iostream>

int foo(int, int, int);


int main(void)
{
    return foo(1,2,3);
}

int foo(int a, int b, int c)
{
    asm volatile("add %1, %0\n\t"
                 "add %2, %0\n\t"
                 "add $0x01, %0":"+r"(a):"r"(b), "r"(c):"cc");
}

其中输出以下汇编代码:

main:
.LFB969:
    subq    $40, %rsp
    .seh_stackalloc 40
    .seh_endprologue
    call    __main
    movl    $3, %r8d
    movl    $2, %edx
    movl    $1, %ecx
    call    _Z3fooiii

......没有显示的东西......

_Z3fooiii:
.LFB970:
    .seh_endprologue
    movl    %ecx, 8(%rsp)
    movl    %edx, 16(%rsp)
    movl    %r8d, 24(%rsp)
    movl    16(%rsp), %edx
    movl    24(%rsp), %ecx
    movl    8(%rsp), %eax
/APP
 # 15 "K:\inline_asm_practice_1.cpp" 1
    add %edx, %eax
    add %ecx, %eax
    add $0x01, %eax
 # 0 "" 2
/NO_APP
    movl    %eax, 8(%rsp)
    ret

所以我可以看到它输入我的代码的位置,但是它上面的堆栈操作是什么?有什么办法可以摆脱它们;他们似乎没必要。我应该能够拥有

(主要)

movl    $3, %r8d
movl    $2, %edx
movl    $1, %ecx
call    _Z3fooiii

(在foo中)

add %edx, %ecx
add %r8d, %eax
add $0x01, %eax
ret

如何让gcc明白它不需要在堆栈上推送东西并以不同的顺序将它们带回来?我已经把fastcall和regparam炒了,我找不到任何东西。

1 个答案:

答案 0 :(得分:0)

您可能需要通过类似-O2的方式启用优化,以便让编译器尝试编写更好/更快的代码,而不是更简单/更容易调试/理解代码。