esp8266 串口通訊


1、發送

  調用uart_init(115200,115200);初始化串口,波特率設置為115200.前面一個是設置uart0的波特率、后面一個是設置、uart的波特率

  然后就可以使用uart0_tx_buffer(uint8 *buf, uint16 len)從uart0發送數據,同時也可以使用os_printf()函數來發送數據,不過需要注意如果是使用串口1

  想要使用os_printf()需要修改

  os_printf本接口默認從 UART 0 打印。IOT_Demo 中的 uart_init 可以設置波特率,其中

  os_install_putc1((void *)uart1_write_char) 將 os_printf 改為從 UART 1 打印

  2、接收

  進入串口初始化函數uart_init,可以看到如下函數

  system_os_task(uart_recvTask, uart_recvTaskPrio, uart_recvTaskQueue, uart_recvTaskQueueLen);

  這個函數是創建一個任務,就是用如處理串口0的接收數據的,

  uart_config(UART0);

  這就是配置串口寄存器,在這個里面有設置了串口的回調函數

  ETS_UART_INTR_ATTACH(uart0_rx_intr_handler, &(UartDev.rcv_buff));

  利用 ETS_UART_INTR_ATTACH設置了串口的回調函數uart0_rx_intr_handler

  在uart0_rx_intr_handler里面有各種中斷的標志判斷,正常的情況會進入UART_RXFIFO_TOUT_INT_ST,也就是,停⽌止傳輸的時間超過所設定的⻔門

  限值,然后調用system_os_post發送消息給在初始化函數uart_init創建的任務uart_recvTask,,然后大家看看uart_recvTask(os_event_t *events)

  LOCAL void ICACHE_FLASH_ATTR ///////

  uart_recvTask(os_event_t *events)

  {

  if(events-》sig == 0){

  #if UART_BUFF_EN

  Uart_rx_buff_enq();

  #else

  uint8 fifo_len = (READ_PERI_REG(UART_STATUS(UART0))》》UART_RXFIFO_CNT_S)&UART_RXFIFO_CNT;

  uint8 d_tmp = 0;

  uint8 idx=0;

  for(idx=0;idx《fifo_len;idx++) {

  d_tmp = READ_PERI_REG(UART_FIFO(UART0)) & 0xFF;

  uart_tx_one_char(UART0, d_tmp);

  }

  WRITE_PERI_REG(UART_INT_CLR(UART0), UART_RXFIFO_FULL_INT_CLR|UART_RXFIFO_TOUT_INT_CLR);

  uart_rx_intr_enable(UART0);

  #endif

  }else if(events-》sig == 1){

  #if UART_BUFF_EN

  //already move uart buffer output to uart empty interrupt

  //tx_start_uart_buffer(UART0);

  #else

  #endif

  }

  }

  在這個里面就是把接收到的數據通過 uart_tx_one_char(UART0, d_tmp);一個個的發送出來,如果我們想處理

  自己接收的數據,只要把它放到緩沖區就處理就可以。


免責聲明!

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



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