blob: bf9833bf4b4003b5ae05aa1202bd229252b2ede0 [file] [log] [blame]
Raul E Rangelb3c41322020-05-20 14:07:41 -06001/* SPDX-License-Identifier: GPL-2.0-or-later */
2
Martin Roth726504a2020-10-30 16:41:32 -06003#include <acpi/acpi.h>
Raul E Rangelb3c41322020-05-20 14:07:41 -06004#include <baseboard/variants.h>
Furquan Shaikh83025852020-06-22 10:45:12 -07005#include <delay.h>
Martin Roth726504a2020-10-30 16:41:32 -06006#include <ec/google/chromeec/ec.h>
Furquan Shaikh83025852020-06-22 10:45:12 -07007#include <gpio.h>
Raul E Rangelb3c41322020-05-20 14:07:41 -06008#include <soc/gpio.h>
9#include <soc/smi.h>
10#include <stdlib.h>
Raul E Rangelb3c41322020-05-20 14:07:41 -060011#include <variant/gpio.h>
12
Raul E Rangelb3c41322020-05-20 14:07:41 -060013static const struct soc_amd_gpio gpio_set_stage_ram[] = {
Raul E Rangelb3c41322020-05-20 14:07:41 -060014 /* PWR_BTN_L */
Furquan Shaikh7571110d2020-07-16 11:26:10 -070015 PAD_NF(GPIO_0, PWR_BTN_L, PULL_NONE),
Raul E Rangelb3c41322020-05-20 14:07:41 -060016 /* SYS_RESET_L */
17 PAD_NF(GPIO_1, SYS_RESET_L, PULL_NONE),
Rob Barnesd1095c72020-09-25 14:16:46 -060018 /* WIFI_PCIE_WAKE_ODL */
Felix Heldf8e440c2021-03-24 00:17:35 +010019 PAD_NF_SCI(GPIO_2, WAKE_L, PULL_NONE, EDGE_LOW),
Furquan Shaikh65e11172020-07-21 21:51:27 -070020 /* H1_FCH_INT_ODL */
21 PAD_INT(GPIO_3, PULL_NONE, EDGE_LOW, STATUS_DELIVERY),
Raul E Rangelb3c41322020-05-20 14:07:41 -060022 /* PEN_DETECT_ODL */
Furquan Shaikh16868bc2020-06-30 16:13:47 -070023 PAD_WAKE(GPIO_4, PULL_NONE, EDGE_HIGH, S3),
Raul E Rangelb3c41322020-05-20 14:07:41 -060024 /* PEN_POWER_EN - Enabled*/
25 PAD_GPO(GPIO_5, HIGH),
26 /* FPMCU_INT_L */
Furquan Shaikhb0334e12020-09-11 15:43:45 -070027 PAD_SCI(GPIO_6, PULL_NONE, LEVEL_LOW),
Raul E Rangelb3c41322020-05-20 14:07:41 -060028 /* I2S_SDIN */
29 PAD_NF(GPIO_7, ACP_I2S_SDIN, PULL_NONE),
30 /* I2S_LRCLK - Bit banged in depthcharge */
31 PAD_NF(GPIO_8, ACP_I2S_LRCLK, PULL_NONE),
32 /* TOUCHPAD_INT_ODL */
Furquan Shaikhffbf5d92020-06-30 14:07:46 -070033 PAD_SCI(GPIO_9, PULL_NONE, EDGE_LOW),
Martin Roth6a62cc82020-12-02 16:37:58 -070034 /* S0iX SLP - goes to EC & FPMCU */
35 PAD_GPO(GPIO_10, HIGH),
Raul E Rangelb3c41322020-05-20 14:07:41 -060036 /* USI_INT_ODL */
Furquan Shaikh7571110d2020-07-16 11:26:10 -070037 PAD_GPI(GPIO_12, PULL_NONE),
Furquan Shaikhda459c42020-06-18 01:34:48 -070038 /* EN_PWR_TOUCHPAD_PS2 */
39 PAD_GPO(GPIO_13, HIGH),
Raul E Rangelb3c41322020-05-20 14:07:41 -060040 /* BT_DISABLE */
41 PAD_GPO(GPIO_14, LOW),
Furquan Shaikh65e11172020-07-21 21:51:27 -070042 /* GPIO_15: Not available */
Raul E Rangelb3c41322020-05-20 14:07:41 -060043 /* USB_OC0_L - USB C0 + USB A0 */
Furquan Shaikh7571110d2020-07-16 11:26:10 -070044 PAD_NF(GPIO_16, USB_OC0_L, PULL_NONE),
Raul E Rangelb3c41322020-05-20 14:07:41 -060045 /* USB_OC1_L - USB C1 + USB A1 */
Furquan Shaikh7571110d2020-07-16 11:26:10 -070046 PAD_NF(GPIO_17, USB_OC1_L, PULL_NONE),
Raul E Rangelb3c41322020-05-20 14:07:41 -060047 /* WIFI_DISABLE */
48 PAD_GPO(GPIO_18, LOW),
Furquan Shaikh65e11172020-07-21 21:51:27 -070049 /* I2C3_SCL - H1 */
50 PAD_NF(GPIO_19, I2C3_SCL, PULL_NONE),
51 /* I2C3_SDA - H1 */
52 PAD_NF(GPIO_20, I2C3_SDA, PULL_NONE),
Raul E Rangelb3c41322020-05-20 14:07:41 -060053 /* EMMC_CMD */
Furquan Shaikh7571110d2020-07-16 11:26:10 -070054 PAD_NF(GPIO_21, EMMC_CMD, PULL_NONE),
Raul E Rangelb3c41322020-05-20 14:07:41 -060055 /* EC_FCH_SCI_ODL */
Furquan Shaikh7571110d2020-07-16 11:26:10 -070056 PAD_SCI(GPIO_22, PULL_NONE, EDGE_LOW),
Raul E Rangelb3c41322020-05-20 14:07:41 -060057 /* AC_PRES */
58 PAD_NF(GPIO_23, AC_PRES, PULL_UP),
Furquan Shaikh489ffef2020-06-30 14:08:27 -070059 /* EC_FCH_WAKE_L */
60 PAD_SCI(GPIO_24, PULL_NONE, EDGE_LOW),
Furquan Shaikh65e11172020-07-21 21:51:27 -070061 /* GPIO_25: Not available */
62 /* PCIE_RST0_L - Fixed timings */
63 PAD_NF(GPIO_26, PCIE_RST_L, PULL_NONE),
64 /* PCIE_RST1_L (unused) */
65 PAD_NC(GPIO_27),
66 /* GPIO_28: Not available */
Josie Nordrumcc72e152020-08-03 11:39:41 -060067 /* GPIO_29: HP_INT_ODL */
68 PAD_GPI(GPIO_29, PULL_NONE),
Furquan Shaikh65e11172020-07-21 21:51:27 -070069 /* FCH_ESPI_EC_CS_L */
70 PAD_NF(GPIO_30, ESPI_CS_L, PULL_NONE),
Raul E Rangelb3c41322020-05-20 14:07:41 -060071 /* EC_AP_INT_ODL (Sensor Framesync) */
Furquan Shaikh7571110d2020-07-16 11:26:10 -070072 PAD_GPI(GPIO_31, PULL_NONE),
Furquan Shaikh65e11172020-07-21 21:51:27 -070073 /* GPIO_33 - GPIO_39: Not available */
74 /* NVME_AUX_RESET_L */
75 PAD_GPO(GPIO_40, HIGH),
76 /* GPIO_41: Not available */
77 /* GPIO_42: Handled in bootblock for wifi power/reset control. */
78 /* GPIO_43 - GPIO_66: Not available */
Furquan Shaikhda459c42020-06-18 01:34:48 -070079 /* DMIC SEL */
Raul E Rangelb3c41322020-05-20 14:07:41 -060080 /*
Furquan Shaikhda459c42020-06-18 01:34:48 -070081 * Make sure Ext ROM Sharing is disabled before using this GPIO. Otherwise SPI flash
82 * access will be very slow.
Raul E Rangelb3c41322020-05-20 14:07:41 -060083 */
Furquan Shaikhda459c42020-06-18 01:34:48 -070084 PAD_GPO(GPIO_67, LOW), // Select Camera 1 Dmic
Kevin Chiu768f59a2020-09-26 20:34:28 +080085 /* EMMC_RESET_L */
86 PAD_GPO(GPIO_68, HIGH),
Martin Roth726504a2020-10-30 16:41:32 -060087 /* FPMCU_BOOT0 */
Raul E Rangelb3c41322020-05-20 14:07:41 -060088 PAD_GPO(GPIO_69, LOW),
89 /* EMMC_CLK */
90 PAD_NF(GPIO_70, EMMC_CLK, PULL_NONE),
Furquan Shaikh65e11172020-07-21 21:51:27 -070091 /* GPIO_71 - GPIO_73: Not available */
Raul E Rangelb3c41322020-05-20 14:07:41 -060092 /* EMMC_DATA4 */
93 PAD_NF(GPIO_74, EMMC_DATA4, PULL_NONE),
94 /* EMMC_DATA6 */
95 PAD_NF(GPIO_75, EMMC_DATA6, PULL_NONE),
96 /* EN_PWR_CAMERA */
97 PAD_GPO(GPIO_76, HIGH),
Furquan Shaikh65e11172020-07-21 21:51:27 -070098 /* GPIO_77 - GPIO_83: Not available */
99 /* RAM_ID_4 */
100 PAD_GPI(GPIO_84, PULL_NONE),
Chris Wangad481c42020-12-01 17:14:17 +0800101 /* APU_EDP_BL_DISABLE */
102 PAD_GPO(GPIO_85, LOW),
Furquan Shaikh65e11172020-07-21 21:51:27 -0700103 /* WIFI_AUX_RESET_L */
104 PAD_GPO(GPIO_86, HIGH),
Raul E Rangelb3c41322020-05-20 14:07:41 -0600105 /* EMMC_DATA7 */
106 PAD_NF(GPIO_87, EMMC_DATA7, PULL_NONE),
107 /* EMMC_DATA5 */
108 PAD_NF(GPIO_88, EMMC_DATA5, PULL_NONE),
Furquan Shaikh79dba4a2020-08-04 17:16:33 -0700109 /* GPIO_89 - unused */
110 PAD_NC(GPIO_89),
Furquan Shaikh5474f8e2020-08-05 14:54:39 -0700111 /* EN_PWR_TOUCHSCREEN */
112 PAD_GPO(GPIO_90, LOW),
Furquan Shaikh7f892b52020-07-21 22:54:16 -0700113 /* EN_SPKR */
Raul E Rangelb3c41322020-05-20 14:07:41 -0600114 PAD_GPO(GPIO_91, LOW),
Furquan Shaikh65e11172020-07-21 21:51:27 -0700115 /* CLK_REQ0_L - WIFI */
116 PAD_NF(GPIO_92, CLK_REQ0_L, PULL_NONE),
117 /* GPIO_93 - GPIO_103: Not available */
Raul E Rangelb3c41322020-05-20 14:07:41 -0600118 /* EMMC_DATA0 */
119 PAD_NF(GPIO_104, EMMC_DATA0, PULL_NONE),
120 /* EMMC_DATA1 */
121 PAD_NF(GPIO_105, EMMC_DATA1, PULL_NONE),
122 /* EMMC_DATA2 */
123 PAD_NF(GPIO_106, EMMC_DATA2, PULL_NONE),
124 /* EMMC_DATA3 */
125 PAD_NF(GPIO_107, EMMC_DATA3, PULL_NONE),
Furquan Shaikh65e11172020-07-21 21:51:27 -0700126 /* ESPI_ALERT_L */
127 PAD_NF(GPIO_108, ESPI_ALERT_L, PULL_UP),
Raul E Rangelb3c41322020-05-20 14:07:41 -0600128 /* EMMC_DS */
129 PAD_NF(GPIO_109, EMMC_DS, PULL_NONE),
Furquan Shaikh65e11172020-07-21 21:51:27 -0700130 /* GPIO_110 - GPIO112: Not available */
Raul E Rangelb3c41322020-05-20 14:07:41 -0600131 /* I2C2_SCL - USI/Touchpad */
Furquan Shaikh7571110d2020-07-16 11:26:10 -0700132 PAD_NF(GPIO_113, I2C2_SCL, PULL_NONE),
Raul E Rangelb3c41322020-05-20 14:07:41 -0600133 /* I2C2_SDA - USI/Touchpad */
Furquan Shaikh7571110d2020-07-16 11:26:10 -0700134 PAD_NF(GPIO_114, I2C2_SDA, PULL_NONE),
Furquan Shaikh65e11172020-07-21 21:51:27 -0700135 /* CLK_REQ1_L - SD Card */
136 PAD_NF(GPIO_115, CLK_REQ1_L, PULL_NONE),
137 /* RAM_ID_3 */
138 PAD_GPI(GPIO_116, PULL_NONE),
139 /* GPIO_117 - GPIO_119: Not available */
140 /* RAM_ID_1 */
141 PAD_GPI(GPIO_120, PULL_NONE),
142 /* RAM_ID_0 */
143 PAD_GPI(GPIO_121, PULL_NONE),
144 /* GPIO_122 - GPIO_128: Not available */
Raul E Rangelb3c41322020-05-20 14:07:41 -0600145 /* KBRST_L */
Furquan Shaikh7571110d2020-07-16 11:26:10 -0700146 PAD_NF(GPIO_129, KBRST_L, PULL_NONE),
Raul E Rangelb3c41322020-05-20 14:07:41 -0600147 /* EC_IN_RW_OD */
Furquan Shaikh7571110d2020-07-16 11:26:10 -0700148 PAD_GPI(GPIO_130, PULL_NONE),
Furquan Shaikh65e11172020-07-21 21:51:27 -0700149 /* RAM_ID_2 */
150 PAD_GPI(GPIO_131, PULL_NONE),
151 /* CLK_REQ4_L - SSD */
152 PAD_NF(GPIO_132, CLK_REQ4_L, PULL_NONE),
153 /* GPIO_133 - GPIO_134: Not available */
Raul E Rangelb3c41322020-05-20 14:07:41 -0600154 /* DEV_BEEP_CODEC_IN (Dev beep Data out) */
155 PAD_GPI(GPIO_135, PULL_NONE),
Furquan Shaikh65e11172020-07-21 21:51:27 -0700156 /* UART0_RXD - DEBUG */
157 PAD_NF(GPIO_136, UART0_RXD, PULL_NONE),
Furquan Shaikhca36acf2020-07-03 10:32:41 -0700158 /* BIOS_FLASH_WP_ODL */
159 PAD_GPI(GPIO_137, PULL_NONE),
Furquan Shaikh65e11172020-07-21 21:51:27 -0700160 /* UART0_TXD - DEBUG */
161 PAD_NF(GPIO_138, UART0_TXD, PULL_NONE),
Raul E Rangelb3c41322020-05-20 14:07:41 -0600162 /* DEV_BEEP_BCLK */
163 PAD_GPI(GPIO_139, PULL_NONE),
Furquan Shaikhcc6c41f2020-08-04 20:16:55 -0700164 /* USI_RESET_L */
165 PAD_GPO(GPIO_140, LOW),
Raul E Rangelb3c41322020-05-20 14:07:41 -0600166 /* UART1_RXD - FPMCU */
167 PAD_NF(GPIO_141, UART1_RXD, PULL_NONE),
Furquan Shaikh65e11172020-07-21 21:51:27 -0700168 /* SD_AUX_RESET_L */
169 PAD_GPO(GPIO_142, HIGH),
Raul E Rangelb3c41322020-05-20 14:07:41 -0600170 /* UART1_TXD - FPMCU */
171 PAD_NF(GPIO_143, UART1_TXD, PULL_NONE),
172 /* USI_REPORT_EN */
Furquan Shaikhdcee4b62020-07-22 00:47:40 -0700173 PAD_GPO(GPIO_144, LOW),
Raul E Rangelb3c41322020-05-20 14:07:41 -0600174};
175
176const __weak
Raul E Rangelb3c41322020-05-20 14:07:41 -0600177struct soc_amd_gpio *variant_base_gpio_table(size_t *size)
178{
179 *size = ARRAY_SIZE(gpio_set_stage_ram);
180 return gpio_set_stage_ram;
181}
182
Furquan Shaikh70b7fa12020-06-29 11:56:04 -0700183static void wifi_power_reset_configure_active_low_power(void)
Furquan Shaikh83025852020-06-22 10:45:12 -0700184{
185 /*
186 * Configure WiFi GPIOs such that:
187 * - WIFI_AUX_RESET_L is configured first to assert PERST# to WiFi device.
Furquan Shaikh70b7fa12020-06-29 11:56:04 -0700188 * - Enable power to WiFi using EN_PWR_WIFI_L.
Martin Rothcdd7d182020-11-18 09:20:01 -0700189 * - Wait for >50ms after power to WiFi is enabled. (Time between bootblock & ramstage)
190 * - WIFI_AUX_RESET_L gets deasserted later in mainboard_configure_gpios in ramstage
Furquan Shaikh83025852020-06-22 10:45:12 -0700191 */
192 static const struct soc_amd_gpio v3_wifi_table[] = {
193 /* WIFI_AUX_RESET_L */
194 PAD_GPO(GPIO_86, LOW),
Furquan Shaikh70b7fa12020-06-29 11:56:04 -0700195 /* EN_PWR_WIFI_L */
196 PAD_GPO(GPIO_42, LOW),
Furquan Shaikh83025852020-06-22 10:45:12 -0700197 };
198 program_gpios(v3_wifi_table, ARRAY_SIZE(v3_wifi_table));
199
Furquan Shaikh83025852020-06-22 10:45:12 -0700200}
201
Furquan Shaikh70b7fa12020-06-29 11:56:04 -0700202static void wifi_power_reset_configure_active_high_power(void)
203{
204 /*
205 * When GPIO_42 is configured as active high for enabling WiFi power, WIFI_AUX_RESET_L
206 * gets pulled high because of external PU to PP3300_WIFI. Thus, EN_PWR_WIFI needs to be
207 * set low before driving it high to trigger a WiFi power cycle to meet PCIe
208 * requirements. Thus, configura GPIOs such that:
209 * - WIFI_AUX_RESET_L is configured first to assert PERST# to WiFi device
210 * - Disable power to WiFi.
211 * - Wait 10ms for WiFi power to go low.
212 * - Enable power to WiFi using EN_PWR_WIFI.
213 * - Deassert WIFI_AUX_RESET_L.
214 */
215 static const struct soc_amd_gpio v3_wifi_table[] = {
216 /* WIFI_AUX_RESET_L */
217 PAD_GPO(GPIO_86, LOW),
218 /* EN_PWR_WIFI */
219 PAD_GPO(GPIO_42, LOW),
220 };
221 program_gpios(v3_wifi_table, ARRAY_SIZE(v3_wifi_table));
222
223 mdelay(10);
224 gpio_set(GPIO_42, 1);
225 mdelay(50);
226 gpio_set(GPIO_86, 1);
227}
228
Furquan Shaikh30ee0d82020-07-07 12:50:55 -0700229static void wifi_power_reset_configure_v3(void)
Furquan Shaikh70b7fa12020-06-29 11:56:04 -0700230{
Furquan Shaikh30ee0d82020-07-07 12:50:55 -0700231 if (variant_has_active_low_wifi_power())
Furquan Shaikh70b7fa12020-06-29 11:56:04 -0700232 wifi_power_reset_configure_active_low_power();
233 else
234 wifi_power_reset_configure_active_high_power();
235}
236
Furquan Shaikh83025852020-06-22 10:45:12 -0700237static void wifi_power_reset_configure_pre_v3(void)
238{
239 /*
240 * Configure WiFi GPIOs such that:
241 * - WIFI_AUX_RESET_L is configured first to assert PERST# to WiFi device.
242 * - Disable power to WiFi since GPIO_29 goes high on PWRGOOD but has a glitch on RESET#
243 * deassertion causing WiFi to enter a bad state.
244 * - Wait 10ms for WiFi power to go low.
245 * - Enable power to WiFi using EN_PWR_WIFI.
246 * - Wait for 50ms after power to WiFi is enabled.
247 * - Deassert WIFI_AUX_RESET_L.
248 */
249 static const struct soc_amd_gpio pre_v3_wifi_table[] = {
250 /* WIFI_AUX_RESET_L */
251 PAD_GPO(GPIO_42, LOW),
252 /* EN_PWR_WIFI */
253 PAD_GPO(GPIO_29, LOW),
254 };
255 program_gpios(pre_v3_wifi_table, ARRAY_SIZE(pre_v3_wifi_table));
256
257 mdelay(10);
258 gpio_set(GPIO_29, 1);
259 mdelay(50);
260 gpio_set(GPIO_42, 1);
261}
262
Furquan Shaikh56f949c2020-07-15 13:58:59 -0700263__weak void variant_pcie_gpio_configure(void)
Furquan Shaikh83025852020-06-22 10:45:12 -0700264{
Furquan Shaikh56f949c2020-07-15 13:58:59 -0700265 static const struct soc_amd_gpio pcie_gpio_table[] = {
266 /* NVME_AUX_RESET_L */
267 PAD_GPO(GPIO_40, HIGH),
268 /* CLK_REQ0_L - WIFI */
Furquan Shaikh7571110d2020-07-16 11:26:10 -0700269 PAD_NF(GPIO_92, CLK_REQ0_L, PULL_NONE),
Furquan Shaikh56f949c2020-07-15 13:58:59 -0700270 /* CLK_REQ1_L - SD Card */
Furquan Shaikh7571110d2020-07-16 11:26:10 -0700271 PAD_NF(GPIO_115, CLK_REQ1_L, PULL_NONE),
Furquan Shaikh56f949c2020-07-15 13:58:59 -0700272 /* CLK_REQ4_L - SSD */
Furquan Shaikh7571110d2020-07-16 11:26:10 -0700273 PAD_NF(GPIO_132, CLK_REQ4_L, PULL_NONE),
Furquan Shaikh56f949c2020-07-15 13:58:59 -0700274 /* SD_AUX_RESET_L */
275 PAD_GPO(GPIO_142, HIGH),
276 };
277
278 program_gpios(pcie_gpio_table, ARRAY_SIZE(pcie_gpio_table));
279
Furquan Shaikh30ee0d82020-07-07 12:50:55 -0700280 if (variant_uses_v3_schematics())
281 wifi_power_reset_configure_v3();
Furquan Shaikh83025852020-06-22 10:45:12 -0700282 else
283 wifi_power_reset_configure_pre_v3();
284}
Furquan Shaikh189a5c72020-06-29 18:50:50 -0700285
Martin Roth726504a2020-10-30 16:41:32 -0600286__weak void finalize_gpios(int slp_typ)
287{
288 if (variant_has_fingerprint() && slp_typ != ACPI_S3) {
289
290 if (fpmcu_needs_delay())
291 mdelay(550);
292
293 /*
294 * Enable the FPMCU by enabling EN_PWR_FP, then bringing it out
295 * of reset by setting FPMCU_RST_L high 3ms later.
296 */
297 gpio_set(GPIO_32, 1);
298 mdelay(3);
299 gpio_set(GPIO_11, 1);
300 }
301}
302
303static const struct soc_amd_gpio gpio_fingerprint_bootblock_table[] = {
304 /* FPMCU_RST_L */
305 PAD_GPO(GPIO_11, LOW),
306 /* EN_PWR_FP */
307 PAD_GPO(GPIO_32, LOW),
308};
309
310static const struct soc_amd_gpio gpio_no_fingerprint_bootblock_table[] = {
311 /* FPMCU_RST_L */
312 PAD_NC(GPIO_11),
313 /* EN_PWR_FP */
314 PAD_NC(GPIO_32),
315};
316
317const __weak struct soc_amd_gpio *variant_bootblock_gpio_table(size_t *size, int slp_typ)
318{
319 if (variant_has_fingerprint()) {
320 if (slp_typ == ACPI_S3)
321 return NULL;
322
323 *size = ARRAY_SIZE(gpio_fingerprint_bootblock_table);
324 return gpio_fingerprint_bootblock_table;
325 }
326
327 *size = ARRAY_SIZE(gpio_no_fingerprint_bootblock_table);
328 return gpio_no_fingerprint_bootblock_table;
329}
330
Furquan Shaikh189a5c72020-06-29 18:50:50 -0700331static const struct soc_amd_gpio gpio_sleep_table[] = {
Martin Roth6a62cc82020-12-02 16:37:58 -0700332 /* S0iX SLP */
333 PAD_GPO(GPIO_10, LOW),
Furquan Shaikh189a5c72020-06-29 18:50:50 -0700334 /* NVME_AUX_RESET_L */
335 PAD_GPO(GPIO_40, LOW),
336 /* EN_PWR_CAMERA */
337 PAD_GPO(GPIO_76, LOW),
338};
339
Martin Rothd5c3d9c2020-10-30 16:43:31 -0600340static const struct soc_amd_gpio gpio_fp_shutdown_table[] = {
341 /* NVME_AUX_RESET_L */
342 PAD_GPO(GPIO_40, LOW),
343 /* EN_PWR_CAMERA */
344 PAD_GPO(GPIO_76, LOW),
345
346 /* FPMCU_RST_L */
347 PAD_GPO(GPIO_11, LOW),
348 /* EN_PWR_FP */
349 PAD_GPO(GPIO_32, LOW),
350};
351
Furquan Shaikh189a5c72020-06-29 18:50:50 -0700352const __weak struct soc_amd_gpio *variant_sleep_gpio_table(size_t *size, int slp_typ)
353{
Martin Rothd5c3d9c2020-10-30 16:43:31 -0600354 if (slp_typ == SLP_TYP_S5) {
355 *size = ARRAY_SIZE(gpio_fp_shutdown_table);
356 return gpio_fp_shutdown_table;
357 }
358
Furquan Shaikh189a5c72020-06-29 18:50:50 -0700359 *size = ARRAY_SIZE(gpio_sleep_table);
360 return gpio_sleep_table;
361}