我正在开发一款基于iMX31平台的新板,该板采用了美光公司的256MbLPDDR芯片(MT46H64M32LFCM-6),并使用与非门来启动该板(BOOT4:0 = 00001)。
我们知道一旦RedBoot开始运行,它将首先初始化系统,然后将其代码的第一个2KB从NAND复制到DDR,然后跳到DDR的内存位置并从那里运行代码。但在我的例子中,更改为程序计数器只会让我的主板变成一块无声的砖头。下面是我正在讨论的代码片段:
1: ldmia r0!, {r3-r10}
stmia r1!, {r3-r10}
cmp r0, r2
blo 1b
/* Jump to SDRAM */
ldr r1, CONST_0x0FFF
and r0, pc, r1 /* offset of pc */
ldr r1, MXC_REDBOOT_ROM_START
add r1, r1, #0x10
add pc, r0, r1
nop
nop
nop
nop
...一旦add pc, r0, r1被执行,整个过程就会停止。我已经验证了我的DDR初始化是正确的(所有的时序参数,ROW=14,COL=10和数据总线size=x32),并且我已经运行了几次内存测试,没有失败,所以我非常有信心控制器和内存芯片本身是正常的。在RedBoot中,一切看起来和工作都很好,直到我必须手动将程序计数器的值设置为DDR内存映射范围内的某个值。
我已经在这里呆了几天了,我再次检查了我复制到DDR中的数据和NAND中的数据是相同的,PC的值也是正确的。
请帮帮忙,谢谢!
发布于 2011-06-25 12:25:29
ARM不只是停止了,因此它将有助于确定执行实际上在哪里继续。它将是两个地方之一:
我会在中断向量上设置“陷阱”,让它们自己循环。这样你就可以看到PC在“挂起”后指向的任何地方,它会告诉你发生了什么。
在汇编中,它看起来像这样:
B _reset /* Reset */
B . /* Undefined Instruction */
B . /* Software Interrupt*/
B . /* Prefetch Abort*/
B . /* Data Abort*/
B . /* Reserved*/
B . /* IRQ*/
B . /* FIQ*/只需在内存的开头(0x00000000)找到此代码,然后重新运行程序。如果它在0x0000000C (预取中止)或0x000000010 (数据中止)挂起,则可能是SDRAM配置或MMU权限。如果它挂在其他地方,那么这是代码加载PC的问题,可能是加载了错误的地址。
希望这能有所帮助!
https://stackoverflow.com/questions/5507353
复制相似问题