Wordsworth 发表于 2025-6-6 07:20

用DMA给SPI发数据,尾巴那几个字节老出错

数据量大的时候,最后几个字节经常错位,DMA配置不太好找问题。

Clyde011 发表于 2025-6-6 07:22

HAL库那套SPI+DMA处理不太稳,我都是改裸寄存器。

公羊子丹 发表于 2025-6-6 07:23

是不是最后一组数据没对齐?

周半梅 发表于 2025-6-6 07:25

DMA中断处理里有加“传输完成”判断没?

帛灿灿 发表于 2025-6-6 07:28

尾部容易漏发,一般多加几个空字节。

童雨竹 发表于 2025-6-6 07:29

我之前是SPI FIFO溢出导致的。

万图 发表于 2025-6-6 07:30

可以试试DMA链式传输。

Wordsworth 发表于 2025-6-6 07:30

SPI slave端接受不了太快的节奏。

Bblythe 发表于 2025-6-6 07:31

用示波器看看有没有时序问题。

Pulitzer 发表于 2025-6-6 07:32

SPI设置里试过不同数据宽度没?

Uriah 发表于 2025-6-6 07:33

最后一组数据用普通发送确认一下。

onlycook 发表于 2025-6-6 11:13

DMA传输长度配置错误?

classroom 发表于 2025-6-6 11:18

DMA缓冲区被覆盖?将DMA缓冲区声明为全局变量或静态变量。

jcky001 发表于 2025-6-6 11:19

SPI FIFO未清空?

elephant00 发表于 2025-6-6 11:28

检查DMA缓冲区地址是否对齐。

flycamelaaa 发表于 2025-6-6 13:00

SPI时序与DMA不匹配?

powerantone 发表于 2025-6-6 14:00

可能是因为DMA传输的数据缓冲区未对齐到特定边界,将数据缓冲区声明为对齐变量。

stormwind123 发表于 2025-6-6 15:00

DMA传输完成中断可能未正确触发,导致SPI未及时禁用,尾部字节被误读。

jobszheng 发表于 2025-6-6 18:22

这个只能上逻辑分析仪了吧

probedog 发表于 2025-6-6 19:00

SPI从设备响应延迟导致的?
页: [1]
查看完整版本: 用DMA给SPI发数据,尾巴那几个字节老出错