百科问答小站 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的地址,这样无论进程如何切换,内核页表都不需要换出。

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




  

相关话题

  linux在系统调用进入内核时,为什么要将参数从用户空间拷贝到内核空间?不能直接访问,或是使用memcpy吗?非要使用copy_from_user才行吗? 
  你认为 Linux 最差的用户体验是什么? 
  C语言编写时,将参数传递跨越多个函数的方式是否是妥当的? 
  腾讯为什么对开发 Linux 版本的 QQ 不太积极? 
  神舟飞船上的计算机使用什么操作系统,为什么是自研发不是 Linux? 
  如何评价 360 安全卫士 for Linux? 
  C 语言如何不用 goto、多处 return 进行错误处理? 
  CentOS 8 已经停止维护,CentOS 7 也将停止维护,之后我们用什么? 
  Linux 作为服务器操作系统的优势是什么? 
  为什么Markdown在2004年才出现,而推广更晚? 

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





© 2025-03-06 - tinynew.org. All Rights Reserved.
© 2025-03-06 - tinynew.org. 保留所有权利