3_13_DOUBLEWEI 768*(2^22),即0xC0000000,即3072M,即3G。

来源:互联网 发布:网页美工招聘 编辑:程序博客网 时间:2024/05/02 03:03

 /sys/i386/include/pmap.h中与页表相关宏值的含义

/sys/i386/include/pmap.h中定义的宏值:
94  /*
95   * Size of Kernel address space.  This is the number of page table pages
96   * (4MB each) to use for the kernel.  256 pages == 1 Gigabyte.
97   * This **MUST** be a multiple of 4 (eg: 252, 256, 260, etc).
98   */
99  #ifndef KVA_PAGES
100  #ifdef PAE
101  #define KVA_PAGES       512
102  #else
103  #define KVA_PAGES       256
104  #endif
105  #endif
106
107  /*
108   * Pte related macros
109   */
110  #define VADDR(pdi, pti) ((vm_offset_t)(((pdi) 0xffbfffff
138   */
139  #ifdef SMP
140  #define MPPTDI          (NPDEPTD-1)     /* per cpu ptd entry */ !
141  #define KPTDI           (MPPTDI-NKPDE)  /* start of kernel virtual pde's */
142  #else
143  #define KPTDI           (NPDEPTD-NKPDE)/* start of kernel virtual pde's */
144  #endif  /* SMP */
145  #define PTDPTDI         (KPTDI-NPGPTD)  /* ptd entry that points to ptd! */
KVA_PAGES是内核地址空间所占的页表页面总数,此处定义为256,因此内核地址空间的大小
    为1G字节。
VADDR是根据页表目录索引和页表索引得到对应页面的起始虚拟地址,其中pdi是页表目录索引,
    即地址在第22到31比特中的偏移,pti是页表索引,即地址在第12到21比特中的偏移。
NKPT是内核在vm系统工作之前所需的页表页面的数目。对于非PAE的i386而言,其中有18个
    页面是用来存放指向vm_page结构体的页表的。因为4G空间共有1M个页面,因此需要1M个
    vm_page结构体来组织,每个vm_page结构体的大小是72字节,一共需要72M的空间,
    即18432个页面,每个页表页面上可存储1024个页表项,因此,对应于18432个页面的页表项
    共需18个页面来存储。此处定义的30个页面中的剩余12个页面是对内核在此过程中的其它
    内存需求所需页表空间的估计量。全局变量nkpt初始化为NKPT,之后将随着内核地址空间的
    增长而递增。
NKPDE是内核所占的页表目录项的总数,对于非smp,NKPDE就是KVA_PAGES,即内核占用的页表
    页面总数,对于smp,则比KVA_PAGES少1,相当于保留了4M的空间。
MPPTDI是smp环境中用于每个cpu的页表目录项的索引,它是1024个页表目录项中的最后一个,
    表示的是地址空间中最顶端的4M空间(0xffc00000-0xffffffff),因此此处将其定义为1023。
KPTDI是第一个内核页表目录项的索引,对于smp环境,内核页表目录项的总数NKPDE是255,
    而其顶端紧邻NPPTDI,因此KPTDI就是1023减去255,即768。
PTDPTDI是指向页表目录自身所属页表页面的页表目录项的索引,页表目录的页表页面紧邻在
    第一个内核页表页面的下方,而页表目录项只占一个页表页面,因此PTDPTDI就等于768减去1,

即767。
根据上述定义,4G虚拟地址空间的页表目录项可划分如下:0 ... 766 | 767 | 768 ... 1022 | 1023 。
/sys/i386/include/param.h中定义的宏值:
77  #define PAGE_SHIFT      12              /* LOG2(PAGE_SIZE) */
78  #define PAGE_SIZE       (1
PAGE_SHIFT是页表索引在32位地址中的起始比特。
PAGE_SIZE是页面尺寸,此处定义为4096字节。
PAGE_MASK是一个低12比特全1的常量。
NPTEPG是一个页面中能够存放的页表项的数目,对于非PAE的i386而言,
    一个页表项占4个字节,因此NPTEPG为1024。
NPGPTD是页表目录所占用的页面数目,对于非PAE的情况,页表目录共需
    4*(2^10)=4096字节,即1个页面。
PDRSHIFT是页表目录索引在32位地址中的起始比特。
NBPTD是页表目录所占用的字节总数,因为NPGPTD是1,所以NBPTD就是4096。
NPDEPTD是页表目录项的总数,对于非PAE的i386而言,一个页表目录项占4个字节,
    因此NPDEPTD是1024。
NPDEPG是一个页面中存放的页表目录项的总数,即1024。
NBPDR是同属一个页表目录项的字节数目,即4M。
PDRMASK是一个低22比特全1的常量。
KERNBASE是在/sys/i386/include/vmparam.h中定义的:
142  #define KERNBASE                VADDR(KPTDI, 0)
实际上就是根据第一个内核页表目录项的索引KPTDI算出其对应的虚拟地址,
计算方法为768*(2^22),即0xC0000000,即3072M,即3G。