0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Linux中內(nèi)存管理子系統(tǒng)開發(fā)必知的3個結(jié)構(gòu)概念

Dp1040 ? 來源:嵌入式Linux充電站 ? 2023-08-28 09:34 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

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

UMA:一致性內(nèi)存訪問,uniform memory access

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

兩種類型示意圖:

de887aa4-453a-11ee-a2ef-92fbcf53809c.png

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

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

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

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

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

2、區(qū)域

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

include/linux/mmzone.h

enum zone_type{
#ifdef CONFIG_ZONE_DMA
ZONE_DMA,
#endif
#ifdefi CONFIG_ZONE_DMA32
ZONE_DMA32,
#endif
ZONE_NORMAL,
#ifdef CONFIG_HIGHMEM
ZONE_HIGHMEM,
#endif
ZONE_MOVABLE,
#ifdef CONFIG_ZONE_DEVICE
ZONE_DEVICE,
#endif
__MAX_NR_ZONES
};

ZONE_DMA

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

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

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

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

ZONE_DMA32

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

例如在AMD64系統(tǒng)上,該區(qū)域?yàn)榈?a href="http://www.wenjunhu.com/v/tag/9979/" target="_blank">4GB的空間。在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劃分,那么這個固定偏移就是:0xC0000000 - 物理內(nèi)存起始地址。

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

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

ZONE_HIGHMEM

高端內(nèi)存區(qū),32位時代的產(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ú)的映射來完成,并且這類映射不能保證物理地址和虛擬地址之間存在固定的對應(yīng)關(guān)系(例如ZONE_NORMAL的固定偏移)。

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

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

ZONE_MOVABLE

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

ZONE_DEVICE

為支持持久內(nèi)存(persistent memory)熱拔插增加的內(nèi)存區(qū)域。

3、頁

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

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

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

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

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

所以,Linux內(nèi)核的用三級結(jié)構(gòu)來管理物理內(nèi)存,簡言之就是內(nèi)存首先劃分成若干個大的節(jié)點(diǎn),每個節(jié)點(diǎn)又包含若干個區(qū),每個區(qū)有包含若干頁。Linux內(nèi)核按頁管理內(nèi)存,最基本的內(nèi)存分配和釋放都是按頁進(jìn)行的。






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    19843

    瀏覽量

    234100
  • dma
    dma
    +關(guān)注

    關(guān)注

    3

    文章

    576

    瀏覽量

    102852
  • LINUX內(nèi)核
    +關(guān)注

    關(guān)注

    1

    文章

    317

    瀏覽量

    22287
  • UMA
    UMA
    +關(guān)注

    關(guān)注

    0

    文章

    4

    瀏覽量

    6583
  • 虛擬內(nèi)存
    +關(guān)注

    關(guān)注

    0

    文章

    78

    瀏覽量

    8227

原文標(biāo)題:底層開發(fā)必知的3個內(nèi)存結(jié)構(gòu)概念

文章出處:【微信號:玩點(diǎn)嵌入式,微信公眾號:玩點(diǎn)嵌入式】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 0人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    Linux內(nèi)存管理是什么,Linux內(nèi)存管理詳解

    Linux內(nèi)存管理 Linux內(nèi)存管理是一非常
    的頭像 發(fā)表于 05-11 17:54 ?6480次閱讀
    <b class='flag-5'>Linux</b>的<b class='flag-5'>內(nèi)存</b><b class='flag-5'>管理</b>是什么,<b class='flag-5'>Linux</b>的<b class='flag-5'>內(nèi)存</b><b class='flag-5'>管理</b>詳解

    概念增強(qiáng)DRAM內(nèi)存子系統(tǒng)設(shè)計(jì)

      熱管理問題隨著內(nèi)存技術(shù)的發(fā)展而發(fā)展,并成為嵌入式系統(tǒng)、可靠性和性能的關(guān)鍵。系統(tǒng)設(shè)計(jì)師和內(nèi)存子系統(tǒng)
    發(fā)表于 07-12 11:24 ?1067次閱讀
    熱<b class='flag-5'>概念</b>增強(qiáng)DRAM<b class='flag-5'>內(nèi)存</b><b class='flag-5'>子系統(tǒng)</b>設(shè)計(jì)

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

    Linux內(nèi)存管理子系統(tǒng)使用 節(jié)點(diǎn)(node)、區(qū)域(zone)和頁(page) 三級結(jié)構(gòu)描述
    發(fā)表于 08-21 15:35 ?834次閱讀
    <b class='flag-5'>Linux</b>內(nèi)核的物理<b class='flag-5'>內(nèi)存</b>組織<b class='flag-5'>結(jié)構(gòu)</b>詳解

    Linux內(nèi)核內(nèi)存管理架構(gòu)解析

    內(nèi)存管理子系統(tǒng)可能是linux內(nèi)核中最為復(fù)雜的一個子系統(tǒng),其支持的功能需求眾多,如頁面映射、頁面分配、頁面回收、頁面交換、冷熱頁面、緊急頁面
    的頭像 發(fā)表于 01-04 09:24 ?982次閱讀
    <b class='flag-5'>Linux</b>內(nèi)核<b class='flag-5'>內(nèi)存</b><b class='flag-5'>管理</b>架構(gòu)解析

    Linux系統(tǒng)通過預(yù)留物理內(nèi)存實(shí)現(xiàn)ARM與FPGA高效通信的方法

    管理子系統(tǒng)管理。因此,需要預(yù)留一部分物理內(nèi)存,使其不被內(nèi)核管理。接下來將為大家詳細(xì)介紹在 Linux
    的頭像 發(fā)表于 04-16 13:42 ?609次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>系統(tǒng)</b><b class='flag-5'>中</b>通過預(yù)留物理<b class='flag-5'>內(nèi)存</b>實(shí)現(xiàn)ARM與FPGA高效通信的方法

    嵌入式linux內(nèi)核的五個子系統(tǒng)

    嵌入式linux內(nèi)核的五個子系統(tǒng)分享到: Linux內(nèi)核主要由進(jìn)程調(diào)度(SCHED)、內(nèi)存管理(MM)、虛擬文件
    發(fā)表于 09-10 14:09

    嵌入式Linux系統(tǒng)開發(fā)學(xué)習(xí)步驟

    和步驟。今天,筆者和大家分享一很不錯的關(guān)于嵌入式Linux系統(tǒng)開發(fā)學(xué)習(xí)步驟,希望對大家有所幫助?!∫唬呵度胧絚語言  C語言是嵌入式領(lǐng)域最重要也是最主要的編程語言,通過大量編程實(shí)例重點(diǎn)理解C語言
    發(fā)表于 08-25 15:38

    嵌入式Linux系統(tǒng)開發(fā)學(xué)習(xí)步驟

    和步驟。今天,筆者和大家分享一很不錯的關(guān)于嵌入式Linux系統(tǒng)開發(fā)學(xué)習(xí)步驟,希望對大家有所幫助。技術(shù)交流可以加QQ啊2685896890  一:嵌入式c語言  C語言是嵌入式領(lǐng)域最重要也是最主要的編程
    發(fā)表于 06-18 10:31

    嵌入式Linux系統(tǒng)開發(fā)學(xué)習(xí)步驟

    。其實(shí)針對這類的問題主要還是因?yàn)榇蠹覍ψ约旱膶W(xué)習(xí)沒有一清晰的學(xué)習(xí)規(guī)劃和步驟。今天,筆者和大家分享一很不錯的關(guān)于嵌入式Linux系統(tǒng)開發(fā)學(xué)習(xí)步驟,希望對大家有所幫助。 一:嵌入式c語
    發(fā)表于 08-13 16:04

    ARM嵌入式Linux系統(tǒng)開發(fā)詳解

    建立和第一Linux應(yīng)用程序;第2篇介紹了Linux應(yīng)用程序編程基礎(chǔ)、開發(fā)多進(jìn)程/線程程序、網(wǎng)絡(luò)通信應(yīng)用、串行口通信編程、嵌入式GUI程序開發(fā)
    發(fā)表于 09-14 08:57

    Linux內(nèi)核結(jié)構(gòu)詳解

    Linux內(nèi)核主要由五個子系統(tǒng)組成:進(jìn)程調(diào)度,內(nèi)存管理,虛擬文件系統(tǒng),網(wǎng)絡(luò)接口,進(jìn)程間通信。1.進(jìn)程調(diào)度(SCHED):控制進(jìn)程對CPU的訪
    發(fā)表于 07-11 16:59

    【HarmonyOS】HarmonyOS子系統(tǒng)開發(fā)指導(dǎo)

    子系統(tǒng)開發(fā)主要從三方面進(jìn)行指導(dǎo),分別是圖形圖像類子系統(tǒng)開發(fā)指導(dǎo),相機(jī)子系統(tǒng)開發(fā)指導(dǎo)和音視頻子系統(tǒng)開發(fā)指導(dǎo)。圖形圖像容器類組件
    發(fā)表于 09-21 14:50

    Linux虛擬內(nèi)存管理技術(shù)的相關(guān)資料分享

    嵌入式系統(tǒng)開發(fā)嵌入式系統(tǒng)開發(fā)工具進(jìn)程控制Linux虛擬內(nèi)存管理技術(shù)嵌入式系統(tǒng)開發(fā)工具進(jìn)程控制1、
    發(fā)表于 12-22 06:33

    概念增強(qiáng)DRAM內(nèi)存子系統(tǒng)設(shè)計(jì)

      熱管理問題隨著內(nèi)存技術(shù)的發(fā)展而發(fā)展,并成為嵌入式系統(tǒng)、可靠性和性能的關(guān)鍵。系統(tǒng)設(shè)計(jì)師和內(nèi)存子系統(tǒng)
    的頭像 發(fā)表于 08-17 09:51 ?1316次閱讀
    熱<b class='flag-5'>概念</b>增強(qiáng)DRAM<b class='flag-5'>內(nèi)存</b><b class='flag-5'>子系統(tǒng)</b>設(shè)計(jì)

    Linux 內(nèi)存管理總結(jié)

    一、Linux內(nèi)存管理概述 Linux內(nèi)存管理是指對系統(tǒng)
    的頭像 發(fā)表于 11-10 14:58 ?770次閱讀
    <b class='flag-5'>Linux</b> <b class='flag-5'>內(nèi)存</b><b class='flag-5'>管理</b>總結(jié)

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會員交流學(xué)習(xí)
    • 獲取您個性化的科技前沿技術(shù)信息
    • 參加活動獲取豐厚的禮品