linux – 为什么我们在x86上需要zone_highmem?

linux内核中,mem_map是包含所有“struct page”描述符的数组.这些页面包含lowmem中的128MiB内存,用于动态映射highmem.

由于lowmem大小为1GiB,因此mem_map数组只有1GiB / 4KiB = 256KiB条目.如果每个条目大小为32字节,则mem_map内存大小= 8MiB.但是如果我们可以使用mem_map来映射所有4GiB物理内存(如果我们在x86-32上有这么多物理内存可用),那么mem_map数组将占用32MiB,这不是很多内核内存(或者我错了吗?) .

所以我的问题是:为什么我们首先需要将低128MiB用于间接高精度映射?换句话说,为什么不直接在内核空间中映射所有那些最大4GiB物理内存(如果可用)?

注意:如果我对上面的内核源代码的理解有误,请更正.谢谢!

最佳答案
看这里:http://www.xml.com/ldd/chapter/book/ch13.html

内核低内存是“真正的”内存映射,在x86上使用32位指针进行寻址.

内核高内存是“虚拟”内存映射,使用x86上的虚拟结构进行寻址.

您不希望将它全部映射到内核地址空间,因为您无法始终解决所有问题,并且您需要大部分内存用于虚拟内存段(虚拟,页面映射的进程空间).

至少,这就是我读它的方式.哇,这是你提出的一个复杂的问题.

为了引起更多的困惑,第13章讨论了一些无法解决32位空间的PCI设备,这是我之前评论的起源:

在x86上,由于DMA寻址问题,一些内核内存使用仅限于第一千兆字节的内存.我不是100%熟悉这个主题,但PCI总线上有DMA的共处模式.这可能就是你在看的东西.

相关文章

Linux中的ARP防火墙主要用于防御ARP欺骗攻击,其效果取决于多...
insmod和modprobe加-f参数导致Invalid module format错误 这...
将ArchLinux安装到U盘 几个月前入门Arch的时候上网搜了不少安...
1、安装Apache。 1)执行如下命令,安装Apache服务及其扩展包...
一、先说一下用ansible批量采集机器信息的实现办法: 1、先把...
安装配置 1. 安装vsftpd 检查是否安装了vsftpd # rpm -qa | ...