【STM32F411RE和L610物聯網入門學習筆記】
配置MX生成代碼并在KEIL中添加串口通信代碼;
粗淺的學習文章,僅供參考;
廣和通資料群里面的移植示例個人感覺沒什么用處;畢竟粗看過去用到了tcp似乎是;
使用stm32cubeMX配置
我這邊使用的是stm32cubeide和廣和通老師使用的不太一樣但是沒有影響;
按照圖示指示
新建一個工程

選擇stm32f411re
按照廣和通發的pdf–串口進行完畢所有的配置
打開生成的檔案中的MDK-ARM檔案;
打開keil檔案;

勾選三個以便日后查找info;
最重要的一步:配置L610發送命令函式
撰寫ESP8266函式并添加配套函式
首先添加一個或兩個uart重定向printf函式和uart接收中斷處理函式
void u1_printf(char* fmt,...)
{
uint16_t i,j;
va_list ap;
va_start(ap,fmt);
vsprintf((char*)USART_TX_BUF,fmt,ap);
va_end(ap);
i=strlen((const char*)USART_TX_BUF);
for(j=0;j<i;j++)
{
while((USART1->SR&0X40)==0);
USART1->DR =USART_TX_BUF[j];
}
}
此時的思想可以是一個串口用于具體實驗,一個用于除錯
如果你想設定定時器中斷也是可以的,定時器中斷,用來判斷接收命令是否超時,如果超時就按照接受命令
void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{
if(huart->Instance==USART1)//
{
if(recv_way_state==0)
{
if((USART_RX_STA&0x8000)==0)
{
if(USART_RX_STA&0x4000)
{
if(aRxBuffer[0]!=0x0a)USART_RX_STA=0;
else
{
USART_RX_STA|=0x8000;
}
}
else
{
if(aRxBuffer[0]==0x0d)USART_RX_STA|=0x4000;
else
{
USART_RX_BUF[USART_RX_STA&0X3FFF]=aRxBuffer[0] ;
USART_RX_STA++;
if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0;
}
}
}
}
撰寫發送和檢查命令核心函式
uint8_t L610_send_cmd(uint8_t *cmd,uint8_t *ack,uint16_t waittime)
{
uint8_t res = 0;
USART3_RX_STA = 0;
u3_printf("%s\r\n",cmd);
if(ack&&waittime) //需要等待應答
{
while(--waittime) //等待倒計時
{
HAL_Delay(10);
if(USART3_RX_STA&0X8000)//接收到期待的應答結果
{
if(esp8266_check_cmd(ack))
{
u1_printf("ack:%s\r\n",(uint8_t*)ack);
break;//得到有效資料
}
USART3_RX_STA=0;
}
}
if(waittime==0)res=1;
}
return res;
}
撰寫中斷服務函式
/* USER CODE BEGIN USART1_Init 2 */
HAL_UART_Receive_IT(&huart1, (uint8_t*)aRxBuffer, RXBUFFERSIZE);
/* USER CODE END USART1_Init 2 */
// HAL_UART_Receive_IT該函式在檔案Drivers\STM32F4xx_HAL_Driver\Src\stm32f4xx_hal_uart.c中查詢;
aRxBuffer[]儲存了資料
Size大小
剩下的步驟就是決議然后完成你們組的任務了
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/375010.html
標籤:其他
