【stm32】基於hal庫使用野火指南者esp8266 WIFI模塊進行TCP傳輸


UART.c

#include "stm32f1xx_it.h"
#include "LED.h"
#include "UART.h"
#include "string.h"

UART_HandleTypeDef huart1;
UART_HandleTypeDef huart3;
 
#define RXBUFFERSIZE  4096         //最大接收字節數

char RxBuffer1[RXBUFFERSIZE];   //接收數據
uint8_t aRxBuffer1;                            //接收中斷緩沖
uint32_t Uart1_Rx_Cnt = 0;                //接收緩沖計數

char RxBuffer3[RXBUFFERSIZE];   //接收數據
uint8_t aRxBuffer3;                            //接收中斷緩沖
uint32_t Uart3_Rx_Cnt = 0;                //接收緩沖計數

/**
  * @brief USART1 Initialization Function
  * @param None
  * @retval None
  */
void MX_USART1_UART_Init(void){
  /* USER CODE BEGIN USART1_Init 0 */

  /* USER CODE END USART1_Init 0 */

  /* USER CODE BEGIN USART1_Init 1 */

  /* USER CODE END USART1_Init 1 */
  huart1.Instance = USART1;
  huart1.Init.BaudRate = 115200;
  huart1.Init.WordLength = UART_WORDLENGTH_8B;
  huart1.Init.StopBits = UART_STOPBITS_1;
  huart1.Init.Parity = UART_PARITY_NONE;
  huart1.Init.Mode = UART_MODE_TX_RX;
  huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  huart1.Init.OverSampling = UART_OVERSAMPLING_16;
  if (HAL_UART_Init(&huart1) != HAL_OK)
  {
    Error_Handler();
  }
  /* USER CODE BEGIN USART1_Init 2 */
    HAL_UART_MspInit(&huart1);
    HAL_UART_Receive_IT(&huart1, (uint8_t *)&aRxBuffer1, 1);   //開啟接收中斷
  /* USER CODE END USART1_Init 2 */
}

/**
  * @brief USART3 Initialization Function
  * @param None
  * @retval None
  */
void MX_USART3_UART_Init(void)
{
  /* USER CODE BEGIN USART3_Init 0 */

  /* USER CODE END USART3_Init 0 */

  /* USER CODE BEGIN USART3_Init 1 */

  /* USER CODE END USART3_Init 1 */
  huart3.Instance = USART3;
  huart3.Init.BaudRate = 115200;
  huart3.Init.WordLength = UART_WORDLENGTH_8B;
  huart3.Init.StopBits = UART_STOPBITS_1;
  huart3.Init.Parity = UART_PARITY_NONE;
  huart3.Init.Mode = UART_MODE_TX_RX;
  huart3.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  huart3.Init.OverSampling = UART_OVERSAMPLING_16;
  if (HAL_UART_Init(&huart3) != HAL_OK)
  {
    Error_Handler();
  }
  /* USER CODE BEGIN USART3_Init 2 */
    HAL_UART_MspInit(&huart3);
    HAL_UART_Receive_IT(&huart3, (uint8_t *)&aRxBuffer3, 1);   //再開啟接收中斷
  /* USER CODE END USART3_Init 2 */
}

/**
  * @brief  This function is executed in case of error occurrence.
  * @retval None
  */
void Error_Handler(void)
{
  /* USER CODE BEGIN Error_Handler_Debug */
  /* User can add his own implementation to report the HAL error return state */
  __disable_irq();
  while (1){}
  /* USER CODE END Error_Handler_Debug */
}

void send_to_Usart3(char * cmd){
    HAL_UART_Transmit(&huart3, (uint8_t *)cmd,strlen(cmd),0xFFFF); 
    while(HAL_UART_GetState(&huart3) == HAL_UART_STATE_BUSY_TX);//檢測UART發送結束
}

void show_Usart3_Message(){
    HAL_UART_Transmit(&huart1, (uint8_t *)&RxBuffer3, Uart3_Rx_Cnt,0xFFFF); //將收到的信息發送出去
    while(HAL_UART_GetState(&huart1) == HAL_UART_STATE_BUSY_TX);//檢測UART發送結束
    Uart3_Rx_Cnt = 0;
    memset(RxBuffer3,0x00,sizeof(RxBuffer3)); //清空數組
}

void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart){
    if(huart->Instance==USART1){
        if(Uart1_Rx_Cnt >= (RXBUFFERSIZE-1)){  //溢出判斷
            Uart1_Rx_Cnt = 0;
            memset(RxBuffer1,0x00,sizeof(RxBuffer1));
            HAL_UART_Transmit(&huart1, (uint8_t *)"數據溢出", 10,0xFFFF);     
        }else{
            RxBuffer1[Uart1_Rx_Cnt++] = aRxBuffer1;   //接收數據轉存
            //HAL_UART_Transmit(&huart3, (uint8_t *)test, sizeof(test),0xFFFF);
            
            /*
            if((RxBuffer1[Uart1_Rx_Cnt-1] == 0x0A)&&(RxBuffer1[Uart1_Rx_Cnt-2] == 0x0D)){ //判斷結束位
                HAL_UART_Transmit(&huart3, (uint8_t *)&RxBuffer1, Uart1_Rx_Cnt,0xFFFF); //將收到的信息發送出去
                while(HAL_UART_GetState(&huart3) == HAL_UART_STATE_BUSY_TX);//檢測UART發送結束
                Uart1_Rx_Cnt = 0;
                memset(RxBuffer1,0x00,sizeof(RxBuffer1)); //清空數組
            }
            */
        }
        HAL_UART_Receive_IT(&huart1, (uint8_t *)&aRxBuffer1, 1);   //再開啟接收中斷
    }
    if(huart->Instance==USART3){
        if(Uart3_Rx_Cnt >= (RXBUFFERSIZE-1)){  //溢出判斷
            Uart3_Rx_Cnt = 0;
            memset(RxBuffer3,0x00,sizeof(RxBuffer3));
            HAL_UART_Transmit(&huart1, (uint8_t *)"數據溢出", 10,0xFFFF);     
        }else{
            RxBuffer3[Uart3_Rx_Cnt++] = aRxBuffer3;   //接收數據轉存
            /*
            if(((RxBuffer3[Uart3_Rx_Cnt-1] == 0x0A)&&(RxBuffer3[Uart3_Rx_Cnt-2] == 0x0D))){ //判斷結束位
                HAL_UART_Transmit(&huart1, (uint8_t *)&RxBuffer3, Uart3_Rx_Cnt,0xFFFF); //將收到的信息發送出去
                while(HAL_UART_GetState(&huart1) == HAL_UART_STATE_BUSY_TX);//檢測UART發送結束
                Uart3_Rx_Cnt = 0;
                memset(RxBuffer3,0x00,sizeof(RxBuffer3)); //清空數組
            }
            */
        }
        HAL_UART_Receive_IT(&huart3, (uint8_t *)&aRxBuffer3, 1);   //再開啟接收中斷
    }
}

//重定向c庫函數printf到串口DEBUG_USART,重定向后可使用printf函數
int fputc(int ch, FILE *f){
    /* 發送一個字節數據到串口DEBUG_USART */
    HAL_UART_Transmit(&huart1, (uint8_t *)&ch, 1, 1000);    
    return (ch);
}

main.c

/**
  * @brief  The application entry point.
  * @retval int
  */
int main(void)
{
  /* USER CODE BEGIN 1 */

  /* USER CODE END 1 */

  /* MCU Configuration--------------------------------------------------------*/

  /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  HAL_Init();

  /* USER CODE BEGIN Init */

  /* USER CODE END Init */

  /* Configure the system clock */
  SystemClock_Config();
  /* USER CODE BEGIN SysInit */

  /* USER CODE END SysInit */

  /* Initialize all configured peripherals */
  MX_GPIO_Init();
  MX_USART1_UART_Init();
  MX_USART3_UART_Init();
  /* USER CODE BEGIN 2 */
    LED_GPIO_Config();
    esp8266_Init();
  /* USER CODE END 2 */
  /* Infinite loop */
  /* USER CODE BEGIN WHILE */
    //unsigned char hello[]="hello\n\r";
    //HAL_UART_Transmit(&huart1,hello,sizeof(hello),0x10);
    HAL_Delay(2000);
    show_Usart3_Message();
    
    char cmd1[]="AT+CWLAP\r\n";
    send_to_Usart3(cmd1);
    HAL_Delay(10000);
    show_Usart3_Message();
    
    char cmd2[]="AT+CWJAP=\"Redmi K30\",\"lpnb6666\"\r\n";
    send_to_Usart3(cmd2);
    HAL_Delay(20000);
    show_Usart3_Message();

    char cmd4[]="AT+CIPMUX=0\r\n";
    send_to_Usart3(cmd4);
    HAL_Delay(3000);
    show_Usart3_Message();
    
    char cmd5[]="AT+CIPMODE=1\r\n";
    send_to_Usart3(cmd5);
    HAL_Delay(3000);
    show_Usart3_Message();
    
    char cmd3[]="AT+CIFSR\r\n";
    send_to_Usart3(cmd3);
    HAL_Delay(3000);
    show_Usart3_Message();

    send_to_Usart3("AT+CIPSTART=\"TCP\",\"192.168.43.193\",8899\r\n");
    HAL_Delay(10000);
    show_Usart3_Message();
    
    send_to_Usart3("AT+CIPSEND\r\n");
    HAL_Delay(3000);
    show_Usart3_Message();
    
    send_to_Usart3(">\r\n");
    HAL_Delay(3000);
    show_Usart3_Message();
    
    send_to_Usart3("lp\r\n");
    HAL_Delay(3000);
    show_Usart3_Message();
    
    send_to_Usart3("123456\r\n");
    HAL_Delay(3000);
    show_Usart3_Message();
    
    send_to_Usart3("hello everyone\r\n");
    HAL_Delay(3000);
    show_Usart3_Message();
    
    send_to_Usart3("+++");
    HAL_Delay(3000);
    show_Usart3_Message();
  while (1)
  {
        send_to_Usart3("AT\r\n");
    HAL_Delay(1000);
        show_Usart3_Message();
  }
  /* USER CODE END 3 */
}

注意事項:

首先,不能連續 發AT+指令,需要等上一個指令處理完再發下一個指令,具體怎么等可以用AT指令查詢

其次,不能直接用C庫接收,要使用串口中斷接收

再次,發送給esp8266模塊的數據要以\r\n結尾,數據透傳用>\r\n開始,用+++結束,其中+++沒有\r\n

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM