求教:DSP6678多核EDMA问题。自己设计的函数 用EDMA 把2维的100*400字节的图像数据从DDR3 搬到DDR3 每次都能成功。但是与sl2互相搬数的时候,第一次能成功,后面几次失败
现象描述:现在用的两个核,0核进行数据通信,1核用作算法处理。我主要用1核。由于时间要求高,运算数据量大,不能把数据都放在6678的共享内存中,只能存放在DDR3中,需要的时候再把数据搬进来。
现在用EDMA 把100*400字节的图像数据从DDR3 搬到DDR3 每次都能成功,DDR3 (0x83000000)搬到sl2(0x0C200000)第一次能成功,后面几次失败,搬过来的数据只是其中的一小部分,总是搬不全。导致后面用到这部分数据做运算时,数据还没有来全,导致结果都是错的。
ps:其中SL2用到的0x0C200000-0x0C400000的这部分内存都是通过0核1核的CMD文件分配好了,0核1核都将他开辟出来,没有存放数据,只用来做运算内存空间
问题1:
怎么定位问题?是不是有成功案例,就可以排除配置问题?
问题2:
有可能是冲突问题吗?我的通道,核的配置,事件队列,与0核都不相同
问题3:
执行搬数函数的时间我不能知道,现在测试执行这个函数的主频是0.01ms,有人数时间太长,这个怎么理解?