今天师兄讲了下汇编如何向函数传参数,为了怕以后忘记,先记在这里。
在老内核里面,汇编往函数传递参数是第一个参数是栈顶,依次往后。但是得在函数定义的时候用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,因为栈地址是从高到低的,所以栈顶指针加就可以理解了。