美文网首页
用户态和核心态的区别

用户态和核心态的区别

作者: 断点看回忆 | 来源:发表于2018-10-09 16:05 被阅读0次

转自 https://www.cnblogs.com/Allen-rg/p/7171105.html

1.操作系统需要两种CPU状态:

内核态(Kernel Mode):运行操作系统程序

用户态(User Mode):运行用户程序

2.指令划分:

特权指令:只能由操作系统使用、用户程序不能使用的指令。 举例:启动I/O 内存清零 修改程序状态字 设置时钟 允许/禁止终端 停机

非特权指令:用户程序可以使用的指令。 举例:控制转移 算数运算 取数指令 访管指令(使用户程序从用户态陷入内核态)

3.特权级别:

特权环:R0、R1、R2和R3

R0相当于内核态,R3相当于用户态;

不同级别能够运行不同的指令集合;

4.CPU状态之间的转换:

用户态--->内核态:唯一途径是通过中断、异常、陷入机制(访管指令)

内核态--->用户态:设置程序状态字PSW

5.内核态与用户态的区别:

1)内核态与用户态是操作系统的两种运行级别,当程序运行在3级特权级上时,就可以称之为运行在用户态。因为这是最低特权级,是普通的用户进程运行的特权级,大部分用户直接面对的程序都是运行在用户态;

2)当程序运行在0级特权级上时,就可以称之为运行在内核态。

3)运行在用户态下的程序不能直接访问操作系统内核数据结构和程序。当我们在系统中执行一个程序时,大部分时间是运行在用户态下的,在其需要操作系统帮助完成某些它没有权力和能力完成的工作时就会切换到内核态。

4)这两种状态的主要差别是:
处于用户态执行时,进程所能访问的内存空间和对象受到限制,其所处于占有的处理机是可被抢占的 ;
而处于核心态执行中的进程,则能访问所有的内存空间和对象,且所占有的处理机是不允许被抢占的。

  1. 通常来说,以下三种情况会导致用户态到内核态的切换:

1)系统调用

这是用户态进程主动要求切换到内核态的一种方式,用户态进程通过系统调用申请使用操作系统提供的服务程序完成工作。比如前例中fork()实际上就是执行了一个创建新进程的系统调用。
而系统调用的机制其核心还是使用了操作系统为用户特别开放的一个中断来实现,例如Linux的int 80h中断。

2)异常

当CPU在执行运行在用户态下的程序时,发生了某些事先不可知的异常,这时会触发由当前运行进程切换到处理此异常的内核相关程序中,也就转到了内核态,比如缺页异常。

3)外围设备的中断

当外围设备完成用户请求的操作后,会向CPU发出相应的中断信号,这时CPU会暂停执行下一条即将要执行的指令转而去执行与中断信号对应的处理程序,
如果先前执行的指令是用户态下的程序,那么这个转换的过程自然也就发生了由用户态到内核态的切换。比如硬盘读写操作完成,系统会切换到硬盘读写的中断处理程序中执行后续操作等。

这3种方式是系统在运行时由用户态转到内核态的最主要方式,其中系统调用可以认为是用户进程主动发起的,异常和外围设备中断则是被动的。

相关文章

  • 用户态和核心态的区别

    转自 https://www.cnblogs.com/Allen-rg/p/7171105.html 1.操作系统...

  • 内核态和用户态、

    内核态和用户态的区别 内核态切换用户态耗时的原因

  • Java NIO 底层原理

    一、概念说明 1、内核态(内核空间)和用户态(用户空间)的区别和联系?用户空间是用户进程所在的内存区域,系统空间是...

  • 用户态和核心态

    当程序运行在3级特权级上时,就可以称之为运行在用户态,因为这是最低特权级,是普通的用户进程运行的特权级,大部分用户...

  • Linux IO模式 select poll epoll详解

    概念说明 内核态(内核空间)和用户态(用户空间)的区别和联系 用户空间是用户进程所在的内存区域,系统空间是操作系统...

  • 关于内核态和用户态的区别

    参考文章:https://juejin.cn/post/6844903646216323086[https://j...

  • 中断和系统调用

    中断和异常 中断本质 需要操作系统介入 ,开展管理工作 CPU状态从用户态转换为核心态核心态到用户态程序状态子(P...

  • os面试备用

    1、信号量和自旋锁的区别? 2、Linux用户态和内核态通信方式? 3、Coredump 4、字节序

  • Linux用户态和内核态

    用户态和内核态的概念区别 究竟什么是用户态,什么是内核态,这两个基本概念以前一直理解得不是很清楚,根本原因个人觉得...

  • 用户栈和内核栈

    为了区分程序的运行级别,有用户态和核心态之分,也叫目态和管态。硬件驱动、CPU和内存管理等底层操作和进程管理、诊断...

网友评论

      本文标题:用户态和核心态的区别

      本文链接:https://www.haomeiwen.com/subject/zfqyaftx.html