C6678的SPI Flash启动失败

XX板上的6678使用I2C外接其他主机启动。但设计时保留了Nor Flash启动方式作为备份启动方式,因此需要调试SPI Flash启动。

6678支持多种启动方式,在《Bootloader for the C66x DSP User Guide(sprugy5b)》中都有描述。不同的启动方式由上电时启动模式引脚的状态配置,XX板上在研发阶段采用了拨码配置。

根据手册说明,需要先生成一个启动镜像烧入到Nor Flash中。SPI Flash模式下的启动镜像分两部分,一是启动参数表,二是启动表。启动表是从编译生成的.out文件经过TI提供的一些工具逐步转换格式生成的,启动参数表在每种启动模式下均不相同,可以手工逐字节填写。

首先做了一个简单的闪灯程序,用仿真器下载运行成功,然后用工具转化出启动表。最后需要手工加上启动参数表。
TI提供的示例中有I2C EEPROM的启动镜像,但是没有SPI镜像。两者的启动表格式相同,但启动参数表格式略有区别。参考手册并仿照I2C进行修改后生成镜像,烧进去后修改拨码,上电后发现灯不亮。

这时回到手册再仔细分析,花费两天时间也没有发现问题,网上也查找不到相应资料。后来把思路重新整理了一下,根据手册整理出CPU的启动流程图,然后准备一步步排查。

首先上电后采样引脚确定启动模式。用万用表测量拨码电平,没有发现问题。用示波器排查CPU时钟输出引脚,发现有输出信号,说明CPU在正常工作。
然后就要读Flash数据了,用示波器看Flash波形,有输出和输入信号,证实了CPU进入了SPI启动的分支。但持续约几十个字节后信号消失,而正常情况下应该有几百字节才对。这里明显有问题,但原因不明。
由于启动过程CPU都是在执行BootROM里的指令

  • 5
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值