天嵌 ARM开发社区

 找回密码
 注册
查看: 2576|回复: 1

Nand Flash启动疑问....

[复制链接]
回帖奖励 2 回复本帖可获得 2 奖励! 每人限 1 次
Romatom 发表于 2012-9-7 21:37:05 | 显示全部楼层 |阅读模式
本帖最后由 Romatom 于 2012-9-8 22:25 编辑

以S3C2440为例子,选择从nand flash启动,开始时硬件自动将nand flash中前4k内容拷贝到steppingtone中运行。一般情况下,这4k代码会完成将nand flash中的数据或者代码拷贝到sdram中去。
前4k中肯定有跳转到sdram中跳转代码,比如 b xmain。
问题1:假如b xmain这句代码在需要跳转的代码段在前4k以内,那么pc是跳转到这4k代码中中xmain标号中,还是跳转到Sdram中xmain标号处?
问题2:假如跳转到Sdram中执行代码,硬件上是不是通过地址重映射(MMU或者CP15,我不知道,只是猜测),将sdram的起始地址(0x30000000)映射为地址0x00000000,然后开始执行前4K中所没有的代码?
问题3:如果上诉两个问题我没有表述清楚,望大侠能够给详细解释一下nand flash启动的过程。谢谢大侠们了......
 楼主| Romatom 发表于 2012-10-16 09:34:50 | 显示全部楼层
在启动代码中,有一行代码是ldr pc,=copy_proc_beg。作用是将copy_proc_beg的绝对地址加载到程序计数器PC中,其绝对地址是0x30000000+偏移量。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

i.MX8系列ARM cortex A53 M4 工控板上一条 /1 下一条

Archiver|手机版|小黑屋|天嵌 嵌入式开发社区 ( 粤ICP备11094220号 )

GMT+8, 2024-5-15 21:41 , Processed in 1.078125 second(s), 23 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表