Leo Chou | 1a4c91a | 2024-04-01 13:52:59 +0800 | [diff] [blame^] | 1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
| 2 | |
| 3 | #include <baseboard/gpio.h> |
| 4 | #include <baseboard/variants.h> |
| 5 | #include <commonlib/helpers.h> |
| 6 | #include <soc/gpio.h> |
| 7 | #include <fw_config.h> |
| 8 | |
| 9 | /* Pad configuration in ramstage for Sundance */ |
| 10 | static const struct pad_config override_gpio_table[] = { |
| 11 | /* A8 : WWAN_RF_DISABLE_ODL */ |
| 12 | PAD_CFG_GPO(GPP_A8, 1, DEEP), |
| 13 | /* A20 : NC */ |
| 14 | PAD_NC_LOCK(GPP_A20, NONE, LOCK_CONFIG), |
| 15 | /* B5 : NC */ |
| 16 | PAD_NC_LOCK(GPP_B5, NONE, LOCK_CONFIG), |
| 17 | /* B6 : NC */ |
| 18 | PAD_NC_LOCK(GPP_B6, NONE, LOCK_CONFIG), |
| 19 | /* C1 : SMBDATA ==> USI_RST_L */ |
| 20 | PAD_CFG_TERM_GPO(GPP_C1, 1, UP_20K, DEEP), |
| 21 | /* D3 : WCAM_RST_L ==> NC */ |
| 22 | PAD_NC_LOCK(GPP_D3, NONE, LOCK_CONFIG), |
| 23 | /* D6 : SRCCLKREQ1# ==> WWAN_EN */ |
| 24 | PAD_CFG_GPO(GPP_D6, 1, DEEP), |
| 25 | /* D8 : NC */ |
| 26 | PAD_NC_LOCK(GPP_D8, NONE, LOCK_CONFIG), |
| 27 | /* D15 : EN_PP2800_WCAM_X ==> NC */ |
| 28 | PAD_NC_LOCK(GPP_D15, NONE, LOCK_CONFIG), |
| 29 | /* D16 : EN_PP1800_PP1200_WCAM_X ==> NC */ |
| 30 | PAD_NC_LOCK(GPP_D16, NONE, LOCK_CONFIG), |
| 31 | /* D17 : NC ==> SD_WAKE_N */ |
| 32 | PAD_CFG_GPI_LOCK(GPP_D17, NONE, LOCK_CONFIG), |
| 33 | /* E20 : NC */ |
| 34 | PAD_NC_LOCK(GPP_E20, NONE, LOCK_CONFIG), |
| 35 | /* E21 : NC */ |
| 36 | PAD_NC_LOCK(GPP_E21, NONE, LOCK_CONFIG), |
| 37 | /* F12 : WWAN_RST_L */ |
| 38 | PAD_CFG_GPO_LOCK(GPP_F12, 1, LOCK_CONFIG), |
| 39 | /* F13 : NC */ |
| 40 | PAD_NC_LOCK(GPP_F13, NONE, LOCK_CONFIG), |
| 41 | /* F15 : NC */ |
| 42 | PAD_NC_LOCK(GPP_F15, NONE, LOCK_CONFIG), |
| 43 | /* H12 : NC */ |
| 44 | PAD_NC_LOCK(GPP_H12, NONE, LOCK_CONFIG), |
| 45 | /* H13 : NC */ |
| 46 | PAD_NC_LOCK(GPP_H13, NONE, LOCK_CONFIG), |
| 47 | /* H19 : NC */ |
| 48 | PAD_NC_LOCK(GPP_H19, NONE, LOCK_CONFIG), |
| 49 | /* H22 : WCAM_MCLK_R ==> NC */ |
| 50 | PAD_NC(GPP_H22, NONE), |
| 51 | /* H23 : WWAN_SAR_DETECT_ODL ==> NC */ |
| 52 | PAD_NC_LOCK(GPP_H23, NONE, LOCK_CONFIG), |
| 53 | }; |
| 54 | |
| 55 | /* Early pad configuration in bootblock */ |
| 56 | static const struct pad_config early_gpio_table[] = { |
| 57 | /* A13 : GPP_A13 ==> GSC_SOC_INT_ODL */ |
| 58 | PAD_CFG_GPI_APIC(GPP_A13, NONE, PLTRST, LEVEL, INVERT), |
| 59 | /* |
| 60 | * WWAN_EN is asserted in ramstage to meet the 500 ms warm reset toff |
| 61 | * requirement. WWAN_EN must be asserted before WWAN_RST_L is released |
| 62 | * (with min delay 0 ms), so this works as long as the pin used for |
| 63 | * WWAN_EN comes before the pin used for WWAN_RST_L. |
| 64 | */ |
| 65 | /* D6 : SRCCLKREQ1# ==> WWAN_EN */ |
| 66 | PAD_CFG_GPO(GPP_D6, 0, DEEP), |
| 67 | /* E12 : THC0_SPI1_IO1 ==> SOC_WP_OD */ |
| 68 | PAD_CFG_GPI_GPIO_DRIVER(GPP_E12, NONE, DEEP), |
| 69 | /* F12 : WWAN_RST_L */ |
| 70 | PAD_CFG_GPO(GPP_F12, 0, DEEP), |
| 71 | /* F18 : THC1_SPI2_INT# ==> EC_IN_RW_OD */ |
| 72 | PAD_CFG_GPI(GPP_F18, NONE, DEEP), |
| 73 | /* H4 : I2C0_SDA ==> SOC_I2C_GSC_SDA */ |
| 74 | PAD_CFG_NF(GPP_H4, NONE, DEEP, NF1), |
| 75 | /* H5 : I2C0_SCL ==> SOC_I2C_GSC_SCL */ |
| 76 | PAD_CFG_NF(GPP_H5, NONE, DEEP, NF1), |
| 77 | /* H10 : UART0_RXD ==> UART_SOC_RX_DBG_TX */ |
| 78 | PAD_CFG_NF(GPP_H10, NONE, DEEP, NF2), |
| 79 | /* H11 : UART0_TXD ==> UART_SOC_TX_DBG_RX */ |
| 80 | PAD_CFG_NF(GPP_H11, NONE, DEEP, NF2), |
| 81 | }; |
| 82 | |
| 83 | /* Pad configuration in romstage for Sundance */ |
| 84 | static const struct pad_config romstage_gpio_table[] = { |
| 85 | /* Enable touchscreen, hold in reset */ |
| 86 | /* C0 : SMBCLK ==> EN_PP3300_TCHSCR */ |
| 87 | PAD_CFG_GPO(GPP_C0, 1, DEEP), |
| 88 | /* C1 : SMBDATA ==> USI_RST_L */ |
| 89 | PAD_CFG_TERM_GPO(GPP_C1, 0, UP_20K, DEEP), |
| 90 | }; |
| 91 | |
| 92 | const struct pad_config *variant_gpio_override_table(size_t *num) |
| 93 | { |
| 94 | *num = ARRAY_SIZE(override_gpio_table); |
| 95 | return override_gpio_table; |
| 96 | } |
| 97 | |
| 98 | const struct pad_config *variant_early_gpio_table(size_t *num) |
| 99 | { |
| 100 | |
| 101 | *num = ARRAY_SIZE(early_gpio_table); |
| 102 | return early_gpio_table; |
| 103 | } |
| 104 | |
| 105 | const struct pad_config *variant_romstage_gpio_table(size_t *num) |
| 106 | { |
| 107 | *num = ARRAY_SIZE(romstage_gpio_table); |
| 108 | return romstage_gpio_table; |
| 109 | } |