免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1914 | 回复: 5
打印 上一主题 下一主题

[内存管理] free_pages_ok函数,不解? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-07-05 16:06 |只看该作者 |倒序浏览
本帖最后由 zmmkele 于 2013-07-05 16:09 编辑

linux版本: 2.4.0

在free_pages_ok()函数源码中有两个疑问:
  1. while (mask + (1 << (MAX_ORDER-1))) {
  2.                 struct page *buddy1, *buddy2;

  3.                 if (area >= zone->free_area + MAX_ORDER)
  4.                         BUG();
  5.                 [color=Red]/* 这边改变的貌似只能是area_map的第一个int中的bit而已? */[/color]
  6.                 if (!test_and_change_bit(index, area->map))
  7.                         /*
  8.                          * the buddy page is still allocated.
  9.                          */
  10.                         break;
  11.                 /*
  12.                  * Move the buddy up one level.
  13.                  */
  14.                 buddy1 = base + (page_idx ^ -mask);
  15.                 buddy2 = base + page_idx;
  16.                 if (BAD_RANGE(zone,buddy1))
  17.                         BUG();
  18.                 if (BAD_RANGE(zone,buddy2))
  19.                         BUG();

  20.               [color=Red] /* 怎么只删除了buddy1所在的list,没操作area其它页面? */[/color]
  21.                 memlist_del(&buddy1->list);
  22.                 mask <<= 1;
  23.                 area++;
  24.                 index >>= 1;
  25.                 page_idx &= mask;
  26.         }
复制代码
刚看内存管理部分,望大家指教。
问题1: if (!test_and_change_bit(index, area->map)),  这边改变的貌似只能是area_map的第一个int中的bit而已?
问题2: memlist_del(&buddy1->list), 怎么只删除了buddy1所在的list,没操作area其它页面?

BR

论坛徽章:
0
2 [报告]
发表于 2013-07-05 16:56 |只看该作者
问题2,推测了下,buddy1为2^order area的首页面,即代表着一整个area。
而一个area就只有首页吗链在area->free_list中。

论坛徽章:
0
3 [报告]
发表于 2013-07-06 09:57 |只看该作者
我去,大神在哪里?

问题1: test_and_change_bit只改变map第一个int的第一个bit,
            那么是不是说一个zone的buddy系统所管理的最大的内存size=32bits*2*4k per page*(2^0+2^1+....+2^10)
                                                                                               = 32*2*2^12*(2^11-1)
                                                                                               = 512M?

可以这么理解么?

论坛徽章:
0
4 [报告]
发表于 2013-08-21 08:34 |只看该作者
问题一:
buddy系统中两个buddies之间,共用一个map中的bit。
test_and_change_bit(index, area->map)为什么会跟int有关系?这里是bit操作!
它反转area->map 中第index个bit的值,并返回原来该bit的值。比如原来该第index个bit为1,这里返回1,并置第index个bit为0.
问题二:没看懂要问什么

论坛徽章:
0
5 [报告]
发表于 2013-08-21 11:41 |只看该作者
2.6.24已经不用位图了

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
6 [报告]
发表于 2013-08-21 13:09 |只看该作者
回复 1# zmmkele
linux版本: 2.4.0


版本如此之老啊。估计研究这个版本的大神现在都创业去了,没时间给你回答问题了

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP