linux system函数传参,Linux系统调用例程system_call和参数传递

系统调用接口调用“int $Ox8O”指令进入内核并准各了相关参数后,剩下的工作就由系统调用例程来进行。Linux定义的系统调用 例程的入口为system_call。下面具体介绍system_call所做的工作。

system_call是用汇编语言编写的,在i386体系中,其前半部分代码如下:

758ab910d01219f552896c8778f6c950.gif

这部分代码的任务是传递系统调用号和参数。

前面谈到,为了识别具体的内核服务例程,必须用寄存器eax传递系统调用号。除此之外,某些内核服务例程还需要一些由用户提供 的参数。例如,内核服务例程mmap()除系统调用号之外还需要6个参数。

传递参数的任务是由处理器的寄存器来完成的。

在IJbO系统中,用来进行参数传递工作的寄存器依次为eax、ebx、ecx、edx、est和edi。其中,eax被指定用于系统调用号的传递。 所以,在函数system_call中,一开始就使用宏SAVE_ALL把处理器的各寄存器压栈,以便以后系统调用服务例程可从内核堆栈中根据 需要找到相关的参数。

可见,为了传递参数,在系统调用接口中就应把所有参数按照规定事先存入各寄存器。至于参数多于6个的情况,可采用在内存中设 置一个参数缓冲区,而让处理器的寄存器作为指针指向的这个参数缓冲区的办法来解决。

接下来,程序对进程传递的系统调用号进行有效性检查。如果无效,则系统调用中止:

745b6b39b6644f25684f008149abfa09.gif

如果有效,则根据寄存器eax提供的系统调用号并通过Syscall_table来调用对应的内核服务例程:call*sys_call_table(0,% eax,4)

当服务例程结束时,system_call从eax获得返回值,然后跳转到返回函数ret_from_sys_call返回用户态:

movl % eax,24(% esp)

jmp ret_from_sys_call

:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值