Linux中ipv6代码阅读(4)

本文详细分析了Linux系统中从用户空间的socket调用如何进入内核空间的sys_socketcall函数,涉及asmlinkage宏、cond_syscall宏的使用,以及中断处理流程,包括系统调用中断号0x80和system_call函数的调用过程。
摘要由CSDN通过智能技术生成
 

四、从用户空间到内核空间

在内核空间,跟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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值