用户态切换到内核态的过程

      在linux系统中,每个系统调用被赋予一个系统调用号。这样通过这个独一无二的号码就可以关联系统调用。当用户空间执行的进程执行一个系统调用的时候,这个系统调用号就用来告诉内核要执行哪一个系统调用。

      内核记录了系统调用表中所有已注册过的系统调用的列表,这个表为每一个有效的系统调用指定了唯一的系统调用号。

用户空间程序无法执行内核代码。它们不能直接调用内核中的函数,因为内核驻留在受保护的地址空间上。所以应用程序必须先通知系统,告诉自己需要执行一个系统调用,希望系统切换到内核态,这样内核就可以代表应用程序在内核空间执行系统调用。

       Linux系统是依靠软中断来实现用户态到内核态的切换的。具体过程可分为以下几步:

  1. 用户程序执行到调用系统调用处引发一个异常,这个异常就是触发int&0x80指令
  2. int&0x80会导致系统切换到内核态,并执行第128号异常(中断)处理程序
  3. 而第128号异常处理程序就是用来执行系统调用的,其实现是调用system_call()来执行具体的系统调用,这里可能会疑惑,system_call()如何知道该执行哪一个系统调用,这是系统调用号就起作用了,用户程序会将所调用的系统调用号告知内核,内核根据系统调用号来确定执行哪一个系统调用

参数传递:系统调用号是通过eax寄存器传递给内核的,而对应的系统调用可能需要一些参数,ebx、ecx、edx、esi、edi这五个寄存器是用来传递系统调用参数的,如果出现参数大于五个的话,那就需要创建一个堆栈,用一个单独的寄存器来保存这个堆栈的地址,从而将参数传递到内核态

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值