汇编向函数传参数

今天师兄讲了下汇编如何向函数传参数,为了怕以后忘记,先记在这里。

在老内核里面,汇编往函数传递参数是第一个参数是栈顶,依次往后。但是得在函数定义的时候用asmlinkage 前缀,是函数强制从汇编里面取参数。现在新内核是汇编的第一个参数是eax,第二个参数是edx。

 以下代码是在师兄的程序里面看到的,

struct test{
        int a1;
        int b1;
};

int print(int a , struct test *ll)
{
        printk("the data is %d/n", a);
        printk("the struct is %d , %d/n", ll->a1, ll->b1);
        return 789;
}
static int __init hello_init(void)
{
asm("pushl $12/n/t"
            "pushl $34/n/t"
            "movl $56,%%eax/n/t"
            "movl %%esp, %%edx/n/t"
            "call print/n/t"
            "addl $8,%%esp/n/t"
                ::);
        return 0;
}

该程序 运行结果打印顺序应该是:56 34 12,print第二个参数是指针,  movl %%esp, %%edx 是把栈顶指针付给eax,所以eax就指向了34,然后指针往上移动,打印了12,因为栈地址是从高到低的,所以栈顶指针加就可以理解了。

你可能感兴趣的:(汇编向函数传参数)