soc/intel/meteorlake: Hook up UPD CnviWifiCore

Hook the newly created/exposed CnviWifiCore UPD up as a chip driver.
Enable this option by default to maintain the existing behavior.

BUG=b:270985197
TEST=Verified by enabling/disabling the UPD on google/rex

Signed-off-by: Kapil Porwal <kapilporwal@google.com>
Change-Id: I5b4662c2a064f7c9074797c8a2541dcf1dd686fe
Reviewed-on: https://review.coreboot.org/c/coreboot/+/74306
Reviewed-by: Eric Lai <eric_lai@quanta.corp-partner.google.com>
Reviewed-by: Subrata Banik <subratabanik@google.com>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
Kapil Porwal 2023-04-12 10:30:48 +05:30 committed by Felix Held
parent 02b39efca4
commit 78cc76d204
3 changed files with 9 additions and 0 deletions

View file

@ -242,6 +242,9 @@ struct soc_intel_meteorlake_config {
*/ */
uint8_t serial_io_gspi_cs_state[CONFIG_SOC_INTEL_COMMON_BLOCK_GSPI_MAX]; uint8_t serial_io_gspi_cs_state[CONFIG_SOC_INTEL_COMMON_BLOCK_GSPI_MAX];
/* CNVi WiFi Core Enable/Disable */
bool cnvi_wifi_core;
/* CNVi BT Core Enable/Disable */ /* CNVi BT Core Enable/Disable */
bool cnvi_bt_core; bool cnvi_bt_core;

View file

@ -18,6 +18,9 @@ chip soc/intel/meteorlake
# putting it under register "common_soc_config" in overridetree.cb file. # putting it under register "common_soc_config" in overridetree.cb file.
register "common_soc_config.pch_thermal_trip" = "130" register "common_soc_config.pch_thermal_trip" = "130"
# Enable CNVi WiFi
register "cnvi_wifi_core" = "true"
device domain 0 on device domain 0 on
device pci 00.0 alias system_agent on end device pci 00.0 alias system_agent on end
device pci 01.0 alias pcie_rp12 off end device pci 01.0 alias pcie_rp12 off end

View file

@ -562,8 +562,11 @@ static void fill_fsps_cnvi_params(FSP_S_CONFIG *s_cfg,
{ {
/* CNVi */ /* CNVi */
s_cfg->CnviMode = is_devfn_enabled(PCI_DEVFN_CNVI_WIFI); s_cfg->CnviMode = is_devfn_enabled(PCI_DEVFN_CNVI_WIFI);
s_cfg->CnviWifiCore = config->cnvi_wifi_core;
s_cfg->CnviBtCore = config->cnvi_bt_core; s_cfg->CnviBtCore = config->cnvi_bt_core;
s_cfg->CnviBtAudioOffload = config->cnvi_bt_audio_offload; s_cfg->CnviBtAudioOffload = config->cnvi_bt_audio_offload;
/* Assert if CNVi WiFi is enabled without CNVi being enabled. */
assert(s_cfg->CnviMode || !s_cfg->CnviWifiCore);
/* Assert if CNVi BT is enabled without CNVi being enabled. */ /* Assert if CNVi BT is enabled without CNVi being enabled. */
assert(s_cfg->CnviMode || !s_cfg->CnviBtCore); assert(s_cfg->CnviMode || !s_cfg->CnviBtCore);
/* Assert if CNVi BT offload is enabled without CNVi BT being enabled. */ /* Assert if CNVi BT offload is enabled without CNVi BT being enabled. */