免费注册 查看新帖 |

Chinaunix

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

问一个mmap内存映射的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-06-23 18:42 |只看该作者 |倒序浏览
小弟新手,现在想在用户进程中用mmap映射内核申请到的分页。
我现在使用的是rhel5.2 x86_64版本,内核2.6.18,内存4G。

我在内核中通过__get_free_pages申请到的逻辑地址是: 0xffff81010f000000
然后通过__pa()计算出物理地址是:0x10f000000

看了以前高手们的帖子得知:可以直接使用mmap()函数映射的方式直接访问这个分页,其中偏移量就是物理地址。
事实上,我的程序也成功的访问了这个区域,我的问题是:
很明显,0x10f000000这个偏移量已经超过了4GB的物理内存空间。那么到底我的分页是在什么位置?
如果可以的话,请高手们详细讲解一下x86_64环境下,内存的分配方式。谢谢

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
2 [报告]
发表于 2009-06-23 23:19 |只看该作者

回复 #1 lzg2099379 的帖子

X86—64和32位系统差别还真大,这个可能需要看一下代码才知道

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
3 [报告]
发表于 2009-06-23 23:30 |只看该作者

回复 #1 lzg2099379 的帖子

#define RGN_KERNEL        7        /* Identity mapped region */
#define PAGE_OFFSET                        RGN_BASE(RGN_KERNEL)

#define RGN_BASE(r)        (__IA64_UL_CONST(r)<<RGN_SHIFT)
# define __IA64_UL_CONST(x)        x##UL
#define RGN_SHIFT        (61)

由此跟下来,在64位系统中,PAGE_OFFSET的值为 7 <<  61,即真实的物理地址映射到0xE000000000000000地址开始的地方;
按照它这个规范,虚拟地址已经突破了4GB的限制,而应该是2^64的虚拟地址空间,只是把物理地址映射到了0xE000000000000000地址开始的地方而已。我猜想具体的内核空间应该是0xE000000000000000—0xFFFFFFFFFFFFFFFF的范围。
实际情况可能需要跟踪代码才能搞清楚了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP