Linux內(nèi)核的物理內(nèi)存組織結(jié)構(gòu)詳解_第1頁
Linux內(nèi)核的物理內(nèi)存組織結(jié)構(gòu)詳解_第2頁
Linux內(nèi)核的物理內(nèi)存組織結(jié)構(gòu)詳解_第3頁
Linux內(nèi)核的物理內(nèi)存組織結(jié)構(gòu)詳解_第4頁
Linux內(nèi)核的物理內(nèi)存組織結(jié)構(gòu)詳解_第5頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

第第頁Linux內(nèi)核的物理內(nèi)存組織結(jié)構(gòu)詳解

(Linux)中內(nèi)存管理子系統(tǒng)使用節(jié)點(diǎn)(node)、區(qū)域(zone)和頁(page)三級(jí)結(jié)構(gòu)描述物理內(nèi)存。

內(nèi)存節(jié)點(diǎn)

內(nèi)存節(jié)點(diǎn)分兩種情況:UMA和NUMA。

從管理內(nèi)存的方法上區(qū)分,計(jì)算機(jī)可以分為兩種類型:UMA和NUMA。

UMA:一致性內(nèi)存訪問,unif(or)mmemory(ac)cess

NUMA:非一致性內(nèi)存訪問,non-uniformmemoryaccess

兩種類型示意圖:

對(duì)UMA來說,每一個(gè)(CPU)訪問的都是同一塊內(nèi)存,因此各CPU對(duì)內(nèi)存的訪問不存在性能差異

對(duì)NUMA來說,各內(nèi)存和各CPU通過總線連在一起,每個(gè)CPU都有一個(gè)本地內(nèi)存,訪問速度快,CPU也可以訪問其他CPU的本地內(nèi)存,但速度稍慢

Linux為了統(tǒng)一這兩種平臺(tái),在內(nèi)存組織中,將最高層次定義為內(nèi)存節(jié)點(diǎn).

可以看到,圖中UMA只有一個(gè)內(nèi)存節(jié)點(diǎn),而NUMA有兩個(gè)內(nèi)存節(jié)點(diǎn)。

實(shí)際上,UMA其實(shí)是NUMA的一個(gè)特例,所以內(nèi)核可以將內(nèi)存都看做NUMA類型的。

區(qū)域

每個(gè)內(nèi)存節(jié)點(diǎn)都劃分為多個(gè)區(qū),Linux內(nèi)核中定義了以下幾個(gè)區(qū):

include/linux/mmzone.h

enumzone_type{#ifdefCONFIG_ZONE_(DMA)ZONE_DMA,#endif#ifdefiCONFIG_ZONE_DMA32ZONE_DMA32,#endifZONE_NORMAL,#ifdefCONFIG_HIGHMEMZONE_HIGHMEM,#endifZONE_MOVABLE,#ifdefCONFIG_ZONE_DEVICEZONE_DEVICE,#endif__MAX_NR_ZONES};ZONE_DMA

DMA是“DirectMemoryAccess”的縮寫,直接內(nèi)存訪問。

該區(qū)域用于ISA設(shè)備的DMA操作,范圍是0-16MB。

如果有些設(shè)備不能直接訪問所有內(nèi)存,則需要使用DMA區(qū)域。例如舊的(工業(yè))標(biāo)準(zhǔn)體系結(jié)構(gòu)(IndustryStandardArchi(te)cture,ISA)總線只能直接訪問16MB以下的內(nèi)存。

只適用于(Intel)x86架構(gòu),(ARM)架構(gòu)沒有這個(gè)內(nèi)存管理區(qū)。

ZONE_DMA32

在64位的系統(tǒng)上使用32位地址尋址的適合DMA操作的內(nèi)存區(qū)。

例如在(AMD)64系統(tǒng)上,該區(qū)域?yàn)榈停?G)B的空間。在32位系統(tǒng)上,本區(qū)域通常是空的。

ZONE_NORMAL

常規(guī)內(nèi)存區(qū),指的是可以直接映射到內(nèi)核空間的內(nèi)存。

也常稱為“普通區(qū)域”“直接映射區(qū)域”“線性映射區(qū)域”。

所謂線性映射就是物理地址和映射后的虛擬地址存在一種簡單的關(guān)系,即虛擬地址=物理地址+固定偏移。

在32位系統(tǒng)上,內(nèi)核空間和用戶空間按1:3劃分,那么這個(gè)固定偏移就是:0xC0000000-物理內(nèi)存起始地址。

既然存在一種線性關(guān)系,那還需要使用頁表對(duì)物理地址和虛擬地址做映射嗎?

不同(處理器)架構(gòu)實(shí)現(xiàn)不一樣,ARM需要使用頁表映射,MIPS則不需要。

ZONE_HIGHMEM

高端內(nèi)存區(qū),32位時(shí)代的產(chǎn)物。在32位系統(tǒng)上,指的是高于896M的物理內(nèi)存。

32位系統(tǒng)中,內(nèi)核和用戶地址空間按1:3劃分,內(nèi)核地址空間只有1GB,所以不能把1GB以上的內(nèi)存直接映射到內(nèi)核地址空間,因此就把不能直接映射的內(nèi)存劃分到了高端內(nèi)存區(qū)。

要將高于896MB的物理內(nèi)存映射在內(nèi)核空間的話,需要通過單獨(dú)的映射來完成,并且這類映射不能保證物理地址和虛擬地址之間存在固定的對(duì)應(yīng)關(guān)系(例如ZONE_NORMAL的固定偏移)。

ZONE_DMA、ZONE_DMA32、ZONE_NORMAL通常都統(tǒng)稱為低端內(nèi)存區(qū)。

64位系統(tǒng)中沒有這個(gè)區(qū)域,即沒有高端內(nèi)存。因?yàn)?4系統(tǒng)的內(nèi)核虛擬地址空間非常大,不再需要高端內(nèi)存區(qū)域。

ZONE_MOVABLE

一個(gè)偽內(nèi)存區(qū),用來防止內(nèi)存碎片。

ZONE_DEVICE

為支持持久內(nèi)存(pe(rs)istentmemory)熱拔插增加的內(nèi)存區(qū)域

站在處理器的角度來看,管理物理內(nèi)存的最小單位是頁面。

現(xiàn)在的處理器都采用分頁機(jī)制來管理內(nèi)存,在處理器內(nèi)部有一個(gè)MMU(硬件),它會(huì)處理虛擬內(nèi)存到物理內(nèi)存的映射,也就是做頁表的翻譯工作。

Linux內(nèi)核中使用一個(gè)page數(shù)據(jù)結(jié)構(gòu)來描述一個(gè)物理頁面。

頁的大小通常是4KB,但有個(gè)的架構(gòu)的處理器可以支持大于4KB的頁,例如8KB、16KB或者64KB的頁。

目前Linux內(nèi)核默認(rèn)使用4KB的頁面。

所以,Linux內(nèi)核的用三級(jí)結(jié)構(gòu)來管理物理內(nèi)存,簡言之就是內(nèi)存首先劃分成若干個(gè)大的節(jié)點(diǎn),每個(gè)節(jié)點(diǎn)又包

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論