blob: 8f228353f4965f88b36fc74248b50da76ee4c12e [file] [log] [blame]
Angel Ponsb5a2a522020-04-05 13:21:48 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Martin Rothac35e622017-11-07 13:43:02 -07002
Martin Rothb77bc6f2017-11-11 14:33:47 -07003#include <baseboard/variants.h>
Martin Roth38115912017-11-20 16:19:00 -07004#include <soc/gpio.h>
Martin Rothac35e622017-11-07 13:43:02 -07005#include <soc/southbridge.h>
Daniel Kurtzd6487302018-04-18 17:57:09 -06006#include <variant/gpio.h>
Martin Rothac35e622017-11-07 13:43:02 -07007
Martin Roth38115912017-11-20 16:19:00 -07008/*
Richard Spiegele539c852017-12-25 18:25:58 -07009 * As a rule of thumb, GPIO pins used by coreboot should be initialized at
10 * bootblock while GPIO pins used only by the OS should be initialized at
11 * ramstage.
12 */
Richard Spiegel6fcb9b02018-04-18 08:06:33 -070013static const struct soc_amd_gpio gpio_set_stage_reset[] = {
Richard Spiegele07e4f32018-03-27 17:41:11 -070014 /* GPIO_4 - EN_PP3300_WLAN */
15 PAD_GPO(GPIO_4, HIGH),
16
Felix Held9ef72ca2020-12-12 22:28:54 +010017 /* GPIO_6 - APU_RST_L / EC_SMI_ODL, SMI gets configured in ramstage */
18 PAD_GPI(GPIO_6, PULL_UP),
Richard Spiegele07e4f32018-03-27 17:41:11 -070019
Furquan Shaikhaaff4012020-06-27 15:24:09 -070020 /* GPIO_9 - H1_PCH_INT_ODL */
Richard Spiegel2db06bb2018-04-20 16:50:12 -070021 PAD_INT(GPIO_9, PULL_UP, EDGE_LOW, STATUS),
Richard Spiegele07e4f32018-03-27 17:41:11 -070022
23 /* GPIO_15 - EC_IN_RW_OD */
24 PAD_GPI(GPIO_15, PULL_UP),
25
Felix Held9ef72ca2020-12-12 22:28:54 +010026 /* GPIO_22 - EC_SCI_ODL, SCI gets configured in ramstage */
27 PAD_GPI(GPIO_22, PULL_UP),
Richard Spiegele07e4f32018-03-27 17:41:11 -070028
Felix Held9ef72ca2020-12-12 22:28:54 +010029 /* GPIO_24 - EC_PCH_WAKE_L, SCI gets configured in ramstage */
30 PAD_GPI(GPIO_24, PULL_UP),
Richard Spiegele07e4f32018-03-27 17:41:11 -070031
32 /* GPIO_26 - APU_PCIE_RST_L */
33 PAD_NF(GPIO_26, PCIE_RST_L, PULL_NONE),
34
35 /* GPIO_40 - EMMC_BRIDGE_RST */
Martin Rothc3f52932018-09-17 09:16:31 -060036 PAD_GPO(GPIO_40, LOW),
Richard Spiegele07e4f32018-03-27 17:41:11 -070037
Richard Spiegele07e4f32018-03-27 17:41:11 -070038 /* GPIO_74 - LPC_CLK0_EC_R */
39 PAD_NF(GPIO_74, LPCCLK0, PULL_DOWN),
40
41 /* GPIO_92 - WLAN_PCIE_CLKREQ_3V3_ODL */
42 PAD_NF(GPIO_92, CLK_REQ0_L, PULL_UP),
43
Daniel Kurtzc3e74162018-05-23 17:58:59 -060044 /* GPIO_122 - APU_BIOS_FLASH_WP_L */
45 PAD_GPI(GPIO_122, PULL_NONE),
46
Richard Spiegele07e4f32018-03-27 17:41:11 -070047 /* GPIO_131 - CONFIG_STRAP3 */
48 PAD_GPI(GPIO_131, PULL_NONE),
49
50 /* GPIO_132 - CONFIG_STRAP4 */
51 PAD_GPI(GPIO_132, PULL_NONE),
52
53 /* GPIO_136 - UART_PCH_RX_DEBUG_TX */
54 PAD_NF(GPIO_136, UART0_RXD, PULL_NONE),
55
56 /* GPIO_138 - UART_PCH_TX_DEBUG_RX */
57 PAD_NF(GPIO_138, UART0_TXD, PULL_NONE),
58
59 /* GPIO_139 - CONFIG_STRAP1 */
60 PAD_GPI(GPIO_139, PULL_NONE),
61
62 /* GPIO_142 - CONFIG_STRAP2 */
63 PAD_GPI(GPIO_142, PULL_NONE),
64};
65
Kevin Chiu8c4ad5b2020-05-01 20:59:28 +080066static const struct soc_amd_gpio gpio_wlan_rst_early_reset[] = {
67 /* GPIO_70 - WLAN_PE_RST_L */
68 PAD_GPO(GPIO_70, HIGH),
69};
70
Martin Roth03f05cf2018-12-04 15:16:00 -070071static const struct soc_amd_gpio gpio_set_stage_rom[] = {
Matt DeVillier150b8092022-11-14 09:38:21 -060072 /* Enable touchscreen, hold in reset */
73 /* GPIO_76 - EN_PP3300_TOUCHSCREEN */
74 PAD_GPO(GPIO_76, HIGH),
75 /* GPIO_85 - TOUCHSCREEN_RST (Active High) */
76 PAD_GPO(GPIO_85, HIGH),
Martin Roth03f05cf2018-12-04 15:16:00 -070077 /* GPIO_133 - APU_EDP_BKLTEN_L (backlight - Active LOW) */
78 PAD_GPO(GPIO_133, HIGH),
79};
80
Richard Spiegel6fcb9b02018-04-18 08:06:33 -070081static const struct soc_amd_gpio gpio_set_stage_ram[] = {
Richard Spiegele07e4f32018-03-27 17:41:11 -070082 /* GPIO_0 - EC_PCH_PWR_BTN_ODL */
83 PAD_NF(GPIO_0, PWR_BTN_L, PULL_UP),
84
85 /* GPIO_1 - SYS_RST_ODL */
86 PAD_NF(GPIO_1, SYS_RESET_L, PULL_UP),
87
Martin Rothd0bc79b2018-03-19 16:39:19 -060088 /* GPIO_2 - WLAN_PCIE_WAKE_3V3_ODL */
Felix Heldf8e440c2021-03-24 00:17:35 +010089 PAD_NF_SCI(GPIO_2, WAKE_L, PULL_UP, EDGE_LOW),
Martin Rothd0bc79b2018-03-19 16:39:19 -060090
Richard Spiegele07e4f32018-03-27 17:41:11 -070091 /* GPIO_3 - MEM_VOLT_SEL */
92 PAD_GPI(GPIO_3, PULL_UP),
93
94 /* GPIO_5 - PCH_TRACKPAD_INT_3V3_ODL, SCI */
Richard Spiegel2db06bb2018-04-20 16:50:12 -070095 PAD_SCI(GPIO_5, PULL_UP, EDGE_LOW),
Richard Spiegele07e4f32018-03-27 17:41:11 -070096
Felix Held9ef72ca2020-12-12 22:28:54 +010097 /* GPIO_6 - APU_RST_L / EC_SMI_ODL, SMI */
98 PAD_SMI(GPIO_6, PULL_UP, LEVEL_LOW),
99
Richard Spiegele07e4f32018-03-27 17:41:11 -0700100 /* GPIO_7 - APU_PWROK_OD (currently not used) */
101 PAD_GPI(GPIO_7, PULL_UP),
102
103 /* GPIO_8 - DDR_ALERT_3V3_L (currently not used) */
104 PAD_GPI(GPIO_8, PULL_UP),
105
Edward Hillf14445c2019-02-04 14:42:03 -0700106 /* GPIO_10 - SLP_S0_L, EC_SYNC_IRQ */
107 PAD_GPI(GPIO_10, PULL_UP),
Martin Rothd0bc79b2018-03-19 16:39:19 -0600108
Richard Spiegele07e4f32018-03-27 17:41:11 -0700109 /* GPIO_11 - TOUCHSCREEN_INT_3V3_ODL, SCI */
Richard Spiegel2db06bb2018-04-20 16:50:12 -0700110 PAD_SCI(GPIO_11, PULL_UP, EDGE_LOW),
Richard Spiegele07e4f32018-03-27 17:41:11 -0700111
Martin Rothd0bc79b2018-03-19 16:39:19 -0600112 /* GPIO_12 - EN_PP3300_TRACKPAD */
113 PAD_GPO(GPIO_12, HIGH),
114
115 /* GPIO_13 - APU_PEN_PDCT_ODL (currently not used) */
116 PAD_GPI(GPIO_13, PULL_UP),
117
Richard Spiegele07e4f32018-03-27 17:41:11 -0700118 /* GPIO_14 - APU_HP_INT_ODL, SCI */
Richard Spiegel2db06bb2018-04-20 16:50:12 -0700119 PAD_SCI(GPIO_14, PULL_UP, EDGE_LOW),
Richard Spiegele07e4f32018-03-27 17:41:11 -0700120
Martin Rothd0bc79b2018-03-19 16:39:19 -0600121 /* GPIO_16 - USB_C0_OC_L */
122 PAD_NF(GPIO_16, USB_OC0_L, PULL_UP),
123
124 /* GPIO_17 - USB_C1_OC_L */
125 PAD_NF(GPIO_17, USB_OC1_L, PULL_UP),
126
127 /* GPIO_18 - USB_A0_OC_ODL */
128 PAD_NF(GPIO_18, USB_OC2_L, PULL_UP),
129
Richard Spiegele07e4f32018-03-27 17:41:11 -0700130 /* GPIO_19 - APU_I2C_SCL3 (Touchscreen) */
131 PAD_NF(GPIO_19, I2C3_SCL, PULL_UP),
132
133 /* GPIO_20 - APU_I2C_SDA3 (Touchscreen) */
134 PAD_NF(GPIO_20, I2C3_SDA, PULL_UP),
135
136 /* GPIO_21 - APU_PEN_INT_ODL, SCI */
Richard Spiegel2db06bb2018-04-20 16:50:12 -0700137 PAD_SCI(GPIO_21, PULL_UP, EDGE_LOW),
Richard Spiegele07e4f32018-03-27 17:41:11 -0700138
Felix Held9ef72ca2020-12-12 22:28:54 +0100139 /* GPIO_22 - EC_SCI_ODL, SCI */
140 PAD_SCI(GPIO_22, PULL_UP, EDGE_LOW),
141
142 /* GPIO_24 - EC_PCH_WAKE_L, SCI */
143 PAD_SCI(GPIO_24, PULL_UP, EDGE_LOW),
144
Richard Spiegele07e4f32018-03-27 17:41:11 -0700145 /* GPIO_25 - SD_CD */
146 PAD_NF(GPIO_25, SD0_CD, PULL_UP),
147
148 /* GPIO_42 - S5_MUX_CTRL */
149 PAD_NF(GPIO_42, S5_MUX_CTRL, PULL_NONE),
150
Martin Rothd0bc79b2018-03-19 16:39:19 -0600151 /* GPIO_67 - PEN_RESET */
152 PAD_GPO(GPIO_67, LOW),
153
154 /* GPIO_75 - Unused (strap) (R139/R130) */
155 PAD_GPI(GPIO_75, PULL_UP),
156
157 /* GPIO_76 - EN_PP3300_TOUCHSCREEN */
158 PAD_GPO(GPIO_76, HIGH),
159
Richard Spiegele07e4f32018-03-27 17:41:11 -0700160 /* GPIO_84 - HUB_RST (Active High) */
161 PAD_GPO(GPIO_84, LOW),
162
163 /* GPIO_85 - TOUCHSCREEN_RST (Active High) */
164 PAD_GPO(GPIO_85, LOW),
165
Martin Rothd0bc79b2018-03-19 16:39:19 -0600166 /* GPIO_86 - Unused (TP109) */
167 PAD_GPI(GPIO_86, PULL_UP),
168
Richard Spiegele07e4f32018-03-27 17:41:11 -0700169 /* GPIO_87 - LPC_SERIRQ */
170 PAD_NF(GPIO_87, SERIRQ, PULL_NONE),
171
172 /* GPIO_88 - LPC_CLKRUN_L */
173 PAD_NF(GPIO_88, LPC_CLKRUN_L, PULL_NONE),
174
Martin Rothd0bc79b2018-03-19 16:39:19 -0600175 /* GPIO_90 - EN_PP3300_CAMERA */
176 PAD_GPO(GPIO_90, HIGH),
177
Richard Spiegele07e4f32018-03-27 17:41:11 -0700178 /* GPIO_91 - DMIC_CLK1_EN */
179 PAD_GPO(GPIO_91, HIGH),
180
181 /* GPIO_93 - EMMC_RST */
182 PAD_GPO(GPIO_93, LOW),
183
184 /* GPIO_101 - SD_WP_L */
185 PAD_NF(GPIO_101, SD0_WP, PULL_DOWN),
186
Martin Rothd0bc79b2018-03-19 16:39:19 -0600187 /* GPIO_102 - EN_SD_SOCKET_PWR */
188 PAD_NF(GPIO_102, SD0_PWR_CTRL, PULL_DOWN),
189
190 /* GPIO_113 - APU_I2C_SCL2 (Pen & Trackpad) */
191 PAD_NF(GPIO_113, I2C2_SCL, PULL_UP),
192
193 /* GPIO_114 - APU_I2C_SDA2 (Pen & Trackpad) */
194 PAD_NF(GPIO_114, I2C2_SDA, PULL_UP),
195
196 /* GPIO_115 - Unused (TP127) */
197 PAD_GPI(GPIO_115, PULL_UP),
198
Richard Spiegele07e4f32018-03-27 17:41:11 -0700199 /* GPIO_116 - PCIE_EMMC_CLKREQ_L */
200 PAD_NF(GPIO_116, CLK_REQ2_L, PULL_NONE),
201
202 /* GPIO_118 - PCH_SPI_CS0_L */
203 PAD_NF(GPIO_118, SPI_CS1_L, PULL_NONE),
204
205 /* GPIO_119 - SPK_PA_EN */
Raul E Rangeldeed1e32018-11-21 15:26:46 -0700206 PAD_GPO(GPIO_119, LOW),
Richard Spiegele07e4f32018-03-27 17:41:11 -0700207
Richard Spiegele07e4f32018-03-27 17:41:11 -0700208 /* GPIO_126 - DMIC_CLK2_EN */
209 PAD_GPO(GPIO_126, HIGH),
210
211 /* GPIO_129 - APU_KBRST_L */
212 PAD_NF(GPIO_129, KBRST_L, PULL_UP),
213
Martin Rothd0bc79b2018-03-19 16:39:19 -0600214 /* GPIO_130 - Unused (TP55) */
215 PAD_GPI(GPIO_130, PULL_UP),
216
Martin Roth11f72982018-09-04 15:24:59 -0600217 /* GPIO_135 - BCLK Buffer Enable */
218 PAD_GPO(GPIO_135, HIGH),
Richard Spiegele07e4f32018-03-27 17:41:11 -0700219
220 /* GPIO_137 - Unused (TP27) */
221 PAD_GPI(GPIO_137, PULL_UP),
222
223 /* GPIO_140 - I2S_BCLK_R (init to func0, used for I2S) */
224 PAD_NF(GPIO_140, UART1_CTS_L, PULL_NONE),
225
226 /* GPIO_141 - I2S2_DATA_MIC2 (init to func0, used for I2S) */
227 PAD_NF(GPIO_141, UART1_RXD, PULL_NONE),
228
229 /* GPIO_143 - I2S2_DATA (init to func0, used for I2S) */
230 PAD_NF(GPIO_143, UART1_TXD, PULL_NONE),
231
232 /* GPIO_144 - I2S_LR_R (init to func0, used for I2S) */
233 PAD_NF(GPIO_144, UART1_INTR, PULL_NONE),
234
235 /* GPIO_145 - PCH_I2C_AUDIO_SCL */
236 PAD_NF(GPIO_145, I2C0_SCL, PULL_NONE),
237
238 /* GPIO_146 - PCH_I2C_AUDIO_SDA */
239 PAD_NF(GPIO_146, I2C0_SDA, PULL_NONE),
240
241 /* GPIO_147 - PCH_I2C_H1_TPM_SCL */
242 PAD_NF(GPIO_147, I2C1_SCL, PULL_NONE),
243
244 /* GPIO_148 - PCH_I2C_H1_TPM_SDA */
245 PAD_NF(GPIO_148, I2C1_SDA, PULL_NONE),
Martin Rothd0bc79b2018-03-19 16:39:19 -0600246};
247
Aaron Durbin64031672018-04-21 14:45:32 -0600248const __weak
Richard Spiegel6fcb9b02018-04-18 08:06:33 -0700249struct soc_amd_gpio *variant_early_gpio_table(size_t *size)
Richard Spiegele539c852017-12-25 18:25:58 -0700250{
Martin Rothb855f7e2018-06-02 21:48:14 -0600251 *size = ARRAY_SIZE(gpio_set_stage_reset);
252 return gpio_set_stage_reset;
Justin TerAvest3fe3f042018-02-14 19:10:15 -0700253}
254
Aaron Durbin64031672018-04-21 14:45:32 -0600255const __weak
Kevin Chiu8c4ad5b2020-05-01 20:59:28 +0800256struct soc_amd_gpio *variant_wlan_rst_early_gpio_table(size_t *size)
257{
258 *size = ARRAY_SIZE(gpio_wlan_rst_early_reset);
259 return gpio_wlan_rst_early_reset;
260}
261
Matt DeVillier046e2952022-11-14 09:25:18 -0600262const
263struct soc_amd_gpio *baseboard_romstage_gpio_table(size_t *size)
Martin Roth03f05cf2018-12-04 15:16:00 -0700264{
265 *size = ARRAY_SIZE(gpio_set_stage_rom);
266 return gpio_set_stage_rom;
267}
268
269const __weak
Richard Spiegel6fcb9b02018-04-18 08:06:33 -0700270struct soc_amd_gpio *variant_gpio_table(size_t *size)
Justin TerAvest3fe3f042018-02-14 19:10:15 -0700271{
Martin Rothb855f7e2018-06-02 21:48:14 -0600272 *size = ARRAY_SIZE(gpio_set_stage_ram);
273 return gpio_set_stage_ram;
Richard Spiegele539c852017-12-25 18:25:58 -0700274}
275
Aaron Durbin64031672018-04-21 14:45:32 -0600276int __weak variant_get_xhci_oc_map(uint16_t *map)
Marc Jonesdf6b51b2017-11-29 20:07:46 -0700277{
Martin Roth96b2de92017-12-13 20:07:26 -0700278 *map = USB_OC0 << OC_PORT0_SHIFT; /* USB-C Port0/4 = OC0 */
279 *map |= USB_OC1 << OC_PORT1_SHIFT; /* USB-C Port1/5 = OC1 */
280 *map |= USB_OC2 << OC_PORT2_SHIFT; /* USB-A HUB Port2/6 = OC2 */
Marc Jonesdf6b51b2017-11-29 20:07:46 -0700281 *map |= USB_OC_DISABLE << OC_PORT3_SHIFT;
282 return 0;
283}
284
Aaron Durbin64031672018-04-21 14:45:32 -0600285int __weak variant_get_ehci_oc_map(uint16_t *map)
Marc Jonesdf6b51b2017-11-29 20:07:46 -0700286{
Martin Roth96b2de92017-12-13 20:07:26 -0700287 *map = USB_OC_DISABLE_ALL;
Marc Jonesdf6b51b2017-11-29 20:07:46 -0700288 return 0;
289}