This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

[参考译文] TMS320C6424:EDMA 丢失数据

Guru**** 2539500 points


请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。

https://e2e.ti.com/support/processors-group/processors/f/processors-forum/572291/tms320c6424-edma-missing-data

器件型号:TMS320C6424

您好 TI

我有两个 EDMA 传输设置、它们都在传输中丢失数据。 因此、我认为这可能是一种常规配置、我缺失或被误解了。

EDMA 1)
我在内部存储器中有一个32字节(数组)的数据块、该数据块将被移动到外部 DDR RAM 中的循环缓冲器。 我的工作非常好、除了在参数已用尽且重新加载时、我在最后一次传输中只获得16个字节。

参数41 + 42:

ui32Option = 0;
ui32Src = 0x10F0F0B4
ui32Dst = 0x83A9A510
ui32BcntAcnt = 0x04B00020
ui32BcntrldLink = 0x04B04540
ui32DstSrcBIDx = 0x00200000
ui32Ccnt = 1.
ui32DstSrcCidx = 0

我通过写入以下内容来触发参数41:

regui32EmbcrH |= 1 << 9;
regui32esrH |= 1 << 9;

我已经通过 JTAG 手动触发了传输、并且除了最后一个块(只有一半)之外、每个数据块都被正确传输。 从参数42重新加载也可以正常工作。

EDMA 2)
另一个 EDMA 将一半数据从循环缓冲器移动到 DDR 中的另一个缓冲器、也会手动触发。 ACNT = 19200、BCNT=1和 CCNT = 1。 我有时会传输所有数据、但最终通常会丢失数据

我将通过用'1'填充循环缓冲区(没有比这更进一步的更新)、清除('0')接收缓冲区、然后触发传输来进行测试。

我错过了什么?

  • 请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。
    您好、Tomas、

    我已将此事转交给专家。 他们的反馈应发布在此处。

    BR
    Tsvetolin Shulev
  • 请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。

    谢谢你 Tsvetolin。
    创建帖子后、我认为这可能是缓存问题、我刚刚完成了将缓冲区移动到非缓存位置的测试、这似乎解决了问题。 现在、我将研究高速缓存一致性问题。