aboutsummaryrefslogtreecommitdiff
path: root/src/soc/intel/apollolake/chip.c
diff options
context:
space:
mode:
authorHannah Williams <hannah.williams@intel.com>2017-05-05 16:30:22 -0700
committerAaron Durbin <adurbin@chromium.org>2017-07-21 03:59:09 +0000
commit3ff14a0c8590705ba4cc184f6e9d6e5f6302fb4c (patch)
treeb7e9a0d1a14365ff1cdccce168dc6c94d0e05e0d /src/soc/intel/apollolake/chip.c
parenta77c68adf3a566e3eaa676d5fa4080ed41199e4b (diff)
soc/intel/apollolake: Bring in delta for GLK SOC
Change-Id: I3e76726bb77f0277ab5776ae9d3d42b7eb389fe3 Signed-off-by: Hannah Williams <hannah.williams@intel.com> Reviewed-on: https://review.coreboot.org/19603 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Aaron Durbin <adurbin@chromium.org>
Diffstat (limited to 'src/soc/intel/apollolake/chip.c')
-rw-r--r--src/soc/intel/apollolake/chip.c85
1 files changed, 51 insertions, 34 deletions
diff --git a/src/soc/intel/apollolake/chip.c b/src/soc/intel/apollolake/chip.c
index cd7fa62b1f..f72173da8c 100644
--- a/src/soc/intel/apollolake/chip.c
+++ b/src/soc/intel/apollolake/chip.c
@@ -1,7 +1,7 @@
/*
* This file is part of the coreboot project.
*
- * Copyright (C) 2015 Intel Corp.
+ * Copyright (C) 2015 - 2017 Intel Corp.
* (Written by Alexandru Gagniuc <alexandrux.gagniuc@intel.com> for Intel Corp.)
* (Written by Andrey Petrov <andrey.petrov@intel.com> for Intel Corp.)
*
@@ -445,11 +445,56 @@ static void parse_devicetree(FSP_S_CONFIG *silconfig)
}
}
+static void apl_fsp_silicon_init_params_cb(struct soc_intel_apollolake_config
+ *cfg, FSP_S_CONFIG *silconfig)
+{
+#if !IS_ENABLED(CONFIG_SOC_INTEL_GLK) /* GLK FSP does not have these
+ fields in FspsUpd.h yet */
+ uint8_t port;
+
+ for (port = 0; port < APOLLOLAKE_USB2_PORT_MAX; port++) {
+ if (cfg->usb2eye[port].Usb20PerPortTxPeHalf != 0)
+ silconfig->PortUsb20PerPortTxPeHalf[port] =
+ cfg->usb2eye[port].Usb20PerPortTxPeHalf;
+
+ if (cfg->usb2eye[port].Usb20PerPortPeTxiSet != 0)
+ silconfig->PortUsb20PerPortPeTxiSet[port] =
+ cfg->usb2eye[port].Usb20PerPortPeTxiSet;
+
+ if (cfg->usb2eye[port].Usb20PerPortTxiSet != 0)
+ silconfig->PortUsb20PerPortTxiSet[port] =
+ cfg->usb2eye[port].Usb20PerPortTxiSet;
+
+ if (cfg->usb2eye[port].Usb20HsSkewSel != 0)
+ silconfig->PortUsb20HsSkewSel[port] =
+ cfg->usb2eye[port].Usb20HsSkewSel;
+
+ if (cfg->usb2eye[port].Usb20IUsbTxEmphasisEn != 0)
+ silconfig->PortUsb20IUsbTxEmphasisEn[port] =
+ cfg->usb2eye[port].Usb20IUsbTxEmphasisEn;
+
+ if (cfg->usb2eye[port].Usb20PerPortRXISet != 0)
+ silconfig->PortUsb20PerPortRXISet[port] =
+ cfg->usb2eye[port].Usb20PerPortRXISet;
+
+ if (cfg->usb2eye[port].Usb20HsNpreDrvSel != 0)
+ silconfig->PortUsb20HsNpreDrvSel[port] =
+ cfg->usb2eye[port].Usb20HsNpreDrvSel;
+ }
+#endif
+}
+
+static void glk_fsp_silicon_init_params_cb(
+ struct soc_intel_apollolake_config *cfg, FSP_S_CONFIG *silconfig)
+{
+ silconfig->Gmm = 0;
+ silconfig->HdaEnable = 0;
+}
+
void platform_fsp_silicon_init_params_cb(FSPS_UPD *silupd)
{
FSP_S_CONFIG *silconfig = &silupd->FspsConfig;
static struct soc_intel_apollolake_config *cfg;
- uint8_t port;
/* Load VBT before devicetree-specific config. */
silconfig->GraphicsConfigPtr = (uintptr_t)vbt;
@@ -506,38 +551,10 @@ void platform_fsp_silicon_init_params_cb(FSPS_UPD *silupd)
silconfig->HDAudioPwrGate = cfg->hdaudio_pwr_gate_enable;
/* Bios config lockdown Audio clk and power gate */
silconfig->BiosCfgLockDown = cfg->hdaudio_bios_config_lockdown;
-
- /* USB2 eye diagram settings per port */
- for (port = 0; port < APOLLOLAKE_USB2_PORT_MAX; port++) {
- if (cfg->usb2eye[port].Usb20PerPortTxPeHalf != 0)
- silconfig->PortUsb20PerPortTxPeHalf[port] =
- cfg->usb2eye[port].Usb20PerPortTxPeHalf;
-
- if (cfg->usb2eye[port].Usb20PerPortPeTxiSet != 0)
- silconfig->PortUsb20PerPortPeTxiSet[port] =
- cfg->usb2eye[port].Usb20PerPortPeTxiSet;
-
- if (cfg->usb2eye[port].Usb20PerPortTxiSet != 0)
- silconfig->PortUsb20PerPortTxiSet[port] =
- cfg->usb2eye[port].Usb20PerPortTxiSet;
-
- if (cfg->usb2eye[port].Usb20HsSkewSel != 0)
- silconfig->PortUsb20HsSkewSel[port] =
- cfg->usb2eye[port].Usb20HsSkewSel;
-
- if (cfg->usb2eye[port].Usb20IUsbTxEmphasisEn != 0)
- silconfig->PortUsb20IUsbTxEmphasisEn[port] =
- cfg->usb2eye[port].Usb20IUsbTxEmphasisEn;
-
- if (cfg->usb2eye[port].Usb20PerPortRXISet != 0)
- silconfig->PortUsb20PerPortRXISet[port] =
- cfg->usb2eye[port].Usb20PerPortRXISet;
-
- if (cfg->usb2eye[port].Usb20HsNpreDrvSel != 0)
- silconfig->PortUsb20HsNpreDrvSel[port] =
- cfg->usb2eye[port].Usb20HsNpreDrvSel;
- }
-
+ if (IS_ENABLED(CONFIG_SOC_INTEL_GLK))
+ glk_fsp_silicon_init_params_cb(cfg, silconfig);
+ else
+ apl_fsp_silicon_init_params_cb(cfg, silconfig);
}
struct chip_operations soc_intel_apollolake_ops = {