使用先前传递的参数在地址处调用函数

时间:2014-03-30 09:36:35

标签: c inline-assembly calling-convention

我正在尝试创建一个函数来调用位于某个地址的其他函数。 调用另一个函数的函数只接收传入的args类型(如char *),返回类型和参数本身。 但它每次调用函数本身或调用它后突然崩溃。 基本上,我想要达到的目的是在C ++中编写这样的函数:

function callfunc(name,...) --Lua
 local func=_G[name];
 func(...)
end

所以这是我的代码:

#include <stdio.h>
#include <stdarg.h>
void testfunc(char *c){
    printf("Text: %s\n",c);
}
void callfunc(void *ptr,char ret,char *types,int argc,...){
//#define push(w,h,t) *(t*)(w-sizeof(t))=h; w-=sizeof(t)
#define push(w) asm("push %0"::"r"(w))
    typedef void (*funcptr)(...);
    typedef char* char_ptr;
    funcptr func=(funcptr)ptr;
    double d;
    char *p;
    int n;
    va_list vl;
    va_start(vl, argc);
    for(int i=0;i<argc;i++){
        switch(types[i]){
            case 'p':
                p=va_arg(vl,char_ptr);
                printf("Pushing char*: %s\n",p);
                push(p);
                break;
            case 'n':
                n=va_arg(vl,int);
                printf("Pushing int: %d",n);
                push(n);
                break;
            case 'd':
                d=va_arg(vl,double);
                printf("Pushing double: %f",d);
                push(d);
                break;
        }
    }
    va_end(vl);
    asm(
        "call *%0"
        ::"r"(func)
    );
}
int main(int argc, const char * argv[])
{
    //address can be directly set to lets say 0x450F10E0
    //we only know what is passed to function, we cant change function itself

    callfunc((void*)testfunc,'v',"p",1,"Hi!");
    return 0;
}

有人可以帮忙吗?

修改  我想调用的函数是__stdcall。

1 个答案:

答案 0 :(得分:1)

不要与va_list混在一起,这非常不便携。特别是,许多平台ABI都在寄存器中传递了一些参数的参数,你完全没有这个方面。 (你甚至没告诉我们你正在使用哪种ABI。)

标准预见的方法是将va_list传递给您要调用的函数,并在那里对参数进行解释。