- 1、本文档共4页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Linux虚拟内存管理笔记1
Linux虚拟内存管理笔记1
Linux将内存管理分为三个层次:存储节点(node),管理区(zone),和页面(page)。
1.存储节点
Linux把cpu访问时间相同的存储空间叫做:存储节点。其数据结构为:
typedef struct pglist_data {
zone_t node_zones[MAX_NR_ZONES];
zonelist_t node_zonelists[GFP_ZONEMASK+1];
int nr_zones;/*表示该节点中管理区的个数,1--3*/
struct page *node_mem_map;
unsigned long *valid_addr_bitmap;
struct bootmem_data *bdata;
unsigned long node_start_paddr;/*节点的起始地址对应的页号*/
unsigned long node_start_mapnr;
unsigned long node_size;/*节点中页面总数*/
int node_id;
struct pglist_data *node_next;
} pg_data_t;
若干存储节点的pglist_data数据结构可以通过node_next形成一个单链表队列。
每个结构中的node_mem_map指向具体节点的page结构数组,该数组包含了存储节点中的所有物理页框。数组的下标就是页号。
数组node_zone[]就是该节点的最多三个页面管理区。
在pglist_data结构里设置了一个node_zonelists数组,其类型定义也在同一文件中:typedef struct zonelist_struct {
zone_t *zone[MAX_NR_ZONE+1]; //NULL delimited
Int gfp_mast;
} zonelist_t; 每一个zonelist_t代表一种页面分配策略。
2.管理区
Linux将一个节点中的存储区域划分为三个管理区,分别是ZONE_DMA区(小于16MB),ZONE_NORMAL(16MB~896MB),ZONE_HIGHMEM区(大于896MB)。其数据结构为:
typedef struct zone_struct {
spinlock_t lock;
unsigned long free_pages;
unsigned long pages_min, pages_low, pages_high;
int need_balance;
free_area_t free_area[MAX_ORDER];
struct pglist_data *zone_pgdat;
struct page *zone_mem_map;
unsigned long zone_start_paddr;
unsigned long zone_start_mapnr;
char *name;
unsigned long size;
} zone_t;
#define ZONE_DMA 0
#define ZONE_NORMAL 1
#define ZONE_HIGHMEM 2
#define MAX_NR_ZONES 3
lock :用来保证对该结构中其它域的串行访问
free_pages :在这个区中现有空闲页的个数
pages_min、pages_low及 pages_high是对这个区最少、次少及最多页面个数的描述
need_balance:与kswapd合在一起使用
free_area:在伙伴分配系统中的位图数组和页面链表
zone_pgdat:本管理区所在的存储节点
zone_mem_map:该管理区的内存映射表
zone_start_paddr:该管理区的起始物理地址
zone_start_mapnr:在mem_map中的索引(或下标)
name:该管理区的名字
size:该管理区物理内存总的大小
其中,free_area_t定义为:
#difine MAX_ORDER 10
type struct free_area_struct {
struct list_he
您可能关注的文档
- 3.9.2用对立统一的观点看问题.ppt
- 朱正威老师谈生物新课改教学.doc
- 第一练习---生态系统基因工程.doc
- 定语从句(讲义+35).doc
- 研究生考试交流会.ppt
- 大同县一中新课程实验准备工作及进展情况的报告.doc
- 甘肃兰州02-03年上学期初二物理期末考试.doc
- 计算机基础+二级.doc
- 考研英语答题卡_打印版_实物_.doc
- 角平分线常见辅助线作法.doc
- 甘肃省XB师范大学附属中学2025届高三上学期一模诊断考试地理答案.doc
- 甘肃省XB师范大学附属中学2025届高三上学期一模诊断政治含解析.doc
- 安徽省皖江名校2024-2025学年高一上学期12月联考英语无答案.doc
- 2025年1月八省联考高考综合改革适应性测高三化学陕西山西宁夏青海卷无答案.doc
- 2025年1月八省联考高考综合改革适应性测高三化学四川卷无答案.doc
- 2025年1月八省联考高考综合改革适应性测高三政治陕西山西宁夏青海卷无答案.doc
- 2025年1月内蒙古自治区普通高等学校招生考试适应性测试(八省联考)历史无答案.doc
- 2025年1月内蒙古自治区普通高等学校招生考试适应性测试(八省联考)历史含解析.doc
- 2025年1月四川省普通高等学校招生考试适应性测试(八省联考)历史含解析.doc
- 2025年1月四川省普通高等学校招生考试适应性测试(八省联考)政治无答案.doc
文档评论(0)