操作系统笔记_系统调用实现过程

围绕两个问题:

  1. 用户应用程序调用系统函数能不能直接访问内核函数?
  2. 应用程序进行系统调用时,如何才能进入内核访问对应函数?

操作系统提供的系统函数和用户应用程序都在内存中

为什么要执行中断而不能直接访问?

因为在内存中应用程序和内核之间存在隔离,分有内核态和用户态;

如果没有隔离,应用程序就有可能会破坏底层数据,造成操作系统不安全。

当内核态被访问时,操作系统通过段寄存器判断特权级来决定访问权限

只有(DPL(Descriptor Privilege Level)>=CPL(Current Privilege Level)),才可以进入内核态。

内核态在操作系统初始化时DPL被置成0,用户态为3。数字越小特权级越大。

应用程序要访问内核时,它的CPL就为3,所以不能直接进入内核。

所以,在用户调用一个printf函数后,发生了什么事?

  1. 用户函数通过库函数展开成包含int指令(interrupt 中断)(int 0x80)的汇编指令进入内核态(改变DPL、CPL)
  2. 通过int 0x80执行系统初始化时设定好的中断处理程序system_call()
  3. 中断处理程序中查一个全局函数数组sys_call_table
  4. 对应调用函数下标_NR_write=4,调用数组中函数sys_write(功能实现)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值