内核态和用户态的区别
来源:互联网 发布:手机五线谱记谱软件 编辑:程序博客网 时间:2024/04/29 11:59
当一个任务(进程)执行系统调用而陷入内核代码中执行时,我们就称进程处于内核运行态(或简称为内核态)。此时处理器处于特权级最高的(0级)内核代码中执行。当进程处于内核态时,执行的内核代码会使用当前进程的内核栈。每个进程都有自己的内核栈。当进程在执行用户自己的代码时,则称其处于用户运行态(用户态)。即此时处理器在特权级最低的(3级)用户代码中运行。当正在执行用户程序而突然被中断程序中断时,此时用户程序也可以象征性地称为处于进程的内核态。因为中断处理程序将使用当前进程的内核栈。这与处于内核态的进程的状态有些类似。
内核态与用户态是操作系统的两种运行级别,跟intel cpu没有必然的联系, intel cpu提供Ring0-Ring3三种级别的运行模式,Ring0级别最高,Ring3最低。Linux使用了Ring3级别运行用户态,Ring0作为 内核态,没有使用Ring1和Ring2。Ring3状态不能访问Ring0的地址空间,包括代码和数据。Linux进程的4GB地址空间,3G-4G部 分大家是共享的,是内核态的地址空间,这里存放在整个内核的代码和所有的内核模块,以及内核所维护的数据。用户运行一个程序,该程序所创建的进程开始是运 行在用户态的,如果要执行文件操作,网络数据发送等操作,必须通过write,send等系统调用,这些系统调用会调用内核中的代码来完成操作,这时,必 须切换到Ring0,然后进入3GB-4GB中的内核地址空间去执行这些代码完成操作,完成后,切换回Ring3,回到用户态。这样,用户态的程序就不能 随意操作内核地址空间,具有一定的安全保护作用。
至于说保护模式,是说通过内存页表操作等机制,保证进程间的地址空间不会互相冲突,一个进程的操作不会修改另一个进程的地址空间中的数据。
内核态与用户态是操作系统的两种运行级别,跟intel cpu没有必然的联系, intel cpu提供Ring0-Ring3三种级别的运行模式,Ring0级别最高,Ring3最低。Linux使用了Ring3级别运行用户态,Ring0作为 内核态,没有使用Ring1和Ring2。Ring3状态不能访问Ring0的地址空间,包括代码和数据。Linux进程的4GB地址空间,3G-4G部 分大家是共享的,是内核态的地址空间,这里存放在整个内核的代码和所有的内核模块,以及内核所维护的数据。用户运行一个程序,该程序所创建的进程开始是运 行在用户态的,如果要执行文件操作,网络数据发送等操作,必须通过write,send等系统调用,这些系统调用会调用内核中的代码来完成操作,这时,必 须切换到Ring0,然后进入3GB-4GB中的内核地址空间去执行这些代码完成操作,完成后,切换回Ring3,回到用户态。这样,用户态的程序就不能 随意操作内核地址空间,具有一定的安全保护作用。
至于说保护模式,是说通过内存页表操作等机制,保证进程间的地址空间不会互相冲突,一个进程的操作不会修改另一个进程的地址空间中的数据。
0 0
- 内核态和用户态的区别
- 内核态和用户态的区别
- 内核态和用户态的区别
- 内核态和用户态的区别
- 用户态和内核态的区别
- 内核态和用户态的区别
- 内核态和用户态的区别
- 内核态和用户态的区别
- 用户态和内核态的区别
- 内核态和用户态的区别
- 内核态和用户态的区别
- 内核态和用户态的区别
- 内核态和用户态的区别
- 用户态和内核态的区别
- 用户态和内核态的区别
- 用户态和内核态的区别
- linux的内核、内核态和用户态的区别
- 内核态和用户态的区别以及内核栈
- MyEclipse中将文件中选中的字符大写转成小写或小写转大写
- hdu 1010 Tempter of the Bone
- LINUX内存相关的内核参数
- 设计模式观后(c++还原之六 工厂模式)
- Android listview与adapter用法
- 内核态和用户态的区别
- 服务器将存储虚拟化作为解决方案
- c/c++中库函数sort的用法
- MVC模式(三层架构模式)
- poj 2570 Fiber Network (Floyd)
- 完美解决office无法正常卸载以及卸载后无法重装
- myeclipse扩大tomcat内存
- 不要放弃你的梦想
- 将QT开发的界面程序封装成DLL,在VC中成功调用