记一次stm32的SPI调试

项目上以前英飞凌的芯片停产了,要换ST,功能要移植上去。

开始调试后发现SPI的数据收发有问题。调试半天后找到了原因。

  1. 改挂SPI设备数据宽度是16bit,但是hal库的API长这样HAL_StatusTypeDef HAL_SPI_TransmitReceive(SPI_HandleTypeDef *hspi, uint8_t *pTxData, uint8_t *pRxData, uint16_t Size,
    uint32_t Timeout);
    数据是unsigned char型的,所以写short型数据的时候要做数据类型转换。因为stm32f4是小端序的,所以读写数组的低字节实际上是要写的short数据的低位,这里我弄错了,所以导致有问题。

  2. HAL_StatusTypeDef HAL_SPI_TransmitReceive(SPI_HandleTypeDef *hspi, uint8_t *pTxData, uint8_t *pRxData, uint16_t Size,
    uint32_t Timeout);这个API中的size参数一开始理解成了读写数组长度,后来发现理解错了。当SPI数据宽度是8bit时,这个size是读写数组长度。而当SPI数据宽度是16bit时,这里的size实际上是要写的short类型数据的数量。也就是说实际放到TxData数组里的内容是2字节,但是size要填的是1,也就是代表1个short数据。这里我也搞错了,所以导致有问题。

  3. 上述问题都好了后进行测试,还是有问题,收发的数据和实际不符,只要数据有高低bit变化的地方就有问题,直觉告诉我是硬件问题,因为spi的布线很长,甚至跨板了,波特率高了导致硬件上的缺陷暴露了。 于是把波特率改低,然后就好了。

记录下,权当备忘。

首先,确保你已经正确配置了STM32SPI外设,并且SPI总线上连接的设备的电源和信号线都正常。 接着,你可以使用STM32提供的HAL库函数来进行SPI通信调试。以下是一个简单的SPI发送和接收数据的示例代码: ```c #include "stm32f4xx_hal.h" #define SPI_TIMEOUT 1000 // 超时时间 SPI_HandleTypeDef hspi1; // SPI1外设句柄 uint8_t tx_buffer[10] = {0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A}; // 发送缓冲区 uint8_t rx_buffer[10] = {0}; // 接收缓冲区 int main(void) { // 初始化HALHAL_Init(); // 初始化SPI1外设 hspi1.Instance = SPI1; hspi1.Init.Mode = SPI_MODE_MASTER; hspi1.Init.Direction = SPI_DIRECTION_2LINES; hspi1.Init.DataSize = SPI_DATASIZE_8BIT; hspi1.Init.CLKPolarity = SPI_POLARITY_LOW; hspi1.Init.CLKPhase = SPI_PHASE_1EDGE; hspi1.Init.NSS = SPI_NSS_SOFT; hspi1.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_256; hspi1.Init.FirstBit = SPI_FIRSTBIT_MSB; hspi1.Init.TIMode = SPI_TIMODE_DISABLE; hspi1.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE; hspi1.Init.CRCPolynomial = 10; HAL_SPI_Init(&hspi1); // 发送数据 if (HAL_SPI_Transmit(&hspi1, tx_buffer, 10, SPI_TIMEOUT) != HAL_OK) { // 发送失败处理 } // 接收数据 if (HAL_SPI_Receive(&hspi1, rx_buffer, 10, SPI_TIMEOUT) != HAL_OK) { // 接收失败处理 } // 关闭SPI1外设 HAL_SPI_DeInit(&hspi1); while (1) {} } ``` 在以上代码中,我们使用了HAL_SPI_Transmit和HAL_SPI_Receive函数来进行SPI发送和接收数据。需要注意的是,在使用HAL_SPI_Transmit函数前,需要先将待发送的数据存放在发送缓冲区tx_buffer中。同样,在使用HAL_SPI_Receive函数后,接收到的数据会存放在接收缓冲区rx_buffer中。在函数调用后,需要检查返回值是否为HAL_OK来判断SPI通信是否成功。同时,在发送和接收数据前,需要确保SPI总线上的设备已经准备好了数据,否则可能会出现通信失败的情况。 最后,你可以使用调试器(如ST-Link)来观察SPI总线上的信号波形,以进一步排查通信问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值