百科问答小站 logo
百科问答小站 font logo



页表到底是保存在内核空间中还是用户空间中? 第1页

  

user avatar   bei-ji-85 网友的相关建议: 
      

第一个问题,答案很明确:页表在内核空间中

至于题主问的访问页表是否会陷入内核,这要看你是:

1. CPU地址翻译的过程中的页表访问;
2. 增加修改页表项。

如果是第一种,CPU地址翻译,那么这种访问是硬件完成的,整个过程不需要代码参与,没有任何性能上的损失。
如果是第二种,是会慢一些。

这种慢是为了安全,如果页表在用户空间,那么用户就可能自己修改页表,映射任意的内存地址,访问任何内存,甚至是直接操作硬件,进程间、内核的隔离保护就失去了意义。

而且,应用程序虽然可能频繁的malloc或者free,但在页表层面上,并不会频繁的创建、删除页表项,主要原因是,malloc/free操作的接口都是C库的接口,在C库里,还有另外一层次的封装,来保证不会频繁的提交页表的操作申请。

第二个问题:内核页表一般指的是内核地址空间的页表,用户页表表示用户地址空间的。

用32位操作系统作为例子,虽然操作系统有N个进程,每个进程都有各自页表,但内核的页表只有一个。当发生进程切换时,只有用户页表被切换走,内核页表并不改变。

具体的做法是,把地址空间的高1G或者2G的地址都固定划分给内核,用户进程只能使用低3G或者低2G的地址,这样无论进程如何切换,内核页表都不需要换出。

这也就是内核页表和用户页表的区别。




  

相关话题

  Linus 真心诚意地夸过哪些人或技术? 
  企业用哪个版本的 Linux? 
  操作系统能否知道自己处于虚拟机中? 
  大型c++项目在linux下如何调试? 
  Linux不同发行版之间可以互换吗? 
  2021年有没有什么适合Linux的笔记本? 
  linux在系统调用进入内核时,为什么要将参数从用户空间拷贝到内核空间?不能直接访问,或是使用memcpy吗?非要使用copy_from_user才行吗? 
  因为折腾了linux导致业务水平跟不上怎么有什么较好的处理办法? 
  操作系统能不能继续分两部分:硬件相关和硬件无关?并且让驱动只依赖硬件相关部分而不依赖操作系统? 
  KDE如何配置得漂亮大气? 

前一个讨论
为什么51单片机编程喜欢用unsigned(无符号)类型定义变量呢直接用 int.char..不好吗?
下一个讨论
中断为什么一定要在内核空间处理,如果把中断放到用户态处理可能会产生什么问题?





© 2025-05-14 - tinynew.org. All Rights Reserved.
© 2025-05-14 - tinynew.org. 保留所有权利