/* * This file is part of the coreboot project. * * Copyright (C) 2013 Google Inc. * Copyright (C) 2014 Sage Electronic Engineering, LLC. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; version 2 of the License. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. */ #include <stdlib.h> #include <soc/gpio.h> #include "irqroute.h" /* * For multiplexed functions, look in EDS: * 10.3 Ball Name and Function by Location * * The pads list is in the BWG_VOL2 Rev1p2: * Note that Pad # is not the same as GPIO# * 37 GPIO Handling: * Table 37-1. SCORE Pads List * Table 37-2. SSUSORE Pads List */ /* NCORE GPIOs */ static const struct soc_gpio_map gpncore_gpio_map[] = { GPIO_FUNC2, // GPIO_S0_NC[00] - HDMI_HPD GPIO_FUNC2, // GPIO_S0_NC[01] - HDMI_DDCDAT GPIO_FUNC2, // GPIO_S0_NC[02] - HDMI_DDCCLK GPIO_NC, // GPIO_S0_NC[03] - No Connect GPIO_NC, // GPIO_S0_NC[04] - No Connect GPIO_NC, // GPIO_S0_NC[05] - No Connect GPIO_NC, // GPIO_S0_NC[06] - No Connect GPIO_FUNC2, // GPIO_S0_NC[07] - DDI1_DDCDAT GPIO_NC, // GPIO_S0_NC[08] - No Connect GPIO_NC, // GPIO_S0_NC[09] - No Connect GPIO_NC, // GPIO_S0_NC[10] - No Connect GPIO_NC, // GPIO_S0_NC[11] - No Connect GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S0_NC[12] - TP15 GPIO_NC, // GPIO_S0_NC[13] - No Connect GPIO_NC, // GPIO_S0_NC[14] - No Connect GPIO_NC, // GPIO_S0_NC[15] - No Connect GPIO_NC, // GPIO_S0_NC[16] - No Connect GPIO_NC, // GPIO_S0_NC[17] - No Connect GPIO_NC, // GPIO_S0_NC[18] - No Connect GPIO_NC, // GPIO_S0_NC[19] - No Connect GPIO_NC, // GPIO_S0_NC[20] - No Connect GPIO_NC, // GPIO_S0_NC[21] - No Connect GPIO_NC, // GPIO_S0_NC[22] - No Connect GPIO_NC, // GPIO_S0_NC[23] - No Connect GPIO_NC, // GPIO_S0_NC[24] - No Connect GPIO_NC, // GPIO_S0_NC[25] - No Connect GPIO_NC, // GPIO_S0_NC[26] - No Connect GPIO_END }; /* SCORE GPIOs (GPIO_S0_SC_XX) */ static const struct soc_gpio_map gpscore_gpio_map[] = { GPIO_FUNC1, // GPIO_S0_SC[000] - SATA_GP0 GPIO_FUNC1, // GPIO_S0_SC[001] - SATA_GP1 GPIO_FUNC1, // GPIO_S0_SC[002] - SATA_LED_B GPIO_FUNC1, // GPIO_S0_SC[003] - PCIE_CLKREQ_0 GPIO_FUNC1, // GPIO_S0_SC[004] - PCIE_CLKREQ_1 GPIO_FUNC1, // GPIO_S0_SC[005] - PCIE_CLKREQ_2 GPIO_FUNC1, // GPIO_S0_SC[006] - PCIE_CLKREQ_3 GPIO_FUNC2, // GPIO_S0_SC[007] - SD3_WP GPIO_NC, // GPIO_S0_SC[008] - No Connect GPIO_NC, // GPIO_S0_SC[009] - No Connect GPIO_NC, // GPIO_S0_SC[010] - No Connect GPIO_NC, // GPIO_S0_SC[011] - No Connect GPIO_NC, // GPIO_S0_SC[012] - No Connect GPIO_NC, // GPIO_S0_SC[013] - No Connect GPIO_NC, // GPIO_S0_SC[014] - No Connect GPIO_NC, // GPIO_S0_SC[015] - No Connect GPIO_NC, // GPIO_S0_SC[016] - No Connect GPIO_NC, // GPIO_S0_SC[017] - No Connect GPIO_NC, // GPIO_S0_SC[018] - No Connect GPIO_NC, // GPIO_S0_SC[019] - No Connect GPIO_NC, // GPIO_S0_SC[020] - No Connect GPIO_NC, // GPIO_S0_SC[021] - No Connect GPIO_NC, // GPIO_S0_SC[022] - No Connect GPIO_NC, // GPIO_S0_SC[023] - No Connect GPIO_NC, // GPIO_S0_SC[024] - No Connect GPIO_NC, // GPIO_S0_SC[025] - No Connect GPIO_NC, // GPIO_S0_SC[026] - No Connect GPIO_NC, // GPIO_S0_SC[027] - No Connect GPIO_NC, // GPIO_S0_SC[028] - No Connect GPIO_NC, // GPIO_S0_SC[029] - No Connect GPIO_NC, // GPIO_S0_SC[030] - No Connect GPIO_NC, // GPIO_S0_SC[031] - No Connect GPIO_NC, // GPIO_S0_SC[032] - No Connect GPIO_FUNC1, // GPIO_S0_SC[033] - SD3_CLK GPIO_FUNC1, // GPIO_S0_SC[034] - SD3_D0 GPIO_FUNC1, // GPIO_S0_SC[035] - SD3_D1 GPIO_FUNC1, // GPIO_S0_SC[036] - SD3_D2 GPIO_FUNC1, // GPIO_S0_SC[037] - SD3_D3 GPIO_FUNC1, // GPIO_S0_SC[038] - SD3_CD# GPIO_FUNC1, // GPIO_S0_SC[039] - SD3_CMD GPIO_FUNC1, // GPIO_S0_SC[040] - TP12 (SD3_1P8EN) GPIO_FUNC1, // GPIO_S0_SC[041] - TP11 (/SD3_PWREN) GPIO_NC, // GPIO_S0_SC[042] - No Connect GPIO_NC, // GPIO_S0_SC[043] - No Connect GPIO_NC, // GPIO_S0_SC[044] - No Connect GPIO_NC, // GPIO_S0_SC[045] - No Connect GPIO_NC, // GPIO_S0_SC[046] - No Connect GPIO_NC, // GPIO_S0_SC[047] - No Connect GPIO_NC, // GPIO_S0_SC[048] - No Connect GPIO_NC, // GPIO_S0_SC[049] - No Connect GPIO_NC, // GPIO_S0_SC[050] - No Connect GPIO_FUNC1, // GPIO_S0_SC[051] - PCU_SMB_DATA GPIO_FUNC1, // GPIO_S0_SC[052] - PCU_SMB_CLK GPIO_FUNC1, // GPIO_S0_SC[053] - PCU_SMB_ALERT GPIO_FUNC1, // GPIO_S0_SC[054] - ILB_8254_SPKR GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S0_SC[055] - TP8 (GPIO_S0_SC_55) GPIO_FUNC0, // GPIO_S0_SC[056] - GPIO_S0_SC_56 GPIO_FUNC1, // GPIO_S0_SC[057] - PCU_UART3_TXD GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S0_SC[058] - TP9 (GPIO_S0_SC_58) GPIO_FUNC0, // GPIO_S0_SC[059] - HDMI_DCDC_ENB GPIO_FUNC0, // GPIO_S0_SC[060] - HDMI_LDSW_ENB GPIO_FUNC1, // GPIO_S0_SC[061] - PCU_UART3_RXD GPIO_FUNC1, // GPIO_S0_SC[062] - LPE_I2S_CLK GPIO_FUNC1, // GPIO_S0_SC[063] - LPE_I2S_FRM GPIO_FUNC1, // GPIO_S0_SC[064] - LPE_I2S_DATIN GPIO_FUNC1, // GPIO_S0_SC[065] - LPE_I2S_DATOUT GPIO_FUNC1, // GPIO_S0_SC[066] - SOC_SIO_SPI_CS1 GPIO_FUNC1, // GPIO_S0_SC[067] - SOC_SIO_SPI_MISO GPIO_FUNC1, // GPIO_S0_SC[068] - SOC_SIO_SPI_MOSI GPIO_FUNC1, // GPIO_S0_SC[069] - SOC_SIO_SPI_CLK GPIO_FUNC1, // GPIO_S0_SC[070] - SIO_UART1_RXD GPIO_FUNC1, // GPIO_S0_SC[071] - SIO_UART1_TXD GPIO_FUNC1, // GPIO_S0_SC[072] - SIO_UART1_RTSB GPIO_FUNC1, // GPIO_S0_SC[073] - SIO_UART1_CTSB GPIO_FUNC1, // GPIO_S0_SC[074] - SIO_UART2_RXD GPIO_FUNC1, // GPIO_S0_SC[075] - SIO_UART2_TXD GPIO_NC, // GPIO_S0_SC[076] - No Connect GPIO_NC, // GPIO_S0_SC[077] - No Connect GPIO_NC, // GPIO_S0_SC[078] - No Connect GPIO_NC, // GPIO_S0_SC[079] - No Connect GPIO_FUNC1, // GPIO_S0_SC[080] - TP6 (SIO_I2C1_SDA) GPIO_FUNC1, // GPIO_S0_SC[081] - TP5 (SIO_I2C1_SCL) GPIO_NC, // GPIO_S0_SC[082] - No Connect GPIO_NC, // GPIO_S0_SC[083] - No Connect GPIO_NC, // GPIO_S0_SC[084] - No Connect GPIO_NC, // GPIO_S0_SC[085] - No Connect GPIO_NC, // GPIO_S0_SC[086] - No Connect GPIO_NC, // GPIO_S0_SC[087] - No Connect GPIO_FUNC1, // GPIO_S0_SC[088] - LSS_I2C_SDA GPIO_FUNC1, // GPIO_S0_SC[089] - LSS_I2C_SCL GPIO_FUNC1, // GPIO_S0_SC[090] - EXP_I2C_SDA GPIO_FUNC1, // GPIO_S0_SC[091] - EXP_I2C_SCL GPIO_FUNC(1, PULL_UP, 20K), // GPIO_S0_SC[092] - TP13 GPIO_FUNC(1, PULL_UP, 20K), // GPIO_S0_SC[093] - TP16 GPIO_FUNC1, // GPIO_S0_SC[094] - SOC_PWM0 GPIO_FUNC1, // GPIO_S0_SC[095] - SOC_PWM1 GPIO_NC, // GPIO_S0_SC[096] - No Connect GPIO_NC, // GPIO_S0_SC[097] - No Connect GPIO_NC, // GPIO_S0_SC[098] - No Connect GPIO_NC, // GPIO_S0_SC[099] - No Connect GPIO_NC, // GPIO_S0_SC[100] - No Connect GPIO_NC, // GPIO_S0_SC[101] - No Connect GPIO_END }; /* SSUS GPIOs (GPIO_S5) */ static const struct soc_gpio_map gpssus_gpio_map[] = { GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S5[00] - SOC_GPIO_S5_0 GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S5[01] - SOC_GPIO_S5_1 GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S5[02] - SOC_GPIO_S5_2 GPIO_FUNC6, // GPIO_S5[03] - mPCIE_WAKEB GPIO_NC, // GPIO_S5[04] - No Connect GPIO_INPUT, // GPIO_S5[05] - BOM_OP1 // Memory: 0=1GB 1=2GB or 4GB GPIO_INPUT, // GPIO_S5[06] - BOM_OP2 GPIO_INPUT, // GPIO_S5[07] - BOM_OP3 GPIO_OUT_HIGH_LEGACY, // GPIO_S5[08] - SOC_USB_HOST_EN0 GPIO_OUT_HIGH_LEGACY, // GPIO_S5[09] - SOC_USB_HOST_EN1 GPIO_OUT_HIGH_LEGACY, // GPIO_S5[10] - GPIO_S5_10_UNLOCK GPIO_FUNC0, // GPIO_S5[11] - SUSPWRDNACK (TP14) GPIO_FUNC0, // GPIO_S5[12] - PMC_SUSCLK0 GPIO_FUNC1, // GPIO_S5[13] - PMC_SLP_S0IX (TP10) GPIO_FUNC1, // GPIO_S5[14] - GPIO_S514_J20 GPIO_FUNC0, // GPIO_S5[15] - PMC_PCIE_WAKE_R GPIO_FUNC0, // GPIO_S5[16] - PMC_PWRBTN GPIO_NC, // GPIO_S5[17] - No Connect GPIO_FUNC1, // GPIO_S5[18] - LPCPD_L (TP7) GPIO_FUNC0, // GPIO_S5[19] - SOC_USB_HOST_OC0 GPIO_FUNC0, // GPIO_S5[20] - SOC_USB_HOST_OC1 GPIO_FUNC0, // GPIO_S5[21] - SOC_SPI_CS1B GPIO_INPUT_PD, // GPIO_S5[22] - NC or LED D2 GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S5[23] - XDP_H_OBSDATA_A0 GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S5[24] - XDP_H_OBSDATA_A1 GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S5[25] - XDP_H_OBSDATA_A2 GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S5[26] - XDP_H_OBSDATA_A3 GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S5[27] - EXP_GPIO1 GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S5[28] - EXP_GPIO2 GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S5[29] - EXP_GPIO3 GPIO_FUNC(0, PULL_UP, 20K), // GPIO_S5[30] - EXP_GPIO4 GPIO_NC, // GPIO_S5[31] - No Connect GPIO_NC, // GPIO_S5[32] - No Connect GPIO_NC, // GPIO_S5[33] - No Connect GPIO_NC, // GPIO_S5[34] - No Connect GPIO_NC, // GPIO_S5[35] - No Connect GPIO_NC, // GPIO_S5[36] - No Connect GPIO_NC, // GPIO_S5[37] - No Connect GPIO_NC, // GPIO_S5[38] - No Connect GPIO_NC, // GPIO_S5[39] - No Connect GPIO_NC, // GPIO_S5[40] - No Connect GPIO_NC, // GPIO_S5[41] - No Connect GPIO_NC, // GPIO_S5[42] - No Connect GPIO_NC, // GPIO_S5[43] - No Connect GPIO_END }; static struct soc_gpio_config gpio_config = { .ncore = gpncore_gpio_map, .score = gpscore_gpio_map, .ssus = gpssus_gpio_map, .core_dirq = NULL, .sus_dirq = NULL, }; struct soc_gpio_config *mainboard_get_gpios(void) { return &gpio_config; }