程序經(jīng)過編譯后,變成了可執(zhí)行的文件,可執(zhí)行文件主要包括代碼和數(shù)據(jù)兩部分,代碼是只讀的,數(shù)據(jù)則是可讀可寫的。
可執(zhí)行文件由操作系統(tǒng)加載到內(nèi)存中,交由CPU去執(zhí)行,現(xiàn)在問題來了,CPU怎么去訪問代碼和數(shù)據(jù)?,訪問的方式經(jīng)歷過四個(gè)階段:
1.直接訪問
2.段基址+段偏移地址
3.段選擇子+段偏移地址
4.虛擬地址
現(xiàn)代操作系統(tǒng)采用的是虛擬地址,這也是本篇文章闡述的重點(diǎn),但虛擬地址是由13階段發(fā)展而來的,所以也有必要闡述13三種訪問方式。
直接訪問
直接訪問很好理解,程序經(jīng)過編譯后,生成了可執(zhí)行文件,編譯器給每行數(shù)據(jù)和代碼分配了一個(gè)唯一的地址,如下圖

可執(zhí)行文件
如上圖可執(zhí)行文件中10001024之間的地址,加載到內(nèi)存后,內(nèi)存的地址也是10001024,在可執(zhí)行文件中分配的唯一地址就是內(nèi)存中的物理地址,這就叫直接訪問,直接定訪問干脆直接,沒有那些彎彎繞。
當(dāng)時(shí)問題也不少,例如同一個(gè)可執(zhí)行文件不能同時(shí)執(zhí)行,它們的物理地址一樣,沖突了,必須一個(gè)接一個(gè),還有就是可執(zhí)行文件的物理地址已經(jīng)固定了,如果想在其它物理地址運(yùn)行,必須地重新編譯,生成新的物理地址。
可見直接定位是計(jì)算機(jī)發(fā)展早期的產(chǎn)物,早期沒有那么多的程序要運(yùn)行,程序都是一個(gè)接一個(gè)地去執(zhí)行的,因此早期這種定位比較簡(jiǎn)單,直接高效。
段基址+段偏移地址
隨著多任務(wù)需求的來臨,現(xiàn)在內(nèi)存中要并發(fā)運(yùn)行多個(gè)程序,雖然采用直接定位把每個(gè)不同的程序放在不同的內(nèi)存段中,勉強(qiáng)可以滿足,但是一個(gè)可執(zhí)行文件不能同時(shí)運(yùn)行多個(gè),另外程序必須在固定的物理地址運(yùn)行,靈活性大大減弱,調(diào)度起來也是非常麻煩,因此CPU設(shè)計(jì)師和操作系統(tǒng)開發(fā)人員發(fā)明了段基址+段偏移地址。
Inter 8086處理器就是采用這種定位方式,我們知道可執(zhí)行文件主要分為數(shù)據(jù)段和內(nèi)存段,如下圖

由上圖紅色部分可知,0,4,8就是相對(duì)于數(shù)據(jù)段的偏移地址,0,4,8,12是相對(duì)于代碼段的偏移地址。
在可執(zhí)行文件中,一個(gè)段的偏移地址是固定的,無論可執(zhí)行文件加載到內(nèi)存的什么位置,這個(gè)偏移地址是固定的。
當(dāng)可執(zhí)行文件加載到內(nèi)存時(shí),先在內(nèi)存中分配一個(gè)數(shù)據(jù)段和代碼段,這兩個(gè)段理論上可以不挨著,一般情況下,代碼段和數(shù)據(jù)段是挨著的,代碼段和數(shù)據(jù)段在內(nèi)存中都有一個(gè)起始地址,這個(gè)起始地址就叫做段基址,這個(gè)段基址是放在段寄存器里,例如代碼段基址放在CS寄存器,數(shù)據(jù)段基址放在DS寄存器,當(dāng)然還有其他的段例如棧段,棧段剛開始大小為0,隨著程序的運(yùn)行入棧,出棧,這個(gè)棧段在不斷擴(kuò)展,當(dāng)然,咋們主要說的是數(shù)據(jù)段和代碼段,棧段只是簡(jiǎn)單帶過。
假設(shè)可執(zhí)行文件被加載到了內(nèi)存中,如下圖

如上圖所示,代碼段被布局到以0x00600000為起始地址的內(nèi)存中,數(shù)據(jù)段被布局到以0x00601000為起始地址的內(nèi)存中。
當(dāng)CPU開始執(zhí)行代碼段的第一條指令時(shí),會(huì)將代碼段的起始地址放入到段寄存器中,此時(shí)CS代碼段寄存器中存儲(chǔ)的就是0x00600000,然后開始從起始地址處開始執(zhí)行第一條代碼指令,此時(shí)把代碼指令的偏移地址放入到IP寄存器中,IP寄存器存儲(chǔ)的就是0,所以CPU要定位一條代碼指令時(shí)通過CS:IP的方式定位的,如下圖所示

定位指令
當(dāng)CPU執(zhí)行到0x00600000處的代碼指令時(shí),該指令為MOV AX,[0],該指令的意思是把地址0處的數(shù)據(jù)存儲(chǔ)到AX寄存器,這個(gè)0就是數(shù)據(jù)段的偏移地址,此時(shí)CPU會(huì)將數(shù)據(jù)段的起始地址加入到DS段寄存器中,然后將數(shù)據(jù)段寄存器的值+偏移地址即0x00601000+0=0x00601000定位到了數(shù)據(jù)123,然后將123存儲(chǔ)到AX寄存器中。

定位數(shù)據(jù)
上述過程就是【段基址+段偏移地址】的定位方式,之所以把起始地址加入到寄存器中,也是為了后續(xù)再執(zhí)行指令或者獲取數(shù)據(jù)時(shí),可以直接從寄存器獲取,加快CPU執(zhí)行的速度。
段選擇子+段偏移地址
【段選擇子+段偏移地址】與【段基址+段偏移地址】有些相似之處,之所以采用【段選擇子+段偏移地址】主要是為了安全,原來的【段基址+段偏移地址】方式,程序員可以直接跳轉(zhuǎn)到其他代碼段和數(shù)據(jù)段,沒有任何限制,安全性全依賴于程序員的職業(yè)操守和水平,因此CPU設(shè)計(jì)者就發(fā)明了【段選擇子+段偏移地址】。
【段選擇子+段偏移地址】中的段選擇子可以認(rèn)為是一個(gè)索引,這個(gè)索引指向了全局段描述符表中的一項(xiàng),全局段描述表存儲(chǔ)在內(nèi)存中,它的起始地址存儲(chǔ)在全局段描述符寄存器中。
全局段描述符表有很多個(gè)段描述符,每個(gè)段描述占用8個(gè)字節(jié),這個(gè)段描述符里面就包括了段基址,另外還有一些安全性相關(guān)的描述信息例如段的可讀,可寫,可執(zhí)行,段的大小等。
段選擇子存儲(chǔ)在了段寄存器中,總共16位,其中高13位就是全局段描述表的索引。
當(dāng)CPU開始執(zhí)行代碼段的第一條指令時(shí),會(huì)將代碼段的選擇子放入到CS段寄存器中,然后CPU從段寄存器中的獲取段選擇子,然后截取選擇子的高13位獲取索引,然后根據(jù)全局描述符表寄存器的地址找到全局描述符表的起始地址,根據(jù)起始地址+索引*8找到段描述符,然后根據(jù)段描述符獲取段的基址,段的基址加上ip寄存器中的偏移地址就是指令的物理地址,如下圖所示1~6步驟所示

定位指令
當(dāng)CPU執(zhí)行到0x00600000處的代碼指令時(shí),該指令為MOV AX,[0],該指令的意思是把地址0處的數(shù)據(jù)存儲(chǔ)到AX寄存器,這個(gè)0就是數(shù)據(jù)段的偏移地址,此時(shí)CPU會(huì)將數(shù)據(jù)段的選擇子加入到DS段寄存器中,然后CPU獲取段選擇的高13位獲取索引,然后根據(jù)全局描述符表寄存器的地址找到全局描述符表的起始地址,根據(jù)起始地址+索引*8找到段描述符,然后根據(jù)段描述符獲取段的基址,段的基址加上數(shù)據(jù)段的偏移地址就是數(shù)據(jù)的物理地址,如下圖1~6步驟所示

定位數(shù)據(jù)
上述過程就是【段選擇子+段偏移地址】的定位方式。
虛擬地址
現(xiàn)代的操作系統(tǒng)和CPU未打開分頁(yè)時(shí)采用的是【段選擇子+段偏移地址】訪問代碼和數(shù)據(jù),而一旦打開分頁(yè)時(shí),經(jīng)過【段選擇子+段偏移地址】得到的地址不再是物理地址了,而是叫做虛擬地址,默認(rèn)則是打開分頁(yè)的。
現(xiàn)代的操作系統(tǒng)和CPU采用的平坦模型,平坦模型就是整個(gè)內(nèi)存就一個(gè)段,因此段基址就是0,段偏移地址就等于虛擬地址了。
下面將從以下幾個(gè)方面來闡述虛擬地址相關(guān)的話題。
1.什么是虛擬地址,物理地址,虛擬地址空間,物理地址空間,虛擬內(nèi)存,物理內(nèi)存?
2.什么是進(jìn)程虛擬地址空間?
3.什么是虛擬頁(yè),物理頁(yè)?
4.什么是頁(yè)表?
5.虛擬地址怎么樣訪問物理內(nèi)存?
什么是虛擬地址,物理地址,虛擬地址空間,物理地址空間,虛擬內(nèi)存,物理內(nèi)存?
虛擬地址空間是虛擬地址的集合,假設(shè)虛擬地址空間是N位的,它的地址范圍為{02的N次方-1}即它有2的N次方個(gè)虛擬地址,例如16位的虛擬地址空間,它的地址范圍為{065535},這意味著16位的虛擬地址空間有65536個(gè)虛擬地址。
物理地址空間是物理地址的集合,假設(shè)物理地址空間有M個(gè)字節(jié),它的地址范圍為{0M-1},M不一定是2的多少次冪,例如M=100,表示物理地址空間大小為100個(gè)字節(jié),它的地址范圍為{099},通常情況下物理地址空間是2的冪次方,例如65536,這也是為了計(jì)算機(jī)方便處理而已,并不是強(qiáng)制要求的。
物理內(nèi)存可以認(rèn)為是一個(gè)的物理字節(jié)數(shù)組,每個(gè)物理地址指向這個(gè)物理字節(jié)數(shù)組中的一項(xiàng)。
虛擬內(nèi)存也一樣,它也可以認(rèn)為是一個(gè)物理字節(jié)數(shù)組,不過這個(gè)字節(jié)數(shù)組是存儲(chǔ)在磁盤上。
物理地址空間是物理內(nèi)存的范圍,虛擬地址空間是虛擬內(nèi)存的范圍,物理地址空間中的每個(gè)物理地址都是實(shí)打?qū)嵉刂赶蛄司唧w的存儲(chǔ)單元,虛擬地址空間中每個(gè)虛擬地址指向哪里有3種情況:
a.未分配,這個(gè)虛擬地址僅僅是個(gè)數(shù)字而已,沒有任何指向。
b.未緩沖,這個(gè)虛擬地址指向了磁盤的某個(gè)字節(jié)存儲(chǔ)單元,里面存儲(chǔ)了指令或者數(shù)據(jù)。
c.已緩沖,這個(gè)虛擬地址指向了物理內(nèi)存的某個(gè)字節(jié)存儲(chǔ)單元,里面存儲(chǔ)了指令或者數(shù)據(jù)。
2.什么是進(jìn)程虛擬地址空間?
操作系統(tǒng)加載可執(zhí)行文件后,創(chuàng)建了一個(gè)進(jìn)程,這個(gè)進(jìn)程就有了自己的虛擬地址空間,每個(gè)進(jìn)程的虛擬地址空間都一樣,如下圖所示

進(jìn)程虛擬地址空間
如上圖所示,進(jìn)程的虛擬地址空間被統(tǒng)一劃分成了多個(gè)固定區(qū)域,例如代碼區(qū),數(shù)據(jù)區(qū),堆區(qū),共享區(qū),棧區(qū),內(nèi)核區(qū)。
代碼區(qū)和數(shù)據(jù)區(qū)域:來自于可執(zhí)行文件,代碼區(qū)和數(shù)據(jù)區(qū)挨著,代碼區(qū)總是在0x0040000地址以上,0x0040000地址以下另有它用。
運(yùn)行時(shí)堆區(qū)域:它初始化大小為0,隨著動(dòng)態(tài)分配內(nèi)存(malloc),運(yùn)行時(shí)堆不斷往高地址方向擴(kuò)展,有個(gè)指針brk指向了堆的最高地址。
共享庫(kù)的內(nèi)存映射區(qū)域:這個(gè)區(qū)域是一些標(biāo)準(zhǔn)的系統(tǒng)庫(kù),這個(gè)共享庫(kù)在物理內(nèi)存中只存儲(chǔ)一份,每個(gè)進(jìn)程將這個(gè)區(qū)域的虛擬地址映射到同一份共享庫(kù)物理內(nèi)存上。
用戶棧區(qū)域:這個(gè)區(qū)域緊挨著內(nèi)核區(qū)域,處于高地址處,隨著用戶棧的出棧,入棧,動(dòng)態(tài)擴(kuò)展,入棧向低地址方向擴(kuò)展,出棧則向高地址方向收縮,棧頂指針存儲(chǔ)在棧寄存器(ESP)中。
內(nèi)核區(qū)域:這個(gè)區(qū)域是操作系統(tǒng)自己代碼,數(shù)據(jù),??臻g,內(nèi)核在物理內(nèi)存中只存儲(chǔ)一份,每個(gè)進(jìn)程將這個(gè)區(qū)域的虛擬地址映射到同一份內(nèi)核物理內(nèi)存上。

內(nèi)核和共享庫(kù)的映射
3.什么是虛擬頁(yè),物理頁(yè)?
現(xiàn)代操作操作和CPU將物理內(nèi)存按照固定的頁(yè)大小分成很多份,每一份叫做物理頁(yè)(PP),每一份有一個(gè)編號(hào)叫做物理頁(yè)號(hào)(PPN),這個(gè)物理頁(yè)大小通常是4KB,例如一個(gè)物理內(nèi)存大小為20KB,這個(gè)物理內(nèi)存可以分成5個(gè)物理頁(yè),那么物理頁(yè)號(hào)(PPN)就是0,1,2,3,4。
虛擬內(nèi)存也一樣,它的頁(yè)大小與物理內(nèi)存的頁(yè)大小相同,虛擬內(nèi)存也被分成了很多份,每一份叫做虛擬頁(yè)(VP),每一份的編號(hào)叫做虛擬頁(yè)號(hào)(VPN),例如假設(shè)虛擬頁(yè)大小為4KB,一個(gè)虛擬內(nèi)存大小為10KB,這個(gè)虛擬內(nèi)存可以分成2個(gè)虛擬頁(yè)(VP),虛擬頁(yè)號(hào)(VPN)就是0,1
每個(gè)物理頁(yè)存儲(chǔ)在物理內(nèi)存上,每個(gè)虛擬頁(yè)存儲(chǔ)在磁盤上,如下圖所示

虛擬內(nèi)存和物理內(nèi)存
上圖的虛擬內(nèi)存有8個(gè)虛擬頁(yè),物理內(nèi)存有6個(gè)物理內(nèi)存頁(yè),虛擬頁(yè)存儲(chǔ)在磁盤上,物理頁(yè)則存儲(chǔ)在DRARM上。
每個(gè)虛擬頁(yè)可以有三種狀態(tài),未分配,已緩沖,未緩沖
未分配:虛擬頁(yè)還沒有分配磁盤空間
已緩沖:虛擬頁(yè)緩沖或者映射在了物理頁(yè)上。
未緩沖:虛擬頁(yè)分配了磁盤空間,但沒有在物理頁(yè)上緩沖。
通常操作系統(tǒng)加載可執(zhí)行文件后,創(chuàng)建了一個(gè)進(jìn)程,這個(gè)進(jìn)程就有了虛擬地址空間,這并不意味著可執(zhí)行文件已經(jīng)從磁盤加載到內(nèi)存中了,操作系統(tǒng)只是為了進(jìn)程虛擬地址空間的每個(gè)區(qū)域分配了虛擬頁(yè)。
代碼和數(shù)據(jù)區(qū)域的虛擬頁(yè)被分配到了可執(zhí)行文件的適當(dāng)位置,此時(shí)虛擬頁(yè)狀態(tài)為未緩沖,虛擬頁(yè)指向了磁盤地址。
操作系統(tǒng)和共享庫(kù)的虛擬頁(yè)被映射到了物理內(nèi)存,因?yàn)椴僮飨到y(tǒng)和共享庫(kù)已經(jīng)在物理內(nèi)存了,這些虛擬頁(yè)的狀態(tài)為已緩沖。
用戶棧,運(yùn)行時(shí)堆的虛擬頁(yè)沒有任何分配,不占用任何空間,這些虛擬頁(yè)的狀態(tài)為未分配。
那么進(jìn)程虛擬地址空間的代碼和數(shù)據(jù),用戶棧,運(yùn)行時(shí)堆的物理內(nèi)存什么時(shí)候分配呢,答案就是處理器用虛擬地址執(zhí)行代碼,讀取數(shù)據(jù)時(shí),這個(gè)下一章闡述。
虛擬地址訪問物理內(nèi)存
先普及幾個(gè)概念:
VPO即虛擬頁(yè)偏移量:
虛擬地址由虛擬頁(yè)號(hào)+虛擬頁(yè)偏移量組成,虛擬頁(yè)偏移量是相對(duì)某個(gè)虛擬頁(yè)的偏移量。
PPO即物理頁(yè)偏移量:
物理地址由物理頁(yè)號(hào)+物理頁(yè)偏移量組成,物理頁(yè)偏移量是相對(duì)某個(gè)物理頁(yè)的偏移量,
VPO等于PPO
頁(yè)表(Page Table)PT:
頁(yè)表是建立虛擬頁(yè)號(hào)和物理頁(yè)號(hào)映射關(guān)系的表結(jié)構(gòu),每個(gè)頁(yè)表項(xiàng)(PTE)包括了有效位,物理頁(yè)號(hào),磁盤地址等信息,如下圖:

頁(yè)表與物理內(nèi)存,虛擬內(nèi)存的關(guān)系
由上圖可以得知,操作系統(tǒng)可以根據(jù)頁(yè)表項(xiàng)的有效位和地址信息判斷出虛擬頁(yè)目前所處的狀態(tài)即未分配,已緩沖,未緩沖
如上圖所示,頁(yè)表有8個(gè)頁(yè)表項(xiàng),每個(gè)頁(yè)表項(xiàng)里包含一個(gè)有效位和地址信息。
當(dāng)頁(yè)表項(xiàng) PTE n的頁(yè)表項(xiàng)有效位為0時(shí),表示虛擬頁(yè) n沒有緩沖在物理內(nèi)存,可能在磁盤或者未分配,例如PTE 0頁(yè)表項(xiàng)里存儲(chǔ)的是null,表明虛擬頁(yè)0即VP0是未分配狀態(tài),PTE 3里存儲(chǔ)的是磁盤地址,表明虛擬頁(yè) 3即VP3在磁盤里,但沒有緩沖,VP3狀態(tài)為未緩沖。
當(dāng)頁(yè)表項(xiàng)PTE n的頁(yè)表項(xiàng)的有效位為1時(shí),表示虛擬頁(yè)n緩沖在物理內(nèi)存,PTE n存儲(chǔ)了物理頁(yè)號(hào),虛擬頁(yè) n的狀態(tài)為已緩沖,例如PTE 1的頁(yè)表項(xiàng),有效位為1,則虛擬頁(yè)VP1緩沖在了物理頁(yè)中。
頁(yè)表基址寄存器(PTBR):
每個(gè)進(jìn)程都有自己的頁(yè)表,CPU執(zhí)行某個(gè)進(jìn)程時(shí),會(huì)先把該進(jìn)程的一級(jí)頁(yè)表起始地址存儲(chǔ)到頁(yè)表基址寄存器,這樣CPU查找一級(jí)頁(yè)表起始地址可以直接從寄存器查找,加快了查找效率。
好了,概念介紹到這里,先來看看虛擬地址翻譯物理地址的過程,按照一級(jí)頁(yè)表來演示,如下圖所示:

虛擬地址翻譯物理地址
上圖為虛擬地址翻譯物理地址的示意圖,可以看出VPO等于PPO。
下面看看計(jì)算機(jī)各個(gè)部件是怎么通過虛擬地址訪問物理內(nèi)存的。
處理器根據(jù)虛擬地址訪問物理內(nèi)存的分為頁(yè)表項(xiàng)命中和頁(yè)表項(xiàng)未命中兩種情況,頁(yè)表項(xiàng)命中意味著頁(yè)表項(xiàng)的有效位為1,頁(yè)表項(xiàng)存儲(chǔ)的是物理頁(yè)號(hào),虛擬頁(yè)緩沖在物理頁(yè)中,未命中意味著頁(yè)表項(xiàng)有效位為0,此時(shí)需要發(fā)送缺頁(yè)中斷。
頁(yè)表項(xiàng)命中的步驟如下圖:

頁(yè)表項(xiàng)命中翻譯步驟
1.CPU將虛擬地址(VA)送入MMU,MMU根據(jù)頁(yè)表基址寄存器中頁(yè)表的起始地址加上虛擬頁(yè)號(hào),找到了頁(yè)表項(xiàng)的物理地址PTEA。
2.MMU將PTEA送入到高速緩沖或者內(nèi)存。
3.從高速緩沖或者內(nèi)存中找到頁(yè)表項(xiàng)(PTE),返回頁(yè)表項(xiàng)(PTE)給MMU。
4.MMU根據(jù)PTE找出物理頁(yè)號(hào),然后加上虛擬頁(yè)偏移量形成物理地址(PA),送入到高速緩沖或者內(nèi)存。
5.高速緩沖或者內(nèi)存獲取數(shù)據(jù),返回?cái)?shù)據(jù)給處理器。
頁(yè)表項(xiàng)未命中的步驟如下圖:

頁(yè)表項(xiàng)未命中翻譯步驟
1.CPU將虛擬地址(VA)送入MMU,MMU根據(jù)頁(yè)表基址寄存器中頁(yè)表的起始地址加上虛擬頁(yè)號(hào),找到了頁(yè)表項(xiàng)的物理地址PTEA。
2.MMU將PTEA送入到高速緩沖或者內(nèi)存。
3.從高速緩沖或者內(nèi)存中找到頁(yè)表項(xiàng)(PTE),返回頁(yè)表項(xiàng)(PTE)給MMU。
4.MMU根據(jù)PTE,發(fā)現(xiàn)頁(yè)不在內(nèi)存中,未命中,因此MMU發(fā)送一個(gè)缺頁(yè)中斷,交由缺頁(yè)異常處理程序處理。
5.缺頁(yè)異常處理程序根據(jù)頁(yè)置換算法,選擇出一個(gè)犧牲頁(yè),如果這個(gè)頁(yè)面已經(jīng)被修改了,則寫出到磁盤上,最后將這個(gè)犧牲頁(yè)的頁(yè)表項(xiàng)有效位設(shè)置為0,存入磁盤地址。
6.缺頁(yè)異常程序處理程序調(diào)入新的頁(yè)面,如果該虛擬頁(yè)尚未分配磁盤空間,則分配磁盤空間,然后磁盤空間的頁(yè)數(shù)據(jù)拷貝到空閑的物理頁(yè)上,并更新PTE的有效位為1,更新物理頁(yè)號(hào),缺頁(yè)異常處理程序返回后,再回到發(fā)生缺頁(yè)中斷的指令處,重新按照頁(yè)表項(xiàng)命中的步驟執(zhí)行。
虛擬地址翻譯物理地址的過程介紹完了,另外要說的是現(xiàn)代的CPU和操作系統(tǒng)為了加快虛擬地址翻譯物理地址的過程,做了以下兩點(diǎn)優(yōu)化:
1.建立了虛擬號(hào)(VPN)和頁(yè)表項(xiàng)(PTE)的映射關(guān)系,存儲(chǔ)在TLB中,當(dāng)MMU根據(jù)虛擬地址獲取頁(yè)表項(xiàng)時(shí),先查詢TLB,在TLB找到了頁(yè)表項(xiàng)后,就不需要從高速緩沖或者內(nèi)存中獲取了,找不到了才會(huì)計(jì)算頁(yè)表項(xiàng)地址PTEA,然后再?gòu)母咚倬彌_或者內(nèi)存中獲取頁(yè)表項(xiàng)(PTE)。
2.某些熱點(diǎn)物理地址對(duì)應(yīng)的數(shù)據(jù),存儲(chǔ)在L1緩沖中,MMU根據(jù)物理地址獲取頁(yè)表項(xiàng)或者代碼數(shù)據(jù)時(shí),先從L1緩沖中獲取,找不到再?gòu)膬?nèi)存中獲取。
上述的翻譯過程是通過一級(jí)頁(yè)表來翻譯,現(xiàn)在操作系統(tǒng)支持多級(jí)頁(yè)表,多級(jí)頁(yè)表與一級(jí)頁(yè)表比較類似,如下圖所示:

K頁(yè)表
上圖為K級(jí)頁(yè)表,頁(yè)表基址寄存器存儲(chǔ)的是一級(jí)頁(yè)表的地址,1到K-1的頁(yè)表的每一項(xiàng)存儲(chǔ)的下一級(jí)頁(yè)表的起始地址,K級(jí)頁(yè)表的每一項(xiàng)存儲(chǔ)的是物理頁(yè)號(hào)或者磁盤地址。
好了,關(guān)于虛擬地址,虛擬內(nèi)存,虛擬地址空間的話題就介紹到這里了。
-
cpu
+關(guān)注
關(guān)注
68文章
11281瀏覽量
225090 -
數(shù)據(jù)
+關(guān)注
關(guān)注
8文章
7335瀏覽量
94801 -
操作系統(tǒng)
+關(guān)注
關(guān)注
37文章
7402瀏覽量
129339 -
代碼
+關(guān)注
關(guān)注
30文章
4968瀏覽量
73999
發(fā)布評(píng)論請(qǐng)先 登錄
51單片機(jī)存儲(chǔ)程序和數(shù)據(jù)的方式概述
怎樣使用代碼來訪問PLC數(shù)據(jù)
如何去計(jì)算CPU的地址線和數(shù)據(jù)線
CPU對(duì)齊訪問的基礎(chǔ)知識(shí)
IMXRT1170 Cortex M4沒有SDRAM,是否可以增加CM4的代碼和數(shù)據(jù)空間?
PLD和數(shù)據(jù)通路來釋放微控制器中CPU資源
如何寫出讓CPU執(zhí)行更快的代碼?
關(guān)于組態(tài)CPU的訪問保護(hù)淺析
CPU是怎樣訪問內(nèi)存的?資料下載
CPU的訪問保護(hù)與訪問級(jí)別
Verilog代碼封裝后門訪問
MMU原理:CPU是如何訪問到內(nèi)存的?
EE-132:使用VisualDSP將C代碼和數(shù)據(jù)模塊放入SHARC存儲(chǔ)器中
CPU怎么訪問代碼和數(shù)據(jù)
評(píng)論