免费注册 查看新帖 |

Chinaunix

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

[内存管理] 对内存管理的不懂。。望高手指导 看了很多资料还是不太明白 [复制链接]

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
11 [报告]
发表于 2013-10-23 15:59 |只看该作者
回复 10# mordorwww
vmalloc是非线性映射
vmalloc和kmalloc各自对应的页表entry是不同的item

   

论坛徽章:
16
CU十二周年纪念徽章
日期:2013-10-24 15:41:3415-16赛季CBA联赛之广东
日期:2015-12-23 21:21:55青铜圣斗士
日期:2015-12-05 10:35:30黄金圣斗士
日期:2015-11-26 20:42:16神斗士
日期:2015-11-19 12:47:50每日论坛发贴之星
日期:2015-11-18 06:20:00程序设计版块每日发帖之星
日期:2015-11-18 06:20:002015亚冠之城南
日期:2015-11-10 19:10:492015亚冠之萨济拖拉机
日期:2015-10-28 18:47:282015亚冠之柏太阳神
日期:2015-08-30 17:21:492015亚冠之山东鲁能
日期:2015-07-07 18:48:39摩羯座
日期:2014-08-29 23:01:42
12 [报告]
发表于 2013-10-23 18:43 |只看该作者
回复 7# humjb_1983


    thanks,正在学习中,希望以后多交流

论坛徽章:
9
程序设计版块每日发帖之星
日期:2016-02-13 06:20:00数据库技术版块每日发帖之星
日期:2016-06-15 06:20:00数据库技术版块每日发帖之星
日期:2016-06-16 06:20:00数据库技术版块每日发帖之星
日期:2016-06-18 06:20:00程序设计版块每日发帖之星
日期:2016-06-27 06:20:00程序设计版块每日发帖之星
日期:2016-07-09 06:20:00IT运维版块每日发帖之星
日期:2016-07-15 06:20:00IT运维版块每日发帖之星
日期:2016-07-27 06:20:00程序设计版块每日发帖之星
日期:2016-08-18 06:20:00
13 [报告]
发表于 2013-10-23 20:33 |只看该作者
arm-linux-gcc 发表于 2013-10-23 15:59
回复 10# mordorwww
vmalloc是非线性映射
vmalloc和kmalloc各自对应的页表entry是不同的item




不是问你这个
是问你vmalloc 区,也就是非线性区从哪段物理内存分配
前面不是说从896MB以上分配么,可是我这电脑896MB以上压根就木有内存

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
14 [报告]
发表于 2013-10-23 20:40 |只看该作者
回复 13# mordorwww


    没有高端内存时,vmalloc从低端内存拿,只不过映射到vmalloc zone而已

论坛徽章:
9
程序设计版块每日发帖之星
日期:2016-02-13 06:20:00数据库技术版块每日发帖之星
日期:2016-06-15 06:20:00数据库技术版块每日发帖之星
日期:2016-06-16 06:20:00数据库技术版块每日发帖之星
日期:2016-06-18 06:20:00程序设计版块每日发帖之星
日期:2016-06-27 06:20:00程序设计版块每日发帖之星
日期:2016-07-09 06:20:00IT运维版块每日发帖之星
日期:2016-07-15 06:20:00IT运维版块每日发帖之星
日期:2016-07-27 06:20:00程序设计版块每日发帖之星
日期:2016-08-18 06:20:00
15 [报告]
发表于 2013-10-23 20:44 |只看该作者
arm-linux-gcc 发表于 2013-10-23 20:40
回复 13# mordorwww



低端内存已经分配给线性区了,不冲突么

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
16 [报告]
发表于 2013-10-23 21:27 |只看该作者
回复 15# mordorwww


    不会冲突,低端物理内存即映射到线性区,也映射到非线性区

论坛徽章:
3
双鱼座
日期:2013-09-04 19:47:39天蝎座
日期:2013-12-11 20:30:532015年亚洲杯之澳大利亚
日期:2015-04-20 00:28:02
17 [报告]
发表于 2013-10-23 22:46 |只看该作者
回复 3# tc1989tc


     不管是kernel thread还是normal process, 它们要使用内存都必须向memory allocator提出申请, 并不是说kernel address直接映射了, kernel thread就可以直接使用这些内存. 内存管理 , 指的是有管理者。即使是同样内核的子系统, 也必须向他申请内存. 所以不会出现你所的那种冲突的情况。 一旦申请成功, memory allocator就会标记这些分配的page frame已经分配; 提出申请者没释放之前是不可能再分配这些已分配的内存的。
     
    其次,进程/kernel thread面向的是addresss space. 他们并不知道实际的物理内存. 比如malloc()函数, mm子系统会给他在user mode address space中分配一个VMA(virual address region), 并且分配一些物理内存给他, 然后通过page table 来记录, mm子系统就会知道进程提出的想要读取的0x8000 0000的数据,实际上是要读取物理内存0x1FFF FFFF的数据。vmalloc()函数同理. 0x8000 0000 -> 0x1FFF FFFF这个过程就是解析paging hierarchy, 间接通过paging hierarchy得到virutal address和physical address的映射。

    另外可以看alloc_page()和get_user_page()
    1) alloc_page() , 会向memory allocator申请1<<order个page frame, 并返回第一个块page frame的page descriptor *page. 因为page descriptor在都被分配在低端内存(属于直接映射部分)因此可以直接使用.  因此不需要转换就可以知道虚拟地址*page所在物理内存的地址。即使是高端内存也可以通过简单的计算得到其描述的page frame的地址(page_to_pfn() -- 建议不要看这个函数, 这个函数涉及到memory model 。你就当是从page descriptor得到物理内存中该page frame一个全局唯一的序号PFN) 。因此即使是高端内存的page frame, 只要得到page descriptor就可以知道分配的PFN(page frame number).   所以alloc_page才会有这个(__GFP_HIGHMEM)标志, 允许申请高端内存的物理页。

论坛徽章:
16
CU十二周年纪念徽章
日期:2013-10-24 15:41:3415-16赛季CBA联赛之广东
日期:2015-12-23 21:21:55青铜圣斗士
日期:2015-12-05 10:35:30黄金圣斗士
日期:2015-11-26 20:42:16神斗士
日期:2015-11-19 12:47:50每日论坛发贴之星
日期:2015-11-18 06:20:00程序设计版块每日发帖之星
日期:2015-11-18 06:20:002015亚冠之城南
日期:2015-11-10 19:10:492015亚冠之萨济拖拉机
日期:2015-10-28 18:47:282015亚冠之柏太阳神
日期:2015-08-30 17:21:492015亚冠之山东鲁能
日期:2015-07-07 18:48:39摩羯座
日期:2014-08-29 23:01:42
18 [报告]
发表于 2013-10-23 23:04 |只看该作者
回复 17# kiongf


    另外可以看alloc_page()和get_user_page()
     1) alloc_page() , 会向memory allocator申请1<<order个page frame, 并返回第一个块page frame的page descriptor *page. 因为page descriptor在都被分配在低端内存(属于直接映射部分)因此可以直接使用.  因此不需要转换就可以知道虚拟地址*page所在物理内存的地址。即使是高端内存也可以通过简单的计算得到其描述的page frame的地址(page_to_pfn() -- 建议不要看这个函数, 这个函数涉及到memory model 。你就当是从page descriptor得到物理内存中该page frame一个全局唯一的序号PFN) 。因此即使是高端内存的page frame, 只要得到page descriptor就可以知道分配的PFN(page frame number).   所以alloc_page才会有这个(__GFP_HIGHMEM)标志, 允许申请高端内存的物理页。

请问你所说的page descriptor 就是struct page结构吧?
还有就是不明白了vmalloc分配的是内核那个只有128M大小虚拟地址的空间,,这个怎么又跟我们进程用户空间的虚拟地址联系起来了啊??我们进程用户空间的虚拟地址不是通过页表和物理地址联系的了嘛??感觉很混

论坛徽章:
3
双鱼座
日期:2013-09-04 19:47:39天蝎座
日期:2013-12-11 20:30:532015年亚洲杯之澳大利亚
日期:2015-04-20 00:28:02
19 [报告]
发表于 2013-10-23 23:19 |只看该作者
回复 18# tc1989tc


    是的. page descriptor就是struct page.

         
     vmalloc() 和 你常见的c的malloc()都是申请虚拟内存区间, 来建立虚拟地址对物理地址的映射.他们同样是通过page table来记录的这段映射.   他们的区别在于一个只能被内核层使用, 一个同时可以被用户层和内核层使用。

     两者没有太多联系. 都是抢固定大小物理内存。 没有足够物理内存, 那么申请内存的进程/kernel thread要么放弃,要么就睡觉
     

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
20 [报告]
发表于 2013-10-24 08:52 |只看该作者
回复 12# tc1989tc

呵呵,互相学习~
   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP