mb/google/dedede: Add SD card support
1. Configure SD card GPIOs. 2. Set SD card power polarity and card detect configs. SD card CMD. DATA and CLK GPIOs are set for native pad termination as per recommendation in EDS vol1 section 10.4.10 BUG=b:150872580 TEST=Verify SD card enumeration and read/write transactions. Change-Id: I90c8ceb85ada23718ff7b6fd7013317c818dd532 Signed-off-by: Aamir Bohra <aamir.bohra@intel.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/39237 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Furquan Shaikh <furquan@google.com>
This commit is contained in:
parent
3fd5a1bbbb
commit
29c6169efd
2 changed files with 19 additions and 10 deletions
|
@ -114,6 +114,11 @@ chip soc/intel/jasperlake
|
||||||
# Enable EMMC HS400 mode
|
# Enable EMMC HS400 mode
|
||||||
register "ScsEmmcHs400Enabled" = "1"
|
register "ScsEmmcHs400Enabled" = "1"
|
||||||
|
|
||||||
|
# GPIO for SD card detect
|
||||||
|
register "sdcard_cd_gpio" = "VGPIO_39"
|
||||||
|
# SD card power enable polarity
|
||||||
|
register "SdCardPowerEnableActiveHigh" = "1"
|
||||||
|
|
||||||
# Display related UPDs
|
# Display related UPDs
|
||||||
# Select eDP for port A
|
# Select eDP for port A
|
||||||
register "DdiPortAConfig" = "1"
|
register "DdiPortAConfig" = "1"
|
||||||
|
@ -255,7 +260,7 @@ chip soc/intel/jasperlake
|
||||||
register "wake" = "GPE0_PME_B0"
|
register "wake" = "GPE0_PME_B0"
|
||||||
device pci 14.3 on end # CNVi wifi
|
device pci 14.3 on end # CNVi wifi
|
||||||
end
|
end
|
||||||
device pci 14.5 off end # SDCard
|
device pci 14.5 on end # SDCard
|
||||||
device pci 15.0 on end # I2C 0
|
device pci 15.0 on end # I2C 0
|
||||||
device pci 15.1 on end # I2C 1
|
device pci 15.1 on end # I2C 1
|
||||||
device pci 15.2 on end # I2C 2
|
device pci 15.2 on end # I2C 2
|
||||||
|
|
|
@ -267,26 +267,26 @@ static const struct pad_config gpio_table[] = {
|
||||||
PAD_CFG_NF(GPP_F18, NONE, DEEP, NF1),
|
PAD_CFG_NF(GPP_F18, NONE, DEEP, NF1),
|
||||||
|
|
||||||
/* G0 : SD_CMD */
|
/* G0 : SD_CMD */
|
||||||
PAD_NC(GPP_G0, NONE),
|
PAD_CFG_NF(GPP_G0, NATIVE, DEEP, NF1),
|
||||||
/* G1 : SD_DATA0 */
|
/* G1 : SD_DATA0 */
|
||||||
PAD_NC(GPP_G1, NONE),
|
PAD_CFG_NF(GPP_G1, NATIVE, DEEP, NF1),
|
||||||
/* G2 : SD_DATA1 */
|
/* G2 : SD_DATA1 */
|
||||||
PAD_NC(GPP_G2, NONE),
|
PAD_CFG_NF(GPP_G2, NATIVE, DEEP, NF1),
|
||||||
/* G3 : SD_DATA2 */
|
/* G3 : SD_DATA2 */
|
||||||
PAD_NC(GPP_G3, NONE),
|
PAD_CFG_NF(GPP_G3, NATIVE, DEEP, NF1),
|
||||||
/* G4 : SD_DATA3 */
|
/* G4 : SD_DATA3 */
|
||||||
PAD_NC(GPP_G4, NONE),
|
PAD_CFG_NF(GPP_G4, NATIVE, DEEP, NF1),
|
||||||
/* G5 : SD_CD_ODL */
|
/* G5 : SD_CD_ODL */
|
||||||
PAD_NC(GPP_G5, NONE),
|
PAD_CFG_NF(GPP_G5, NONE, PLTRST, NF1),
|
||||||
/* G6 : SD_CLK */
|
/* G6 : SD_CLK */
|
||||||
PAD_NC(GPP_G6, NONE),
|
PAD_CFG_NF(GPP_G6, NATIVE, DEEP, NF1),
|
||||||
/* G7 : SD_SDIO_WP */
|
/* G7 : SD_SDIO_WP */
|
||||||
PAD_NC(GPP_G7, NONE),
|
PAD_CFG_NF(GPP_G7, DN_20K, DEEP, NF1),
|
||||||
|
|
||||||
/* H0 : WWAN_PERST */
|
/* H0 : WWAN_PERST */
|
||||||
PAD_NC(GPP_H0, NONE),
|
PAD_NC(GPP_H0, NONE),
|
||||||
/* H1 : EN_PP3300_SD_U */
|
/* H1 : EN_PP3300_SD_U */
|
||||||
PAD_NC(GPP_H1, NONE),
|
PAD_CFG_NF(GPP_H1, NONE, DEEP, NF1),
|
||||||
/* H2 : CNV_CLKREQ0 */
|
/* H2 : CNV_CLKREQ0 */
|
||||||
PAD_CFG_NF(GPP_H2, NONE, DEEP, NF3),
|
PAD_CFG_NF(GPP_H2, NONE, DEEP, NF3),
|
||||||
/* H3 : GPP_H03/SX_EXIT_HOLDOFF_N */
|
/* H3 : GPP_H03/SX_EXIT_HOLDOFF_N */
|
||||||
|
@ -382,6 +382,10 @@ static const struct pad_config gpio_table[] = {
|
||||||
PAD_NC(GPD9, NONE),
|
PAD_NC(GPD9, NONE),
|
||||||
/* GPD10 : AP_SLP_S5_L */
|
/* GPD10 : AP_SLP_S5_L */
|
||||||
PAD_NC(GPD10, NONE),
|
PAD_NC(GPD10, NONE),
|
||||||
|
|
||||||
|
/* SD card detect virtual GPIO */
|
||||||
|
PAD_CFG_GPI_GPIO_DRIVER(VGPIO_39, NONE, PLTRST),
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Early pad configuration in bootblock */
|
/* Early pad configuration in bootblock */
|
||||||
|
|
Loading…
Reference in a new issue