童雨竹 发表于 2025-5-6 07:37

SPI发送数据怎么带前导0?

我只发了8位,它居然前面补了好几位0,是不是配置有误?

Clyde011 发表于 2025-5-6 07:42

配置成DMA模式发有没有区别?

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

是不是用了16位帧宽却只发了8位?

周半梅 发表于 2025-5-6 07:44

SPI模式设错会影响对齐位顺序。

帛灿灿 发表于 2025-5-6 07:44

我之前是MSB和LSB顺序没注意。

童雨竹 发表于 2025-5-6 07:45

你试试发0xFF看前导是不是变了?

万图 发表于 2025-5-6 07:46

H5系列的SPI挺挑初始化顺序的。

Wordsworth 发表于 2025-5-6 07:47

看下HAL库那部分是不是拼包了数据?

Bblythe 发表于 2025-5-6 07:48

会不会你发的是uint8_t数组?

Pulitzer 发表于 2025-5-6 07:49

看下寄存器是不是有自动填充?

Uriah 发表于 2025-5-6 07:49

我觉得可能是buffer前有脏数据。

别乱了阵脚 发表于 2025-5-13 20:30

在STM32H5的SPI通信中,若发送8位数据时出现前导0(如实际发送数据为0x00XXXXXX),通常由SPI配置错误(如数据帧格式、时钟极性/相位、DMA/硬件填充)或代码逻辑问题(如数据未对齐、寄存器操作不当)导致

光辉梦境 发表于 2025-5-13 20:39

未等待发送完成,在数据未完全发送时(如未检查BSY标志),直接写入新数据可能导致数据重叠或填充0

暖了夏天蓝了海 发表于 2025-5-13 20:57

1.数据长度(DFF)与实际发送位宽不匹配,STM32H5的SPI支持8位(SPI_CR1_DFF=0)或16位(SPI_CR1_DFF=1)数据帧。若配置为16位但实际仅发送8位数据,硬件可能自动填充高位为0。

夜阑风雨 发表于 2025-5-13 21:32

LSBFIRST(低位优先)模式未启用

远山寻你 发表于 2025-5-13 22:06

若数据传输顺序配置为MSB优先(默认),但用户代码按LSB顺序组织数据,可能导致硬件解析错误(如误判高位填充)

三生万物 发表于 2025-5-13 22:49

时钟空闲电平与从机要求不符,若STM32H5的SPI配置为CPOL=1(时钟空闲高电平),但从机设备要求CPOL=0(时钟空闲低电平),可能导致从机在时钟无效期间采样数据,误判为前导0。

淡漠安然 发表于 2025-5-13 23:34

DMA缓冲区未对齐或传输长度错误,使用DMA传输时,若缓冲区未对齐(如uint8_t数组但DMA配置为16位传输),可能导致硬件自动填充0

江河千里 发表于 2025-5-13 23:42

FIFO或缓存自动填充,部分STM32H5的SPI外设支持硬件FIFO(如发送FIFO深度为4),若未正确填充FIFO,硬件可能自动补0以满足传输需求

冰春彩落下 发表于 2025-5-14 00:10

数据未对齐或寄存器操作不当,直接操作SPIx->DR寄存器时,若未清除高位或未正确处理数据对齐(如将uint8_t强制转换为uint16_t),可能导致高位填充0
页: [1]
查看完整版本: SPI发送数据怎么带前导0?