物理内存申请过程分析

http://www.linuxidc.com/Linux/2012-09/70711p3.htm

memory_pressure 分配内存时候++,释放内存--

inactive_target

z->pages_min

 z->pages_low

 z->pages_high


栈变量

direct_reclaim : 是否能从inactive_clean中分配一个页面,成立条件:分配一个页面&&不是内存管理程序&&(gfp_mask & __GFP_WAIT)

1 首先尝试从zone的free_area中分配内存

for (;;) { zone_t *z = *(zone++);

if (!z) break; if (!z->size) BUG();

        if (z->free_pages >= z->pages_low) {

             page = rmqueue(z, order);    //尝试从free_area中分配

            if (page)       

               return page;

           } else if (z->free_pages < z->pages_min && waitqueue_active(&kreclaimd_wait)) {

                    wake_up_interruptible(&kreclaimd_wait);  //唤醒kreclaimd

           }

}

2 尝试使用高水位进行分配内存 page = __alloc_pages_limit(zonelist,order,PAGES_HIGH,direct_reclaim); 

该函数主要考虑从free + inactive_clean中分配,如果是分配一个页面,则可能从inactive_clean中分配,或者从free_area中分配

if (z->free_pages + z->inactive_clean_pages > water_mark) {

     struct page *page = NULL; /* If possible, reclaim a page directly. */

     if (direct_reclaim && z->free_pages < z->pages_min + 8)

                 page = reclaim_page(z);

               /* If that fails, fall back to rmqueue. */

              if (!page)

                  page = rmqueue(z, order);

              if (page)

                 return page;

}

3  尝试使用低水位进行分配内存 __alloc_pages_limit(zonelist,order,PAGES_LOW,direct_reclaim)

该函数主要考虑从free + inactive_clean中分配,如果是分配一个页面,则可能从inactive_clean中分配,或者从free_area中分配

4 如果还没有分配到页面则唤醒kswap交换内存,并执行调度(给kswap运行的机会),之后以最低水位执行page = __alloc_pages_limit(zonelist,order,PAGES_MIN,direct_reclaim);


5  如果还没有申请到内存 ,有可能有两个原因,执行不同策略

- 我们正在进行分配一个大的内存块(order比较大) - >将页面移动到空闲列表中,直到成功

- 我们在内存上真的很紧 - >等待kswapd等待队列,直到内存被释放

首先来看对与普通程序 非内存管理程序


对于分配大块内存情况

对于分配大内存情况首先用page_launder清洗不活跃脏页面。然后尝试从不活跃脏页面释放页面,之后分配页面


内存真的紧张

到了这里内存已经非常紧张,如果不允许分配失败,__GFP_IO(内存查找期间可以进行IO操作,只有这样才有必要进行交换释放页面,中断中不允许io操作,太慢)

首先同步唤醒kswapd进行清洗页面,如果申请一个页面返回最开始处进行分配

否则 如果不允许失败则释放page,order=下0则到try_again 处重新进行分配


6 最后实在分配出来则执行后面逻辑


最终逻辑

首先如果是分配单个页面的普通程序肯定不会走到这里,如一种所说是当oomkiller杀进程的时候分配页面,另外一种就是管理程序或者普通程序

申请多个页面 


7 最总还没有分配到则

printk(KERN_ERR"__alloc_pages: %lu-order allocation failed.\n",order);

returnNULL; 

由此可见申请大的连续物理页面一定要小心,因为很容易申请失败。

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