7#include <driver/uart.h>
9#ifdef USE_LOGGER_USB_SERIAL_JTAG
10#include <driver/usb_serial_jtag.h>
11#if ESP_IDF_VERSION < ESP_IDF_VERSION_VAL(5, 3, 0)
12#include <esp_vfs_dev.h>
13#include <esp_vfs_usb_serial_jtag.h>
15#include <driver/usb_serial_jtag_vfs.h>
19#include "esp_idf_version.h"
20#include "freertos/FreeRTOS.h"
30static const char *
const TAG =
"logger";
32#ifdef USE_LOGGER_USB_SERIAL_JTAG
33static void init_usb_serial_jtag_() {
34 setvbuf(stdin, NULL, _IONBF, 0);
36#if ESP_IDF_VERSION < ESP_IDF_VERSION_VAL(5, 3, 0)
38 esp_vfs_dev_usb_serial_jtag_set_rx_line_endings(ESP_LINE_ENDINGS_CR);
40 esp_vfs_dev_usb_serial_jtag_set_tx_line_endings(ESP_LINE_ENDINGS_CRLF);
43 usb_serial_jtag_vfs_set_rx_line_endings(ESP_LINE_ENDINGS_CR);
45 usb_serial_jtag_vfs_set_tx_line_endings(ESP_LINE_ENDINGS_CRLF);
49 fcntl(fileno(stdout), F_SETFL, 0);
50 fcntl(fileno(stdin), F_SETFL, 0);
52 usb_serial_jtag_driver_config_t usb_serial_jtag_config{};
53 usb_serial_jtag_config.rx_buffer_size = 512;
54 usb_serial_jtag_config.tx_buffer_size = 512;
56 esp_err_t ret = ESP_OK;
58 ret = usb_serial_jtag_driver_install(&usb_serial_jtag_config);
64#if ESP_IDF_VERSION < ESP_IDF_VERSION_VAL(5, 3, 0)
65 esp_vfs_usb_serial_jtag_use_driver();
67 usb_serial_jtag_vfs_use_driver();
73 uart_config_t uart_config{};
74 uart_config.baud_rate = (int) baud_rate;
75 uart_config.data_bits = UART_DATA_8_BITS;
76 uart_config.parity = UART_PARITY_DISABLE;
77 uart_config.stop_bits = UART_STOP_BITS_1;
78 uart_config.flow_ctrl = UART_HW_FLOWCTRL_DISABLE;
79 uart_config.source_clk = UART_SCLK_DEFAULT;
80 uart_param_config(uart_num, &uart_config);
83 const int min_rx_buffer_size = UART_HW_FIFO_LEN(uart_num) + 1;
84 uart_driver_install(uart_num, min_rx_buffer_size, tx_buffer_size, 0,
nullptr, 0);
90 switch (this->
uart_) {
99#ifdef USE_ESP32_VARIANT_ESP32
105#ifdef USE_LOGGER_USB_CDC
109#ifdef USE_LOGGER_USB_SERIAL_JTAG
111 init_usb_serial_jtag_();
120 ESP_LOGI(TAG,
"Log initialized");
121#ifdef USE_ESP32_CRASH_HANDLER
127 switch (this->
uart_) {
129 return LOG_STR(
"UART0");
131 return LOG_STR(
"UART1");
132#ifdef USE_ESP32_VARIANT_ESP32
134 return LOG_STR(
"UART2");
136#ifdef USE_LOGGER_USB_CDC
138 return LOG_STR(
"USB_CDC");
140#ifdef USE_LOGGER_USB_SERIAL_JTAG
142 return LOG_STR(
"USB_SERIAL_JTAG");
145 return LOG_STR(
"UNKNOWN");
const LogString * get_uart_selection_()
void pre_setup()
Set up this component.
void crash_handler_log()
Log crash data if a crash was detected on previous boot.
@ UART_SELECTION_USB_SERIAL_JTAG
void init_uart(uart_port_t uart_num, uint32_t baud_rate, int tx_buffer_size)
int HOT esp_idf_log_vprintf_(const char *format, va_list args)