64位地址采用4层地址映射,如下图:
另外64位地址时支持的物理内存最大为64T,见e820.c中MAX_ARCH_PFN的定义:
# define MAX_ARCH_PFN MAXMEM>>PAGE_SHIFT
其中MAXMEM为2^46,PAGE_SHIFT为12。
而在32位地址时最大支持的物理内存为64G(开启PAE选项)。
在/arch/x86/include/asm/page_64_types.h下有如下两行:
#define __START_KERNEL_map _AC(0xffffffff80000000, UL)
#define KERNEL_IMAGE_START _AC(0xffffffff80000000, UL)
这就是对空间大小的划分,在0xffffffff80000000之前的是给用户空间,在0xffffffff80000000之后的给内核空间