免费注册 查看新帖 |

Chinaunix

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

[BootLoader] 求教LowLevel_init.s的SMRDATA问题 [复制链接]

论坛徽章:
2
水瓶座
日期:2013-09-04 15:09:57白羊座
日期:2014-04-17 16:48:13
1 [报告]
发表于 2011-08-29 15:58 |显示全部楼层
看样子好像是内存控制器BANK0-BANK7的设置内容,一个总控寄存器+8个BANK的寄存器。

不懂LZ说的13个地址是什么意思?

论坛徽章:
2
水瓶座
日期:2013-09-04 15:09:57白羊座
日期:2014-04-17 16:48:13
2 [报告]
发表于 2011-08-29 16:19 |显示全部楼层

  1.         ldr        r1, =BWSCON        /* Bus Width Status Controller */
  2.         add     r2, r0, #13*4
  3. 0:
  4.         ldr     r3, [r0], #4
  5.         str     r3, [r1], #4
  6.         cmp     r2, r0
  7.         bne     0b
复制代码
这段应该是把SMRDATA开始的13个DWORD写到从BWSCON开始的对应的13个寄存器中。

上面那段不清楚那几个常量ld脚本里是怎么定义的,大概作用注释里面也说了
当前内存控制器还没初始化,所以要算出SMRDATA开始的数据在SoC的内部RAM上的地址而不是链接脚本里面写的地址。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP