虛擬地址到物理地址轉(zhuǎn)換過程
虛擬地址和物理地址都被劃分了兩部分:
虛擬地址由虛擬頁面號VPN和虛擬地址偏移VA offset兩部分組成。同樣,物理地址由物理頁幀號PFN和物理地址偏移PA offset兩部分組成。
虛擬地址轉(zhuǎn)換成物理地址時,需要將VPN轉(zhuǎn)成PFN。PA offset通常就是VA offset。
所以物理地址 = PFN + VA offset
這里的核心就是VPN到PFN的映射,而VPN到PFN的映射關(guān)系是通過頁表記錄。就是說,頁表存儲了VPN和PFN的映射關(guān)系,MMU根據(jù)VPN,在頁表中找到PFN,再把PFN和VA offset相加,就得到了物理地址,從而將虛擬地址轉(zhuǎn)為物理地址。
這里要區(qū)分一下,頁表存儲了VA到PA的映射關(guān)系,所以說找到頁表就找到了物理地址。但是這個頁表是軟件提供的,MMU只負(fù)責(zé)將虛擬地址翻譯成物理地址,翻譯的依據(jù)就是頁表,MMU本身不負(fù)責(zé)創(chuàng)建頁表。所以說,在開啟MMU之前,系統(tǒng)就要提前建立好虛擬地址到物理地址的映射關(guān)系,然后保存到頁表中,這樣開啟MMU時,MMU才能正確找到對應(yīng)的物理地址。
頁表在哪
頁表都存儲在物理內(nèi)存中, MMU將虛擬地址轉(zhuǎn)換為物理地址,需要訪問物理內(nèi)存中對應(yīng)的頁表。
實(shí)際上,頁表通常就是用一個數(shù)組來表示。
這里可能會一些疑問:
疑問:放到物理內(nèi)存,每次轉(zhuǎn)換都要訪問內(nèi)存,速度不慢嗎?
答:慢。怎么解決呢?如果有cache是不是就很快了?是的,這塊cache就叫TLB。
疑問:都放到物理內(nèi)存,占用物理內(nèi)存空間不大嗎?
答:大,怎么解決?多級頁表+缺頁異常!多級頁表可以減少內(nèi)存占用,而通常只需將一級頁表存儲到物理內(nèi)存,查找的時候,找不到二級頁表,觸發(fā)一個缺頁異常,這時再分配頁表,從而節(jié)省內(nèi)存。
關(guān)于頁表放到物理內(nèi)存的問題,涉及到cache和其他的一些知識,內(nèi)容很多且比較復(fù)雜,暫時不深究,知道頁表是放在內(nèi)存中的即可。
-
Linux
+關(guān)注
關(guān)注
87文章
11465瀏覽量
212817 -
內(nèi)存
+關(guān)注
關(guān)注
8文章
3109瀏覽量
75001 -
MMU
+關(guān)注
關(guān)注
0文章
92瀏覽量
18641
發(fā)布評論請先 登錄
操作系統(tǒng)中的邏輯地址和物理地址
請問ARM虛擬地址 物理地址 加載地址 運(yùn)行地址的聯(lián)系是什么?
為什么MMU的地址映射中物理地址會跳變?
【HarmonyOS】虛擬地址<->物理地址是如何映射的
物理地址到虛擬地址的轉(zhuǎn)換步驟
linux kernel實(shí)現(xiàn)物理地址到虛擬地址空間的切換方法
RT-Thread smart內(nèi)存虛擬地址到物理地址的轉(zhuǎn)換是一個什么樣的流程
用戶態(tài)得到虛擬地址對應(yīng)的物理地址

鴻蒙內(nèi)核中虛擬地址與物理地址之間是如何映射的

虛擬地址物理地址等眾多地址及MMU相關(guān)知識

虛擬地址翻譯物理地址的流程有哪些呢?

Linux系統(tǒng)為什么需要引入虛擬地址

Linux虛擬地址空間和物理地址空間的關(guān)系

評論