- 内核态、用户态的概念
内核态:执行内核代码的状态
用户态:执行用户代码的状态 - 什么时候用户态会切到内核态?
《1》系统调用时
例如调用fork、open等系统函数时。
《2》发生异常时
例如缺页异常。当cpu执行运行在用户态的程序时,发生了一些事先不可知的异常。
《3》外设产生中断
如硬盘读写操作的完成,系统会切换到硬盘读写的中断处,处理程序继续完成后续操作。 - 怎样进行切换?
通过系统调用。内核态和用户态分别处于两个不同的栈上,所以不可能通过简单的传递函数指针来进行调用,而且处在用户态和内核态是相互不可见的,内核态堆栈在用户态是不可见的。
每个系统调用,都在内核中对应着一个数字–系统调用号,这个数字就是系统调用函数指针的偏移量。
当每次调用系统函数的,都会在表里查找这个系统调用号,找到后放在寄存器中(eax),当切换到系统内核时,根据这个系统调用号,找到执行例程的函数名,从而找出函数的入口地址。
在内核态下,CPU可执行任何指令,在用户态下CPU只能执行非特权指令。当CPU处于内核态,可以随意进入用户态;而当CPU处于用户态,只能通过中断的方式进入内核态。一般程序一开始都是运行于用户态,当程序需要使用系统资源时,就必须通过调用软中断进入内核态。
内核态、用户态的切换
最新推荐文章于 2024-03-26 08:00:00 发布