esp32C2串口不够用(esp_log_set_vprintf)使用任意IO模拟串口解决

c 复制代码
#define GPIO_OUTPUT_IO_0    10
#define GPIO_OUTPUT_PIN_SEL ((1ULL << GPIO_OUTPUT_IO_0))

// 模拟串口0初始化
void iouart0_init(void)
{
    gpio_config_t io_conf = {};
    // disable interrupt
    io_conf.intr_type = GPIO_INTR_DISABLE;
    // set as output mode
    io_conf.mode = GPIO_MODE_OUTPUT;
    // bit mask of the pins that you want to set,e.g.GPIO18/19
    io_conf.pin_bit_mask = GPIO_OUTPUT_PIN_SEL;
    // disable pull-down mode
    io_conf.pull_down_en = 0;
    // disable pull-up mode
    io_conf.pull_up_en = 0;
    // configure GPIO with the given settings
    gpio_config(&io_conf);
}

void iouart1_TXD(uint8_t option)
{
    if (1 == option) {
        gpio_set_level(GPIO_OUTPUT_IO_0, 1);
    } else {
        gpio_set_level(GPIO_OUTPUT_IO_0, 0);
    }
}

/*****************************************
 *	函 数 名: iouart1_SendByte
 *	功能说明: 模拟串口发送一字节数据
 *	形    参:无
 *	返 回 值: 无
 ******************************************/
void iouart1_SendByte(uint8_t datatoSend)
{
    uint8_t i, tmp;

    // 开始位
    iouart1_TXD(0); // 将TXD的引脚的电平置低
    esp_rom_delay_us(IO_USART_SENDDELAY_TIME);

    for (i = 0; i < 8; i++) {
        tmp = (datatoSend >> i) & 0x01;

        if (tmp == 0) {
            iouart1_TXD(0);
            esp_rom_delay_us(IO_USART_SENDDELAY_TIME); // 0
        } else {
            iouart1_TXD(1);
            esp_rom_delay_us(IO_USART_SENDDELAY_TIME); // 1
        }
    }

    // 结束位
    iouart1_TXD(1); // 将TXD的引脚的电平置高
    esp_rom_delay_us(IO_USART_SENDDELAY_TIME);
}

void USART_Send(uint8_t *buf, uint8_t len)
{
    uint8_t t;
    for (t = 0; t < len; t++) {
        iouart1_SendByte(buf[t]);
    }
}

uint8_t esp_gpio_log_vprintf(const char *fmt, va_list vp)
{
    static char log_buffer[512];

    taskENTER_CRITICAL();
    size_t len = vsnprintf(log_buffer, sizeof(log_buffer), fmt, vp);
    if (len > sizeof(log_buffer) - 1) {
        log_buffer[sizeof(log_buffer) - 1] = 0;
    }
    USART_Send((uint8_t *)log_buffer, len);
    taskEXIT_CRITICAL(); // 退出基本临界区
    return len;
}

然后重点来了

结果打印 9600 如下

相关推荐
mark-puls24 分钟前
C语言打印爱心
c语言·开发语言·算法
西阳未落31 分钟前
C语言柔性数组详解与应用
c语言·开发语言·柔性数组
小莞尔3 小时前
【51单片机】【protues仿真】基于51单片机数控直流稳压电源系统
c语言·stm32·单片机·嵌入式硬件·51单片机
小莞尔3 小时前
【51单片机】【protues仿真】基于51单片机密码锁系统
c语言·stm32·单片机·嵌入式硬件·51单片机
用户6120414922133 小时前
C语言做的停车场管理系统
c语言·后端·敏捷开发
野生的编程萌新4 小时前
【C++深学日志】C++编程利器:缺省参数、函数重载、引用详解
c语言·开发语言·c++
智者知已应修善业5 小时前
【矩阵找最大小所在位置】2022-11-13
c语言·c++·经验分享·笔记·算法·矩阵
屁股割了还要学5 小时前
【数据结构入门】排序算法(4)归并排序
c语言·数据结构·学习·算法·排序算法
SccTsAxR5 小时前
[C语言]常见排序算法①
c语言·开发语言·经验分享·笔记·其他·排序算法
笑口常开xpr5 小时前
Linux 库开发入门:静态库与动态库的 2 种构建方式 + 5 个编译差异 + 3 个加载技巧,新手速看
linux·c语言·动态库·静态库