coreboot
coreboot is an Open Source project aimed at replacing the proprietary BIOS found in most computers.
gpio.c
Go to the documentation of this file.
1
/* SPDX-License-Identifier: GPL-2.0-only */
2
3
#include <mainboard/gpio.h>
4
#include <soc/gpe.h>
5
#include <soc/gpio.h>
6
7
static
const
struct
pad_config
gpio_table
[] = {
8
/* ------- GPIO Group GPD ------- */
9
PAD_CFG_NF
(
GPD0
,
NONE
, DEEP, NF1),
// PM_BATLOW#
10
PAD_CFG_NF
(
GPD1
, NATIVE, DEEP, NF1),
// AC_PRESENT
11
PAD_CFG_GPI
(
GPD2
, NATIVE, PWROK),
// LAN_WAKEUP#
12
PAD_CFG_NF
(
GPD3
, UP_20K, DEEP, NF1),
// PWR_BTN#
13
PAD_CFG_NF
(
GPD4
,
NONE
, DEEP, NF1),
// SUSB#_PCH
14
PAD_CFG_NF
(
GPD5
,
NONE
, DEEP, NF1),
// SUSC#_PCH
15
PAD_NC
(
GPD6
,
NONE
),
16
PAD_CFG_GPI
(
GPD7
, UP_20K, PWROK),
/* GPD_7 (crystal input
17
low = single ended,
18
high = differential)
19
*/
20
PAD_CFG_NF
(
GPD8
,
NONE
, DEEP, NF1),
// PCH_SUSCLK
21
PAD_NC
(
GPD9
,
NONE
),
22
PAD_NC
(
GPD10
,
NONE
),
23
PAD_CFG_GPO
(
GPD11
, 1, DEEP),
// LAN_DISABLE#
24
25
/* ------- GPIO Group GPP_A ------- */
26
PAD_CFG_NF
(
GPP_A0
,
NONE
, DEEP, NF1),
// SB_KBCRST#
27
PAD_CFG_NF
(
GPP_A1
,
NONE
, DEEP, NF1),
// LPC_AD0
28
PAD_CFG_NF
(
GPP_A2
,
NONE
, DEEP, NF1),
// LPC_AD1
29
PAD_CFG_NF
(
GPP_A3
,
NONE
, DEEP, NF1),
// LPC_AD2
30
PAD_CFG_NF
(
GPP_A4
,
NONE
, DEEP, NF1),
// LPC_AD3
31
PAD_CFG_NF
(
GPP_A5
,
NONE
, DEEP, NF1),
// LPC_FRAME#
32
PAD_CFG_NF
(
GPP_A6
,
NONE
, DEEP, NF1),
// SERIRQ
33
PAD_CFG_NF
(
GPP_A7
,
NONE
, DEEP, NF1),
// LPC_PIRQA#
34
PAD_CFG_NF
(
GPP_A8
,
NONE
, DEEP, NF1),
// PM_CLKRUN#
35
PAD_CFG_NF
(
GPP_A9
,
NONE
, DEEP, NF1),
// PCLK_KBC
36
PAD_NC
(
GPP_A10
,
NONE
),
37
PAD_CFG_GPI_APIC_HIGH
(
GPP_A11
,
NONE
, PLTRST),
// INTP_OUT
38
PAD_NC
(
GPP_A12
,
NONE
),
39
PAD_NC
(
GPP_A13
,
NONE
),
// SUSWARN# (test point)
40
PAD_NC
(
GPP_A14
,
NONE
),
// (test point)
41
PAD_NC
(
GPP_A15
,
NONE
),
// SUS_PWR_ACK# (test point)
42
PAD_NC
(
GPP_A16
,
NONE
),
43
PAD_NC
(
GPP_A17
,
NONE
),
44
PAD_NC
(
GPP_A18
,
NONE
),
45
PAD_CFG_GPO
(
GPP_A19
, 1, DEEP),
// SB_BLON
46
PAD_CFG_GPI
(
GPP_A20
,
NONE
, DEEP),
// PEX_WAKE#
47
PAD_NC
(
GPP_A21
,
NONE
),
48
PAD_CFG_GPO
(
GPP_A22
, 1, DEEP),
// WLAN_SSD2_GPIO1
49
PAD_CFG_GPO
(
GPP_A23
, 1, DEEP),
// WLAN_SSD2_GPIO
50
51
/* ------- GPIO Group GPP_B ------- */
52
PAD_CFG_GPI
(
GPP_B0
, UP_20K, DEEP),
// TPM_PIRQ#
53
PAD_NC
(
GPP_B1
,
NONE
),
54
PAD_NC
(
GPP_B2
,
NONE
),
55
PAD_CFG_GPO
(
GPP_B3
, 1, DEEP),
// BT_RF_KILL_R_N
56
PAD_CFG_GPO
(
GPP_B4
, 1, DEEP),
// WIFI_RF_KILL_R_N
57
PAD_NC
(
GPP_B5
,
NONE
),
58
PAD_NC
(
GPP_B6
,
NONE
),
59
PAD_CFG_GPO
(
GPP_B7
, 1, PLTRST),
// CR_GPIO_RST#
60
PAD_CFG_GPO
(
GPP_B8
, 1, PLTRST),
// CR_GPIO_WAKE#
61
PAD_NC
(
GPP_B9
,
NONE
),
62
PAD_NC
(
GPP_B10
,
NONE
),
63
PAD_NC
(
GPP_B11
,
NONE
),
64
PAD_CFG_GPI
(
GPP_B12
, UP_20K, DEEP),
// SLP_S0#
65
PAD_CFG_NF
(
GPP_B13
,
NONE
, DEEP, NF1),
// PLT_RST#
66
PAD_CFG_NF
(
GPP_B14
,
NONE
, DEEP, NF1),
// PCH_SPKR
67
PAD_NC
(
GPP_B15
,
NONE
),
68
PAD_NC
(
GPP_B16
,
NONE
),
69
PAD_NC
(
GPP_B17
,
NONE
),
70
PAD_NC
(
GPP_B18
,
NONE
),
// LPSS_GSPI0_MOSI (test point)
71
PAD_NC
(
GPP_B19
,
NONE
),
72
PAD_CFG_GPI_SMI
(
GPP_B20
,
NONE
, DEEP, EDGE_SINGLE,
NONE
),
// SMI#
73
PAD_NC
(
GPP_B21
,
NONE
),
74
PAD_CFG_GPI
(
GPP_B22
, UP_20K, DEEP),
// LPSS_GSPI1_MOSI
75
PAD_CFG_GPI_SCI_LOW
(
GPP_B23
, UP_20K, PLTRST, LEVEL),
// SCI#
76
77
/* ------- GPIO Group GPP_C ------- */
78
PAD_CFG_NF
(
GPP_C0
,
NONE
, DEEP, NF1),
// SMB_CLK
79
PAD_CFG_NF
(
GPP_C1
,
NONE
, DEEP, NF1),
// SMB_DATA
80
PAD_CFG_GPI
(
GPP_C2
, UP_20K, DEEP),
// GPP_C2_BT_UART_WAKE_N
81
PAD_NC
(
GPP_C3
,
NONE
),
82
PAD_NC
(
GPP_C4
,
NONE
),
83
PAD_CFG_GPI
(
GPP_C5
, UP_20K, DEEP),
// M.2_WLAN_WIFI_WAKE_N
84
PAD_CFG_GPI
(
GPP_C6
, UP_20K, DEEP),
// SMC_CPU_THERM
85
PAD_CFG_GPI
(
GPP_C7
, UP_20K, DEEP),
// SMD_CPU_THERM
86
PAD_CFG_GPI
(
GPP_C8
,
NONE
, DEEP),
// TPM_DET
87
PAD_CFG_GPI
(
GPP_C9
, DN_20K, DEEP),
// BOARD_ID1
88
PAD_CFG_GPI
(
GPP_C10
, DN_20K, DEEP),
// BOARD_ID2
89
PAD_CFG_GPI
(
GPP_C11
, DN_20K, DEEP),
// BOARD_ID3
90
PAD_CFG_GPI
(
GPP_C12
,
NONE
, DEEP),
// GC6_FB_EN_PCH
91
PAD_CFG_GPO
(
GPP_C13
, 1, DEEP),
// GPU_EVENT#
92
PAD_CFG_GPO
(
GPP_C14
, 1, DEEP),
// M.2_PLT_RST_CNTRL1#
93
PAD_CFG_GPO
(
GPP_C15
, 1, DEEP),
// M.2_PLT_RST_CNTRL2#
94
PAD_CFG_NF
(
GPP_C16
,
NONE
, PLTRST, NF1),
// I2C_SDA_TP
95
PAD_CFG_NF
(
GPP_C17
,
NONE
, PLTRST, NF1),
// I2C_SCL_TP
96
PAD_CFG_NF
(
GPP_C18
,
NONE
, PLTRST, NF1),
// SMD_7411_I2C
97
PAD_CFG_NF
(
GPP_C19
,
NONE
, PLTRST, NF1),
// SMC_7411_I2C
98
//PAD_CFG_NF(GPP_C20, NONE, DEEP, NF1), // UART2_RXD
99
//PAD_CFG_NF(GPP_C21, NONE, DEEP, NF1), // UART2_TXD
100
PAD_CFG_NF
(
GPP_C22
, UP_20K, DEEP, NF1),
// UART2_RTS# / LAN_PLT_RST#
101
PAD_CFG_NF
(
GPP_C23
, UP_20K, DEEP, NF1),
// BOARD_ID4
102
103
/* ------- GPIO Group GPP_D ------- */
104
PAD_NC
(
GPP_D0
,
NONE
),
105
PAD_NC
(
GPP_D1
,
NONE
),
106
PAD_NC
(
GPP_D2
,
NONE
),
107
PAD_NC
(
GPP_D3
,
NONE
),
108
PAD_NC
(
GPP_D4
,
NONE
),
109
PAD_CFG_NF
(
GPP_D5
,
NONE
, DEEP, NF3),
// M.2_BT_PCMFRM_CRF_RST_N
110
PAD_CFG_NF
(
GPP_D6
,
NONE
, DEEP, NF3),
// M.2_BT_PCMOUT_CLKREQ0
111
PAD_CFG_GPI
(
GPP_D7
, UP_20K, DEEP),
// M.2_BT_PCMIN
112
PAD_CFG_GPI
(
GPP_D8
, UP_20K, DEEP),
// M.2_BT_PCMCLK
113
PAD_NC
(
GPP_D9
,
NONE
),
114
PAD_NC
(
GPP_D10
,
NONE
),
115
PAD_NC
(
GPP_D11
,
NONE
),
116
PAD_NC
(
GPP_D12
,
NONE
),
117
PAD_NC
(
GPP_D13
,
NONE
),
// 10k pull up
118
PAD_NC
(
GPP_D14
,
NONE
),
// 10k pull up
119
PAD_NC
(
GPP_D15
,
NONE
),
120
PAD_NC
(
GPP_D16
,
NONE
),
121
PAD_NC
(
GPP_D17
,
NONE
),
122
PAD_NC
(
GPP_D18
,
NONE
),
123
PAD_NC
(
GPP_D19
,
NONE
),
124
PAD_NC
(
GPP_D20
,
NONE
),
125
PAD_NC
(
GPP_D21
,
NONE
),
126
PAD_NC
(
GPP_D22
,
NONE
),
127
PAD_NC
(
GPP_D23
,
NONE
),
128
129
/* ------- GPIO Group GPP_E ------- */
130
PAD_NC
(
GPP_E0
,
NONE
),
131
PAD_CFG_NF
(
GPP_E1
,
NONE
, DEEP, NF1),
// SATAGP1 / M.2_SSD1_PEDET
132
PAD_NC
(
GPP_E2
,
NONE
),
133
PAD_NC
(
GPP_E3
,
NONE
),
134
PAD_NC
(
GPP_E4
,
NONE
),
135
PAD_CFG_GPI
(
GPP_E5
, UP_20K, DEEP),
// M2_P0_SATA_DEVSLP
136
PAD_NC
(
GPP_E6
,
NONE
),
137
PAD_CFG_GPI_APIC_EDGE_LOW
(
GPP_E7
,
NONE
, PLTRST),
// TP_ATTN#
138
PAD_CFG_NF
(
GPP_E8
,
NONE
, DEEP, NF1),
// PCH_SATAHDD_LED#
139
PAD_NC
(
GPP_E9
,
NONE
),
// USB_OC0# (test point)
140
PAD_NC
(
GPP_E10
,
NONE
),
// USB_OC1# (test point)
141
PAD_NC
(
GPP_E11
,
NONE
),
// USB_OC2# (test point)
142
PAD_NC
(
GPP_E12
,
NONE
),
// USB_OC3# (test point)
143
144
/* ------- GPIO Group GPP_F ------- */
145
PAD_NC
(
GPP_F0
,
NONE
),
146
PAD_CFG_NF
(
GPP_F1
,
NONE
, DEEP, NF1),
// SATAGP4 / M.2_SSD2_PEDET
147
PAD_NC
(
GPP_F2
,
NONE
),
148
PAD_NC
(
GPP_F3
,
NONE
),
149
PAD_NC
(
GPP_F4
,
NONE
),
150
PAD_NC
(
GPP_F5
,
NONE
),
151
PAD_CFG_NF
(
GPP_F6
,
NONE
, DEEP, NF1),
// M2_P4_SATA_DEVSLP
152
PAD_NC
(
GPP_F7
,
NONE
),
153
PAD_NC
(
GPP_F8
,
NONE
),
154
PAD_NC
(
GPP_F9
,
NONE
),
155
PAD_CFG_GPI
(
GPP_F10
, UP_20K, DEEP),
// BIOS_REC
156
PAD_CFG_GPI
(
GPP_F11
, UP_20K, DEEP),
// GPP_F11
157
PAD_NC
(
GPP_F12
,
NONE
),
158
PAD_CFG_GPI
(
GPP_F13
, UP_20K, DEEP),
// GP39_GFX_CRB_DETECT
159
PAD_CFG_GPI
(
GPP_F14
, UP_20K, DEEP),
// H_SKTOCC_N
160
PAD_NC
(
GPP_F15
,
NONE
),
// USB_OC4# (test point)
161
PAD_NC
(
GPP_F16
,
NONE
),
162
PAD_NC
(
GPP_F17
,
NONE
),
163
PAD_NC
(
GPP_F18
,
NONE
),
// USB_OC7# (test point)
164
PAD_CFG_NF
(
GPP_F19
,
NONE
, DEEP, NF1),
// NB_ENAVDD
165
PAD_CFG_NF
(
GPP_F20
,
NONE
, DEEP, NF1),
// BLON
166
PAD_CFG_NF
(
GPP_F21
,
NONE
, DEEP, NF1),
// EDP_BRIGHTNESS
167
PAD_CFG_GPO
(
GPP_F22
, 0, DEEP),
// DGPU_RST#_PCH
168
PAD_CFG_GPO
(
GPP_F23
, 0, DEEP),
// DGPU_PWR_EN
169
170
/* ------- GPIO Group GPP_G ------- */
171
PAD_NC
(
GPP_G0
,
NONE
),
172
PAD_CFG_NF
(
GPP_G1
,
NONE
, DEEP, NF1),
// CNVI_WIGIG_DET#
173
PAD_NC
(
GPP_G2
,
NONE
),
174
PAD_NC
(
GPP_G3
,
NONE
),
175
PAD_NC
(
GPP_G4
,
NONE
),
176
PAD_NC
(
GPP_G5
,
NONE
),
177
PAD_CFG_GPI_SCI_LOW
(
GPP_G6
,
NONE
, DEEP, LEVEL),
// SWI#
178
PAD_NC
(
GPP_G7
,
NONE
),
179
180
/* ------- GPIO Group GPP_H ------- */
181
PAD_NC
(
GPP_H0
,
NONE
),
182
PAD_NC
(
GPP_H1
,
NONE
),
183
PAD_CFG_NF
(
GPP_H2
,
NONE
, DEEP, NF1),
// CLK_REQ9_PEG#
184
PAD_NC
(
GPP_H3
,
NONE
),
185
PAD_NC
(
GPP_H4
,
NONE
),
186
PAD_CFG_NF
(
GPP_H5
,
NONE
, DEEP, NF1),
// CLK_REQ12_SSD2#
187
PAD_CFG_NF
(
GPP_H6
,
NONE
, DEEP, NF1),
// CLK_REQ13_SSD1#
188
PAD_CFG_NF
(
GPP_H7
,
NONE
, DEEP, NF1),
// GPP_H_0_SRCCLKREQB_14
189
PAD_CFG_NF
(
GPP_H8
,
NONE
, DEEP, NF1),
// CLK_REQ15_LAN#
190
PAD_CFG_NF
(
GPP_H9
,
NONE
, DEEP, NF1),
// CLK_REQ16_CARD#
191
PAD_NC
(
GPP_H10
,
NONE
),
192
PAD_NC
(
GPP_H11
,
NONE
),
193
PAD_NC
(
GPP_H12
,
NONE
),
// GPP_H_12 (test point)
194
PAD_NC
(
GPP_H13
,
NONE
),
195
PAD_NC
(
GPP_H14
,
NONE
),
196
PAD_NC
(
GPP_H15
,
NONE
),
// GPP_H15 (reserved)
197
PAD_NC
(
GPP_H16
,
NONE
),
198
PAD_NC
(
GPP_H17
,
NONE
),
199
PAD_NC
(
GPP_H18
,
NONE
),
200
PAD_CFG_GPI
(
GPP_H19
, UP_20K, DEEP),
// GPIO_CARD1
201
PAD_CFG_GPI
(
GPP_H20
, UP_20K, DEEP),
// GPIO_CARD
202
PAD_CFG_GPI
(
GPP_H21
, DN_20K, DEEP),
// 4.7k pull up, 20k pull down
203
PAD_NC
(
GPP_H22
,
NONE
),
204
PAD_NC
(
GPP_H23
,
NONE
),
205
206
/* ------- GPIO Group GPP_I ------- */
207
PAD_CFG_GPI_SCI_LOW
(
GPP_I0
,
NONE
, DEEP, EDGE_BOTH),
// G_DP_DHPD_A
208
PAD_CFG_GPI_SCI_LOW
(
GPP_I1
,
NONE
, DEEP, EDGE_BOTH),
// HDMI_HPD
209
PAD_CFG_GPI_SCI_LOW
(
GPP_I2
,
NONE
, DEEP, EDGE_BOTH),
// G_DP_DHPD_E
210
PAD_NC
(
GPP_I3
,
NONE
),
211
PAD_CFG_NF
(
GPP_I4
,
NONE
, DEEP, NF1),
// EDP_HDP
212
PAD_NC
(
GPP_I5
,
NONE
),
213
PAD_NC
(
GPP_I6
,
NONE
),
214
PAD_NC
(
GPP_I7
,
NONE
),
215
PAD_NC
(
GPP_I8
,
NONE
),
216
PAD_NC
(
GPP_I9
,
NONE
),
217
PAD_NC
(
GPP_I10
,
NONE
),
218
PAD_CFG_GPI
(
GPP_I11
, UP_20K, DEEP),
// H_SKTOCC_N
219
PAD_CFG_GPO
(
GPP_I12
, 1, DEEP),
// SATA_PWR_EN
220
PAD_NC
(
GPP_I13
,
NONE
),
221
PAD_NC
(
GPP_I14
,
NONE
),
222
223
/* ------- GPIO Group GPP_J ------- */
224
PAD_CFG_NF
(
GPP_J0
,
NONE
, DEEP, NF1),
// CNVI_GNSS_PA_BLANKING
225
PAD_CFG_GPO
(
GPP_J1
, 1, DEEP),
// GPP_J1
226
PAD_NC
(
GPP_J2
,
NONE
),
227
PAD_NC
(
GPP_J3
,
NONE
),
228
PAD_CFG_NF
(
GPP_J4
,
NONE
, DEEP, NF1),
// M.2_CNV_VRI_DT_BT_UART0_RTS
229
PAD_CFG_NF
(
GPP_J5
, UP_20K, DEEP, NF1),
// M.2_CNV_BRI_RSP
230
PAD_CFG_NF
(
GPP_J6
,
NONE
, DEEP, NF1),
// M.2_CNV_RGI_DT_BT_UART0_TX
231
PAD_CFG_NF
(
GPP_J7
, UP_20K, DEEP, NF1),
// M.2_CNV_RGI_RSP
232
PAD_NC
(
GPP_J8
,
NONE
),
233
PAD_CFG_GPI
(
GPP_J9
, UP_20K, DEEP),
// CNVI_MFUART2_TXD
234
PAD_NC
(
GPP_J10
,
NONE
),
235
PAD_NC
(
GPP_J11
,
NONE
),
236
237
/* ------- GPIO Group GPP_K ------- */
238
PAD_NC
(
GPP_K0
,
NONE
),
239
PAD_NC
(
GPP_K1
,
NONE
),
240
PAD_NC
(
GPP_K2
,
NONE
),
241
PAD_NC
(
GPP_K3
,
NONE
),
242
PAD_NC
(
GPP_K4
,
NONE
),
243
PAD_NC
(
GPP_K5
,
NONE
),
244
PAD_NC
(
GPP_K6
,
NONE
),
245
PAD_NC
(
GPP_K7
,
NONE
),
246
PAD_CFG_GPO
(
GPP_K8
, 1, DEEP),
// SATA_M2_PWR_EN1
247
PAD_CFG_GPO
(
GPP_K9
, 1, DEEP),
// SATA_M2_PWR_EN2
248
PAD_NC
(
GPP_K10
,
NONE
),
249
PAD_NC
(
GPP_K11
,
NONE
),
250
PAD_NC
(
GPP_K12
,
NONE
),
251
PAD_NC
(
GPP_K13
,
NONE
),
252
PAD_CFG_GPO
(
GPP_K14
, 0, DEEP),
// GPP_K_14_GSXDIN (test point), 7411_TEST_R
253
PAD_NC
(
GPP_K15
,
NONE
),
254
PAD_NC
(
GPP_K16
,
NONE
),
255
PAD_NC
(
GPP_K17
,
NONE
),
256
PAD_NC
(
GPP_K18
,
NONE
),
257
PAD_NC
(
GPP_K19
,
NONE
),
258
PAD_NC
(
GPP_K20
,
NONE
),
259
PAD_NC
(
GPP_K21
,
NONE
),
260
PAD_NC
(
GPP_K22
,
NONE
),
261
PAD_NC
(
GPP_K23
,
NONE
),
262
};
263
264
void
mainboard_configure_gpios
(
void
)
265
{
266
gpio_configure_pads
(
gpio_table
,
ARRAY_SIZE
(
gpio_table
));
267
}
GPD11
#define GPD11
Definition:
gpio_soc_defs.h:392
GPP_A4
#define GPP_A4
Definition:
gpio_soc_defs.h:123
GPP_H22
#define GPP_H22
Definition:
gpio_soc_defs.h:238
GPP_C15
#define GPP_C15
Definition:
gpio_soc_defs.h:552
GPD3
#define GPD3
Definition:
gpio_soc_defs.h:384
GPP_H20
#define GPP_H20
Definition:
gpio_soc_defs.h:236
GPP_B6
#define GPP_B6
Definition:
gpio_soc_defs.h:59
GPP_H19
#define GPP_H19
Definition:
gpio_soc_defs.h:235
GPP_D1
#define GPP_D1
Definition:
gpio_soc_defs.h:253
GPD9
#define GPD9
Definition:
gpio_soc_defs.h:390
GPP_C2
#define GPP_C2
Definition:
gpio_soc_defs.h:539
GPP_D10
#define GPP_D10
Definition:
gpio_soc_defs.h:262
GPP_D8
#define GPP_D8
Definition:
gpio_soc_defs.h:260
GPP_D17
#define GPP_D17
Definition:
gpio_soc_defs.h:269
GPP_E3
#define GPP_E3
Definition:
gpio_soc_defs.h:631
GPP_A18
#define GPP_A18
Definition:
gpio_soc_defs.h:137
GPP_F21
#define GPP_F21
Definition:
gpio_soc_defs.h:594
GPP_C12
#define GPP_C12
Definition:
gpio_soc_defs.h:549
GPP_F12
#define GPP_F12
Definition:
gpio_soc_defs.h:585
GPP_F16
#define GPP_F16
Definition:
gpio_soc_defs.h:589
GPP_H15
#define GPP_H15
Definition:
gpio_soc_defs.h:231
GPP_H16
#define GPP_H16
Definition:
gpio_soc_defs.h:232
GPP_E0
#define GPP_E0
Definition:
gpio_soc_defs.h:628
GPP_F6
#define GPP_F6
Definition:
gpio_soc_defs.h:579
GPP_H18
#define GPP_H18
Definition:
gpio_soc_defs.h:234
GPP_D14
#define GPP_D14
Definition:
gpio_soc_defs.h:266
GPP_B1
#define GPP_B1
Definition:
gpio_soc_defs.h:54
GPP_F20
#define GPP_F20
Definition:
gpio_soc_defs.h:593
GPP_F23
#define GPP_F23
Definition:
gpio_soc_defs.h:596
GPP_C5
#define GPP_C5
Definition:
gpio_soc_defs.h:542
GPP_H11
#define GPP_H11
Definition:
gpio_soc_defs.h:227
GPP_A14
#define GPP_A14
Definition:
gpio_soc_defs.h:133
GPP_B12
#define GPP_B12
Definition:
gpio_soc_defs.h:65
GPP_H17
#define GPP_H17
Definition:
gpio_soc_defs.h:233
GPP_D12
#define GPP_D12
Definition:
gpio_soc_defs.h:264
GPP_B16
#define GPP_B16
Definition:
gpio_soc_defs.h:69
GPP_A5
#define GPP_A5
Definition:
gpio_soc_defs.h:124
GPP_B2
#define GPP_B2
Definition:
gpio_soc_defs.h:55
GPP_D7
#define GPP_D7
Definition:
gpio_soc_defs.h:259
GPP_B13
#define GPP_B13
Definition:
gpio_soc_defs.h:66
GPP_E6
#define GPP_E6
Definition:
gpio_soc_defs.h:634
GPP_F0
#define GPP_F0
Definition:
gpio_soc_defs.h:573
GPP_D6
#define GPP_D6
Definition:
gpio_soc_defs.h:258
GPP_A19
#define GPP_A19
Definition:
gpio_soc_defs.h:138
GPP_D2
#define GPP_D2
Definition:
gpio_soc_defs.h:254
GPP_H12
#define GPP_H12
Definition:
gpio_soc_defs.h:228
GPP_H6
#define GPP_H6
Definition:
gpio_soc_defs.h:222
GPP_C9
#define GPP_C9
Definition:
gpio_soc_defs.h:546
GPP_H2
#define GPP_H2
Definition:
gpio_soc_defs.h:218
GPP_C22
#define GPP_C22
Definition:
gpio_soc_defs.h:559
GPP_H9
#define GPP_H9
Definition:
gpio_soc_defs.h:225
GPD0
#define GPD0
Definition:
gpio_soc_defs.h:380
GPP_D9
#define GPP_D9
Definition:
gpio_soc_defs.h:261
GPP_F5
#define GPP_F5
Definition:
gpio_soc_defs.h:578
GPP_B15
#define GPP_B15
Definition:
gpio_soc_defs.h:68
GPP_A2
#define GPP_A2
Definition:
gpio_soc_defs.h:121
GPP_H21
#define GPP_H21
Definition:
gpio_soc_defs.h:237
GPP_C23
#define GPP_C23
Definition:
gpio_soc_defs.h:560
GPP_H13
#define GPP_H13
Definition:
gpio_soc_defs.h:229
GPP_C8
#define GPP_C8
Definition:
gpio_soc_defs.h:545
GPP_D11
#define GPP_D11
Definition:
gpio_soc_defs.h:263
GPP_H7
#define GPP_H7
Definition:
gpio_soc_defs.h:223
GPP_A6
#define GPP_A6
Definition:
gpio_soc_defs.h:125
GPP_H1
#define GPP_H1
Definition:
gpio_soc_defs.h:217
GPP_C11
#define GPP_C11
Definition:
gpio_soc_defs.h:548
GPP_H14
#define GPP_H14
Definition:
gpio_soc_defs.h:230
GPP_D5
#define GPP_D5
Definition:
gpio_soc_defs.h:257
GPP_B22
#define GPP_B22
Definition:
gpio_soc_defs.h:75
GPP_A23
#define GPP_A23
Definition:
gpio_soc_defs.h:142
GPP_C18
#define GPP_C18
Definition:
gpio_soc_defs.h:555
GPP_F9
#define GPP_F9
Definition:
gpio_soc_defs.h:582
GPP_C13
#define GPP_C13
Definition:
gpio_soc_defs.h:550
GPP_E9
#define GPP_E9
Definition:
gpio_soc_defs.h:637
GPP_C17
#define GPP_C17
Definition:
gpio_soc_defs.h:554
GPP_E8
#define GPP_E8
Definition:
gpio_soc_defs.h:636
GPP_A7
#define GPP_A7
Definition:
gpio_soc_defs.h:126
GPP_E5
#define GPP_E5
Definition:
gpio_soc_defs.h:633
GPP_A0
#define GPP_A0
Definition:
gpio_soc_defs.h:119
GPD7
#define GPD7
Definition:
gpio_soc_defs.h:388
GPP_B8
#define GPP_B8
Definition:
gpio_soc_defs.h:61
GPP_B20
#define GPP_B20
Definition:
gpio_soc_defs.h:73
GPP_A20
#define GPP_A20
Definition:
gpio_soc_defs.h:139
GPP_A16
#define GPP_A16
Definition:
gpio_soc_defs.h:135
GPP_F1
#define GPP_F1
Definition:
gpio_soc_defs.h:574
GPP_F17
#define GPP_F17
Definition:
gpio_soc_defs.h:590
GPP_A12
#define GPP_A12
Definition:
gpio_soc_defs.h:131
GPP_F15
#define GPP_F15
Definition:
gpio_soc_defs.h:588
GPP_D4
#define GPP_D4
Definition:
gpio_soc_defs.h:256
GPP_C10
#define GPP_C10
Definition:
gpio_soc_defs.h:547
GPP_C6
#define GPP_C6
Definition:
gpio_soc_defs.h:543
GPD2
#define GPD2
Definition:
gpio_soc_defs.h:383
GPP_F10
#define GPP_F10
Definition:
gpio_soc_defs.h:583
GPP_A3
#define GPP_A3
Definition:
gpio_soc_defs.h:122
GPP_E7
#define GPP_E7
Definition:
gpio_soc_defs.h:635
GPP_C16
#define GPP_C16
Definition:
gpio_soc_defs.h:553
GPP_F7
#define GPP_F7
Definition:
gpio_soc_defs.h:580
GPD1
#define GPD1
Definition:
gpio_soc_defs.h:382
GPP_F13
#define GPP_F13
Definition:
gpio_soc_defs.h:586
GPP_C4
#define GPP_C4
Definition:
gpio_soc_defs.h:541
GPP_D18
#define GPP_D18
Definition:
gpio_soc_defs.h:270
GPP_B19
#define GPP_B19
Definition:
gpio_soc_defs.h:72
GPP_E2
#define GPP_E2
Definition:
gpio_soc_defs.h:630
GPP_H0
#define GPP_H0
Definition:
gpio_soc_defs.h:215
GPP_H5
#define GPP_H5
Definition:
gpio_soc_defs.h:221
GPP_B9
#define GPP_B9
Definition:
gpio_soc_defs.h:62
GPD10
#define GPD10
Definition:
gpio_soc_defs.h:391
GPP_F14
#define GPP_F14
Definition:
gpio_soc_defs.h:587
GPP_H3
#define GPP_H3
Definition:
gpio_soc_defs.h:219
GPP_F4
#define GPP_F4
Definition:
gpio_soc_defs.h:577
GPP_A10
#define GPP_A10
Definition:
gpio_soc_defs.h:129
GPP_A8
#define GPP_A8
Definition:
gpio_soc_defs.h:127
GPP_D0
#define GPP_D0
Definition:
gpio_soc_defs.h:252
GPP_A1
#define GPP_A1
Definition:
gpio_soc_defs.h:120
GPP_B14
#define GPP_B14
Definition:
gpio_soc_defs.h:67
GPP_B11
#define GPP_B11
Definition:
gpio_soc_defs.h:64
GPP_D13
#define GPP_D13
Definition:
gpio_soc_defs.h:265
GPP_B18
#define GPP_B18
Definition:
gpio_soc_defs.h:71
GPP_B5
#define GPP_B5
Definition:
gpio_soc_defs.h:58
GPP_B0
#define GPP_B0
Definition:
gpio_soc_defs.h:53
GPP_A11
#define GPP_A11
Definition:
gpio_soc_defs.h:130
GPP_C14
#define GPP_C14
Definition:
gpio_soc_defs.h:551
GPP_A15
#define GPP_A15
Definition:
gpio_soc_defs.h:134
GPP_A9
#define GPP_A9
Definition:
gpio_soc_defs.h:128
GPP_E10
#define GPP_E10
Definition:
gpio_soc_defs.h:638
GPP_F8
#define GPP_F8
Definition:
gpio_soc_defs.h:581
GPP_C19
#define GPP_C19
Definition:
gpio_soc_defs.h:556
GPD8
#define GPD8
Definition:
gpio_soc_defs.h:389
GPP_A13
#define GPP_A13
Definition:
gpio_soc_defs.h:132
GPP_A21
#define GPP_A21
Definition:
gpio_soc_defs.h:140
GPP_B23
#define GPP_B23
Definition:
gpio_soc_defs.h:76
GPP_B10
#define GPP_B10
Definition:
gpio_soc_defs.h:63
GPP_D19
#define GPP_D19
Definition:
gpio_soc_defs.h:271
GPP_C1
#define GPP_C1
Definition:
gpio_soc_defs.h:538
GPP_F2
#define GPP_F2
Definition:
gpio_soc_defs.h:575
GPP_E11
#define GPP_E11
Definition:
gpio_soc_defs.h:639
GPD6
#define GPD6
Definition:
gpio_soc_defs.h:387
GPP_F18
#define GPP_F18
Definition:
gpio_soc_defs.h:591
GPP_B3
#define GPP_B3
Definition:
gpio_soc_defs.h:56
GPP_A22
#define GPP_A22
Definition:
gpio_soc_defs.h:141
GPP_F22
#define GPP_F22
Definition:
gpio_soc_defs.h:595
GPP_D15
#define GPP_D15
Definition:
gpio_soc_defs.h:267
GPP_F11
#define GPP_F11
Definition:
gpio_soc_defs.h:584
GPP_B21
#define GPP_B21
Definition:
gpio_soc_defs.h:74
GPD4
#define GPD4
Definition:
gpio_soc_defs.h:385
GPP_B4
#define GPP_B4
Definition:
gpio_soc_defs.h:57
GPP_D16
#define GPP_D16
Definition:
gpio_soc_defs.h:268
GPP_F3
#define GPP_F3
Definition:
gpio_soc_defs.h:576
GPP_H10
#define GPP_H10
Definition:
gpio_soc_defs.h:226
GPP_C3
#define GPP_C3
Definition:
gpio_soc_defs.h:540
GPP_E12
#define GPP_E12
Definition:
gpio_soc_defs.h:640
GPP_A17
#define GPP_A17
Definition:
gpio_soc_defs.h:136
GPP_B17
#define GPP_B17
Definition:
gpio_soc_defs.h:70
GPP_E4
#define GPP_E4
Definition:
gpio_soc_defs.h:632
GPP_C0
#define GPP_C0
Definition:
gpio_soc_defs.h:537
GPD5
#define GPD5
Definition:
gpio_soc_defs.h:386
GPP_E1
#define GPP_E1
Definition:
gpio_soc_defs.h:629
GPP_H8
#define GPP_H8
Definition:
gpio_soc_defs.h:224
GPP_F19
#define GPP_F19
Definition:
gpio_soc_defs.h:592
GPP_H4
#define GPP_H4
Definition:
gpio_soc_defs.h:220
GPP_H23
#define GPP_H23
Definition:
gpio_soc_defs.h:239
GPP_B7
#define GPP_B7
Definition:
gpio_soc_defs.h:60
GPP_C7
#define GPP_C7
Definition:
gpio_soc_defs.h:544
GPP_D3
#define GPP_D3
Definition:
gpio_soc_defs.h:255
ARRAY_SIZE
#define ARRAY_SIZE(a)
Definition:
helpers.h:12
GPP_D23
#define GPP_D23
Definition:
gpio_soc_defs.h:133
GPP_G1
#define GPP_G1
Definition:
gpio_soc_defs.h:89
GPP_G7
#define GPP_G7
Definition:
gpio_soc_defs.h:95
GPP_D22
#define GPP_D22
Definition:
gpio_soc_defs.h:132
GPP_G4
#define GPP_G4
Definition:
gpio_soc_defs.h:92
GPP_G2
#define GPP_G2
Definition:
gpio_soc_defs.h:90
GPP_D21
#define GPP_D21
Definition:
gpio_soc_defs.h:131
GPP_G6
#define GPP_G6
Definition:
gpio_soc_defs.h:94
GPP_G0
#define GPP_G0
Definition:
gpio_soc_defs.h:88
GPP_D20
#define GPP_D20
Definition:
gpio_soc_defs.h:130
GPP_G3
#define GPP_G3
Definition:
gpio_soc_defs.h:91
GPP_G5
#define GPP_G5
Definition:
gpio_soc_defs.h:93
GPP_K4
#define GPP_K4
Definition:
gpio_soc_defs_cnp_h.h:209
GPP_I12
#define GPP_I12
Definition:
gpio_soc_defs_cnp_h.h:347
GPP_I5
#define GPP_I5
Definition:
gpio_soc_defs_cnp_h.h:340
GPP_J7
#define GPP_J7
Definition:
gpio_soc_defs_cnp_h.h:362
GPP_J4
#define GPP_J4
Definition:
gpio_soc_defs_cnp_h.h:359
GPP_K2
#define GPP_K2
Definition:
gpio_soc_defs_cnp_h.h:207
GPP_K9
#define GPP_K9
Definition:
gpio_soc_defs_cnp_h.h:214
GPP_J5
#define GPP_J5
Definition:
gpio_soc_defs_cnp_h.h:360
GPP_K16
#define GPP_K16
Definition:
gpio_soc_defs_cnp_h.h:221
GPP_I10
#define GPP_I10
Definition:
gpio_soc_defs_cnp_h.h:345
GPP_K13
#define GPP_K13
Definition:
gpio_soc_defs_cnp_h.h:218
GPP_J8
#define GPP_J8
Definition:
gpio_soc_defs_cnp_h.h:363
GPP_J0
#define GPP_J0
Definition:
gpio_soc_defs_cnp_h.h:355
GPP_J2
#define GPP_J2
Definition:
gpio_soc_defs_cnp_h.h:357
GPP_J9
#define GPP_J9
Definition:
gpio_soc_defs_cnp_h.h:364
GPP_I8
#define GPP_I8
Definition:
gpio_soc_defs_cnp_h.h:343
GPP_J1
#define GPP_J1
Definition:
gpio_soc_defs_cnp_h.h:356
GPP_J6
#define GPP_J6
Definition:
gpio_soc_defs_cnp_h.h:361
GPP_K18
#define GPP_K18
Definition:
gpio_soc_defs_cnp_h.h:223
GPP_I7
#define GPP_I7
Definition:
gpio_soc_defs_cnp_h.h:342
GPP_I3
#define GPP_I3
Definition:
gpio_soc_defs_cnp_h.h:338
GPP_I6
#define GPP_I6
Definition:
gpio_soc_defs_cnp_h.h:341
GPP_J10
#define GPP_J10
Definition:
gpio_soc_defs_cnp_h.h:365
GPP_K7
#define GPP_K7
Definition:
gpio_soc_defs_cnp_h.h:212
GPP_I11
#define GPP_I11
Definition:
gpio_soc_defs_cnp_h.h:346
GPP_I9
#define GPP_I9
Definition:
gpio_soc_defs_cnp_h.h:344
GPP_K11
#define GPP_K11
Definition:
gpio_soc_defs_cnp_h.h:216
GPP_K17
#define GPP_K17
Definition:
gpio_soc_defs_cnp_h.h:222
GPP_K21
#define GPP_K21
Definition:
gpio_soc_defs_cnp_h.h:226
GPP_K20
#define GPP_K20
Definition:
gpio_soc_defs_cnp_h.h:225
GPP_K1
#define GPP_K1
Definition:
gpio_soc_defs_cnp_h.h:206
GPP_I13
#define GPP_I13
Definition:
gpio_soc_defs_cnp_h.h:348
GPP_I2
#define GPP_I2
Definition:
gpio_soc_defs_cnp_h.h:337
GPP_J11
#define GPP_J11
Definition:
gpio_soc_defs_cnp_h.h:366
GPP_J3
#define GPP_J3
Definition:
gpio_soc_defs_cnp_h.h:358
GPP_I0
#define GPP_I0
Definition:
gpio_soc_defs_cnp_h.h:335
GPP_K10
#define GPP_K10
Definition:
gpio_soc_defs_cnp_h.h:215
GPP_K5
#define GPP_K5
Definition:
gpio_soc_defs_cnp_h.h:210
GPP_K6
#define GPP_K6
Definition:
gpio_soc_defs_cnp_h.h:211
GPP_K0
#define GPP_K0
Definition:
gpio_soc_defs_cnp_h.h:205
GPP_K14
#define GPP_K14
Definition:
gpio_soc_defs_cnp_h.h:219
GPP_K12
#define GPP_K12
Definition:
gpio_soc_defs_cnp_h.h:217
GPP_I14
#define GPP_I14
Definition:
gpio_soc_defs_cnp_h.h:349
GPP_K22
#define GPP_K22
Definition:
gpio_soc_defs_cnp_h.h:227
GPP_I4
#define GPP_I4
Definition:
gpio_soc_defs_cnp_h.h:339
GPP_K3
#define GPP_K3
Definition:
gpio_soc_defs_cnp_h.h:208
GPP_I1
#define GPP_I1
Definition:
gpio_soc_defs_cnp_h.h:336
GPP_K19
#define GPP_K19
Definition:
gpio_soc_defs_cnp_h.h:224
GPP_K23
#define GPP_K23
Definition:
gpio_soc_defs_cnp_h.h:228
GPP_K15
#define GPP_K15
Definition:
gpio_soc_defs_cnp_h.h:220
GPP_K8
#define GPP_K8
Definition:
gpio_soc_defs_cnp_h.h:213
mainboard_configure_gpios
void mainboard_configure_gpios(void)
Definition:
gpio.c:223
gpio_table
const struct pad_config gpio_table[]
Definition:
gpio.c:33
NONE
@ NONE
Definition:
qup_se_handlers_common.h:196
gpio_configure_pads
void gpio_configure_pads(const struct soc_amd_gpio *gpio_list_ptr, size_t size)
program a particular set of GPIO
Definition:
gpio.c:307
PAD_NC
#define PAD_NC(pin)
Definition:
gpio_defs.h:263
PAD_CFG_GPI
#define PAD_CFG_GPI(pad, pull, rst)
Definition:
gpio_defs.h:284
PAD_CFG_GPI_SCI_LOW
#define PAD_CFG_GPI_SCI_LOW(pad, pull, rst, trig)
Definition:
gpio_defs.h:452
PAD_CFG_GPI_SMI
#define PAD_CFG_GPI_SMI(pad, pull, rst, trig, inv)
Definition:
gpio_defs.h:412
PAD_CFG_NF
#define PAD_CFG_NF(pad, pull, rst, func)
Definition:
gpio_defs.h:197
PAD_CFG_GPI_APIC_EDGE_LOW
#define PAD_CFG_GPI_APIC_EDGE_LOW(pad, pull, rst)
Definition:
gpio_defs.h:408
PAD_CFG_GPI_APIC_HIGH
#define PAD_CFG_GPI_APIC_HIGH(pad, pull, rst)
Definition:
gpio_defs.h:405
PAD_CFG_GPO
#define PAD_CFG_GPO(pad, val, rst)
Definition:
gpio_defs.h:247
pad_config
Definition:
gpio.h:75
src
mainboard
system76
oryp5
gpio.c
Generated by
1.9.1