/* * This file is part of the coreboot project. * * Copyright (C) 2013 Google Inc. * Copyright (C) 2015 Intel Corp. * * 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 <chip.h> #include <console/console.h> #include <device/device.h> #include <device/pci.h> #include <fsp/util.h> #include <soc/pci_devs.h> #include <soc/ramstage.h> static void pci_domain_set_resources(struct device *dev) { printk(BIOS_SPEW, "%s/%s (%s)\n", __FILE__, __func__, dev_name(dev)); assign_resources(dev->link_list); } static struct device_operations pci_domain_ops = { .read_resources = pci_domain_read_resources, .set_resources = pci_domain_set_resources, .enable_resources = NULL, .init = NULL, .scan_bus = pci_domain_scan_bus, }; static void cpu_bus_noop(struct device *dev) { } static struct device_operations cpu_bus_ops = { .read_resources = cpu_bus_noop, .set_resources = cpu_bus_noop, .enable_resources = cpu_bus_noop, .init = soc_init_cpus }; static void enable_dev(struct device *dev) { printk(BIOS_SPEW, "----------\n%s/%s (%s), type: %d\n", __FILE__, __func__, dev_name(dev), dev->path.type); printk(BIOS_SPEW, "vendor: 0x%04x. device: 0x%04x\n", pci_read_config16(dev, PCI_VENDOR_ID), pci_read_config16(dev, PCI_DEVICE_ID)); printk(BIOS_SPEW, "class: 0x%02x %s\n" "subclass: 0x%02x %s\n" "prog: 0x%02x\n" "revision: 0x%02x\n", pci_read_config16(dev, PCI_CLASS_DEVICE) >> 8, get_pci_class_name(dev), pci_read_config16(dev, PCI_CLASS_DEVICE) & 0xff, get_pci_subclass_name(dev), pci_read_config8(dev, PCI_CLASS_PROG), pci_read_config8(dev, PCI_REVISION_ID)); /* Set the operations if it is a special bus type */ if (dev->path.type == DEVICE_PATH_DOMAIN) { dev->ops = &pci_domain_ops; } else if (dev->path.type == DEVICE_PATH_CPU_CLUSTER) { dev->ops = &cpu_bus_ops; } else if (dev->path.type == DEVICE_PATH_PCI) { /* Handle south cluster enablement. */ if (PCI_SLOT(dev->path.pci.devfn) > GFX_DEV && (dev->ops == NULL || dev->ops->enable == NULL)) { southcluster_enable_dev(dev); } } } __weak void board_silicon_USB2_override(SILICON_INIT_UPD *params) { } void soc_silicon_init_params(SILICON_INIT_UPD *params) { struct device *dev = dev_find_slot(0, PCI_DEVFN(LPC_DEV, LPC_FUNC)); struct soc_intel_braswell_config *config; if (!dev) { printk(BIOS_ERR, "Error! Device (%s) not found, " "soc_silicon_init_params!\n", dev_path(dev)); return; } config = dev->chip_info; /* Set the parameters for SiliconInit */ printk(BIOS_DEBUG, "Updating UPD values for SiliconInit\n"); params->PcdSdcardMode = config->PcdSdcardMode; params->PcdEnableHsuart0 = config->PcdEnableHsuart0; params->PcdEnableHsuart1 = config->PcdEnableHsuart1; params->PcdEnableAzalia = config->PcdEnableAzalia; params->PcdEnableSata = config->PcdEnableSata; params->PcdEnableXhci = config->PcdEnableXhci; params->PcdEnableLpe = config->PcdEnableLpe; params->PcdEnableDma0 = config->PcdEnableDma0; params->PcdEnableDma1 = config->PcdEnableDma1; params->PcdEnableI2C0 = config->PcdEnableI2C0; params->PcdEnableI2C1 = config->PcdEnableI2C1; params->PcdEnableI2C2 = config->PcdEnableI2C2; params->PcdEnableI2C3 = config->PcdEnableI2C3; params->PcdEnableI2C4 = config->PcdEnableI2C4; params->PcdEnableI2C5 = config->PcdEnableI2C5; params->PcdEnableI2C6 = config->PcdEnableI2C6; params->GraphicsConfigPtr = 0; params->AzaliaConfigPtr = 0; params->PunitPwrConfigDisable = config->PunitPwrConfigDisable; params->ChvSvidConfig = config->ChvSvidConfig; params->DptfDisable = config->DptfDisable; params->PcdEmmcMode = config->PcdEmmcMode; params->PcdUsb3ClkSsc = config->PcdUsb3ClkSsc; params->PcdDispClkSsc = config->PcdDispClkSsc; params->PcdSataClkSsc = config->PcdSataClkSsc; params->Usb2Port0PerPortPeTxiSet = config->Usb2Port0PerPortPeTxiSet; params->Usb2Port0PerPortTxiSet = config->Usb2Port0PerPortTxiSet; params->Usb2Port0IUsbTxEmphasisEn = config->Usb2Port0IUsbTxEmphasisEn; params->Usb2Port0PerPortTxPeHalf = config->Usb2Port0PerPortTxPeHalf; if (config->D0Usb2Port0PerPortRXISet != 0) params->D0Usb2Port0PerPortRXISet = config->D0Usb2Port0PerPortRXISet; params->Usb2Port1PerPortPeTxiSet = config->Usb2Port1PerPortPeTxiSet; params->Usb2Port1PerPortTxiSet = config->Usb2Port1PerPortTxiSet; params->Usb2Port1IUsbTxEmphasisEn = config->Usb2Port1IUsbTxEmphasisEn; params->Usb2Port1PerPortTxPeHalf = config->Usb2Port1PerPortTxPeHalf; if (config->D0Usb2Port1PerPortRXISet != 0) params->D0Usb2Port1PerPortRXISet = config->D0Usb2Port1PerPortRXISet; params->Usb2Port2PerPortPeTxiSet = config->Usb2Port2PerPortPeTxiSet; params->Usb2Port2PerPortTxiSet = config->Usb2Port2PerPortTxiSet; params->Usb2Port2IUsbTxEmphasisEn = config->Usb2Port2IUsbTxEmphasisEn; params->Usb2Port2PerPortTxPeHalf = config->Usb2Port2PerPortTxPeHalf; if (config->D0Usb2Port2PerPortRXISet != 0) params->D0Usb2Port2PerPortRXISet = config->D0Usb2Port2PerPortRXISet; params->Usb2Port3PerPortPeTxiSet = config->Usb2Port3PerPortPeTxiSet; params->Usb2Port3PerPortTxiSet = config->Usb2Port3PerPortTxiSet; params->Usb2Port3IUsbTxEmphasisEn = config->Usb2Port3IUsbTxEmphasisEn; params->Usb2Port3PerPortTxPeHalf = config->Usb2Port3PerPortTxPeHalf; if (config->D0Usb2Port3PerPortRXISet != 0) params->D0Usb2Port3PerPortRXISet = config->D0Usb2Port3PerPortRXISet; params->Usb2Port4PerPortPeTxiSet = config->Usb2Port4PerPortPeTxiSet; params->Usb2Port4PerPortTxiSet = config->Usb2Port4PerPortTxiSet; params->Usb2Port4IUsbTxEmphasisEn = config->Usb2Port4IUsbTxEmphasisEn; params->Usb2Port4PerPortTxPeHalf = config->Usb2Port4PerPortTxPeHalf; if (config->D0Usb2Port4PerPortRXISet != 0) params->D0Usb2Port4PerPortRXISet = config->D0Usb2Port4PerPortRXISet; params->Usb3Lane0Ow2tapgen2deemph3p5 = config->Usb3Lane0Ow2tapgen2deemph3p5; params->Usb3Lane1Ow2tapgen2deemph3p5 = config->Usb3Lane1Ow2tapgen2deemph3p5; params->Usb3Lane2Ow2tapgen2deemph3p5 = config->Usb3Lane2Ow2tapgen2deemph3p5; params->Usb3Lane3Ow2tapgen2deemph3p5 = config->Usb3Lane3Ow2tapgen2deemph3p5; params->PcdSataInterfaceSpeed = config->PcdSataInterfaceSpeed; params->PcdPchUsbSsicPort = config->PcdPchUsbSsicPort; params->PcdPchUsbHsicPort = config->PcdPchUsbHsicPort; params->PcdPcieRootPortSpeed = config->PcdPcieRootPortSpeed; params->PcdPchSsicEnable = config->PcdPchSsicEnable; params->PcdLogoPtr = config->PcdLogoPtr; params->PcdLogoSize = config->PcdLogoSize; params->PcdRtcLock = config->PcdRtcLock; params->PMIC_I2CBus = config->PMIC_I2CBus; params->ISPEnable = config->ISPEnable; params->ISPPciDevConfig = config->ISPPciDevConfig; params->PcdSdDetectChk = config->PcdSdDetectChk; params->I2C0Frequency = config->I2C0Frequency; params->I2C1Frequency = config->I2C1Frequency; params->I2C2Frequency = config->I2C2Frequency; params->I2C3Frequency = config->I2C3Frequency; params->I2C4Frequency = config->I2C4Frequency; params->I2C5Frequency = config->I2C5Frequency; params->I2C6Frequency = config->I2C6Frequency; board_silicon_USB2_override(params); } void soc_display_silicon_init_params(const SILICON_INIT_UPD *old, SILICON_INIT_UPD *new) { /* Display the parameters for SiliconInit */ printk(BIOS_SPEW, "UPD values for SiliconInit:\n"); fsp_display_upd_value("PcdSdcardMode", 1, old->PcdSdcardMode, new->PcdSdcardMode); fsp_display_upd_value("PcdEnableHsuart0", 1, old->PcdEnableHsuart0, new->PcdEnableHsuart0); fsp_display_upd_value("PcdEnableHsuart1", 1, old->PcdEnableHsuart1, new->PcdEnableHsuart1); fsp_display_upd_value("PcdEnableAzalia", 1, old->PcdEnableAzalia, new->PcdEnableAzalia); fsp_display_upd_value("AzaliaConfigPtr", 4, (uint32_t)old->AzaliaConfigPtr, (uint32_t)new->AzaliaConfigPtr); fsp_display_upd_value("PcdEnableSata", 1, old->PcdEnableSata, new->PcdEnableSata); fsp_display_upd_value("PcdEnableXhci", 1, old->PcdEnableXhci, new->PcdEnableXhci); fsp_display_upd_value("PcdEnableLpe", 1, old->PcdEnableLpe, new->PcdEnableLpe); fsp_display_upd_value("PcdEnableDma0", 1, old->PcdEnableDma0, new->PcdEnableDma0); fsp_display_upd_value("PcdEnableDma1", 1, old->PcdEnableDma1, new->PcdEnableDma1); fsp_display_upd_value("PcdEnableI2C0", 1, old->PcdEnableI2C0, new->PcdEnableI2C0); fsp_display_upd_value("PcdEnableI2C1", 1, old->PcdEnableI2C1, new->PcdEnableI2C1); fsp_display_upd_value("PcdEnableI2C2", 1, old->PcdEnableI2C2, new->PcdEnableI2C2); fsp_display_upd_value("PcdEnableI2C3", 1, old->PcdEnableI2C3, new->PcdEnableI2C3); fsp_display_upd_value("PcdEnableI2C4", 1, old->PcdEnableI2C4, new->PcdEnableI2C4); fsp_display_upd_value("PcdEnableI2C5", 1, old->PcdEnableI2C5, new->PcdEnableI2C5); fsp_display_upd_value("PcdEnableI2C6", 1, old->PcdEnableI2C6, new->PcdEnableI2C6); fsp_display_upd_value("PcdGraphicsConfigPtr", 4, old->GraphicsConfigPtr, new->GraphicsConfigPtr); fsp_display_upd_value("GpioFamilyInitTablePtr", 4, (uint32_t)old->GpioFamilyInitTablePtr, (uint32_t)new->GpioFamilyInitTablePtr); fsp_display_upd_value("GpioPadInitTablePtr", 4, (uint32_t)old->GpioPadInitTablePtr, (uint32_t)new->GpioPadInitTablePtr); fsp_display_upd_value("PunitPwrConfigDisable", 1, old->PunitPwrConfigDisable, new->PunitPwrConfigDisable); fsp_display_upd_value("ChvSvidConfig", 1, old->ChvSvidConfig, new->ChvSvidConfig); fsp_display_upd_value("DptfDisable", 1, old->DptfDisable, new->DptfDisable); fsp_display_upd_value("PcdEmmcMode", 1, old->PcdEmmcMode, new->PcdEmmcMode); fsp_display_upd_value("PcdUsb3ClkSsc", 1, old->PcdUsb3ClkSsc, new->PcdUsb3ClkSsc); fsp_display_upd_value("PcdDispClkSsc", 1, old->PcdDispClkSsc, new->PcdDispClkSsc); fsp_display_upd_value("PcdSataClkSsc", 1, old->PcdSataClkSsc, new->PcdSataClkSsc); fsp_display_upd_value("Usb2Port0PerPortPeTxiSet", 1, old->Usb2Port0PerPortPeTxiSet, new->Usb2Port0PerPortPeTxiSet); fsp_display_upd_value("Usb2Port0PerPortTxiSet", 1, old->Usb2Port0PerPortTxiSet, new->Usb2Port0PerPortTxiSet); fsp_display_upd_value("Usb2Port0IUsbTxEmphasisEn", 1, old->Usb2Port0IUsbTxEmphasisEn, new->Usb2Port0IUsbTxEmphasisEn); fsp_display_upd_value("Usb2Port0PerPortTxPeHalf", 1, old->Usb2Port0PerPortTxPeHalf, new->Usb2Port0PerPortTxPeHalf); fsp_display_upd_value("D0Usb2Port0PerPortRXISet", 1, old->D0Usb2Port0PerPortRXISet, new->D0Usb2Port0PerPortRXISet); fsp_display_upd_value("Usb2Port1PerPortPeTxiSet", 1, old->Usb2Port1PerPortPeTxiSet, new->Usb2Port1PerPortPeTxiSet); fsp_display_upd_value("Usb2Port1PerPortTxiSet", 1, old->Usb2Port1PerPortTxiSet, new->Usb2Port1PerPortTxiSet); fsp_display_upd_value("Usb2Port1IUsbTxEmphasisEn", 1, old->Usb2Port1IUsbTxEmphasisEn, new->Usb2Port1IUsbTxEmphasisEn); fsp_display_upd_value("Usb2Port1PerPortTxPeHalf", 1, old->Usb2Port1PerPortTxPeHalf, new->Usb2Port1PerPortTxPeHalf); fsp_display_upd_value("D0Usb2Port1PerPortRXISet", 1, old->D0Usb2Port1PerPortRXISet, new->D0Usb2Port1PerPortRXISet); fsp_display_upd_value("Usb2Port2PerPortPeTxiSet", 1, old->Usb2Port2PerPortPeTxiSet, new->Usb2Port2PerPortPeTxiSet); fsp_display_upd_value("Usb2Port2PerPortTxiSet", 1, old->Usb2Port2PerPortTxiSet, new->Usb2Port2PerPortTxiSet); fsp_display_upd_value("Usb2Port2IUsbTxEmphasisEn", 1, old->Usb2Port2IUsbTxEmphasisEn, new->Usb2Port2IUsbTxEmphasisEn); fsp_display_upd_value("Usb2Port2PerPortTxPeHalf", 1, old->Usb2Port2PerPortTxPeHalf, new->Usb2Port2PerPortTxPeHalf); fsp_display_upd_value("D0Usb2Port2PerPortRXISet", 1, old->D0Usb2Port2PerPortRXISet, new->D0Usb2Port2PerPortRXISet); fsp_display_upd_value("Usb2Port3PerPortPeTxiSet", 1, old->Usb2Port3PerPortPeTxiSet, new->Usb2Port3PerPortPeTxiSet); fsp_display_upd_value("Usb2Port3PerPortTxiSet", 1, old->Usb2Port3PerPortTxiSet, new->Usb2Port3PerPortTxiSet); fsp_display_upd_value("Usb2Port3IUsbTxEmphasisEn", 1, old->Usb2Port3IUsbTxEmphasisEn, new->Usb2Port3IUsbTxEmphasisEn); fsp_display_upd_value("Usb2Port3PerPortTxPeHalf", 1, old->Usb2Port3PerPortTxPeHalf, new->Usb2Port3PerPortTxPeHalf); fsp_display_upd_value("D0Usb2Port3PerPortRXISet", 1, old->D0Usb2Port3PerPortRXISet, new->D0Usb2Port3PerPortRXISet); fsp_display_upd_value("Usb2Port4PerPortPeTxiSet", 1, old->Usb2Port4PerPortPeTxiSet, new->Usb2Port4PerPortPeTxiSet); fsp_display_upd_value("Usb2Port4PerPortTxiSet", 1, old->Usb2Port4PerPortTxiSet, new->Usb2Port4PerPortTxiSet); fsp_display_upd_value("Usb2Port4IUsbTxEmphasisEn", 1, old->Usb2Port4IUsbTxEmphasisEn, new->Usb2Port4IUsbTxEmphasisEn); fsp_display_upd_value("Usb2Port4PerPortTxPeHalf", 1, old->Usb2Port4PerPortTxPeHalf, new->Usb2Port4PerPortTxPeHalf); fsp_display_upd_value("D0Usb2Port4PerPortRXISet", 1, old->D0Usb2Port4PerPortRXISet, new->D0Usb2Port4PerPortRXISet); fsp_display_upd_value("Usb3Lane0Ow2tapgen2deemph3p5", 1, old->Usb3Lane0Ow2tapgen2deemph3p5, new->Usb3Lane0Ow2tapgen2deemph3p5); fsp_display_upd_value("Usb3Lane1Ow2tapgen2deemph3p5", 1, old->Usb3Lane1Ow2tapgen2deemph3p5, new->Usb3Lane1Ow2tapgen2deemph3p5); fsp_display_upd_value("Usb3Lane2Ow2tapgen2deemph3p5", 1, old->Usb3Lane2Ow2tapgen2deemph3p5, new->Usb3Lane2Ow2tapgen2deemph3p5); fsp_display_upd_value("Usb3Lane3Ow2tapgen2deemph3p5", 1, old->Usb3Lane3Ow2tapgen2deemph3p5, new->Usb3Lane3Ow2tapgen2deemph3p5); fsp_display_upd_value("PcdSataInterfaceSpeed", 1, old->PcdSataInterfaceSpeed, new->PcdSataInterfaceSpeed); fsp_display_upd_value("PcdPchUsbSsicPort", 1, old->PcdPchUsbSsicPort, new->PcdPchUsbSsicPort); fsp_display_upd_value("PcdPchUsbHsicPort", 1, old->PcdPchUsbHsicPort, new->PcdPchUsbHsicPort); fsp_display_upd_value("PcdPcieRootPortSpeed", 1, old->PcdPcieRootPortSpeed, new->PcdPcieRootPortSpeed); fsp_display_upd_value("PcdPchSsicEnable", 1, old->PcdPchSsicEnable, new->PcdPchSsicEnable); fsp_display_upd_value("PcdLogoPtr", 4, old->PcdLogoPtr, new->PcdLogoPtr); fsp_display_upd_value("PcdLogoSize", 4, old->PcdLogoSize, new->PcdLogoSize); fsp_display_upd_value("PcdRtcLock", 1, old->PcdRtcLock, new->PcdRtcLock); fsp_display_upd_value("PMIC_I2CBus", 1, old->PMIC_I2CBus, new->PMIC_I2CBus); fsp_display_upd_value("ISPEnable", 1, old->ISPEnable, new->ISPEnable); fsp_display_upd_value("ISPPciDevConfig", 1, old->ISPPciDevConfig, new->ISPPciDevConfig); fsp_display_upd_value("PcdSdDetectChk", 1, old->PcdSdDetectChk, new->PcdSdDetectChk); } /* Called at BS_DEV_INIT_CHIPS time -- very early. Just after BS_PRE_DEVICE. */ static void soc_init(void *chip_info) { printk(BIOS_SPEW, "%s/%s\n", __FILE__, __func__); soc_init_pre_device(chip_info); } struct chip_operations soc_intel_braswell_ops = { CHIP_NAME("Intel Braswell SoC") .enable_dev = enable_dev, .init = soc_init, }; static void pci_set_subsystem(struct device *dev, unsigned int vendor, unsigned int device) { printk(BIOS_SPEW, "%s/%s (%s, 0x%04x, 0x%04x)\n", __FILE__, __func__, dev_name(dev), vendor, device); if (!vendor || !device) { pci_write_config32(dev, PCI_SUBSYSTEM_VENDOR_ID, pci_read_config32(dev, PCI_VENDOR_ID)); } else { pci_write_config32(dev, PCI_SUBSYSTEM_VENDOR_ID, ((device & 0xffff) << 16) | (vendor & 0xffff)); } } struct pci_operations soc_pci_ops = { .set_subsystem = &pci_set_subsystem, }; /** Return SoC stepping type @retval SOC_STEPPING SoC stepping type **/ int SocStepping(void) { struct device *dev = dev_find_slot(0, PCI_DEVFN(LPC_DEV, LPC_FUNC)); u8 revid = pci_read_config8(dev, 0x8); switch (revid & B_PCH_LPC_RID_STEPPING_MASK) { case V_PCH_LPC_RID_A0: return SocA0; case V_PCH_LPC_RID_A1: return SocA1; case V_PCH_LPC_RID_A2: return SocA2; case V_PCH_LPC_RID_A3: return SocA3; case V_PCH_LPC_RID_A4: return SocA4; case V_PCH_LPC_RID_A5: return SocA5; case V_PCH_LPC_RID_A6: return SocA6; case V_PCH_LPC_RID_A7: return SocA7; case V_PCH_LPC_RID_B0: return SocB0; case V_PCH_LPC_RID_B1: return SocB1; case V_PCH_LPC_RID_B2: return SocB2; case V_PCH_LPC_RID_B3: return SocB3; case V_PCH_LPC_RID_B4: return SocB4; case V_PCH_LPC_RID_B5: return SocB5; case V_PCH_LPC_RID_B6: return SocB6; case V_PCH_LPC_RID_B7: return SocB7; case V_PCH_LPC_RID_C0: return SocC0; case V_PCH_LPC_RID_C1: return SocC1; case V_PCH_LPC_RID_C2: return SocC2; case V_PCH_LPC_RID_C3: return SocC3; case V_PCH_LPC_RID_C4: return SocC4; case V_PCH_LPC_RID_C5: return SocC5; case V_PCH_LPC_RID_C6: return SocC6; case V_PCH_LPC_RID_C7: return SocC7; case V_PCH_LPC_RID_D0: return SocD0; case V_PCH_LPC_RID_D1: return SocD1; case V_PCH_LPC_RID_D2: return SocD2; case V_PCH_LPC_RID_D3: return SocD3; case V_PCH_LPC_RID_D4: return SocD4; case V_PCH_LPC_RID_D5: return SocD5; case V_PCH_LPC_RID_D6: return SocD6; case V_PCH_LPC_RID_D7: return SocD7; default: return SocSteppingMax; } }