2023-06-29 23:29:39 -04:00
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: 2022-2023 Espressif Systems (Shanghai) CO LTD
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "soc/uart_periph.h"
|
2023-09-07 03:40:14 -04:00
|
|
|
#include "soc/lp_gpio_sig_map.h"
|
2023-06-29 23:29:39 -04:00
|
|
|
|
|
|
|
/*
|
|
|
|
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] = {
|
2023-09-07 03:40:14 -04:00
|
|
|
{ // HP UART0
|
|
|
|
.pins = {
|
|
|
|
[SOC_UART_TX_PIN_IDX] = {
|
|
|
|
.default_gpio = U0TXD_GPIO_NUM,
|
|
|
|
.iomux_func = U0TXD_MUX_FUNC,
|
|
|
|
.input = 0,
|
|
|
|
.signal = UART0_TXD_PAD_OUT_IDX,
|
|
|
|
},
|
2023-06-29 23:29:39 -04:00
|
|
|
|
2023-09-07 03:40:14 -04:00
|
|
|
[SOC_UART_RX_PIN_IDX] = {
|
|
|
|
.default_gpio = U0RXD_GPIO_NUM,
|
|
|
|
.iomux_func = U0RXD_MUX_FUNC,
|
|
|
|
.input = 1,
|
|
|
|
.signal = UART0_RXD_PAD_IN_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_RTS_PIN_IDX] = {
|
|
|
|
.default_gpio = U0RTS_GPIO_NUM,
|
|
|
|
.iomux_func = U0RTS_MUX_FUNC,
|
|
|
|
.input = 0,
|
|
|
|
.signal = UART0_RTS_PAD_OUT_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_CTS_PIN_IDX] = {
|
|
|
|
.default_gpio = U0CTS_GPIO_NUM,
|
|
|
|
.iomux_func = U0CTS_MUX_FUNC,
|
|
|
|
.input = 1,
|
|
|
|
.signal = UART0_CTS_PAD_IN_IDX,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
.irq = ETS_UART0_INTR_SOURCE,
|
|
|
|
.module = PERIPH_UART0_MODULE,
|
|
|
|
},
|
|
|
|
|
|
|
|
{ // HP UART1
|
|
|
|
.pins = {
|
|
|
|
[SOC_UART_TX_PIN_IDX] = {
|
|
|
|
.default_gpio = U1TXD_GPIO_NUM,
|
|
|
|
.iomux_func = U1TXD_MUX_FUNC,
|
|
|
|
.input = 0,
|
|
|
|
.signal = UART1_TXD_PAD_OUT_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_RX_PIN_IDX] = {
|
|
|
|
.default_gpio = U1RXD_GPIO_NUM,
|
|
|
|
.iomux_func = U1RXD_MUX_FUNC,
|
|
|
|
.input = 1,
|
|
|
|
.signal = UART1_RXD_PAD_IN_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_RTS_PIN_IDX] = {
|
|
|
|
.default_gpio = U1RTS_GPIO_NUM,
|
|
|
|
.iomux_func = U1RTS_MUX_FUNC,
|
|
|
|
.input = 0,
|
|
|
|
.signal = UART1_RTS_PAD_OUT_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_CTS_PIN_IDX] = {
|
|
|
|
.default_gpio = U1CTS_GPIO_NUM,
|
|
|
|
.iomux_func = U1CTS_MUX_FUNC,
|
|
|
|
.input = 1,
|
|
|
|
.signal = UART1_CTS_PAD_IN_IDX,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
.irq = ETS_UART1_INTR_SOURCE,
|
|
|
|
.module = PERIPH_UART1_MODULE,
|
|
|
|
},
|
|
|
|
|
|
|
|
{ // HP UART2
|
|
|
|
.pins = {
|
|
|
|
[SOC_UART_TX_PIN_IDX] = {
|
|
|
|
.default_gpio = U2TXD_GPIO_NUM,
|
|
|
|
.iomux_func = U2TXD_MUX_FUNC,
|
|
|
|
.input = 0,
|
|
|
|
.signal = UART2_TXD_PAD_OUT_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_RX_PIN_IDX] = {
|
|
|
|
.default_gpio = U2RXD_GPIO_NUM,
|
|
|
|
.iomux_func = U2RXD_MUX_FUNC,
|
|
|
|
.input = 1,
|
|
|
|
.signal = UART2_RXD_PAD_IN_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_RTS_PIN_IDX] = {
|
|
|
|
.default_gpio = U2RTS_GPIO_NUM,
|
|
|
|
.iomux_func = U2RTS_MUX_FUNC,
|
|
|
|
.input = 0,
|
|
|
|
.signal = UART2_RTS_PAD_OUT_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_CTS_PIN_IDX] = {
|
|
|
|
.default_gpio = U2CTS_GPIO_NUM,
|
|
|
|
.iomux_func = U2CTS_MUX_FUNC,
|
|
|
|
.input = 1,
|
|
|
|
.signal = UART2_CTS_PAD_IN_IDX,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
.irq = ETS_UART2_INTR_SOURCE,
|
|
|
|
.module = PERIPH_UART2_MODULE,
|
|
|
|
},
|
|
|
|
|
|
|
|
{ // HP UART3
|
|
|
|
.pins = {
|
|
|
|
[SOC_UART_TX_PIN_IDX] = {
|
|
|
|
.default_gpio = U3TXD_GPIO_NUM,
|
|
|
|
.iomux_func = U3TXD_MUX_FUNC,
|
|
|
|
.input = 0,
|
|
|
|
.signal = UART3_TXD_PAD_OUT_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_RX_PIN_IDX] = {
|
|
|
|
.default_gpio = U3RXD_GPIO_NUM,
|
|
|
|
.iomux_func = U3RXD_MUX_FUNC,
|
|
|
|
.input = 1,
|
|
|
|
.signal = UART3_RXD_PAD_IN_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_RTS_PIN_IDX] = {
|
|
|
|
.default_gpio = U3RTS_GPIO_NUM,
|
|
|
|
.iomux_func = U3RTS_MUX_FUNC,
|
|
|
|
.input = 0,
|
|
|
|
.signal = UART3_RTS_PAD_OUT_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_CTS_PIN_IDX] = {
|
|
|
|
.default_gpio = U3CTS_GPIO_NUM,
|
|
|
|
.iomux_func = U3CTS_MUX_FUNC,
|
|
|
|
.input = 1,
|
|
|
|
.signal = UART3_CTS_PAD_IN_IDX,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
.irq = ETS_UART3_INTR_SOURCE,
|
|
|
|
.module = PERIPH_UART3_MODULE,
|
|
|
|
},
|
|
|
|
|
|
|
|
{ // HP UART4
|
|
|
|
.pins = {
|
|
|
|
[SOC_UART_TX_PIN_IDX] = {
|
|
|
|
.default_gpio = U4TXD_GPIO_NUM,
|
|
|
|
.iomux_func = U4TXD_MUX_FUNC,
|
|
|
|
.input = 0,
|
|
|
|
.signal = UART4_TXD_PAD_OUT_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_RX_PIN_IDX] = {
|
|
|
|
.default_gpio = U4RXD_GPIO_NUM,
|
|
|
|
.iomux_func = U4RXD_MUX_FUNC,
|
|
|
|
.input = 1,
|
|
|
|
.signal = UART4_RXD_PAD_IN_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_RTS_PIN_IDX] = {
|
|
|
|
.default_gpio = U4RTS_GPIO_NUM,
|
|
|
|
.iomux_func = U4RTS_MUX_FUNC,
|
|
|
|
.input = 0,
|
|
|
|
.signal = UART4_RTS_PAD_OUT_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_CTS_PIN_IDX] = {
|
|
|
|
.default_gpio = U4CTS_GPIO_NUM,
|
|
|
|
.iomux_func = U4CTS_MUX_FUNC,
|
|
|
|
.input = 1,
|
|
|
|
.signal = UART4_CTS_PAD_IN_IDX,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
.irq = ETS_UART4_INTR_SOURCE,
|
|
|
|
.module = PERIPH_UART4_MODULE,
|
|
|
|
},
|
2023-09-24 23:12:09 -04:00
|
|
|
{ // LP UART0
|
|
|
|
.pins = {
|
|
|
|
[SOC_UART_TX_PIN_IDX] = {
|
|
|
|
.default_gpio = LP_U0TXD_GPIO_NUM,
|
|
|
|
.iomux_func = LP_U0TXD_MUX_FUNC,
|
|
|
|
.input = 0,
|
|
|
|
.signal = LP_UART_TXD_PAD_OUT_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_RX_PIN_IDX] = {
|
|
|
|
.default_gpio = LP_U0RXD_GPIO_NUM,
|
|
|
|
.iomux_func = LP_U0RXD_MUX_FUNC,
|
|
|
|
.input = 1,
|
|
|
|
.signal = LP_UART_RXD_PAD_IN_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_RTS_PIN_IDX] = {
|
|
|
|
.default_gpio = LP_U0RTS_GPIO_NUM,
|
|
|
|
.iomux_func = LP_U0RTS_MUX_FUNC,
|
|
|
|
.input = 0,
|
|
|
|
.signal = LP_UART_RTSN_PAD_OUT_IDX,
|
|
|
|
},
|
|
|
|
|
|
|
|
[SOC_UART_CTS_PIN_IDX] = {
|
|
|
|
.default_gpio = LP_U0CTS_GPIO_NUM,
|
|
|
|
.iomux_func = LP_U0CTS_MUX_FUNC,
|
|
|
|
.input = 1,
|
|
|
|
.signal = LP_UART_CTSN_PAD_IN_IDX,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
.irq = ETS_LP_UART_INTR_SOURCE,
|
|
|
|
.module = PERIPH_LP_UART0_MODULE,
|
|
|
|
},
|
2023-06-29 23:29:39 -04:00
|
|
|
};
|