淺析linux內核內存管理之PAE
早期Intel處理器從80386到Pentium使用32位物理地址,理論上,這樣可以訪問4GB的RAM。然而,大型服務器需要大于4GB的RAM來同時運行數以千計的進程,近幾年來這對Intel造成了壓力,所以必須擴展32位80x86所支持的RAM容量。 Intel通過在它的處理器上把管腳數從32增加到36已經滿足了這些需求,可以尋址64GB。同時引入了一種新的分頁機制PAE(Physical Address Extension,物理地址擴展)把32位線性地址轉換為36位物理地址才能使用所增加的物理內存,通過設置CR4的第5位來開啟對PAE的支持。引入PAE就是為了訪問大于4GB的RAM,線性地址仍然是32位,而物理地址是36位。 64GB的RAM被分為2^24個頁框,頁表項的物理地址字段從20位擴展到了24位。PAE表項必須包含12個標志位和24個物理地址位,總數之和為36,頁表項大小從32位變?yōu)?4位。這樣原來一個頁框有1024個entry,現在有512個entry。開啟PAE的80x86 32位使用的是三級頁表,第一級是新引入的PDPT(頁目錄指針表,相當于PGD了),第二級是PMD,第三級是PTE。PDPT只有4個entry,每個對應1GB RAM,每個entry 是64位。CR3中有27位作為PDPT的起始地址。 在開啟PAE前,CR3中用20來存儲頁目錄的起始地址;開啟PAE后,用27位來存儲page directory pointer table的起始地址。 下邊分兩種情況來討論,一個是PS=0,一個是PS=1: 當CR4的第5位被置位(開啟PAE),第4位被置位(開啟PSE)
當CR4的第5位被置位(開啟PAE),第4位被清除(關閉PSE)
如何訪問64GB? 從上邊的三級分頁可以看到2^2*2^9*2^9*2^11=4GB,仍然訪問的是4GB。訪問64GB方法如下:
但是實際上是不能訪問這么大的內存的,實際可用的內存被限制在16GB,因為如果有64GB,那么每個struct page結構需要32字節(jié),總共512MB,這樣ZONE_NORMAL的內核地址空間就被大量占用,這樣是不允許的。
|
|