summaryrefslogtreecommitdiff
path: root/src/mainboard/google/brox/variants/jubilant/variant.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/mainboard/google/brox/variants/jubilant/variant.c')
-rw-r--r--src/mainboard/google/brox/variants/jubilant/variant.c29
1 files changed, 29 insertions, 0 deletions
diff --git a/src/mainboard/google/brox/variants/jubilant/variant.c b/src/mainboard/google/brox/variants/jubilant/variant.c
index e085a86ff8..dda054e370 100644
--- a/src/mainboard/google/brox/variants/jubilant/variant.c
+++ b/src/mainboard/google/brox/variants/jubilant/variant.c
@@ -3,6 +3,7 @@
#include <assert.h>
#include <baseboard/variants.h>
#include <chip.h>
+#include <device/device.h>
#include <fw_config.h>
#include <sar.h>
@@ -11,6 +12,11 @@ void variant_update_soc_chip_config(struct soc_intel_alderlake_config *config)
if (fw_config_probe(FW_CONFIG(WIFI_BT, WIFI_BT_CNVI))) {
printk(BIOS_INFO, "CNVi bluetooth enabled by fw_config\n");
config->cnvi_bt_core = true;
+ config->cnvi_bt_audio_offload = true;
+ } else {
+ printk(BIOS_INFO, "CNVi bluetooth disabled by fw_config\n");
+ config->cnvi_bt_core = false;
+ config->cnvi_bt_audio_offload = false;
}
}
@@ -18,3 +24,26 @@ const char *get_wifi_sar_cbfs_filename(void)
{
return get_wifi_sar_fw_config_filename(FW_CONFIG_FIELD(WIFI_BT));
}
+
+void variant_devtree_update(void)
+{
+ struct device *ufs = DEV_PTR(ufs);
+ struct device *ish = DEV_PTR(ish);
+ struct device *nvme_rp = DEV_PTR(pcie4_0);
+
+ if (fw_config_probe(FW_CONFIG(STORAGE, STORAGE_UNPROVISIONED))) {
+ printk(BIOS_INFO, "fw_config storage is unknown so enable all storage devices.\n");
+ return;
+ }
+
+ if (!fw_config_probe(FW_CONFIG(STORAGE, STORAGE_NVME))) {
+ printk(BIOS_INFO, "NVMe disabled by fw_config.\n");
+ nvme_rp->enabled = 0;
+ }
+
+ if (!fw_config_probe(FW_CONFIG(STORAGE, STORAGE_UFS))) {
+ printk(BIOS_INFO, "UFS disabled by fw_config.\n");
+ ufs->enabled = 0;
+ ish->enabled = 0;
+ }
+}