【求教】基于ARM和DSP双核的程序结构问题

2019-03-26 14:53发布

我有一个图片压缩算法,想要移植到DSP+ARM(674x核+cortex a8)的平台上。ARM主要用来控制,DSP用来做 图片压缩处理。ARM上跑的是linux系统,DSP上是SYS/BIOS,开发环境是CCS。按我的想法,程序结构是: (1)DSP和ARM的程序是在同一个main函数里,建立多个线程,线程1用于ARM端写共享buffer,线程2用于DSP 压缩处理;线程3用于ARM端接收压缩数据并组装压缩数据 (2)程序开始,ARM接收图像数据并把其写入共享内存块buf1中,同时DSP挂起等待; (3)当ARM写完一块数据,SEM1++通知DSP开始取数据并进行压缩(4)DSP读取完buf1数据,SEM1--通知ARM继续向buf1写数据;同时DSP进行压缩,压缩完后数据写入共享内存 块buf2中,SEM2++通知ARM开始取数据 ...循环以上步骤   问题: (1)我的程序结构是否是对的?应该不会是ARM核和DSP核各烧一个程序文件吧?那样的话我不知道怎么通信 。。 (2)最终CCS编译出来的程序是烧到ARM核上还是DSP核上呢? (3)关于程序里的ARM和DSP双核信号通信,linux和SYS/BIOS的信号写法都不一样,该怎么统一,这是我最弄 不明白的地方...请高手指导... (4)我目前CCS是在Windows下安装的,这样编译可以吗,还是需要在linux系统下的CCS编译?  以上有做过的敬请指点下哈~没做过的也可以一起探讨下,感谢~~~ 此帖出自小平头技术问答
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
6条回答
breeze505
2019-03-26 23:58
< 非常感谢您的资料!看了资料,对于上面的问题,我是否可以这样理解:
1.  DSP和ARM的程序是在同一个main函数里,程序结构采用多线程,采用DSPLINK 中的MSGQ等模块通信
2. 最程序是烧到ARM核,DSP端的程序是通过DSPLINK的PROG进行加载
3. 程序的编译环境不是在CCS上,是在Linux系统构建的专门DSPLINK编译平台(这里是命令行编译?)

以上请您再次帮忙指正,感谢!!!

一周热门 更多>