免费注册 查看新帖 |

Chinaunix

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

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

论坛徽章:
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
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-10-21 20:23 |只看该作者 |正序浏览
linux地址转换是:逻辑地址转换为线性地址,线性地址通过页表在转换为物理地址。。
但是在今天看内核内存管理的时候,有个struct page 结构说是每个物理页帧的记录者,,还有一个虚拟内存区( VMA )用来管理进程地址空间中不同区域的内核数据结构。不明白这两个结构跟页表有什么联系。。。
还有一个问题就是,一个内核逻辑地址通过一定偏移量就得到对应的物理地址,,,但是这样是不是就会让内核的逻辑地址对应的那些所以的物理地址 都不能分配给其它用户空间的虚拟地址来映射了啊。。也就是说用户空间地址只能映射高端地址???这样肯定是错的,,但是不知道为啥子??希望高手指导哈以上两个问题

论坛徽章:
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
25 [报告]
发表于 2013-10-24 15:10 |只看该作者
回复 24# mordorwww
kmalloc用于分配存放页描述符指针(*page)的数组
alloc_page用于实际page的分配,标记是GFP_KERNEL | __GFP_HIGHMEM


   

论坛徽章:
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
24 [报告]
发表于 2013-10-24 14:03 |只看该作者
humjb_1983 发表于 2013-10-24 11:03
呵呵,对的,其最终还是通过kmalloc和alloc_page接口来分别物理内存的。


vmalloc通过kmalloc干啥

论坛徽章:
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
23 [报告]
发表于 2013-10-24 11:03 |只看该作者
mordorwww 发表于 2013-10-24 10:22
你这话说得貌似 vmalloc 是靠 kmalloc 来分配内存的

呵呵,对的,其最终还是通过kmalloc和alloc_page接口来分别物理内存的。

论坛徽章:
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
22 [报告]
发表于 2013-10-24 10:22 |只看该作者
humjb_1983 发表于 2013-10-24 09:15
vmalloc并没说一定在896M之后的物理内存中分配吧,vmalloc对应的“非连续内存区”实际是线性地址(虚拟地址 ...


你这话说得貌似 vmalloc 是靠 kmalloc 来分配内存的

论坛徽章:
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
21 [报告]
发表于 2013-10-24 09:15 |只看该作者
mordorwww 发表于 2013-10-23 14:42
那这样vmalloc怎么办?所有内存都线性映射?

vmalloc并没说一定在896M之后的物理内存中分配吧,vmalloc对应的“非连续内存区”实际是线性地址(虚拟地址空间中)的概念,其分配的物理内存实际是通过kmalloc和alloc_page接口分配的,分配标记为GFP_KERNEL|GFP_HIGHMEM,表示其分配的物理内存既可以在低端内存,也可以在高端内存中。

论坛徽章:
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

呵呵,互相学习~
   

论坛徽章:
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要么放弃,要么就睡觉
     

论坛徽章:
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
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)标志, 允许申请高端内存的物理页。
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP