TI论坛
直播中

李郝荫

7年用户 1315经验值
私信 关注

请问6678 EDMA搬数数据错误如何解决?

本帖最后由 一只耳朵怪 于 2018-6-19 10:52 编辑

各位专家好,我在6678板子上(CCS5.0)用QDMA进行从片内到片外搬数,但数据有错误。同样的配置片外到片外搬数就是正确的。我将cache关掉还是错误的。以下是部分代码,在这之前已经配置好了其他参数。请问各位专家有什么办法解决吗?谢谢。
  1. myParamSetup[8].srcAddr = (Uint32)&(globaldata_buffer_uv_frm[1][0][0]);
  2. myParamSetup[8].dstAddr = (Uint32)&(img->imgUV[1][globaldata_pix_c_y-3][0]);
  3. myParamSetup[8].aCntbCnt = CSL_EDMA3_CNT_MAKE(globaldata_width_cr,(filter_mbblocksize_2+3));
  4. CSL_edma3ParamSetup(hParamPing2,&myParamSetup[8]);

  5. myParamSetup[7].srcAddr = (Uint32)&(globaldata_buffer_uv_frm[0][0][0]);
  6. myParamSetup[7].dstAddr = (Uint32)&(img->imgUV[0][globaldata_pix_c_y-3][0]);
  7. myParamSetup[7].aCntbCnt = CSL_EDMA3_CNT_MAKE(globaldata_width_cr,filter_mbblocksize_2+3);
  8. CSL_edma3ParamSetup(hParamPong2,&myParamSetup[7]);

  9. myParamSetup[6].srcAddr = (Uint32)&(globaldata_buffer_y_frm[0][0]); //地址是0x0c0747b0
  10. myParamSetup[6].dstAddr =(Uint32)&(img->imgY[globaldata_pix_y-3][0]);//地址是0x81af06f0
  11. myParamSetup[6].aCntbCnt = CSL_EDMA3_CNT_MAKE(globaldata_width,MB_BLOCK_SIZE+3);
  12. CSL_edma3ParamSetup(hParamBasic2,&myParamSetup[6]);
  13. /* Enable Channel */
  14. if (CSL_edma3HwChannelControl(hChannel2,CSL_EDMA3_CMD_CHANNEL_ENABLE, NULL) != CSL_SOK)
  15. [
  16. printf ("Error: EDMA channel enable command failedn");
  17. return ;
  18. ]
  19. status = CSL_edma3ParamWriteWord(hParamBasic2,7,1);
  20. /* Poll IPR bit */
  21. regionIntr.region = CSL_EDMA3_REGION_0;
  22. do [
  23. CSL_edma3GetHwStatus(hModule,CSL_EDMA3_QUERY_INTRPEND,®ionIntr);

  24. ] while (!(regionIntr.intr & 0x4));
  25. /* Clear pending interrupt */
  26. status = CSL_edma3HwControl(hModule,CSL_EDMA3_CMD_INTRPEND_CLEAR,®ionIntr);

回帖(10)

李郝荫

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

杨娟

2018-6-19 06:44:24
引用: keith3000 发表于 2018-6-19 06:27
问题补充:附件中是源地址和目的地址的数据,错误的地方都是0,其他有数据的正确。还有dma和cpu对同一字段的访问谁优先?

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

举报

李郝荫

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

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

杨娟

2018-6-19 07:08:42
引用: keith3000 发表于 2018-6-19 06:53
您好,
我是从SHRAM搬到片外memory的,PaRAM set 的srcAddr的值为0x0c08366c。这个地址值有问题吗?还有,麻烦您看一下我上面的问题补充,附件里的数据可能能提供一些线索。谢谢!

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

举报

更多回帖

发帖
×
20
完善资料,
赚取积分