转帖: TMS320C6474(六核)使用经验总结

2019-07-31 15:40发布

1.main函数中一般不能等待信号量,可能会被无视
      2.使用SRIO在2CPU之间相互交换数据时,数据如果在L2(2级内存,6474为1M)内,则两CPU的L2地址都应设为global地址。即不能为0x08XXXXXX。
      3.6474
      EVM开发板,用ccs中的SRIO示例程序在2个CPU间传递数据时,最多一次传4K,最少目前设为16个,4个不稳定,建议设为256个。原因应该是每次传输一个双字,寄存器可设。4K时为512个双字。
      4.1个CPU的core0运行程序中如有printf语句,自己运行速度无影响,但如果此时core1或core2空转,core0速度会变慢为大约1/4。如无printf语句,则各核速度暂无影响。
      5.一些数据初始化的步骤避免放在main中,可以创建一个最高优先级的初始化任务。否则程序运行一次后,再次运行时可能崩溃。(崩溃应该发生在main运行完转到其他任务时,如在main中加一中断则不会崩溃,原因不明,应该是BIOS操作系统的BUG,貌似可以配置一选项解决(绕过)此问题。)
      6.volatile只能保证读取数据时不读取cache直接读取内存。如果写入后立刻通过SRIO或DMA传输,应用BCACHE_wb立刻把cache中的数据写回内存。BCACHE_inv可使cache无效,可用于读取非volatile数据。
      7.在simulater模式下,同一个CPU的core之间是不能访问对方的L2的。比如core0的L2是0x10800000起始,core1的L2是0x11800000起始,core0不能访问0x11800000起始的长度为0x100000的空间。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
6条回答
益友电子
1楼-- · 2019-07-31 19:35
main函数中不能等待信号量,能不能具体的讲解一下呢,谢谢!
zlove1990
2楼-- · 2019-07-31 23:30
楼主能留个联系方式么
zhangmangui
3楼-- · 2019-08-01 03:22
zlove1990 发表于 2014-8-26 21:46
楼主能留个联系方式么

从楼主的发帖来看  资料来自收集   
还望你找找相关资料    顺便分享给大家
shenmu2012
4楼-- · 2019-08-01 07:36
 精彩回答 2  元偷偷看……
zhangjin_comeon
5楼-- · 2019-08-01 10:51
向楼主学习
小木欧尼
6楼-- · 2019-08-01 15:51
shenmu2012 发表于 2014-8-26 22:53
volatile只能保证读取数据时不读取cache直接读取内存。如果写入后立刻通过SRIO或DMA传输,应用BCACHE_wb立 ...

学习啦

一周热门 更多>