SimonLiu的ESP8266与AliOS Things 学习教程系列之十八:uart0和uart1打印的进一步优化以及不同波特率设置

欢迎加入交流群:ESP8266 AliOS Things 群 号: 107723112
所有教程请看 AliOS Things 入门教程系列
此教程在SimonLiu的CSDN博客同步更新。

小贴士: 如果使用串口接收外设数据,请先关闭CLI,否则可能导致收取数据丢帧或者发生其他错误。

SimonLiu的ESP8266与AliOS Things 学习教程系列之四:uart0和uart1串口打印一文中SimonLiu提供了一个把LOG()重定向到uart1的方法。但是某些情况下,我们还是需要同时使用uart0和uart1,那么如何实现呢?

1. 简单版本

  • 向uart0发送单个字符
    uart0_write_char( char c), 例如 uart0_write_char('a')
  • 向uart0发送字符串
void uart0_sendStr(const char *str)
{
    while(*str){
        uart0_write_char(*str++);
    }
}

2. 复杂版本但是有bug

首先
platform\mcu\esp8266\hal\uart.c文件中,找到int32_t hal_uart_send()函数,把uart0_write_char(pdata[i]);
修改为如下内容:

        if (uart->port == 0)
            uart0_write_char(pdata[i]);
        else
            uart1_write_char(pdata[i]);

然后下面的代码就实现了uart0和uart1的输出。但是有意思的是,这样改还有个bug,就是LOG()输出的信息,前面的部分[******]<V>输出到uart1,而message from LOG输出到了uart0。

#include <stdio.h>

#include <aos/kernel.h>
#include "aos/hal/uart.h"
#include "driver/gpio.h"
#include "uart.h"
#include "ulog/ulog.h"

int application_start(int argc, char *argv[])
{

    uart_config_t uartConfig0;
    uartConfig0.baud_rate = 9600; 
    uartConfig0.parity = 0;
    uartConfig0.stop_bits = 1;
    uart_dev_t uart0;
    uart0.port = 0; 
    uart0.config = uartConfig0;
    hal_uart_init(&uart0);

    uart_config_t uartConfig1;
    uartConfig1.baud_rate = 115200; 
    uart_dev_t uart1;
    uart1.port = 1; 
    uart1.config = uartConfig1;
    hal_uart_init(&uart1);

    while(1) {
        printf("\r\n message from printf(), to uart1 \r\n");
        LOG("message from LOG");
        const char message0[] = "\r\n hal_uart_send message to uart0\r\n";
        const char message1[] = "\r\n hal_uart_send message to uart1\r\n";
        hal_uart_send(&uart0, message0, strlen(message0), 0);
        hal_uart_send(&uart1, message1, strlen(message1), 0);
        aos_msleep(1000);
    };
}

3.关于两个串口设置不同的波特率

串口的初始化apiplatform/mcu/esp8266/bsp/driver/uart.c中,目前的代码是默认如果不设置,uart0波特率是921600。但是一旦初始化了uart1,uart0的波特率会被改为和uart1一样。
如果要设置不同的波特率,需要修改如下函数

void
uart_init_new(uart_dev_t *uart)
{
    UART_WaitTxFifoEmpty(UART0);
    UART_WaitTxFifoEmpty(UART1);

    if (uart == NULL)
    {
        return;
    }

    if (uart->port == 1)
    {
        //printf("port= 1\n ");

        //uart1 setting
        UART_ConfigTypeDef uart_config;
        uart_config.baud_rate = uart->config.baud_rate;
        uart_config.data_bits = UART_WordLength_8b;
        uart_config.parity = USART_Parity_None;
        uart_config.stop_bits = USART_StopBits_1;
        uart_config.flow_ctrl = USART_HardwareFlowControl_None;
        uart_config.UART_RxFlowThresh = 120;
        uart_config.UART_InverseMask = UART_None_Inverse;
        /*注意修改以下部分*/
        UART_ParamConfig(UART1, &uart_config);

        //uart2 setting for log
        // uart_config.baud_rate = uart->config.baud_rate;
        // UART_ParamConfig(UART1, &uart_config);

        // UART_IntrConfTypeDef uart_intr;
        // uart_intr.UART_IntrEnMask = UART_RXFIFO_TOUT_INT_ENA | UART_FRM_ERR_INT_ENA | UART_RXFIFO_FULL_INT_ENA | UART_TXFIFO_EMPTY_INT_ENA;
        // uart_intr.UART_RX_FifoFullIntrThresh = 100;
        // uart_intr.UART_RX_TimeOutIntrThresh = 10;
        // uart_intr.UART_TX_FifoEmptyIntrThresh = 20;
        // UART_IntrConfig(UART0, &uart_intr);
        /*注意修改以上部分*/
        UART_SetPrintPort(UART1);
        UART_intr_handler_register(uart0_rx_isr, NULL);
        ETS_UART_INTR_ENABLE();
    }
    else
    {
        //printf("port= 0 \n ");
        UART_ConfigTypeDef uart_config;
        /*注意修改以下部分*/
        uart_config.baud_rate = BIT_RATE_9600;
        // uart_config.baud_rate = BIT_RATE_921600;
        /*注意修改以上部分*/
        uart_config.data_bits = UART_WordLength_8b;
        uart_config.parity = USART_Parity_None;
        uart_config.stop_bits = USART_StopBits_1;
        uart_config.flow_ctrl = USART_HardwareFlowControl_None;
        uart_config.UART_RxFlowThresh = 120;
        uart_config.UART_InverseMask = UART_None_Inverse;
        UART_ParamConfig(UART0, &uart_config);

        UART_IntrConfTypeDef uart_intr;
        uart_intr.UART_IntrEnMask = UART_RXFIFO_TOUT_INT_ENA | UART_FRM_ERR_INT_ENA | UART_RXFIFO_FULL_INT_ENA | UART_TXFIFO_EMPTY_INT_ENA;
        uart_intr.UART_RX_FifoFullIntrThresh = 10;
        uart_intr.UART_RX_TimeOutIntrThresh = 2;
        uart_intr.UART_TX_FifoEmptyIntrThresh = 20;
        UART_IntrConfig(UART0, &uart_intr);

        UART_SetPrintPort(UART0);
        UART_intr_handler_register(uart0_rx_isr, NULL);
        ETS_UART_INTR_ENABLE();
    }


    /*
    UART_SetWordLength(UART0,UART_WordLength_8b);
    UART_SetStopBits(UART0,USART_StopBits_1);
    UART_SetParity(UART0,USART_Parity_None);
    UART_SetBaudrate(UART0,74880);
    UART_SetFlowCtrl(UART0,USART_HardwareFlowControl_None,0);
    */
}

经测试,uart0波特率只能通过类似uart_config.baud_rate = BIT_RATE_9600;的方式修改,使用uart_config.baud_rate = uart->config.baud_rate;会导致两个串口都乱码,很奇怪。原因不明。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容