美文网首页
物理内存申请过程分析

物理内存申请过程分析

作者: 4528283108ee | 来源:发表于2017-12-10 21:40 被阅读25次

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; 

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

相关文章

  • 物理内存申请过程分析

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

  • 浅析JVM之内存管理

    这是一篇有关JVM内存管理的文章。这里将会简单的分析一下Java如何使用从物理内存上申请下来的内存,以及如何来划分...

  • 内存与性能

    申请与释放内存 申请内存的过程 用户态使用malloc向操作系统申请内存 操作系统查找页面是否有空闲内存,如果有则...

  • HotSpot note(part-7)

    part 7 UseConcMarkSweepGC下的内存申请流程分析 -XX:+UseConcMarkSweep...

  • GC part 7

    part 7 UseConcMarkSweepGC下的内存申请流程分析 -XX:+UseConcMarkSweep...

  • 内存管理

    Memory Management1.什么是内存管理?程序在运行过程中管理内存分配的过程,当需要内存的时候就申请一...

  • Linux 内存管理 应用篇

    1、物理内存和虚拟内存 物理内存:物理内存就是系统硬件提供的内存大小,是真正的内存 虚拟内存:为了满足物理内存的不...

  • linux io与zero copy

    1. 物理内存与虚拟内存 1.1 物理内存 物理内存指通过物理内存条而获得的内存空间。 1.2 虚拟内存 虚拟内存...

  • Volatility初步学习

    Volatility是一个内存分析工具,其能够分析操作系统的物理内存,获取其语义信息。 针对一个Linux操作系统...

  • 内存分配

    虚拟内存简介 当我们向系统申请内存时,系统并不会给你返回物理内存的地址,而是给你一个虚拟内存地址。每个进程都拥有相...

网友评论

      本文标题:物理内存申请过程分析

      本文链接:https://www.haomeiwen.com/subject/xdgvixtx.html