C6678学习——SPI NOR FLASH多核引导资料汇总及个人分享

南楼画角 提交于 2020-04-27 17:44:51

底层的东西比较费时,写出来,帮大家节省时间。
环境:
裸跑,没有操作系统。工具安装路径:C:\ti\pdk_c667x_2_0_9\packages\ti\boot
X龙开发板


先简单介绍单核引导:
参考"C6678_SPIboot_usersManual.pdf"
可能碰到的问题:

  1. xxx.exe如何产生?在utils里只有.c,需要make
    https://blog.csdn.net/Nicholas_Liu2017/article/details/78323391
    https://blog.csdn.net/u012530451/article/details/71125236

  2. 带初始化DDR的gel文件哪里来?
    我是使用了X龙提供的C6678.gel
  3. 加载gel文件即载入app.dat步骤:
    1. 确定已经在noboot模式下正常运行!
    2. 先新建一个ccxml文件,以区别于其他已经存在的工程。
    3. run->debug
    4. load gel文件
    5. 选择core0, connect -->写入gel
    6. load program “norwriter”
    7. 载入数据文件到DDR 0x80000000
    8. run
    9. 看Console的结果是否成功。注意FLASH的字节是否符合。

现在说多核:
一些要用的表格
在这里插入图片描述
在这里插入图片描述
BOOTMODE[2:0] = 6: SPI
internally, boot mode are translated by RBL into the extended boot mode that is used in the boot parameter table.
SPI Boot Mode 50 = 0x32
BOOTMODE[9:3] the device configuration fields
SPI:
BIT12-11: Mode 0: Data is output rising edge BIT10: PIN 0:4-pin mode used
BIT9: AddrWidth 1: 24-bit address width
BIT8-7: ChipSel 0
BIT6-3: ParaTableIndex 0











钱丰前辈给大家做了几个PPT,好好阅读一下
https://wenku.baidu.com/view/f06fb90e8762caaedc33d475.html?rec_flag=default
https://wenku.baidu.com/view/70cc5b87a6c30c2258019e5d.html
相关工具原文件下载:
https://e2echina.ti.com/question_answer/dsp_arm/c6000_multicore/f/53/t/8065#pi239031350=2&pi58417=2
个人解读:
hex6x多个.out, .rmd文件
mergebtbl?即将n个btbl文件组合在一起。将n个btbl文件去除非字节的内容,以及每个文件结尾处的4个0x00字节,最后一个btbl文件的结尾部分不处理。
AddDdrTable6678?当gel可以配置ddr时是否还必要?工具用于在btbl文件前加入6678开发板上的DDR配置表
b2ccs_ex和b2i2c_ex就是对原有工具的SIZE重新定义,更新为128M 0x8000000
qfparse?与romparse的联系/区别?
qf即作者钱丰的缩写,其将romparse由nysh.spi.map到处的文件直接用ParaTable.map替代。
对于xxx.i2c.ccs的前5个字符拷贝处理,更改地址为80000000,最后一个字符+256表示增加256个字节的boot para table,即ParaTable.map中的内容。
而romparse则是通过解析nysh.spi.map文件来得到boot para table. qfparse将其简化。
注意,仍需手动更改0x51–>0x00
modify就是byteswapccs














TI官方提供的资料汇总:
https://e2echina.ti.com/question_answer/dsp_arm/c6000_multicore/f/53/t/4899
https://e2echina.ti.com/question_answer/dsp_arm/c6000_multicore/f/53/t/109255

比较坑人的部分:

  1. 多核同一个工程也需要每个核独立的cmd文件!该IPC中断无需相应
  2. MAGIC ADDRESS 存的是相对地址,所以需要+0x10000000

例子:3核引导的关键代码:

void MulticoreBoot()
{
     uint32_t *pBootMagicAddCore0;
     if (DNUM == 0)
    {
        /*write Boot Magic add of other cores and send IPC interrupt*/
        pBootMagicAddCore0 = (uint32_t *)0x1087FFFC;
       (*pBootMagicAddCore0)+= 0x10000000;// translate to global address
       *(uint32_t *)(0x1187FFFC) = (*pBootMagicAddCore0) + 0x01000000;
       *(uint32_t *)(0x1287FFFC) = (*pBootMagicAddCore0) + 0x01000000 * 2;
    //send a IPC to core 1 to boot up
    IPCGR1 = 0x1;
    IPCGR2 = 0x1;
}
else
{

}
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!