讨论一下关于SPI的HAL的API

HAL_StatusTypeDef HAL_SPI_Transmit(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size, uint32_t Timeout);
HAL_StatusTypeDef HAL_SPI_Receive(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size, uint32_t Timeout);
HAL_StatusTypeDef HAL_SPI_TransmitReceive(SPI_HandleTypeDef *hspi, uint8_t *pTxData, uint8_t *pRxData, uint16_t Size, uint32_t Timeout);
 
请问一下HAL_SPI_Transmit HAL_SPI_Receive连用是否相当于用一个HAL_SPI_TransmitReceive ?
 
在HAL_SPI_Transmit中,核心的就是这句
      if(__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_TXE))
      {
        *((__IO uint8_t*)&hspi->Instance->DR) = (*pData);
        pData += sizeof(uint8_t);
        hspi->TxXferCount--;
      }
不是说SPI的MASTER写出去一个bit,就读回一个bit吗?  这里好像没看出来
 
另外在HAL_SPI_Receive中,核心的是这句
      if(__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_RXNE))
      {
        /* read the received data */
        (* (uint8_t *)pData)= *(__IO uint8_t *)&hspi->Instance->DR;
        pData += sizeof(uint8_t);
        hspi->RxXferCount--;
      }
同样是直接接收,没有发送的过程
 
 
 
 
在HAL_SPI_TransmitReceive中,核心的主要是下面这段,好像是发出了一个byte就接受一个byte,
 
看到这里我是不是觉得自己理解错了,是master发送一个byte,然后接收一个byte吗?
 
之前看到标准貌似是bit全双工的
      if((hspi->TxXferCount > 0U) && (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_TXE)))
      {
        *(__IO uint8_t *)&hspi->Instance->DR = (*pTxData++);
        hspi->TxXferCount--;
      }
      if((hspi->RxXferCount > 0U) && (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_RXNE)))
      {
        (*(uint8_t *)pRxData++) = hspi->Instance->DR;
        hspi->RxXferCount--;
      }
已邀请:

豆泥丸

赞同来自: yanandren

我的理解是:SPI是8位(或16位的)同时收发
  等待发送允许 -》写入发送缓冲 (发收同时开始) -》等待接收完成(实际上等于发送完成)-》读出接收缓冲
  HAL_SPI_Transmit 应该是只对发送过程感兴趣 比如SPI FLASH的写操作。
  HAL_SPI_Receive 就是只关心读取的数据
都是操作串的

要回复问题请先登录注册