Linux内存管理-页描述符与内存管理区

页描述符

我们都知道Linux的内存是分页的,在Linux 中每页的大小是4KB(大部分情况下),Linux需要记录下来每一页的状态,于是很显然地,需要一些额外的内存去存储这些状态信息,对于每一页内存,linux 需要用32个字节去管理(可能与最新版的linux有所出入),称之为页描述符,这些页描述符加起来大概占用不到整个内存的1%

页描述符具体都干了什么?

从最初的Linux版本发展到现在,这个页描述符已经变得相当复杂,下面是一个简化版本

129 typedef struct pglist_data {

130    zone_t node_zones[MAX_NR_ZONES];

131    zonelist_t node_zonelists[GFP_ZONEMASK+1];

132    int nr_zones;

133    struct page *node_mem_map;

134    unsigned long *valid_addr_bitmap;

135    struct bootmem_data *bdata;

136    unsigned long node_start_paddr;

137    unsigned long node_start_mapnr;

138    unsigned long node_size;

139    int node_id;

140    struct pglist_data *node_next;

141 } pg_data_t;


这里面最重要的两个字段是

count:

代表该页的引用计数器,如果等于-1,则代表相应的页框是空闲,可以被分配给任意一个进程或者内核本身,如果大于0则代表已经被分配给了一个或者多个进程

flags:

描述该内存页的状态,标志说明

PG_locked页被锁定

PG_error在传输过程中发生I/O错误

PG_referenced刚刚访问过的页

PG_uptodate在完成读操作后置位

等等..

内存管理区

在实际的计算机体系结构中,Linux并不能对所有的内存一视同仁,因为现有的硬件约束不允许,主要来自以下两点

1、ISA总线的DMA直接内存存取处理器有严格的限制,只能对RAM的前16M寻址(因为ISA的总线只有16位)

2、在具有大容量RAM的现代32位计算机中,CPU不能 访问所有的物理内存,因为线性地址太小 

为了应对这两种限制,Linux把每个内存节点物理内存划分为3个管理区

1、ZONE_DMA,包含低于16M的内存页框

2、ZONE_NORMAL,包含低于16M且低于896M的内存页框

3、ZONE_HIGHMEM,包含高于896M的内存页框

想必有一个问题是无法避免的,为什么ZONE_NORMAL只包含到896M的内存?

我的个人理解是,Linux把地址空间分为用户地址空间和内核地址空间,在4GB的LInux机器上3GB用来做用户地址空间,1GB用来做内核地址空间(大部分情况下是这样,可以配置),内核有时需要访问用户地址空间中的物理地址,于是内核划分128M来用于映射用户地址空间的地址,如此一来1GB-128M=896MB。

这种情况在64位系统上有所不同,在64位系统上,LInux也只使用其中的48位用来寻址,也就是说, 总的虚拟地址空间为256TB( 2^48 )。这其中0000000000000000 - 00007fffffffffff(128TB)为用户空间, ffff800000000000 - ffffffffffffffff(128TB)为内核空间,可以看到内核空间之大,已经可以足够映射所有的物理内存了,所以在X86-64的Linux系统上,ZONE_HIGHMEM不存在。

还有一个名词叫做内存节点,这个东西很不常用,主要是有一种比较诡异的内存模型称之为Non-Uniform Memory Access (NUMA),在这种内存模型下,CPU对不同地址寻址的性能可能会不尽相同,LInux为了支持该内存模型,提出了内存节点的概念,把性能相近的地址范围划分在一个内存节点中。整个内存的数据结构如下图所示:

pg_data_t其实就是一个内存节点,在NUMA的机器上可能会有多个,在UMA(Uniform Memory Access)的机器上只有一个,NUMA至少我是没见过。

node_zones其实指的就是内存节点中的物理内存划分了,也就是我们上面讲的那些。

struct page就是页描述符

如有错误请指正。

参考:

《深入理解LInux内核》第三版

https://www.kernel.org/doc/gorman/html/understand/understand005.html

http://adam8157.info/blog/2012/07/linux-x86-64-vm/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容