/* * SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD * * SPDX-License-Identifier: Apache-2.0 */ #include "soc/uart_periph.h" #include "soc/uart_reg.h" /* Bunch of constants for every UART peripheral: GPIO signals, irqs, hw addr of registers etc */ const uart_signal_conn_t uart_periph_signal[SOC_UART_NUM] = { { // HP UART0 .pins = { [SOC_UART_TX_PIN_IDX] = { .default_gpio = U0TXD_GPIO_NUM, .iomux_func = U0TXD_MUX_FUNC, .input = 0, .signal = U0TXD_OUT_IDX, }, [SOC_UART_RX_PIN_IDX] = { .default_gpio = U0RXD_GPIO_NUM, .iomux_func = U0RXD_MUX_FUNC, .input = 1, .signal = U0RXD_IN_IDX, }, [SOC_UART_RTS_PIN_IDX] = { .default_gpio = U0RTS_GPIO_NUM, .iomux_func = U0RTS_MUX_FUNC, .input = 0, .signal = U0RTS_OUT_IDX, }, [SOC_UART_CTS_PIN_IDX] = { .default_gpio = U0CTS_GPIO_NUM, .iomux_func = U0CTS_MUX_FUNC, .input = 1, .signal = U0CTS_IN_IDX, } }, .irq = ETS_UART0_INTR_SOURCE, }, { // HP UART1 .pins = { [SOC_UART_TX_PIN_IDX] = { .default_gpio = U1TXD_GPIO_NUM, .iomux_func = U1TXD_MUX_FUNC, .input = 0, .signal = U1TXD_OUT_IDX, }, [SOC_UART_RX_PIN_IDX] = { .default_gpio = U1RXD_GPIO_NUM, .iomux_func = U1RXD_MUX_FUNC, .input = 1, .signal = U1RXD_IN_IDX, }, [SOC_UART_RTS_PIN_IDX] = { .default_gpio = U1RTS_GPIO_NUM, .iomux_func = U1RTS_MUX_FUNC, .input = 0, .signal = U1RTS_OUT_IDX, }, [SOC_UART_CTS_PIN_IDX] = { .default_gpio = U1CTS_GPIO_NUM, .iomux_func = U1CTS_MUX_FUNC, .input = 1, .signal = U1CTS_IN_IDX, }, }, .irq = ETS_UART1_INTR_SOURCE, }, { // LP UART0 .pins = { [SOC_UART_TX_PIN_IDX] = { .default_gpio = LP_U0TXD_GPIO_NUM, .iomux_func = LP_U0TXD_MUX_FUNC, .input = 0, .signal = UINT8_MAX, // Signal not available in signal map }, [SOC_UART_RX_PIN_IDX] = { .default_gpio = LP_U0RXD_GPIO_NUM, .iomux_func = LP_U0RXD_MUX_FUNC, .input = 1, .signal = UINT8_MAX, // Signal not available in signal map }, [SOC_UART_RTS_PIN_IDX] = { .default_gpio = LP_U0RTS_GPIO_NUM, .iomux_func = LP_U0RTS_MUX_FUNC, .input = 0, .signal = UINT8_MAX, // Signal not available in signal map }, [SOC_UART_CTS_PIN_IDX] = { .default_gpio = LP_U0CTS_GPIO_NUM, .iomux_func = LP_U0CTS_MUX_FUNC, .input = 1, .signal = UINT8_MAX, // Signal not available in signal map }, }, .irq = ETS_LP_UART_INTR_SOURCE, }, }; /** * UART registers to be saved during sleep retention * * Reset TXFIFO and RXFIFO * UART registers require set the reg_update bit to make the configuration take effect */ #define N_REGS_UART(uart_num) (((UART_ID_REG(uart_num) - UART_INT_RAW_REG(uart_num)) / 4) + 1) #define UART_SLEEP_RETENTION_ENTRIES(uart_num) { \ [0] = {.config = REGDMA_LINK_CONTINUOUS_INIT(REGDMA_UART_LINK(0x00), \ UART_INT_RAW_REG(uart_num), UART_INT_RAW_REG(uart_num), \ N_REGS_UART(uart_num), 0, 0 \ ), \ .owner = ENTRY(0) | ENTRY(2) }, \ [1] = {.config = REGDMA_LINK_WRITE_INIT(REGDMA_UART_LINK(0x01), \ UART_REG_UPDATE_REG(uart_num), UART_REG_UPDATE, \ UART_REG_UPDATE_M, 1, 0 \ ), \ .owner = ENTRY(0) | ENTRY(2) }, \ [2] = {.config = REGDMA_LINK_WAIT_INIT(REGDMA_UART_LINK(0x02), \ UART_REG_UPDATE_REG(uart_num), 0x0, \ UART_REG_UPDATE_M, 1, 0 \ ), \ .owner = ENTRY(0) | ENTRY(2) }, \ } static const regdma_entries_config_t uart0_regdma_entries[] = UART_SLEEP_RETENTION_ENTRIES(0); static const regdma_entries_config_t uart1_regdma_entries[] = UART_SLEEP_RETENTION_ENTRIES(1); const uart_reg_retention_info_t uart_reg_retention_info[SOC_UART_HP_NUM] = { [0] = { .regdma_entry_array = uart0_regdma_entries, .array_size = ARRAY_SIZE(uart0_regdma_entries), }, [1] = { .regdma_entry_array = uart1_regdma_entries, .array_size = ARRAY_SIZE(uart1_regdma_entries), }, };