免费注册 查看新帖 |

Chinaunix

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

有关一个内核页表初始化的问题 [复制链接]

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

以下是ULK 第三版中关于 page global directory在 内存小于896MB的等价初始化它的代码:
    pgd = swapper_pg_dir + pgd_index(PAGE_OFFSET); /* 768 */
    phys_addr = 0x00000000;
    while (phys_addr < (max_low_pfn * PAGE_SIZE)) {
        pmd = one_md_table_init(pgd); /* returns pgd itself */
        set_pmd(pmd, _ _pmd(phys_addr | pgprot_val(_ _pgprot(0x1e3))));
        /* 0x1e3 == Present, Accessed, Dirty, Read/Write,
                Page Size, Global */
                phys_addr += PTRS_PER_PTE * PAGE_SIZE; /* 0x400000 */
         ++pgd;
  }

有两点不明白:
1、 是不是小于896M 以下的都这样作连续映射?
2、 为何没有先生成第四级 page table的entry(pte),而后再使pgd (page global directory )entry项指向这个生成的pte,最后再让pte中的内容为phys_addr | pgprot_val(_ _pgprot(0x1e3))
而这里是没有生成pte, 而是直接让pgd的内容为phys_addr | pgprot_val(_ _pgprot(0x1e3))...,也就是说page table没有页表项,没有12bit的flags进行控制?

论坛徽章:
0
2 [报告]
发表于 2011-07-06 14:06 |只看该作者
还没实际用到的内存,为何要做pte的映射

论坛徽章:
0
3 [报告]
发表于 2011-07-06 15:08 |只看该作者
回复 1# lymickey


    lz兄弟的问题,在ULK这本书里面讲的比较清楚,还是把书好好看.ls兄弟的问题,可以参见我的帖子“也谈谈四年来我对内核的研究”中关于这个问题的回答

论坛徽章:
0
4 [报告]
发表于 2011-07-06 15:25 |只看该作者
我2了
楼主专门找代码看一下
有映射的

论坛徽章:
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
5 [报告]
发表于 2011-10-03 15:58 |只看该作者
回复 1# lymickey


    这里使用的是大页(由于PAE未开启,所以是4MB),那个set_pmd()中置位了 PS。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP