内核态与用户态
intel x86 架构的CPU分Ring0-Ring3三种级别的运行模式,Ring0级别最高,Ring3最低。
针对不同的 级别,有很多的限制,比如说传统的 in ,out 指令,就是端口的输入输出指令,在 Ring0 级下是可以用的,但在 Ring3 级下就不能用,你用就产生陷井,告诉你出错了,当然限制还有很多了,不只是这一点。
*** 作系统下是利用这个特点,当 *** 作系统自己的代码运行时, CPU 就切成 Ring0 级,当用户的程序运行是就只让它在 Ring3 级运行,这样如果用户的程序想做什么破坏系统的事情的话,也没办法做到。
当然,低级别的程序是没法把自己升到高级别的,也就是说 用户程序运行在 Ring3 级,他想把自己变成 Ring0 级自己是做不到的,除非是 *** 作系统帮忙。
例如:版主 可以删除你的贴子,你却不能删除 版主 的贴子 ,当然你也没法让自己变成 版主 ,除非 版主 把你升为 版主(或是系统有 bug ).....
利用这个特性
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)