成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

梳理Linux內存尋址之分頁機制

系統 Linux 系統運維
分頁機制主要依賴硬件的實現。Linux采用的四級頁表只是為了最大化兼容不同的硬件實現,單就IA32架構的CPU來說,就有多種分頁實現,常規分頁機制,PAE機制等。不管Linux的分頁機制是怎樣實現的,CPU只按照它的分頁實現來解讀線性地址,所以Linux傳給CPU的線性地址必然是滿足硬件實現的。

【引自ShareHub的博客】在上一篇文章Linux內存尋址之分段機制中,我們了解邏輯地址通過分段機制轉換為線性地址的過程。下面,我們就來看看更加重要和復雜的分頁機制。

分頁機制在段機制之后進行,以完成線性—物理地址的轉換過程。段機制把邏輯地址轉換為線性地址,分頁機制進一步把該線性地址再轉換為物理地址。

硬件中的分頁

分頁機制由CR0中的PG位啟用。如PG=1,啟用分頁機制,并使用本節要描述的機制,把線性地址轉換為物理地址。如PG=0,禁用分頁機制,直接把段機制產生的線性地址當作物理地址使用。分頁機制管理的對象是固定大小的存儲塊,稱之為頁 (page)。分頁機制把整個線性地址空間及整個物理地址空間都看成由頁組成,在線性地址空間中的任何一頁,可以映射為物理地址空間中的任何一頁(我們把物理空間中的一頁叫做一個頁面或頁框(page frame))。

80386 使用4K字節大小的頁。每一頁都有4K字節長,并在4K字節的邊界上對齊,即每一頁的起始地址都能被4K整除。因此,80386把4G字節的線性地址空間,劃分為1G個頁面,每頁有4K字節大小。分頁機制通過把線性地址空間中的頁,重新定位到物理地址空間來進行管理,因為每個頁面的整個4K字節作為一個單位進行映射,并且每個頁面都對齊4K字節的邊界,因此,線性地址的低12位經過分頁機制直接地作為物理地址的低12位使用。

為什么使用兩級頁表

假設每個進程都占用了4G的線性地址空間,頁表共含1M個表項,每個表項占4個字節,那么每個進程的頁表要占據4M的內存空間。為了節省頁表占用的空間,我們使用兩級頁表。每個進程都會被分配一個頁目錄,但是只有被實際使用頁表才會被分配到內存里面。一級頁表需要一次分配所有頁表空間,兩級頁表則可以在需要的時候再分配頁表空間。

兩級頁表結構

兩級表結構的***級稱為頁目錄,存儲在一個4K字節的頁面中。頁目錄表共有1K個表項,每個表項為4個字節,并指向第二級表。線性地址的***10位(即位31~位32)用來產生***級的索引,由索引得到的表項中,指定并選擇了1K個二級表中的一個表。

兩級表結構的第二級稱為頁表,也剛好存儲在一個4K字節的頁面中,包含1K個字節的表項,每個表項包含一個頁的物理基地址。第二級頁表由線性地址的中間10 位(即位21~位12)進行索引,以獲得包含頁的物理地址的頁表項,這個物理地址的高20位與線性地址的低12位形成了***的物理地址,也就是頁轉化過程輸出的物理地址。

兩級頁表結構

頁目錄項

頁目錄項結構

◆第31~12位是20位頁表地址,由于頁表地址的低12位總為0,所以用高20位指出32位頁表地址就可以了。因此,一個頁目錄最多包含1024個頁表地址。

◆第0位是存在位,如果P=1,表示頁表地址指向的該頁在內存中,如果P=0,表示不在內存中。

◆第1位是讀/寫位,第2位是用戶/管理員位,這兩位為頁目錄項提供硬件保護。當特權級為3的進程要想訪問頁面時,需要通過頁保護檢查,而特權級為0的進程就可以繞過頁保護。

◆第3位是PWT(Page Write-Through)位,表示是否采用寫透方式,寫透方式就是既寫內存(RAM)也寫高速緩存,該位為1表示采用寫透方式

◆第4位是PCD(Page Cache Disable)位,表示是否啟用高速緩存,該位為1表示啟用高速緩存。

◆第5位是訪問位,當對頁目錄項進行訪問時,A位=1。

◆第7位是Page Size標志,只適用于頁目錄項。如果置為1,頁目錄項指的是4MB的頁面,請看后面的擴展分頁。

◆第9~11位由操作系統專用,Linux也沒有做特殊之用。

頁面項

頁面項結構

80386的每個頁目錄項指向一個頁表,頁表最多含有1024個頁面項,每項4個字節,包含頁面的起始地址和有關該頁面的信息。頁面的起始地址也是4K的整數倍,所以頁面的低12位也留作它用。

第31~12位是20位物理頁面地址,除第6位外第0~5位及9~11位的用途和頁目錄項一樣,第6位是頁面項獨有的,當對涉及的頁面進行寫操作時,D位被置1。

4GB的內存只有一個頁目錄,它最多有1024個頁目錄項,每個頁目錄項又含有1024個頁面項,因此,內存一共可以分成1024×1024=1M個頁面。由于每個頁面為4K個字節,所以,存儲器的大小正好最多為4GB。

#p#

線性地址到物理地址的轉換

32位線性地址到物理地址的轉換

1.CR3包含著頁目錄的起始地址,用32位線性地址的***10位A31~A22作為頁目錄的頁目錄項的索引,將它乘以4,與CR3中的頁目錄的起始地址相加,形成相應頁表的地址。

2.從指定的地址中取出32位頁目錄項,它的低12位為0,這32位是頁表的起始地址。用32位線性地址中的A21~A12位作為頁表中的頁面的索引,將它乘以4,與頁表的起始地址相加,形成32位頁面地址。

3.將A11~A0作為相對于頁面地址的偏移量,與32位頁面地址相加,形成32位物理地址。

擴展分頁

從奔騰處理器開始,Intel微處理器引進了擴展分頁,它允許頁的大小為4MB。


擴展分頁

在擴展分頁的情況下,分頁機制把32位線性地址分成兩個域:***10位的目錄域和其余22位的偏移量。

頁面高速緩存

頁面高速緩存

由于在分頁情況下,每次存儲器訪問都要存取兩級頁表,這就大大降低了訪問速度。所以,為了提高速度,在386中設置一個最近存取頁面的高速緩存硬件機制,它 自動保持32項處理器最近使用的頁面地址,因此,可以覆蓋128K字節的存儲器地址。當進行存儲器訪問時,先檢查要訪問的頁面是否在高速緩存中,如果在, 就不必經過兩級訪問了,如果不在,再進行兩級訪問。平均來說,頁面高速緩存大約有98%的***率,也就是說每次訪問存儲器時,只有2%的情況必須訪問兩級分頁機構。這就大大加快了速度。

Linux中的分頁機制

Linux使用了一個適合32位和64位系統的分頁機制。

Linux分頁模型

◆頁全局目錄

◆頁***目錄

◆頁中間目錄

◆頁表

頁全局目錄包含若干頁上級目錄的地址,頁上級目錄又依次包含若干頁中間目錄的地址,而頁中間目錄又包含若干頁表的地址。每一個頁表項指向一個頁框。線性地址因此被分成五個部分。圖中沒有顯示位數,因為每一部分的大小與具體的計算機體系結構有關。

對于沒有啟用物理地址擴展的32位系統,兩級頁表已經足夠了。從本質上說,Linux通過使“頁上級目錄”位和“頁中間目錄”位全為0,徹底取消了頁上級目錄和頁中間目錄字段。不過,頁上級目錄和頁中間目錄在指針序列中的位置被保留,以便同樣的代碼在32位系統和64位系統下都能使用。內核為頁上級目錄和頁中間目錄保留了一個位置,這是通過把它們的頁目錄項數設置為1,并把這兩個目錄項映射到頁全局目錄的一個合適的目錄項而實現的。

啟用了物理地址擴展的32 位系統使用了三級頁表。Linux的頁全局目錄對應80×86 的頁目錄指針表(PDPT),取消了頁上級目錄,頁中間目錄對應80×86的頁目錄,Linux的頁表對應80×86的頁表。

***,64位系統使用三級還是四級分頁取決于硬件對線性地址的位的劃分。

總結

這里我們不討論代碼實現,只關注原理。從上面的討論可以看到分頁機制主要依賴硬件的實現。Linux采用的四級頁表只是為了***化兼容不同的硬件實現,單就IA32架構的CPU來說,就有多種分頁實現,常規分頁機制,PAE機制等。

我們雖然討論的是Linux的分頁機制,實際上我們用了大部分篇幅來討論Intel CPU的分頁機制實現。因為Linux的分頁機制是建立在硬件基礎之上的,不同的平臺需要有不同的實現。Linux在軟件層面構造的虛擬地址,最終還是要通過MMU轉換為物理地址,也就是說,不管Linux的分頁機制是怎樣實現的,CPU只按照它的分頁實現來解讀線性地址,所以Linux傳給CPU的線性地址必然是滿足硬件實現的。例如說:Linux在32位CPU上,它的四級頁表結構就會兼容到硬件的兩級頁表結構。可見,Linux在軟件層面上做了一層 抽象,用四級頁表的方式兼容32位和64位CPU內存尋址的不同硬件實現。

參考資料

《深入理解Linux內核》

《深入分析Linux內核源碼》

責任編輯:火鳳凰 來源: ShareHub博客
相關推薦

2015-10-08 17:25:38

分段內存尋址Linux

2020-09-30 06:50:35

Linux內存尋址

2025-04-15 06:00:00

2009-12-17 11:00:47

Linux內存管理

2022-02-16 07:47:48

flask分頁SQLAlchemy

2013-09-29 15:11:46

Linux運維內存管理

2015-06-04 09:38:39

Java垃圾回收機

2025-01-02 11:06:22

2021-07-07 11:35:17

Linux內存段尋址

2010-06-02 11:33:26

Linux 內存監控

2021-11-22 10:00:33

鴻蒙HarmonyOS應用

2025-03-26 00:21:00

2011-01-18 09:51:59

Linux磁盤分區

2017-04-01 16:30:15

cassandrajava數據庫

2023-10-18 13:31:00

Linux內存

2021-10-08 07:53:01

Go 尋址元素

2020-06-22 08:30:42

Linux內存手動釋放

2011-01-18 10:25:19

Linux磁盤分區

2025-04-09 05:22:00

2012-02-01 13:57:40

內存緩存機制
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 中文字幕在线观看一区 | 99免费在线观看 | 拍真实国产伦偷精品 | 一区二区免费 | 国产午夜精品视频 | 久青草影院 | 91久久久久 | 少妇特黄a一区二区三区88av | 国产精品高潮呻吟久久 | 日本爱爱| 精品一区二区免费视频 | 日本中文字幕在线观看 | av永久| 亚洲精品中文字幕在线 | 亚洲成人av一区二区 | 精品国产31久久久久久 | 91最新入口 | 成人亚洲视频 | 97国产超碰 | 在线视频国产一区 | 韩国久久精品 | 久久99蜜桃综合影院免费观看 | 日本不卡免费新一二三区 | 嫩草视频在线免费观看 | 91在线免费视频 | 人人草人人干 | 蜜桃一区二区三区 | 亚洲影音先锋 | 在线色网| 久操亚洲| 亚洲欧美一区二区三区国产精品 | 久久亚洲91 | 免费黄色网址视频 | 精品久久久久久亚洲精品 | 福利片一区二区 | 成人二区| 亚洲一区二区日韩 | 欧美日韩1区2区3区 欧美久久一区 | 日韩靠逼| 日韩成人在线免费观看 | 天堂素人约啪 |