blob: 318a218cc36c65b03b05c01b8223a82c03af39b2 [file] [log] [blame]
Stanley Wu38155a12022-08-15 16:51:11 +08001/* SPDX-License-Identifier: GPL-2.0-or-later */
2
3#include <baseboard/gpio.h>
4#include <baseboard/variants.h>
5#include <console/console.h>
6#include <fw_config.h>
7
Stanley Wu38155a12022-08-15 16:51:11 +08008static const struct pad_config lte_disable_pads[] = {
Reka Norman054620d2022-08-16 10:48:51 +10009 /* A8 : WWAN_RF_DISABLE_ODL */
10 PAD_NC(GPP_A8, NONE),
Leo Chou75388532023-05-11 15:36:48 +080011 /* A12 : WWAN_PCIE_WAKE_ODL */
12 PAD_NC(GPP_A12, NONE),
13 /* D5 : SRCCLKREQ0# ==> WWAN_CLKREQ_ODL */
14 PAD_NC(GPP_D5, NONE),
Stanley Wu38155a12022-08-15 16:51:11 +080015 /* D6 : WWAN_EN */
16 PAD_NC(GPP_D6, NONE),
Leo Chou75388532023-05-11 15:36:48 +080017 /* D15 : EN_PP2800_WCAM_X ==> WWAN_SAR_DETECT_2_ODL */
18 PAD_NC(GPP_D15, NONE),
Stanley Wu38155a12022-08-15 16:51:11 +080019 /* F12 : WWAN_RST_L */
20 PAD_NC_LOCK(GPP_F12, NONE, LOCK_CONFIG),
Reka Norman054620d2022-08-16 10:48:51 +100021 /* H19 : SOC_I2C_SUB_INT_ODL */
22 PAD_NC(GPP_H19, NONE),
Leo Chou75388532023-05-11 15:36:48 +080023 /* H21 : WCAM_MCLK_R ==> WWAN_PERST_L */
24 PAD_NC_LOCK(GPP_H21, NONE, LOCK_CONFIG),
Reka Norman054620d2022-08-16 10:48:51 +100025 /* H23 : WWAN_SAR_DETECT_ODL */
26 PAD_NC(GPP_H23, NONE),
Stanley Wu38155a12022-08-15 16:51:11 +080027};
28
29static const struct pad_config sd_disable_pads[] = {
30 /* D8 : SD_CLKREQ_ODL */
31 PAD_NC(GPP_D8, NONE),
32 /* H12 : SD_PERST_L */
33 PAD_NC_LOCK(GPP_H12, NONE, LOCK_CONFIG),
34 /* H13 : EN_PP3300_SD_X */
35 PAD_NC_LOCK(GPP_H13, NONE, LOCK_CONFIG),
36};
37
Leo Chou0fed078c2022-10-03 16:01:34 +080038static const struct pad_config stylus_disable_pads[] = {
39 /* F13 : SOC_PEN_DETECT_R_ODL */
40 PAD_NC_LOCK(GPP_F13, NONE, LOCK_CONFIG),
41 /* F15 : SOC_PEN_DETECT_ODL */
42 PAD_NC_LOCK(GPP_F15, NONE, LOCK_CONFIG),
43};
44
Stanley Wu38155a12022-08-15 16:51:11 +080045void fw_config_gpio_padbased_override(struct pad_config *padbased_table)
46{
Leo Chou75388532023-05-11 15:36:48 +080047 if (fw_config_probe(FW_CONFIG(LTE, LTE_ABSENT)) && fw_config_probe(FW_CONFIG(WWAN_5G, WWAN_5G_ABSENT))
48 ) {
Stanley Wu38155a12022-08-15 16:51:11 +080049 printk(BIOS_INFO, "Disable LTE-related GPIO pins.\n");
50 gpio_padbased_override(padbased_table, lte_disable_pads,
51 ARRAY_SIZE(lte_disable_pads));
52 }
53
54 if (fw_config_probe(FW_CONFIG(SD_CARD, SD_ABSENT))) {
55 printk(BIOS_INFO, "Disable SD card GPIO pins.\n");
56 gpio_padbased_override(padbased_table, sd_disable_pads,
57 ARRAY_SIZE(sd_disable_pads));
58 }
59
Leo Chou0fed078c2022-10-03 16:01:34 +080060 if (fw_config_probe(FW_CONFIG(STYLUS, STYLUS_ABSENT))) {
61 printk(BIOS_INFO, "Disable Stylus GPIO pins.\n");
62 gpio_padbased_override(padbased_table, stylus_disable_pads,
63 ARRAY_SIZE(stylus_disable_pads));
64 }
Stanley Wu38155a12022-08-15 16:51:11 +080065}