esp8266-SDK的串口发送和中断接收

其实用esp8266编写串口程序非常简单,因为它都给我们写好了,只要调用 uart_init(115200,115200);这个函数就可以。


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             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);一个个的发送出来,如果我们想处理

自己接收的数据,只要把它放到缓冲区就处理就可以。






你可能感兴趣的:(SEP8266)