Matt DeVillier has uploaded this change for review. ( https://review.coreboot.org/c/coreboot/+/87566?usp=email )
Change subject: mb/google/puff: Use CFR setup menu to manage options ......................................................................
mb/google/puff: Use CFR setup menu to manage options
Enable support for managing system options via CFR, and select it by default when using edk2 with SMMSTORE.
TEST=build/boot wyvern w/edk2 payload
Change-Id: I6ccf0c9c50babb3134669c977eb27b7b3f567546 Signed-off-by: Matt DeVillier matt.devillier@gmail.com --- M src/mainboard/google/puff/Kconfig M src/mainboard/google/puff/Makefile.mk A src/mainboard/google/puff/cfr.c 3 files changed, 47 insertions(+), 0 deletions(-)
git pull ssh://review.coreboot.org:29418/coreboot refs/changes/66/87566/1
diff --git a/src/mainboard/google/puff/Kconfig b/src/mainboard/google/puff/Kconfig index d5786a5..c35cf6b 100644 --- a/src/mainboard/google/puff/Kconfig +++ b/src/mainboard/google/puff/Kconfig @@ -11,6 +11,7 @@ select DRIVERS_I2C_HID select DRIVERS_I2C_SX9310 select DRIVERS_INTEL_DPTF + select DRIVERS_OPTION_CFR_ENABLED if PAYLOAD_EDK2 && SMMSTORE select DRIVERS_SPI_ACPI select DRIVERS_USB_ACPI select EC_GOOGLE_CHROMEEC diff --git a/src/mainboard/google/puff/Makefile.mk b/src/mainboard/google/puff/Makefile.mk index b26f1d2..bbe2f38 100644 --- a/src/mainboard/google/puff/Makefile.mk +++ b/src/mainboard/google/puff/Makefile.mk @@ -6,6 +6,7 @@ ramstage-y += ramstage.c ramstage-$(CONFIG_CHROMEOS) += chromeos.c ramstage-$(CONFIG_EC_GOOGLE_CHROMEEC) += ec.c +ramstage-$(CONFIG_DRIVERS_OPTION_CFR) += cfr.c
romstage-y += romstage.c romstage-$(CONFIG_CHROMEOS) += chromeos.c diff --git a/src/mainboard/google/puff/cfr.c b/src/mainboard/google/puff/cfr.c new file mode 100644 index 0000000..8a60ed7 --- /dev/null +++ b/src/mainboard/google/puff/cfr.c @@ -0,0 +1,45 @@ + +/* SPDX-License-Identifier: GPL-2.0-only */ + +#include <boot/coreboot_tables.h> +#include <drivers/option/cfr_frontend.h> +#include <intelblocks/cfr.h> +#include <soc/cfr.h> + +static struct sm_obj_form system = { + .ui_name = "System", + .obj_list = (const struct sm_object *[]) { + &hyper_threading, + &igd_dvmt, + &igd_aperture, + &legacy_8254_timer, + &me_state, + &me_state_counter, + &pciexp_aspm, + &pciexp_clk_pm, + &pciexp_l1ss, + &pciexp_speed, + &s0ix_enable, + &vtd, + NULL + }, +}; + +static struct sm_obj_form power = { + .ui_name = "Power", + .obj_list = (const struct sm_object *[]) { + &power_on_after_fail, + NULL + }, +}; + +static struct sm_obj_form *sm_root[] = { + &system, + &power, + NULL +}; + +void mb_cfr_setup_menu(struct lb_cfr *cfr_root) +{ + cfr_write_setup_menu(cfr_root, sm_root); +}