首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >RedBoot不能从DDR运行

RedBoot不能从DDR运行
EN

Stack Overflow用户
提问于 2011-04-01 06:56:07
回答 1查看 335关注 0票数 2

我正在开发一款基于iMX31平台的新板,该板采用了美光公司的256MbLPDDR芯片(MT46H64M32LFCM-6),并使用与非门来启动该板(BOOT4:0 = 00001)。

我们知道一旦RedBoot开始运行,它将首先初始化系统,然后将其代码的第一个2KB从NAND复制到DDR,然后跳到DDR的内存位置并从那里运行代码。但在我的例子中,更改为程序计数器只会让我的主板变成一块无声的砖头。下面是我正在讨论的代码片段:

代码语言:javascript
复制
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的值也是正确的。

请帮帮忙,谢谢!

EN

回答 1

Stack Overflow用户

发布于 2011-06-25 12:25:29

ARM不只是停止了,因此它将有助于确定执行实际上在哪里继续。它将是两个地方之一:

  1. 您写入pc的PC值。这可能是也可能不是您期望的位置。如果可能,使用调试器来验证R0 & R1实际上是您期望的SDRAM.
  2. 异常,可能是一个中止异常,如预取中止。这意味着存储在PC上的指令所在的内存位置由于内存管理单元上的权限或配置问题(SDRAM?)而无法访问。

我会在中断向量上设置“陷阱”,让它们自己循环。这样你就可以看到PC在“挂起”后指向的任何地方,它会告诉你发生了什么。

在汇编中,它看起来像这样:

代码语言:javascript
复制
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的问题,可能是加载了错误的地址。

希望这能有所帮助!

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5507353

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档