1

我需要使用 gcc 调用我无法在 c++ 中 typedef 的函数指针。我不擅长asm,所以我会很感激你的帮助。

该函数在 eax 中传递 arg1,在 esi 中传递 arg2。args 从右向左推送,调用者清理堆栈

signed int __usercall o_Fkt<eax>(int a1<eax>, int a2<esi>, int a3, int a4, int a5)

编辑:谢谢威廉。我成功地这样称呼它:

    int callfn(void* a1, void* a2, int a3, int a4, void* a5 )
    {
        int result;
        unsigned long fktAddr = 0x0092FE40;
        __asm volatile(
                "push %[a5]\n\t"
                "push %[a4]\n\t"
                "push %[a3]\n\t"
                "call edx\n\t"
                "add esp, 12"
                : "=a" (result)
                :  "d" (fktAddr), "a" (a1), "S" (a2) , [a5] "r" (a5), [a4] "r" (a4), [a3] "r" (a3)
                : "memory"
        );
        return result;
    }

edit2:将“内存”添加到破坏列表

4

1 回答 1

2

像这样的东西 - 我没有测试它,但我认为编译器输出看起来不错。

int oFkt(int a1);
int callfn(int a1, int a2, int a3, int a4, int a5)
{
    int result;
    __asm (
            "push %[a5]\n\t"
            "push %[a4]\n\t"
            "push %[a3]\n\t"
            "call oFkt\n\t"
            "add  esp, 12"
            : "=a" (result)
            : "a" (a1), "S" (a2), [a5] "r" (a5), [a4] "r" (a4), [a3] "r" (a3)
    );
    return result;
}

=a输出约束导致返回值被复制到中resulta输入约束加载a1到 中eaxS加载a2esi 其余部分只是推动其他参数。

于 2012-03-21T11:26:00.290 回答