ESPHome 2026.4.0
Loading...
Searching...
No Matches
logger_esp32.cpp
Go to the documentation of this file.
1#ifdef USE_ESP32
2#include "logger.h"
3
5#include <esp_log.h>
6
7#include <driver/uart.h>
8
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>
14#else
15#include <driver/usb_serial_jtag_vfs.h>
16#endif
17#endif
18
19#include "esp_idf_version.h"
20#include "freertos/FreeRTOS.h"
21
22#include <fcntl.h>
23#include <cstdint>
24#include <cstdio>
25
26#include "esphome/core/log.h"
27
28namespace esphome::logger {
29
30static const char *const TAG = "logger";
31
32#ifdef USE_LOGGER_USB_SERIAL_JTAG
33static void init_usb_serial_jtag_() {
34 setvbuf(stdin, NULL, _IONBF, 0); // Disable buffering on stdin
35
36#if ESP_IDF_VERSION < ESP_IDF_VERSION_VAL(5, 3, 0)
37 // Minicom, screen, idf_monitor send CR when ENTER key is pressed
38 esp_vfs_dev_usb_serial_jtag_set_rx_line_endings(ESP_LINE_ENDINGS_CR);
39 // Move the caret to the beginning of the next line on '\n'
40 esp_vfs_dev_usb_serial_jtag_set_tx_line_endings(ESP_LINE_ENDINGS_CRLF);
41#else
42 // Minicom, screen, idf_monitor send CR when ENTER key is pressed
43 usb_serial_jtag_vfs_set_rx_line_endings(ESP_LINE_ENDINGS_CR);
44 // Move the caret to the beginning of the next line on '\n'
45 usb_serial_jtag_vfs_set_tx_line_endings(ESP_LINE_ENDINGS_CRLF);
46#endif
47
48 // Enable non-blocking mode on stdin and stdout
49 fcntl(fileno(stdout), F_SETFL, 0);
50 fcntl(fileno(stdin), F_SETFL, 0);
51
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;
55
56 esp_err_t ret = ESP_OK;
57 // Install USB-SERIAL-JTAG driver for interrupt-driven reads and writes
58 ret = usb_serial_jtag_driver_install(&usb_serial_jtag_config);
59 if (ret != ESP_OK) {
60 return;
61 }
62
63 // Tell vfs to use usb-serial-jtag driver
64#if ESP_IDF_VERSION < ESP_IDF_VERSION_VAL(5, 3, 0)
65 esp_vfs_usb_serial_jtag_use_driver();
66#else
67 usb_serial_jtag_vfs_use_driver();
68#endif
69}
70#endif
71
72void init_uart(uart_port_t uart_num, uint32_t baud_rate, int tx_buffer_size) {
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);
81 // The logger only writes to UART, never reads, so use the minimum RX buffer.
82 // ESP-IDF requires rx_buffer_size > UART_HW_FIFO_LEN (128 bytes).
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);
85}
86
88 if (this->baud_rate_ > 0) {
89 this->uart_num_ = UART_NUM_0;
90 switch (this->uart_) {
92 this->uart_num_ = UART_NUM_0;
93 init_uart(this->uart_num_, baud_rate_, ESPHOME_LOGGER_TX_BUFFER_SIZE);
94 break;
96 this->uart_num_ = UART_NUM_1;
97 init_uart(this->uart_num_, baud_rate_, ESPHOME_LOGGER_TX_BUFFER_SIZE);
98 break;
99#ifdef USE_ESP32_VARIANT_ESP32
101 this->uart_num_ = UART_NUM_2;
102 init_uart(this->uart_num_, baud_rate_, ESPHOME_LOGGER_TX_BUFFER_SIZE);
103 break;
104#endif
105#ifdef USE_LOGGER_USB_CDC
107 break;
108#endif
109#ifdef USE_LOGGER_USB_SERIAL_JTAG
111 init_usb_serial_jtag_();
112 break;
113#endif
114 }
115 }
116
117 global_logger = this;
118 esp_log_set_vprintf(esp_idf_log_vprintf_);
119
120 ESP_LOGI(TAG, "Log initialized");
121#ifdef USE_ESP32_CRASH_HANDLER
123#endif
124}
125
126const LogString *Logger::get_uart_selection_() {
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");
135#endif
136#ifdef USE_LOGGER_USB_CDC
138 return LOG_STR("USB_CDC");
139#endif
140#ifdef USE_LOGGER_USB_SERIAL_JTAG
142 return LOG_STR("USB_SERIAL_JTAG");
143#endif
144 default:
145 return LOG_STR("UNKNOWN");
146 }
147}
148
149} // namespace esphome::logger
150#endif
UARTSelection uart_
Definition logger.h:355
const LogString * get_uart_selection_()
void pre_setup()
Set up this component.
uart_port_t uart_num_
Definition logger.h:334
void crash_handler_log()
Log crash data if a crash was detected on previous boot.
@ UART_SELECTION_UART2
Definition logger.h:113
@ UART_SELECTION_USB_SERIAL_JTAG
Definition logger.h:119
@ UART_SELECTION_USB_CDC
Definition logger.h:116
@ UART_SELECTION_UART0
Definition logger.h:107
@ UART_SELECTION_UART1
Definition logger.h:111
Logger * global_logger
Definition logger.cpp:272
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)
Definition log.cpp:74
static void uint32_t