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.

[参考译文] TMS320F28377D:关于使用 DMA 存储 SPIRXBUFF 数据但 DMA 存储缓冲区数据未及时更新的问题

Guru**** 2460850 points
Other Parts Discussed in Thread: C2000WARE

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

https://e2e.ti.com/support/microcontrollers/c2000-microcontrollers-group/c2000/f/c2000-microcontrollers-forum/1501358/tms320f28377d-regarding-the-problem-of-using-dma-to-store-spirxbuff-data-but-the-dma-storage-buffer-data-is-not-updated-in-time

器件型号:TMS320F28377D
主题:C2000WARE 中讨论的其他器件

工具/软件:

在 DSP28377D 芯片上、我使用 DMA 存储 SPI 接收到的数据。 我看到 DMA 存储地址已增加接收到的数据数、但当我读取 DMA 存储缓冲区中的数据时、我发现它尚未更新。 在刷新数据之前、我必须等待238条时钟指令。 我使用违例关键字修改了缓冲区、但它不起作用。 这是硬件造成的、还是我处理不当? 我想知道数据刷新的确切时间点。

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

    尊敬的 Yutao:

    我有几个澄清问题:

    • 您如何查看缓冲区? 寄存器? 如果是、能否确保打开持续刷新?
    • 您是否启用了其他 DMA 通道? 如果是、您配置了哪种优先级模式(轮循或通道1优先级)?
    • 此外、您是否尝试过在 C2000ware 中运行 SPI/DMA 示例? 这有助于了解 SPI + DMA 运行所需的配置。 没有这方面的 F2837xD 示例、但您可以查看 F28004x、后者的工作原理相同。 路径中有示例:[C2000ware install[/driverlib/f2837xd/examples/cpu1/spi/spi_ex5_loopback_dma.

    我建议使用 DMA 传输结束中断在每次传输结束时暂停您的代码、并 查看 Memory Browser 中的缓冲区(持续刷新打开)。 确保将 DMA 通道的仿真模式设置为 dma_emulation_stop、以便当 CPU 在断点处停止时、DMA 不会继续运行。

    此致、

    Delaney

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

    尊敬的 Delaney:


     我发现了数据未刷新的问题-数据是否已更新由 dst_ADDR_ACTIVE 决定、而不是由 transfer_COUNT 决定。

     但是、我遇到了另一个问题、即当我连续发送256字节的 SPI 数据时、偶尔会停止发送、从而导致不连续的数据帧和 SPI 从器件无法识别它。 原因是 SpiaRegs SPIFFTX。 位。 TXFFST 峰值、我应该如何解决这个问题? 使用 SPI-DMA 发送?

    此致、

    Yutao



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

    尊敬的 Yutao:

    只是为了验证、您之前的问题已解决、正确吗?

    对于传输 SPI 消息、您似乎使用了轮询方法。 是否希望在 SPI TX 线路上持续传输? 如果是、可能需要提高传输速率、才能不进入 FIFO 已满的条件。

    您能否详细解释一下应用中调用此函数的位置/应用中发生的其他时间关键型操作?

    此致、

    Delaney