mirror of
https://github.com/esphome/esphome.git
synced 2025-09-10 07:12:21 +01:00
47 lines
1.3 KiB
C++
47 lines
1.3 KiB
C++
#ifdef USE_ESP8266
|
|
#include "logger.h"
|
|
#include "esphome/core/log.h"
|
|
|
|
namespace esphome::logger {
|
|
|
|
static const char *const TAG = "logger";
|
|
|
|
void Logger::pre_setup() {
|
|
if (this->baud_rate_ > 0) {
|
|
switch (this->uart_) {
|
|
case UART_SELECTION_UART0:
|
|
case UART_SELECTION_UART0_SWAP:
|
|
this->hw_serial_ = &Serial;
|
|
Serial.begin(this->baud_rate_);
|
|
if (this->uart_ == UART_SELECTION_UART0_SWAP) {
|
|
Serial.swap();
|
|
}
|
|
Serial.setDebugOutput(ESPHOME_LOG_LEVEL >= ESPHOME_LOG_LEVEL_VERBOSE);
|
|
break;
|
|
case UART_SELECTION_UART1:
|
|
this->hw_serial_ = &Serial1;
|
|
Serial1.begin(this->baud_rate_);
|
|
Serial1.setDebugOutput(ESPHOME_LOG_LEVEL >= ESPHOME_LOG_LEVEL_VERBOSE);
|
|
break;
|
|
}
|
|
} else {
|
|
uart_set_debug(UART_NO);
|
|
}
|
|
|
|
global_logger = this;
|
|
|
|
ESP_LOGI(TAG, "Log initialized");
|
|
}
|
|
|
|
void HOT Logger::write_msg_(const char *msg) { this->hw_serial_->println(msg); }
|
|
|
|
static const char UART0_STR[] PROGMEM = "UART0";
|
|
static const char UART1_STR[] PROGMEM = "UART1";
|
|
static const char UART0_SWAP_STR[] PROGMEM = "UART0_SWAP";
|
|
static const char *const UART_SELECTIONS[] PROGMEM = {UART0_STR, UART1_STR, UART0_SWAP_STR};
|
|
|
|
const char *Logger::get_uart_selection_() { return pgm_read_ptr(&UART_SELECTIONS[this->uart_]); }
|
|
|
|
} // namespace esphome::logger
|
|
#endif
|