summaryrefslogtreecommitdiff
path: root/src/mainboard/google/brox/variants/baseboard
diff options
context:
space:
mode:
authorKarthikeyan Ramasubramanian <kramasub@google.com>2024-10-30 10:27:10 -0600
committerKarthik Ramasubramanian <kramasub@google.com>2024-11-06 22:43:10 +0000
commit2ba74b8c188b8234131dff7e12284becf34a6f2f (patch)
tree7d2e9780be707721082415e677d918a87d7705f1 /src/mainboard/google/brox/variants/baseboard
parentede97c29c6f3307f0098e85a6aef998cb2f773f1 (diff)
mb/google/brox: Hint romstage init about upcoming reset
Add support for the mainboard to check for any potential firmware component update and hence the assosicated reset. This indication can be used to avoid any redundant resets during the boot flow. BUG=b:375444631 TEST=Build Brox BIOS image and boot to OS. Ensure that the hints are provided correctly and 2 redundant resets are filtered out. Change-Id: Ieed3f9013dee9aa501a3f0403f3a28722a3878f1 Signed-off-by: Karthikeyan Ramasubramanian <kramasub@google.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/84937 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Subrata Banik <subratabanik@google.com>
Diffstat (limited to 'src/mainboard/google/brox/variants/baseboard')
-rw-r--r--src/mainboard/google/brox/variants/baseboard/brox/Makefile.mk1
-rw-r--r--src/mainboard/google/brox/variants/baseboard/brox/romstage.c65
-rw-r--r--src/mainboard/google/brox/variants/baseboard/include/baseboard/variants.h1
3 files changed, 67 insertions, 0 deletions
diff --git a/src/mainboard/google/brox/variants/baseboard/brox/Makefile.mk b/src/mainboard/google/brox/variants/baseboard/brox/Makefile.mk
index 3a6695828f..b3149ba8aa 100644
--- a/src/mainboard/google/brox/variants/baseboard/brox/Makefile.mk
+++ b/src/mainboard/google/brox/variants/baseboard/brox/Makefile.mk
@@ -4,6 +4,7 @@ bootblock-y += gpio.c
romstage-y += memory.c
romstage-y += gpio.c
+romstage-y += romstage.c
romstage-$(CONFIG_MAINBOARD_USE_EARLY_LIBGFXINIT) += gma-mainboard.ads
ramstage-y += gpio.c
diff --git a/src/mainboard/google/brox/variants/baseboard/brox/romstage.c b/src/mainboard/google/brox/variants/baseboard/brox/romstage.c
new file mode 100644
index 0000000000..66ed99b9f4
--- /dev/null
+++ b/src/mainboard/google/brox/variants/baseboard/brox/romstage.c
@@ -0,0 +1,65 @@
+/* SPDX-License-Identifier: GPL-2.0-or-later */
+
+#include <baseboard/variants.h>
+#include <cbfs.h>
+#include <ec/google/chromeec/ec.h>
+#include <security/vboot/vboot_common.h>
+#include <security/vboot/misc.h>
+#include <soc/romstage.h>
+
+#define FWVER_SIZE 3
+#define FWVER_TO_INT(MAJOR, MINOR, PATCH) \
+ ((uint32_t)(((MAJOR) & 0xFF) << 16 | ((MINOR) & 0xFF) << 8 | ((PATCH) & 0xFF)))
+
+static bool check_auxfw_ver_mismatch(void)
+{
+ uint8_t *new_ver;
+ size_t new_ver_size;
+ struct ec_response_pd_chip_info pd_chip_r = {0};
+ const char *fwver_fname = variant_get_auxfw_version_file();
+ uint8_t cur_major_ver;
+ bool mismatch = false, is_productionfw;
+ int ret;
+
+ ret = google_chromeec_get_pd_chip_info(0, 0, &pd_chip_r);
+ if (ret < 0) {
+ printk(BIOS_INFO, "%s: Cannot get PD port info\n", __func__);
+ return mismatch;
+ }
+ cur_major_ver = (pd_chip_r.fw_version_number >> 16) & 0xFF;
+ is_productionfw = !!(cur_major_ver & 0xF0);
+
+ /* find bundled fw hash */
+ new_ver = cbfs_map(fwver_fname, &new_ver_size);
+ if (new_ver == NULL || new_ver_size != FWVER_SIZE)
+ return mismatch;
+
+ /*
+ * Firmware version mismatches and satisfies anti-rollback conditions.
+ * Anti-rollback conditions are one of the following:
+ * 1) Not a production firmware.
+ * 2) New major version is greater than current major version.
+ */
+ if ((pd_chip_r.fw_version_number !=
+ FWVER_TO_INT(new_ver[0], new_ver[1], new_ver[2])) &&
+ (!is_productionfw || new_ver[0] >= cur_major_ver)) {
+ printk(BIOS_INFO, "%s: Expecting Aux FW update and hence a reset\n", __func__);
+ mismatch = true;
+ }
+
+ cbfs_unmap(new_ver);
+ return mismatch;
+}
+
+bool mainboard_expects_another_reset(void)
+{
+ if (vboot_recovery_mode_enabled())
+ return false;
+
+ if (!CONFIG(VBOOT) ||
+ (vboot_is_gbb_flag_set(VB2_GBB_FLAG_DISABLE_EC_SOFTWARE_SYNC) &&
+ vboot_is_gbb_flag_set(VB2_GBB_FLAG_DISABLE_AUXFW_SOFTWARE_SYNC)))
+ return false;
+
+ return check_auxfw_ver_mismatch();
+}
diff --git a/src/mainboard/google/brox/variants/baseboard/include/baseboard/variants.h b/src/mainboard/google/brox/variants/baseboard/include/baseboard/variants.h
index a1fbe018b1..070b2f8634 100644
--- a/src/mainboard/google/brox/variants/baseboard/include/baseboard/variants.h
+++ b/src/mainboard/google/brox/variants/baseboard/include/baseboard/variants.h
@@ -60,4 +60,5 @@ void variant_update_power_limits(const struct cpu_power_limits *limits,
void variant_init(void);
void variant_finalize(void);
+const char *variant_get_auxfw_version_file(void);
#endif /*__BASEBOARD_VARIANTS_H__ */