免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: lofeng410
打印 上一主题 下一主题

[内存管理] slab分配器为何不能从DMA32分配内存呢?x86_64只有2G物理内存时怎么给slab分配页面呢? [复制链接]

论坛徽章:
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
11 [报告]
发表于 2012-09-20 13:52 |只看该作者
回复 10# embeddedlwp
多谢分享!

可否分享一下#define GFP_SLAB_BUG_MASK (__GFP_DMA32|__GFP_HIGHMEM|~__GFP_BITS_MASK)在内核的用途?

   

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
12 [报告]
发表于 2012-09-20 14:23 |只看该作者
回复 11# 瀚海书香


git show 6cb06229


   

论坛徽章:
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
13 [报告]
发表于 2012-09-24 08:19 |只看该作者
回复 12# embeddedlwp

这个只是设置了flag,并没有解释一楼的疑问啊

x86_64系统下,slab是可以从小于4G (DMA32)申请内存的,为什么会有:

BUG_ON(flags & GFP_SLAB_BUG_MASK);

/* Do not use these with a slab allocator */
#define GFP_SLAB_BUG_MASK (__GFP_DMA32|__GFP_HIGHMEM|~__GFP_BITS_MASK)

   

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
14 [报告]
发表于 2012-09-24 08:22 |只看该作者
本帖最后由 embeddedlwp 于 2012-09-24 08:24 编辑

回复 13# 瀚海书香


IIUC, 那个patch的changelog里:

    Allocator metadata may serve multiple in kernel users and thus should not
    be subject to the limitations arising from a single allocation context.


就是调用kmem_cache_alloc的时候不要传递那个__GFP_DMA32,__GFP_HIGHMEM,不想被限制。


   

论坛徽章:
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
15 [报告]
发表于 2012-09-24 12:07 |只看该作者
回复 14# embeddedlwp
可否给出一个slab申请DMA32内存的函数流程?这样理解起来就比较方便了。

   

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
16 [报告]
发表于 2012-09-24 12:28 |只看该作者
回复 15# 瀚海书香


cache_grow
      ->kmem_getpages
                ->alloc_pages_exact_node
                        ->__alloc_pages
                               ->alloc_pages_nodemask
                                   
__alloc_pages_nodemask根据gfp_mask来选择zonelist中最high分配内存的zone,比如我那个实验,假如现在只有zone_dma32,zone_dma,那么这里就会依次选择zone_dma32->zone_dma

如果现在有zone_normal,zone_dma32,zone_dma,如果调用kmem_cache_alloc的时候设置了__GFP_DMA32标志,那么是不是只能zone_dma32->zone_dma,

这也就是“should not be subject to the limitations arising from a single allocation context.”的意思吧,如果我理解正确的话。


   

论坛徽章:
0
17 [报告]
发表于 2012-09-24 17:22 |只看该作者
会从DMA32中分配内存的,slab默认的是从normal分区中分配内存,你normal分区的大小为0,只好从DMA32中分配内存了,分配顺序是 normal->dma32->dma, 只要条件成立,比如dma等还有自己的保留大小,就能分配。分区越低的内存越珍贵,因为有的应用只能用低端内存。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP