TI中文支持网
TI专业的中文技术问题搜集分享网站

6678 EDMA 搬数数据错误

各位专家好,我在6678板子上(CCS5.0)用QDMA进行从片内到片外搬数,但数据有错误。同样的配置片外到片外搬数就是正确的。我将cache关掉还是错误的。以下是部分代码,在这之前已经配置好了其他参数。请问各位专家有什么办法解决吗?谢谢。

myParamSetup[8].srcAddr = (Uint32)&(globaldata_buffer_uv_frm[1][0][0]);
myParamSetup[8].dstAddr = (Uint32)&(img->imgUV[1][globaldata_pix_c_y-3][0]); myParamSetup[8].aCntbCnt = CSL_EDMA3_CNT_MAKE(globaldata_width_cr,(filter_mbblocksize_2+3));
CSL_edma3ParamSetup(hParamPing2,&myParamSetup[8]);
myParamSetup[7].srcAddr = (Uint32)&(globaldata_buffer_uv_frm[0][0][0]);
myParamSetup[7].dstAddr = (Uint32)&(img->imgUV[0][globaldata_pix_c_y-3][0]);
myParamSetup[7].aCntbCnt = CSL_EDMA3_CNT_MAKE(globaldata_width_cr,filter_mbblocksize_2+3); CSL_edma3ParamSetup(hParamPong2,&myParamSetup[7]);
myParamSetup[6].srcAddr = (Uint32)&(globaldata_buffer_y_frm[0][0]); //地址是0x0c0747b0
myParamSetup[6].dstAddr =(Uint32)&(img->imgY[globaldata_pix_y-3][0]);//地址是0x81af06f0
myParamSetup[6].aCntbCnt = CSL_EDMA3_CNT_MAKE(globaldata_width,MB_BLOCK_SIZE+3); CSL_edma3ParamSetup(hParamBasic2,&myParamSetup[6]);
/* Enable Channel */
if (CSL_edma3HwChannelControl(hChannel2,CSL_EDMA3_CMD_CHANNEL_ENABLE, NULL) != CSL_SOK)
{
printf ("Error: EDMA channel enable command failed\n");
return ;
}
status = CSL_edma3ParamWriteWord(hParamBasic2,7,1);

/* Poll IPR bit */ regionIntr.region = CSL_EDMA3_REGION_0;
do {
CSL_edma3GetHwStatus(hModule,CSL_EDMA3_QUERY_INTRPEND,&regionIntr);
} while (!(regionIntr.intr & 0x4));
/* Clear pending interrupt */
status = CSL_edma3HwControl(hModule,CSL_EDMA3_CMD_INTRPEND_CLEAR,&regionIntr);

jill zhou:

问题补充:附件中是源地址和目的地址的数据,错误的地方都是0,其他有数据的正确。还有dma和cpu对同一字段的访问谁优先?

Andy Yin1:

回复 jill zhou:

您好,

从代码来看感觉在从LL2将数据搬到外部memory,在给QDMA srcAddr赋值时没有转换为全局地址,你可以在配置完QDMA后启动QDMA之前看一下对应PaRAM set中的srcAddr是否为全局的值如0x1n8xxxxx(core_n),如果为0x008xxxxx则说明需要转换为全局地址。请确认后测试反馈一下,谢谢。

jill zhou:

回复 Andy Yin1:

您好,

我是从SHRAM搬到片外memory的,PaRAM set 的srcAddr的值为0x0c08366c。这个地址值有问题吗?还有,麻烦您看一下我上面的问题补充,附件里的数据可能能提供一些线索。谢谢!

Andy Yin1:

回复 jill zhou:

源地址在SL2,还是请确认是否cache的问题。可以在初始化完SL2后通过勾选L1D cache看看memory中的数据是否有变化,如有变化怎会是cache的影响,可以加cache flush。

jill zhou:

回复 Andy Yin1:

您好,

我按您说的查看后,数据没有变化。我的cache是开在L2中的,对从SHRAM到片外的搬数会有影响吗?而且您看过我上述附件里的数据吗?感觉好像是被中断了,是不是和CPU的访问冲突了,如果是的话,可以通过降低DMA的时钟频率改变吗?我之前是一个宏块行整体搬数的,后来改成一个像素行的搬,结果还是这样的错误。谢谢!

jill zhou:

回复 Andy Yin1:

您好,

我按您说的查看后,数据没有变化。我的cache是开在L2中的,对从SHRAM到片外的搬数会有影响吗?而且您看过我上述附件里的数据吗?感觉好像是被中断了,是不是和CPU的访问冲突了,如果是的话,可以通过降低DMA的时钟频率改变吗?我之前是一个宏块行整体搬数的,后来改成一个像素行的搬,结果还是这样的错误。谢谢!

jill zhou:

回复 Andy Yin1:

Hi, Andy

谢谢你的悉心指导,现在可以了。就像你说的那样。是cache和字对齐的问题。非常感谢!

huang kevin2:

回复 jill zhou:

  您好,我也遇到了和您同样的问题,开启cache时候,DMA数据拷贝不正确,想使用cache_wbL1d()对cache里的数据进行回写。

 但是我搬运的数据量SIZE在23K左右,而且是一个复杂的结构体,这样的话,我直观的想法就是

cache_wbL1d(psrc,SIZE,CACHE_WAIT);

CACHE_wbL1dWait();

肯定这个结构只有一部分在这个数据结构中的,但是release版本的不对,

还有那个对齐的问题,地址不是64B对齐的就会出错吗

jill zhou:

回复 huang kevin2:

你好,L1d CACHE是自动enable的,如果你还开了别的CACHE那么要根据数据手册,相应的CACHE写回和无效。关于字对齐我不太了解,我那个问题就是地址是64位对齐的就没有出错

赞(0)
未经允许不得转载:TI中文支持网 » 6678 EDMA 搬数数据错误
分享到: 更多 (0)