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

[复制链接]
513|18
 楼主| Wordsworth 发表于 2025-6-6 07:20 | 显示全部楼层 |阅读模式
DM, DMA, pi, spi, ma
数据量大的时候,最后几个字节经常错位,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从设备响应延迟导致的?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

161

主题

6119

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部