处理器模式

通常操作系统把虚拟地址空间划分为用户空间和内核空间,例如x86平台的Linux系统虚拟地址空间
是0x00000000~0xffffffff,前3GB(0x00000000~0xbfffffff)是用户空间,
后1GB(0xc0000000~0xffffffff)是内核空间。用户程序加载到用户空间,在用户模式下执行,不
能访问内核中的数据,也不能跳转到内核代码中执行。这样可以保护内核,如果一个进程访问了非
法地址,顶多这一个进程崩溃,而不会影响到内核和整个系统的稳定性。CPU在产生中断或异常时
不仅会跳转到中断或异常服务程序,还会自动切换模式,从用户模式切换到特权模式,因此从中断
或异常服务程序可以跳转到内核代码中执行。事实上,整个内核就是由各种中断和异常处理程序组
成的。总结一下:在正常情况下处理器在用户模式执行用户程序,在中断或异常情况下处理器切换
到特权模式执行内核程序,处理完中断或异常之后再返回用户模式继续执行用户程序。
段错误我们已经遇到过很多次了,它是这样产生的:
1. 用户程序要访问的一个VA,经MMU检查无权访问。
2. MMU产生一个异常,CPU从用户模式切换到特权模式,跳转到内核代码中执行异常服务程
序。
3. 内核把这个异常解释为段错误,把引发异常的进程终止掉。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值