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]