soc/intel/cnl: Enable VT-d
Enable VT-d through fsp upd VtdDisable. Update remapping structure types in numerical order as all remapping structures of type 0 (DRHD) enumerated before remapping structures of type 1 (RMRR), and so forth. BUG=b:130351429 TEST=Booted to kernel and verified the DMAR table contents. Change-Id: I1d20932e417b9d324edd98c8f2195dc228d2e092 Signed-off-by: John Zhao <john.zhao@intel.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/32432 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Nico Huber <nico.h@gmx.de> Reviewed-by: Pratikkumar V Prajapati <pratikkumar.v.prajapati@intel.com>
This commit is contained in:
parent
4249348735
commit
1159a163cd
|
@ -304,13 +304,6 @@ static unsigned long soc_fill_dmar(unsigned long current)
|
||||||
current += acpi_create_dmar_ds_pci(current, 0, 2, 0);
|
current += acpi_create_dmar_ds_pci(current, 0, 2, 0);
|
||||||
|
|
||||||
acpi_dmar_drhd_fixup(tmp, current);
|
acpi_dmar_drhd_fixup(tmp, current);
|
||||||
|
|
||||||
/* Add RMRR entry */
|
|
||||||
tmp = current;
|
|
||||||
current += acpi_create_dmar_rmrr(current, 0,
|
|
||||||
sa_get_gsm_base(), sa_get_tolud_base() - 1);
|
|
||||||
current += acpi_create_dmar_ds_pci(current, 0, 2, 0);
|
|
||||||
acpi_dmar_rmrr_fixup(tmp, current);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
struct device *const ipu_dev = dev_find_slot(0, SA_DEVFN_IPU);
|
struct device *const ipu_dev = dev_find_slot(0, SA_DEVFN_IPU);
|
||||||
|
@ -344,6 +337,13 @@ static unsigned long soc_fill_dmar(unsigned long current)
|
||||||
acpi_dmar_drhd_fixup(tmp, current);
|
acpi_dmar_drhd_fixup(tmp, current);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Add RMRR entry */
|
||||||
|
const unsigned long tmp = current;
|
||||||
|
current += acpi_create_dmar_rmrr(current, 0,
|
||||||
|
sa_get_gsm_base(), sa_get_tolud_base() - 1);
|
||||||
|
current += acpi_create_dmar_ds_pci(current, 0, 2, 0);
|
||||||
|
acpi_dmar_rmrr_fixup(tmp, current);
|
||||||
|
|
||||||
return current;
|
return current;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -361,6 +361,7 @@ unsigned long sa_write_acpi_tables(struct device *dev, unsigned long current,
|
||||||
|
|
||||||
printk(BIOS_DEBUG, "ACPI: * DMAR\n");
|
printk(BIOS_DEBUG, "ACPI: * DMAR\n");
|
||||||
acpi_create_dmar(dmar, DMAR_INTR_REMAP, soc_fill_dmar);
|
acpi_create_dmar(dmar, DMAR_INTR_REMAP, soc_fill_dmar);
|
||||||
|
|
||||||
current += dmar->header.length;
|
current += dmar->header.length;
|
||||||
current = acpi_align_current(current);
|
current = acpi_align_current(current);
|
||||||
acpi_add_table(rsdp, dmar);
|
acpi_add_table(rsdp, dmar);
|
||||||
|
|
|
@ -344,9 +344,6 @@ struct soc_intel_cannonlake_config {
|
||||||
/* Enable Pch iSCLK */
|
/* Enable Pch iSCLK */
|
||||||
uint8_t pch_isclk;
|
uint8_t pch_isclk;
|
||||||
|
|
||||||
/* Intel VT configuration */
|
|
||||||
uint8_t VtdDisable;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Acoustic Noise Mitigation
|
* Acoustic Noise Mitigation
|
||||||
* 0b - Disable
|
* 0b - Disable
|
||||||
|
|
|
@ -101,6 +101,7 @@ void platform_fsp_memory_init_params_cb(FSPM_UPD *mupd, uint32_t version)
|
||||||
assert(dev != NULL);
|
assert(dev != NULL);
|
||||||
const config_t *config = dev->chip_info;
|
const config_t *config = dev->chip_info;
|
||||||
FSP_M_CONFIG *m_cfg = &mupd->FspmConfig;
|
FSP_M_CONFIG *m_cfg = &mupd->FspmConfig;
|
||||||
|
FSP_M_TEST_CONFIG *tconfig = &mupd->FspmTestConfig;
|
||||||
|
|
||||||
soc_memory_init_params(m_cfg, config);
|
soc_memory_init_params(m_cfg, config);
|
||||||
|
|
||||||
|
@ -113,6 +114,10 @@ void platform_fsp_memory_init_params_cb(FSPM_UPD *mupd, uint32_t version)
|
||||||
/* Set debug probe type */
|
/* Set debug probe type */
|
||||||
m_cfg->PlatformDebugConsent =
|
m_cfg->PlatformDebugConsent =
|
||||||
CONFIG_SOC_INTEL_CANNONLAKE_DEBUG_CONSENT;
|
CONFIG_SOC_INTEL_CANNONLAKE_DEBUG_CONSENT;
|
||||||
|
|
||||||
|
/* Configure VT-d */
|
||||||
|
tconfig->VtdDisable = 0;
|
||||||
|
|
||||||
mainboard_memory_init_params(mupd);
|
mainboard_memory_init_params(mupd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -33,8 +33,6 @@
|
||||||
*/
|
*/
|
||||||
void soc_add_fixed_mmio_resources(struct device *dev, int *index)
|
void soc_add_fixed_mmio_resources(struct device *dev, int *index)
|
||||||
{
|
{
|
||||||
const struct soc_intel_cannonlake_config *const config = dev->chip_info;
|
|
||||||
|
|
||||||
static const struct sa_mmio_descriptor soc_fixed_resources[] = {
|
static const struct sa_mmio_descriptor soc_fixed_resources[] = {
|
||||||
{ PCIEXBAR, CONFIG_MMCONF_BASE_ADDRESS, CONFIG_SA_PCIEX_LENGTH,
|
{ PCIEXBAR, CONFIG_MMCONF_BASE_ADDRESS, CONFIG_SA_PCIEX_LENGTH,
|
||||||
"PCIEXBAR" },
|
"PCIEXBAR" },
|
||||||
|
@ -63,10 +61,8 @@ void soc_add_fixed_mmio_resources(struct device *dev, int *index)
|
||||||
if ((pci_read_config32(dev, CAPID0_A) & VTD_DISABLE))
|
if ((pci_read_config32(dev, CAPID0_A) & VTD_DISABLE))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (!(config && config->VtdDisable)) {
|
|
||||||
sa_add_fixed_mmio_resources(dev, index, soc_vtd_resources,
|
sa_add_fixed_mmio_resources(dev, index, soc_vtd_resources,
|
||||||
ARRAY_SIZE(soc_vtd_resources));
|
ARRAY_SIZE(soc_vtd_resources));
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
Loading…
Reference in New Issue