上一节中讲述了socket调用的总入口sys_socketcall的宏定义形式,该定义形式还广泛用于其他接口API。现在我们来看看sys_socketcall的实现方式。
在net/socket.c 中,sys_socketcall的实现如下:
2465~2466 API序号鉴定,需要在socket 接口调用范围内。
2468~2470 根据API序号取得该API的参数个数,nargs数组中定义。
2472~2474 将参数从用户态args拷到内核态a中。
2476~2478 是selinux的一些鉴权过程,可以忽略。
2480~2561 是根据对应的API序号进行调用,并将参数强制类型转换为对应API需要的参数类型。
形如 sys_socket 这样的函数,在net/socket.c是找不到定义的。他的定义需要用到上一节说的方法,其定义如下:SYSCALL_DEFINE3(socket, int, family, int, type, int, protocol)
其他API类似,且都在net/socket.c中定义。