Merge branch 'bugfix/tg_wdt_reboot_uart_garbage' into 'master'

bootloader: wait for UART FIFO to be empty before switching frequency

See merge request !1511
pull/1249/head
Ivan Grokhotkov 2017-11-09 17:14:13 +08:00
commit 8e04b86153
1 zmienionych plików z 8 dodań i 2 usunięć

Wyświetl plik

@ -842,6 +842,13 @@ static void IRAM_ATTR flash_gpio_configure()
static void clock_configure(void) static void clock_configure(void)
{ {
// ROM bootloader may have put a lot of text into UART0 FIFO.
// Wait for it to be printed.
// This is not needed on power on reset, when ROM bootloader is running at
// 40 MHz. But in case of TG WDT reset, CPU may still be running at >80 MHZ,
// and will be done with the bootloader much earlier than UART FIFO is empty.
uart_tx_wait_idle(0);
/* Set CPU to 80MHz. Keep other clocks unmodified. */ /* Set CPU to 80MHz. Keep other clocks unmodified. */
rtc_cpu_freq_t cpu_freq = RTC_CPU_FREQ_80M; rtc_cpu_freq_t cpu_freq = RTC_CPU_FREQ_80M;
@ -885,8 +892,7 @@ static void uart_console_configure(void)
uartAttach(); uartAttach();
ets_install_uart_printf(); ets_install_uart_printf();
// ROM bootloader may have put a lot of text into UART0 FIFO. // Wait for UART FIFO to be empty.
// Wait for it to be printed.
uart_tx_wait_idle(0); uart_tx_wait_idle(0);
#if CONFIG_CONSOLE_UART_CUSTOM #if CONFIG_CONSOLE_UART_CUSTOM