Martin Roth | ac35e62 | 2017-11-07 13:43:02 -0700 | [diff] [blame] | 1 | /* |
| 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 Spiegel | 0ad74ac | 2017-12-08 16:53:29 -0700 | [diff] [blame] | 16 | #include <amdblocks/agesawrapper.h> |
Martin Roth | b77bc6f | 2017-11-11 14:33:47 -0700 | [diff] [blame] | 17 | #include <baseboard/variants.h> |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 18 | #include <soc/gpio.h> |
Martin Roth | ac35e62 | 2017-11-07 13:43:02 -0700 | [diff] [blame] | 19 | #include <soc/smi.h> |
| 20 | #include <soc/southbridge.h> |
| 21 | #include <stdlib.h> |
| 22 | |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 23 | /* |
| 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 Spiegel | e539c85 | 2017-12-25 18:25:58 -0700 | [diff] [blame] | 26 | * |
| 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 | */ |
| 31 | const static struct soc_amd_stoneyridge_gpio gpio_set_stage_reset[] = { |
Richard Spiegel | e539c85 | 2017-12-25 18:25:58 -0700 | [diff] [blame] | 32 | /* GPIO_0 - EC_PCH_PWR_BTN_ODL */ |
| 33 | { GPIO_0, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 34 | |
| 35 | /* GPIO_1 - SYS_RST_ODL */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 36 | { GPIO_1, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 37 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 38 | /* GPIO_3 - MEM_VOLT_SEL */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 39 | { GPIO_3, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 40 | |
| 41 | /* GPIO_5 - PCH_TRACKPAD_INT_3V3_ODL, SCI */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 42 | { GPIO_5, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 43 | |
| 44 | /* GPIO_6 - APU_RST_L / EC_SMI_ODL, SMI */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 45 | { GPIO_6, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 46 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 47 | /* GPIO_7 - APU_PWROK_OD (currently not used) */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 48 | { GPIO_7, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 49 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 50 | /* GPIO_8 - DDR_ALERT_3V3_L (currently not used) */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 51 | { GPIO_8, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 52 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 53 | /* GPIO_9 - H1_PCH_INT_ODL, SCI */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 54 | { GPIO_9, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 55 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 56 | /* GPIO_11 - TOUCHSCREEN_INT_3V3_ODL, SCI */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 57 | { GPIO_11, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 58 | |
| 59 | /* GPIO_14 - APU_HP_INT_ODL, SCI */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 60 | { GPIO_14, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 61 | |
| 62 | /* GPIO_15 - EC_IN_RW_OD */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 63 | { GPIO_15, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 64 | |
| 65 | /* GPIO_19 - APU_I2C_SCL3 (Touchscreen) */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 66 | { GPIO_19, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 67 | |
| 68 | /* GPIO_20 - APU_I2C_SDA3 (Touchscreen) */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 69 | { GPIO_20, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 70 | |
| 71 | /* GPIO_21 - APU_PEN_INT_ODL, SCI */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 72 | { GPIO_21, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 73 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 74 | /* GPIO_22 - EC_SCI_ODL, SCI */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 75 | { GPIO_22, Function1, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 76 | |
| 77 | /* GPIO_23 - ACOK_OD */ |
| 78 | /* GPIO_24 - USB_A1_OC_ODL */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 79 | { GPIO_24, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 80 | |
| 81 | /* GPIO_25 - SD_CD */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 82 | { GPIO_25, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 83 | |
| 84 | /* GPIO_26 - APU_PCIE_RST_L */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 85 | { GPIO_26, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 86 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 87 | /* GPIO_40 - EMMC_BRIDGE_RST_L */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 88 | { GPIO_40, Function0, OUTPUT_H }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 89 | |
| 90 | /* GPIO_42 - S5_MUX_CTRL */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 91 | { GPIO_42, Function0, OUTPUT_H }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 92 | |
| 93 | /* GPIO_74 - LPC_CLK0_EC_R */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 94 | { GPIO_74, Function0, FCH_GPIO_PULL_DOWN_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 95 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 96 | /* GPIO_84 - HUB_RST (Active High) */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 97 | { GPIO_84, Function1, OUTPUT_L }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 98 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 99 | /* GPIO_85 - TOUCHSCREEN_RST (Active High) */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 100 | { GPIO_85, Function1, OUTPUT_L }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 101 | |
| 102 | /* GPIO_87 - LPC_SERIRQ */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 103 | { GPIO_87, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 104 | |
| 105 | /* GPIO_88 - LPC_CLKRUN_L */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 106 | { GPIO_88, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 107 | |
| 108 | /* GPIO_92 - WLAN_PCIE_CLKREQ_3V3_ODL */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 109 | { GPIO_92, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 110 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 111 | /* GPIO_93 - EMMC_RST_L */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 112 | { GPIO_93, Function1, OUTPUT_H }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 113 | |
| 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 Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 122 | { GPIO_101, Function0, FCH_GPIO_PULL_DOWN_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 123 | |
| 124 | /* GPIO_116 - PCIE_EMMC_CLKREQ_L */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 125 | { GPIO_116, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 126 | |
| 127 | /* GPIO_117 - PCH_SPI_CLK_R */ |
| 128 | |
| 129 | /* GPIO_118 - PCH_SPI_CS0_L */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 130 | { GPIO_118, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 131 | |
| 132 | /* GPIO_119 - SPK_PA_EN */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 133 | { GPIO_119, Function2, OUTPUT_H }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 134 | |
| 135 | /* GPIO_120 - PCH_SPI_MISO */ |
| 136 | /* GPIO_121 - PCH_SPI_MOSI */ |
| 137 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 138 | /* GPIO_122 - APU_BIOS_FLASH_WP_L */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 139 | { GPIO_122, Function1, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 140 | |
| 141 | /* GPIO_126 - DMIC_CLK2_EN */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 142 | { GPIO_126, Function1, OUTPUT_H }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 143 | |
| 144 | /* GPIO_129 - APU_KBRST_L */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 145 | { GPIO_129, Function0, FCH_GPIO_PULL_UP_ENABLE | INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 146 | |
| 147 | /* GPIO_131 - CONFIG_STRAP3 */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 148 | { GPIO_131, Function3, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 149 | |
| 150 | /* GPIO_132 - CONFIG_STRAP4 */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 151 | { GPIO_132, Function2, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 152 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 153 | /* GPIO_133 - APU_EDP_BKLTEN_L (backlight - Active LOW) */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 154 | { GPIO_133, Function1, OUTPUT_L }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 155 | |
| 156 | /* GPIO_136 - UART_PCH_RX_DEBUG_TX */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 157 | { GPIO_136, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 158 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 159 | /* GPIO_137 - AUDIO_CLK_EN (Remove in EVT?) */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 160 | { GPIO_137, Function1, OUTPUT_H }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 161 | |
| 162 | /* GPIO_138 - UART_PCH_TX_DEBUG_RX */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 163 | { GPIO_138, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 164 | |
| 165 | /* GPIO_139 - CONFIG_STRAP1 */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 166 | { GPIO_139, Function1, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 167 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 168 | /* GPIO_140 - I2S_BCLK_R (init to func0, used for I2S) */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 169 | { GPIO_140, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 170 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 171 | /* GPIO_141 - I2S2_DATA_MIC2 (init to func0, used for I2S) */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 172 | { GPIO_141, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 173 | |
| 174 | /* GPIO_142 - CONFIG_STRAP2 */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 175 | { GPIO_142, Function1, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 176 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 177 | /* GPIO_143 - I2S2_DATA (init to func0, used for I2S) */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 178 | { GPIO_143, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 179 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 180 | /* GPIO_144 - I2S_LR_R (init to func0, used for I2S) */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 181 | { GPIO_144, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 182 | |
| 183 | /* GPIO_145 - PCH_I2C_AUDIO_SCL */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 184 | { GPIO_145, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 185 | |
| 186 | /* GPIO_146 - PCH_I2C_AUDIO_SDA */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 187 | { GPIO_146, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 188 | |
| 189 | /* GPIO_147 - PCH_I2C_HUB_SCL */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 190 | { GPIO_147, Function0, INPUT }, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 191 | |
| 192 | /* GPIO_148 - PCH_I2C_HUB_SDA */ |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 193 | { GPIO_148, Function0, INPUT }, |
Martin Roth | ac35e62 | 2017-11-07 13:43:02 -0700 | [diff] [blame] | 194 | }; |
| 195 | |
Richard Spiegel | 254f10e | 2017-12-26 08:00:53 -0700 | [diff] [blame^] | 196 | const 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 Roth | dffd280 | 2017-11-11 15:22:55 -0700 | [diff] [blame] | 260 | |
Richard Spiegel | e539c85 | 2017-12-25 18:25:58 -0700 | [diff] [blame] | 261 | const __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 Roth | ac35e62 | 2017-11-07 13:43:02 -0700 | [diff] [blame] | 272 | /* |
| 273 | * GPE setup table must match ACPI GPE ASL |
| 274 | * { gevent, gpe, direction, level } |
| 275 | */ |
| 276 | static const struct sci_source gpe_table[] = { |
| 277 | |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 278 | /* 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 Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 286 | /* H1_PCH_INT_ODL */ |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 287 | { |
| 288 | .scimap = 22, |
| 289 | .gpe = 22, |
| 290 | .direction = SMI_SCI_LVL_LOW, |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 291 | .level = SMI_SCI_EDG, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 292 | }, |
| 293 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 294 | /* TOUCHSCREEN_INT_3V3_ODL */ |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 295 | { |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 296 | .scimap = 18, |
| 297 | .gpe = 18, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 298 | .direction = SMI_SCI_LVL_LOW, |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 299 | .level = SMI_SCI_EDG, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 300 | }, |
| 301 | |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 302 | |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 303 | /* APU_HP_INT_ODL */ |
| 304 | { |
| 305 | .scimap = 6, |
| 306 | .gpe = 6, |
| 307 | .direction = SMI_SCI_LVL_LOW, |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 308 | .level = SMI_SCI_EDG, |
Martin Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 309 | }, |
| 310 | |
| 311 | /* APU_PEN_INT_ODL */ |
| 312 | { |
| 313 | .scimap = 5, |
| 314 | .gpe = 5, |
Martin Roth | a55b0e5 | 2017-12-06 00:00:13 -0700 | [diff] [blame] | 315 | .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 Roth | 3811591 | 2017-11-20 16:19:00 -0700 | [diff] [blame] | 324 | .level = SMI_SCI_EDG, |
| 325 | }, |
Martin Roth | ac35e62 | 2017-11-07 13:43:02 -0700 | [diff] [blame] | 326 | }; |
| 327 | |
| 328 | const __attribute__((weak)) struct sci_source *get_gpe_table(size_t *num) |
| 329 | { |
| 330 | *num = ARRAY_SIZE(gpe_table); |
| 331 | return gpe_table; |
| 332 | } |
Marc Jones | df6b51b | 2017-11-29 20:07:46 -0700 | [diff] [blame] | 333 | |
| 334 | int __attribute__((weak)) variant_get_xhci_oc_map(uint16_t *map) |
| 335 | { |
Martin Roth | 96b2de9 | 2017-12-13 20:07:26 -0700 | [diff] [blame] | 336 | *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 Jones | df6b51b | 2017-11-29 20:07:46 -0700 | [diff] [blame] | 339 | *map |= USB_OC_DISABLE << OC_PORT3_SHIFT; |
| 340 | return 0; |
| 341 | } |
| 342 | |
| 343 | int __attribute__((weak)) variant_get_ehci_oc_map(uint16_t *map) |
| 344 | { |
Martin Roth | 96b2de9 | 2017-12-13 20:07:26 -0700 | [diff] [blame] | 345 | *map = USB_OC_DISABLE_ALL; |
Marc Jones | df6b51b | 2017-11-29 20:07:46 -0700 | [diff] [blame] | 346 | return 0; |
| 347 | } |