免费注册 查看新帖 |

Chinaunix

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

[BootLoader] 开了MMU后 调试工具提示不能访问下一条指令 , 怎么办? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-12-10 18:29 |只看该作者 |倒序浏览

        mrc        p15, 0, r0, c1, c0, 0
        orr        r0,r0, #0x0001
        mcr        p15, 0, r0, c1, c0, 0

之前还一些关cache等一些操作 , 总之这最后一条指令完了 MMU就开了 , 然后, 我想 mov pc,lr 返回 , 可是调试工具提示不能访问 下一条指令 这是为什么 ? 地址被映射到别的地方了? 可是又不可能在执行开启MMU前给PC赋值 ,

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
2 [报告]
发表于 2013-12-12 20:44 |只看该作者
页表里需要做一份物理到虚拟的等值映射

论坛徽章:
0
3 [报告]
发表于 2013-12-13 17:50 |只看该作者
回复 1# sainimu78


开关MMU前后这几条指令做一对一的等值映射才行,否则取指会出错
因为一量开启了MMU后,下一条指令地址就是按新映射关系来寻址译码的

论坛徽章:
0
4 [报告]
发表于 2013-12-15 18:50 |只看该作者
回复 3# shuge_guet

arm-linux-gcc 发表于 2013-12-12 20:44 页表里需要做一份物理到虚拟的等值映射

贴一段uboot的代码
/*
* MMU Table for SMDK6400
*/

        /* form a first-level section entry */
.macro FL_SECTION_ENTRY base,ap,d,c,b
        .word (\base << 20) | (\ap << 10) | \
              (\d << 5) | (1<<4) | (\c << 3) | (\b << 2) | (1<<1)
.endm

.section .mmudata, "a"
        .align 14
        /* the following alignment creates the mmu table at address 0x4000. */
        .globl mmu_table
mmu_table:
        .set __base, 0
        /* 1:1 mapping for debugging */
        .rept 0xA00
        FL_SECTION_ENTRY __base, 3, 0, 0, 0
        .set __base, __base + 1
        .endr

        /* access is not allowed. */
        .rept 0xC00 - 0xA00
        .word 0x00000000
        .endr

        /* 128MB for SDRAM 0xC0000000 -> 0x50000000 */
        .set __base, 0x500
        .rept 0xC80 - 0xC00
        FL_SECTION_ENTRY __base, 3, 0, 1, 1
        .set __base, __base + 1
        .endr

        /* access is not allowed. */
        .rept 0x1000 - 0xc80
        .word 0x00000000
        .endr
#endif


        /* 1:1 mapping for debugging */
这个是等值映射的意思吗?

我看uboot里就用mcr p15,0,r1,c2,c0,0 , r1 = 0xce700000

这个地址也就是自己想要映射的虚拟地址吧 ?

那我做点小实验的话也不用做那么长的计算了吧 , 直接给定一个常数 0xce700000就可以了吧

ldr r1,=0xce700000
mcr p15,0,r1,c2,c0,0

是这么做吗?  没出效果啊 , 还是会出现开MMU后读不了下一条指令

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
5 [报告]
发表于 2013-12-15 20:07 |只看该作者
本帖最后由 arm-linux-gcc 于 2013-12-15 20:08 编辑

启动mmu前后,都最好做一下isb,然后再跳转

你这里参考smdk6400的,那么你的是arm1176jzf-s吗?不同版本的arm页表格式稍有不同的,最好参考linux中的值来设置

论坛徽章:
0
6 [报告]
发表于 2013-12-15 20:57 |只看该作者
回复 5# arm-linux-gcc


我用的板是OK6410
    isb 是指什么呢 ?

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
7 [报告]
发表于 2013-12-15 21:19 |只看该作者
isb指令是用来做同步的,在一些特殊的地方,为了避免乱序的影响,需要做等待
有dmb dsb isb三种级别的,开启mmu需要使用isb这种最高级别的
arm11没有isb指令,arm11对isb的实现是通过一条协处理器指令,可以查看kernel里面的实现

论坛徽章:
0
8 [报告]
发表于 2013-12-15 23:22 |只看该作者
回复 7# arm-linux-gcc


    我对linux内核还很陌生 能说说该看哪个文件吗 , 刚进了arm文件夹自己查了一下 , 感觉找不到该看的

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
9 [报告]
发表于 2013-12-16 11:24 |只看该作者
本帖最后由 arm-linux-gcc 于 2013-12-16 11:37 编辑

arch/arm/kernel/head.S
__turn_mmu_on函数
对linux不熟悉的话,建议还是看uboot更好

找个最新的uboot,看看mmu_setup函数

论坛徽章:
0
10 [报告]
发表于 2013-12-23 20:47 |只看该作者
回复 1# sainimu78


   
看看这篇文章对你有没有帮助
Gdb调试内核的启动
http://www.alivepea.me/kernel/gdb-kernel-startup/
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP