1 /* SPDX-License-Identifier: GPL-2.0-only */
3 #include <device/mmio.h>
4 #include <amdblocks/gpio.h>
5 #include <amdblocks/uart.h>
6 #include <commonlib/helpers.h>
7 #include <soc/aoac_defs.h>
10 #include <soc/southbridge.h>
14 static const struct soc_uart_ctrlr_info uart_info
[] = {
15 [0] = { APU_UART0_BASE
, FCH_AOAC_DEV_UART0
, "FUR0", {
16 PAD_NF(GPIO_136
, UART0_RXD
, PULL_NONE
),
17 PAD_NF(GPIO_138
, UART0_TXD
, PULL_NONE
),
19 [1] = { APU_UART1_BASE
, FCH_AOAC_DEV_UART1
, "FUR1", {
20 PAD_NF(GPIO_141
, UART1_RXD
, PULL_NONE
),
21 PAD_NF(GPIO_142
, UART1_TXD
, PULL_NONE
),
23 [2] = { APU_UART2_BASE
, FCH_AOAC_DEV_UART2
, "FUR2", {
24 PAD_NF(GPIO_137
, UART2_RXD
, PULL_NONE
),
25 PAD_NF(GPIO_135
, UART2_TXD
, PULL_NONE
),
29 const struct soc_uart_ctrlr_info
*soc_get_uart_ctrlr_info(size_t *num_ctrlrs
)
31 *num_ctrlrs
= ARRAY_SIZE(uart_info
);
35 void clear_uart_legacy_config(void)
37 write16((void *)FCH_LEGACY_UART_DECODE
, 0);