Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1253164
  • 博文数量: 122
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 4004
  • 用 户 组: 普通用户
  • 注册时间: 2014-02-20 08:27
文章分类
文章存档

2016年(1)

2015年(21)

2014年(100)

分类: LINUX

2014-03-13 14:41:14


点击(此处)折叠或打开

  1. int zone_watermark_ok(struct zone *z, int order, unsigned long mark,
  2.         int classzone_idx, int can_try_harder, int gfp_high)
  3. {
  4.  /* free_pages my go negative - that's OK */
  5.  long min = mark, free_pages = z->free_pages - (1 << order) + 1;
  6.  int o;

  7.  /*如果gfp_high标志被置位。通常atomic方式会置此标记。那么将水线降低一半,即内存分配可以穿越水线一半*/
  8.  if (gfp_high)
  9.   min -= min / 2;
  10.  /*如果can_try_harder标志被置位,水线再减少1/4,can_try_harder通常是当进程是一个实时进程并且在进程上下文中已经完成了内存分配。*/
  11.  if (can_try_harder)
  12.   min -= min / 4;

  13.  if (free_pages <= min + z->lowmem_reserve[classzone_idx])
  14.   return 0;
  15.  for (o = 0; o < order; o++) {
  16.   /* At the next order, this order's pages become unavailable */
  17.   /* 扣除小于目标order的内存块,比如分配内存是指定的order为3,即需要分配32k大小的内存,此时需要扣除掉小于32k大小的内存块,
  18.      因为这些块的大小不足以分配32k的连续空间*/
  19.   free_pages -= z->free_area[o].nr_free << o;
  20.   /* Require fewer higher order pages to be free */
  21.   /*每扣除一个order的块,需要将水线除以2,目的是将水线分担到各个order,当order为3时,最终需要>=32k的内存块的容量>min/8,
  22.     才能继续分配内存*/
  23.   min >>= 1;

  24.   if (free_pages <= min)
  25.    return 0;
  26.  }
  27.  return 1;
  28. }

 

阅读(4430) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~