blob: f51f5458da6cdfe424c9aed9b996d204cdb7ffd6 [file] [log] [blame]
Martin Rothac35e622017-11-07 13:43:02 -07001/*
2 * This file is part of the coreboot project.
3 *
4 * Copyright (C) 2017 Advanced Micro Devices, Inc.
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; version 2 of the License.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 */
15
Richard Spiegel0ad74ac2017-12-08 16:53:29 -070016#include <amdblocks/agesawrapper.h>
Martin Rothb77bc6f2017-11-11 14:33:47 -070017#include <baseboard/variants.h>
Martin Roth38115912017-11-20 16:19:00 -070018#include <soc/gpio.h>
Martin Rothac35e622017-11-07 13:43:02 -070019#include <soc/smi.h>
20#include <soc/southbridge.h>
21#include <stdlib.h>
22
Martin Roth38115912017-11-20 16:19:00 -070023/*
24 * These settings were generated by a spreadsheet. If they need to be updated,
25 * update the spreadsheet shared with the Grunt development team.
Richard Spiegele539c852017-12-25 18:25:58 -070026 *
27 * As a rule of thumb, GPIO pins used by coreboot should be initialized at
28 * bootblock while GPIO pins used only by the OS should be initialized at
29 * ramstage.
30 */
31const static struct soc_amd_stoneyridge_gpio gpio_set_stage_reset[] = {
Richard Spiegele539c852017-12-25 18:25:58 -070032 /* GPIO_0 - EC_PCH_PWR_BTN_ODL */
33 { GPIO_0, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070034
35 /* GPIO_1 - SYS_RST_ODL */
Richard Spiegel254f10e2017-12-26 08:00:53 -070036 { GPIO_1, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070037
Martin Rotha55b0e52017-12-06 00:00:13 -070038 /* GPIO_3 - MEM_VOLT_SEL */
Richard Spiegel254f10e2017-12-26 08:00:53 -070039 { GPIO_3, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070040
41 /* GPIO_5 - PCH_TRACKPAD_INT_3V3_ODL, SCI */
Richard Spiegel254f10e2017-12-26 08:00:53 -070042 { GPIO_5, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070043
44 /* GPIO_6 - APU_RST_L / EC_SMI_ODL, SMI */
Richard Spiegel254f10e2017-12-26 08:00:53 -070045 { GPIO_6, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070046
Martin Rotha55b0e52017-12-06 00:00:13 -070047 /* GPIO_7 - APU_PWROK_OD (currently not used) */
Richard Spiegel254f10e2017-12-26 08:00:53 -070048 { GPIO_7, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070049
Martin Rotha55b0e52017-12-06 00:00:13 -070050 /* GPIO_8 - DDR_ALERT_3V3_L (currently not used) */
Richard Spiegel254f10e2017-12-26 08:00:53 -070051 { GPIO_8, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070052
Martin Rotha55b0e52017-12-06 00:00:13 -070053 /* GPIO_9 - H1_PCH_INT_ODL, SCI */
Richard Spiegel254f10e2017-12-26 08:00:53 -070054 { GPIO_9, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070055
Martin Rotha55b0e52017-12-06 00:00:13 -070056 /* GPIO_11 - TOUCHSCREEN_INT_3V3_ODL, SCI */
Richard Spiegel254f10e2017-12-26 08:00:53 -070057 { GPIO_11, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070058
59 /* GPIO_14 - APU_HP_INT_ODL, SCI */
Richard Spiegel254f10e2017-12-26 08:00:53 -070060 { GPIO_14, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070061
62 /* GPIO_15 - EC_IN_RW_OD */
Richard Spiegel254f10e2017-12-26 08:00:53 -070063 { GPIO_15, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070064
65 /* GPIO_19 - APU_I2C_SCL3 (Touchscreen) */
Richard Spiegel254f10e2017-12-26 08:00:53 -070066 { GPIO_19, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070067
68 /* GPIO_20 - APU_I2C_SDA3 (Touchscreen) */
Richard Spiegel254f10e2017-12-26 08:00:53 -070069 { GPIO_20, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070070
71 /* GPIO_21 - APU_PEN_INT_ODL, SCI */
Richard Spiegel254f10e2017-12-26 08:00:53 -070072 { GPIO_21, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070073
Martin Rotha55b0e52017-12-06 00:00:13 -070074 /* GPIO_22 - EC_SCI_ODL, SCI */
Richard Spiegel254f10e2017-12-26 08:00:53 -070075 { GPIO_22, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070076
77 /* GPIO_23 - ACOK_OD */
78 /* GPIO_24 - USB_A1_OC_ODL */
Richard Spiegel254f10e2017-12-26 08:00:53 -070079 { GPIO_24, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070080
81 /* GPIO_25 - SD_CD */
Richard Spiegel254f10e2017-12-26 08:00:53 -070082 { GPIO_25, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070083
84 /* GPIO_26 - APU_PCIE_RST_L */
Richard Spiegel254f10e2017-12-26 08:00:53 -070085 { GPIO_26, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -070086
Martin Rotha55b0e52017-12-06 00:00:13 -070087 /* GPIO_40 - EMMC_BRIDGE_RST_L */
Richard Spiegel254f10e2017-12-26 08:00:53 -070088 { GPIO_40, Function0, OUTPUT_H },
Martin Roth38115912017-11-20 16:19:00 -070089
90 /* GPIO_42 - S5_MUX_CTRL */
Richard Spiegel254f10e2017-12-26 08:00:53 -070091 { GPIO_42, Function0, OUTPUT_H },
Martin Roth38115912017-11-20 16:19:00 -070092
93 /* GPIO_74 - LPC_CLK0_EC_R */
Richard Spiegel254f10e2017-12-26 08:00:53 -070094 { GPIO_74, Function0, FCH_GPIO_PULL_DOWN_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -070095
Martin Rotha55b0e52017-12-06 00:00:13 -070096 /* GPIO_84 - HUB_RST (Active High) */
Richard Spiegel254f10e2017-12-26 08:00:53 -070097 { GPIO_84, Function1, OUTPUT_L },
Martin Roth38115912017-11-20 16:19:00 -070098
Martin Rotha55b0e52017-12-06 00:00:13 -070099 /* GPIO_85 - TOUCHSCREEN_RST (Active High) */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700100 { GPIO_85, Function1, OUTPUT_L },
Martin Roth38115912017-11-20 16:19:00 -0700101
102 /* GPIO_87 - LPC_SERIRQ */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700103 { GPIO_87, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700104
105 /* GPIO_88 - LPC_CLKRUN_L */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700106 { GPIO_88, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700107
108 /* GPIO_92 - WLAN_PCIE_CLKREQ_3V3_ODL */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700109 { GPIO_92, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700110
Martin Rotha55b0e52017-12-06 00:00:13 -0700111 /* GPIO_93 - EMMC_RST_L */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700112 { GPIO_93, Function1, OUTPUT_H },
Martin Roth38115912017-11-20 16:19:00 -0700113
114 /* GPIO_95 - SD_CLK */
115 /* GPIO_96 - SD_CMD */
116 /* GPIO_97 - SD_D0 */
117 /* GPIO_98 - SD_D1 */
118 /* GPIO_99 - SD_D2 */
119 /* GPIO_100 - SD_D3 */
120
121 /* GPIO_101 - SD_WP_L */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700122 { GPIO_101, Function0, FCH_GPIO_PULL_DOWN_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700123
124 /* GPIO_116 - PCIE_EMMC_CLKREQ_L */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700125 { GPIO_116, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700126
127 /* GPIO_117 - PCH_SPI_CLK_R */
128
129 /* GPIO_118 - PCH_SPI_CS0_L */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700130 { GPIO_118, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700131
132 /* GPIO_119 - SPK_PA_EN */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700133 { GPIO_119, Function2, OUTPUT_H },
Martin Roth38115912017-11-20 16:19:00 -0700134
135 /* GPIO_120 - PCH_SPI_MISO */
136 /* GPIO_121 - PCH_SPI_MOSI */
137
Martin Rotha55b0e52017-12-06 00:00:13 -0700138 /* GPIO_122 - APU_BIOS_FLASH_WP_L */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700139 { GPIO_122, Function1, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700140
141 /* GPIO_126 - DMIC_CLK2_EN */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700142 { GPIO_126, Function1, OUTPUT_H },
Martin Roth38115912017-11-20 16:19:00 -0700143
144 /* GPIO_129 - APU_KBRST_L */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700145 { GPIO_129, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700146
147 /* GPIO_131 - CONFIG_STRAP3 */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700148 { GPIO_131, Function3, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700149
150 /* GPIO_132 - CONFIG_STRAP4 */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700151 { GPIO_132, Function2, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700152
Martin Rotha55b0e52017-12-06 00:00:13 -0700153 /* GPIO_133 - APU_EDP_BKLTEN_L (backlight - Active LOW) */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700154 { GPIO_133, Function1, OUTPUT_L },
Martin Roth38115912017-11-20 16:19:00 -0700155
156 /* GPIO_136 - UART_PCH_RX_DEBUG_TX */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700157 { GPIO_136, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700158
Martin Rotha55b0e52017-12-06 00:00:13 -0700159 /* GPIO_137 - AUDIO_CLK_EN (Remove in EVT?) */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700160 { GPIO_137, Function1, OUTPUT_H },
Martin Roth38115912017-11-20 16:19:00 -0700161
162 /* GPIO_138 - UART_PCH_TX_DEBUG_RX */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700163 { GPIO_138, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700164
165 /* GPIO_139 - CONFIG_STRAP1 */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700166 { GPIO_139, Function1, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700167
Martin Rotha55b0e52017-12-06 00:00:13 -0700168 /* GPIO_140 - I2S_BCLK_R (init to func0, used for I2S) */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700169 { GPIO_140, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700170
Martin Rotha55b0e52017-12-06 00:00:13 -0700171 /* GPIO_141 - I2S2_DATA_MIC2 (init to func0, used for I2S) */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700172 { GPIO_141, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700173
174 /* GPIO_142 - CONFIG_STRAP2 */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700175 { GPIO_142, Function1, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700176
Martin Rotha55b0e52017-12-06 00:00:13 -0700177 /* GPIO_143 - I2S2_DATA (init to func0, used for I2S) */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700178 { GPIO_143, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700179
Martin Rotha55b0e52017-12-06 00:00:13 -0700180 /* GPIO_144 - I2S_LR_R (init to func0, used for I2S) */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700181 { GPIO_144, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700182
183 /* GPIO_145 - PCH_I2C_AUDIO_SCL */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700184 { GPIO_145, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700185
186 /* GPIO_146 - PCH_I2C_AUDIO_SDA */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700187 { GPIO_146, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700188
189 /* GPIO_147 - PCH_I2C_HUB_SCL */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700190 { GPIO_147, Function0, INPUT },
Martin Roth38115912017-11-20 16:19:00 -0700191
192 /* GPIO_148 - PCH_I2C_HUB_SDA */
Richard Spiegel254f10e2017-12-26 08:00:53 -0700193 { GPIO_148, Function0, INPUT },
Martin Rothac35e622017-11-07 13:43:02 -0700194};
195
Richard Spiegel254f10e2017-12-26 08:00:53 -0700196const static struct soc_amd_stoneyridge_gpio gpio_set_stage_ram[] = {
197 /* GPIO_2 - WLAN_PCIE_WAKE_3V3_ODL */
198 { GPIO_2, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
199
200 /* GPIO_4 - EN_PP3300_WLAN */
201 { GPIO_4, Function0, OUTPUT_H },
202
203 /* GPIO_10 - SLP_S0_L (currently not used) */
204 { GPIO_10, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
205
206 /* GPIO_12 - Unused (TP126) */
207 { GPIO_12, Function2, FCH_GPIO_PULL_UP_ENABLE | INPUT },
208
209 /* GPIO_13 - APU_PEN_PDCT_ODL (currently not used) */
210 { GPIO_13, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
211
212 /* GPIO_16 - USB_C0_OC_L */
213 { GPIO_16, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
214
215 /* GPIO_17 - USB_C1_OC_L */
216 { GPIO_17, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
217
218 /* GPIO_18 - USB_A0_OC_ODL */
219 { GPIO_18, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT },
220
221 /* GPIO_67 - PEN_RESET */
222 { GPIO_67, Function0, OUTPUT_L },
223
224 /* GPIO_70 - WLAN_PE_RST_L */
225 { GPIO_70, Function0, OUTPUT_H },
226
227 /* GPIO_75 - Unused (strap) (R139/R130) */
228 { GPIO_75, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
229
230 /* GPIO_76 - EN_PP3300_TOUCHSCREEN */
231 { GPIO_76, Function0, OUTPUT_H },
232
233 /* GPIO_86 - Unused (TP109) */
234 { GPIO_86, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
235
236 /* GPIO_90 - EN_PP3300_CAMERA */
237 { GPIO_90, Function0, OUTPUT_H },
238
239 /* GPIO_91 - EN_PP3300_TRACKPAD */
240 { GPIO_91, Function1, OUTPUT_H },
241
242 /* GPIO_102 - EN_SD_SOCKET_PWR */
243 { GPIO_102, Function0, FCH_GPIO_PULL_DOWN_ENABLE | INPUT },
244
245 /* GPIO_113 - APU_I2C_SCL2 (Pen & Trackpad) */
246 { GPIO_113, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
247
248 /* GPIO_114 - APU_I2C_SDA2 (Pen & Trackpad) */
249 { GPIO_114, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
250
251 /* GPIO_115 - Unused (TP127) */
252 { GPIO_115, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
253
254 /* GPIO_130 - Unused (TP55) */
255 { GPIO_130, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
256
257 /* GPIO_135 - Unused (TP128) */
258 { GPIO_135, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT },
259};
Martin Rothdffd2802017-11-11 15:22:55 -0700260
Richard Spiegele539c852017-12-25 18:25:58 -0700261const __attribute__((weak)) const struct soc_amd_stoneyridge_gpio
262 *board_get_gpio(size_t *size)
263{
264 if (GPIO_TABLE_BOOTBLOCK) {
265 *size = ARRAY_SIZE(gpio_set_stage_reset);
266 return gpio_set_stage_reset;
267 }
268 *size = ARRAY_SIZE(gpio_set_stage_ram);
269 return gpio_set_stage_ram;
270}
271
Martin Rothac35e622017-11-07 13:43:02 -0700272/*
273 * GPE setup table must match ACPI GPE ASL
274 * { gevent, gpe, direction, level }
275 */
276static const struct sci_source gpe_table[] = {
277
Martin Roth38115912017-11-20 16:19:00 -0700278 /* PCH_TRACKPAD_INT_3V3_ODL */
279 {
280 .scimap = 7,
281 .gpe = 7,
282 .direction = SMI_SCI_LVL_LOW,
283 .level = SMI_SCI_EDG,
284 },
285
Martin Rotha55b0e52017-12-06 00:00:13 -0700286 /* H1_PCH_INT_ODL */
Martin Roth38115912017-11-20 16:19:00 -0700287 {
288 .scimap = 22,
289 .gpe = 22,
290 .direction = SMI_SCI_LVL_LOW,
Martin Rotha55b0e52017-12-06 00:00:13 -0700291 .level = SMI_SCI_EDG,
Martin Roth38115912017-11-20 16:19:00 -0700292 },
293
Martin Rotha55b0e52017-12-06 00:00:13 -0700294 /* TOUCHSCREEN_INT_3V3_ODL */
Martin Roth38115912017-11-20 16:19:00 -0700295 {
Martin Rotha55b0e52017-12-06 00:00:13 -0700296 .scimap = 18,
297 .gpe = 18,
Martin Roth38115912017-11-20 16:19:00 -0700298 .direction = SMI_SCI_LVL_LOW,
Martin Rotha55b0e52017-12-06 00:00:13 -0700299 .level = SMI_SCI_EDG,
Martin Roth38115912017-11-20 16:19:00 -0700300 },
301
Martin Rotha55b0e52017-12-06 00:00:13 -0700302
Martin Roth38115912017-11-20 16:19:00 -0700303 /* APU_HP_INT_ODL */
304 {
305 .scimap = 6,
306 .gpe = 6,
307 .direction = SMI_SCI_LVL_LOW,
Martin Rotha55b0e52017-12-06 00:00:13 -0700308 .level = SMI_SCI_EDG,
Martin Roth38115912017-11-20 16:19:00 -0700309 },
310
311 /* APU_PEN_INT_ODL */
312 {
313 .scimap = 5,
314 .gpe = 5,
Martin Rotha55b0e52017-12-06 00:00:13 -0700315 .direction = SMI_SCI_LVL_LOW,
316 .level = SMI_SCI_EDG,
317 },
318
319 /* EC_SCI_ODL */
320 {
321 .scimap = 3,
322 .gpe = 3,
323 .direction = SMI_SCI_LVL_LOW,
Martin Roth38115912017-11-20 16:19:00 -0700324 .level = SMI_SCI_EDG,
325 },
Martin Rothac35e622017-11-07 13:43:02 -0700326};
327
328const __attribute__((weak)) struct sci_source *get_gpe_table(size_t *num)
329{
330 *num = ARRAY_SIZE(gpe_table);
331 return gpe_table;
332}
Marc Jonesdf6b51b2017-11-29 20:07:46 -0700333
334int __attribute__((weak)) variant_get_xhci_oc_map(uint16_t *map)
335{
Martin Roth96b2de92017-12-13 20:07:26 -0700336 *map = USB_OC0 << OC_PORT0_SHIFT; /* USB-C Port0/4 = OC0 */
337 *map |= USB_OC1 << OC_PORT1_SHIFT; /* USB-C Port1/5 = OC1 */
338 *map |= USB_OC2 << OC_PORT2_SHIFT; /* USB-A HUB Port2/6 = OC2 */
Marc Jonesdf6b51b2017-11-29 20:07:46 -0700339 *map |= USB_OC_DISABLE << OC_PORT3_SHIFT;
340 return 0;
341}
342
343int __attribute__((weak)) variant_get_ehci_oc_map(uint16_t *map)
344{
Martin Roth96b2de92017-12-13 20:07:26 -0700345 *map = USB_OC_DISABLE_ALL;
Marc Jonesdf6b51b2017-11-29 20:07:46 -0700346 return 0;
347}