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

底层的东西比较费时,写出来,帮大家节省时间。

环境:

裸跑,没有操作系统。工具安装路径: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
    {
    }
}

TI的资料比较散,C66x系列也比较复杂,希望本文可以帮助到大家,节省底层开发时间。
完!

  • 3
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
冃录 11录 ...............................................................3 C6678多核运行Dem o详解.......................................... 7 1 ・ intc_b「oadcast_ 1 ...................................................................................................... 7 I」功能描述........................................................7 1.2变最定义及使用空间分配.........................................7 1.3实现流程........................................................7 1.4注意事项........................................................9 2. D D R 3......................................................................................................................10 2 .1 功能描述....................................................... 10 2.2变量定义及使用空间分配........................................ 10 2.3实现流程....................................................... 10 2.4注意事项....................................................... 11 3. ipc一 navigator.......................................................................................................... 12 3」功能描述....................................................... 12 3.2变最定义及使用空间分配........................................ 12 V 3 .3 实现流程....................................................... 12 3.4注意事项....................................................... 14 4. emif_nandflash....................................................................................................... 14 4 J 功能描述....................................................... 14 4.2变量定义及使用空间分配........................................ 14 4 .3 实现流程....................................................... 14 4.4注意事项....................................................... 15 5. emif_norflash......................................................................................................... 16 5」功能描述....................................................... 16 5.2变最定义及使用空间分配........................................ 16 5.3实现流程....................................................... 16 5.4注意事项....................................................... 17 6. hyperlink................................................................................................................ 17 6」功能描述....................................................17 6.2变量定义及使用空间分配......................................17 6 .3 实现流程....................................................17 6.4注意事项.................................................... 18 7. i2c_eeprom............................................................................................................. 19 7」功能描述.....................................................19 7.2变最定义及使用空间分配......................................19 7.3实现流程.................................................... 19 7.4注意事项....................................................20 8. i2c_srioswitch........................................................................................................20 & 1功能描述....................................................20 8.2变量定义及使用空间分配......................................20 8.3实现流税.........:............................. =21 8.4注意事项....................................................21 9. sem 2....................................................................................................................... 21 9」功能描述.................................................... 21 9.2变虽定义及使用空间分配......................................22 9.3实现流程....................................................22 9.4注意事项....................................................23 1(). srio...........................................................................................................................24 10」功能描述...................................................24 10.2变暈定义及使用空间分配.....................................24 10.3实现流程...................................................24 10.4注意事项...................................................27 11. tim er....................................................................................................................... 28 11」功能描述...................................................28 11.2变最定义及使用空间分配.....................................28 11.3实现流程...................................................2911.4注意爭项......................................................30 12. SPI_FPGA.............................................................................................................. 30 12」功能描述......................................................30 12.2变量定义及使用空间分配.......................................30 12.3实现流程......................................................30 12.4注意爭项......................................................31 13. SPI_nortlash...........................................................................................................31 13」功能描述......................................................31 13.2变量定义及使用空间分配.......................................31 13.3实现流程......................................................31 13.4注意爭项......................................
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值