四、从用户空间到内核空间
在内核空间,跟socket相关的调用都是在sys_socketcall()函数里面。入口函数就是asmlinkage long sys_socketcall(int call, unsigned long __user *args)。我们这部分就是分析如何从一个用户的程序,如后进入到sys_socketcall()函数。至于进入sys_socketcall()函数以后的操作,可以参考《linux内核源代码情景分析(下) 》,那里面讲的很清楚,这里就不继续叙述了。因为对汇编不太熟悉,理解可能有些偏差,但大体流程不会错。
1. 关于asmlinkage宏
宏asmlinkage定义如下:#define asmlinkage __attribute__((regparm(0))).
gcc编译器在汇编过程中调用c语言函数时传递参数有两种方法:一种是通过堆栈,另一种是通过寄存器。缺省时采用寄存器,假如你要在你的汇编过程中调用c语言函数,并且想通过堆栈传递参数,你定义的c函数时要在函数前加上宏asmlinkage。