Commit 3c16b8ea29 for qemu.org
commit 3c16b8ea293221eb86db4a7c1ef8bfb8573b0083
Author: Patrick Williams <patrick@stwcx.xyz>
Date: Wed Dec 17 14:11:28 2025 -0500
hw/arm/aspeed: catalina: add BSM FRU EEPROM
Use ipmitool/frugen tool to generate a BSM image based on a
sanitized set of data from a real device EEPROM.
Signed-off-by: Patrick Williams <patrick@stwcx.xyz>
Reviewed-by: Cédric Le Goater <clg@redhat.com>
Link: https://lore.kernel.org/qemu-devel/20251217-catalina-eeproms-v1-1-dc7b276efd57@stwcx.xyz
Signed-off-by: Cédric Le Goater <clg@redhat.com>
diff --git a/hw/arm/aspeed_ast2600_catalina.c b/hw/arm/aspeed_ast2600_catalina.c
index 91977a4d3c..0f229f4dc6 100644
--- a/hw/arm/aspeed_ast2600_catalina.c
+++ b/hw/arm/aspeed_ast2600_catalina.c
@@ -26,6 +26,44 @@
#define TYPE_TMP421 "tmp421"
#define TYPE_DS1338 "ds1338"
+/*
+ * "BMC Storage Module" FRU data. Generated with frugen.
+ *
+ * {
+ * "board": {
+ * "mfg": "Quanta",
+ * "pname": "BMC Storage Module (QEMU)",
+ * "pn": "00000000000",
+ * "serial": "00000000000000",
+ * "date": "01/12/2025 00:00",
+ * "custom": ["09-100183"]
+ * },
+ * "product": {
+ * "mfg": "Quanta",
+ * "pname": "CI-Catalina",
+ * "pn": "10000000001",
+ * "ver": "MP",
+ * "serial": "10000000000000",
+ * "atag": "QEMU"
+ * }
+ * }
+ */
+static const uint8_t bsm_eeprom[] = {
+ 0x01, 0x00, 0x00, 0x01, 0x0a, 0x00, 0x00, 0xf4, 0x01, 0x09, 0x19, 0x8c,
+ 0x19, 0xf0, 0xc6, 0x51, 0x75, 0x61, 0x6e, 0x74, 0x61, 0xd9, 0x42, 0x4d,
+ 0x43, 0x20, 0x53, 0x74, 0x6f, 0x72, 0x61, 0x67, 0x65, 0x20, 0x4d, 0x6f,
+ 0x64, 0x75, 0x6c, 0x65, 0x20, 0x28, 0x51, 0x45, 0x4d, 0x55, 0x29, 0x8b,
+ 0x10, 0x04, 0x41, 0x10, 0x04, 0x41, 0x10, 0x04, 0x41, 0x10, 0x04, 0x89,
+ 0x10, 0x04, 0x41, 0x10, 0x04, 0x41, 0x10, 0x04, 0x01, 0xc0, 0x87, 0x50,
+ 0xd6, 0x44, 0x10, 0x14, 0x61, 0x13, 0xc1, 0x59, 0x01, 0x07, 0x19, 0xc6,
+ 0x51, 0x75, 0x61, 0x6e, 0x74, 0x61, 0xcb, 0x43, 0x49, 0x2d, 0x43, 0x61,
+ 0x74, 0x61, 0x6c, 0x69, 0x6e, 0x61, 0x89, 0x11, 0x04, 0x41, 0x10, 0x04,
+ 0x41, 0x10, 0x14, 0x01, 0x82, 0x2d, 0x0c, 0x8b, 0x11, 0x04, 0x41, 0x10,
+ 0x04, 0x41, 0x10, 0x04, 0x41, 0x10, 0x04, 0x83, 0x71, 0xd9, 0xd6, 0xc0,
+ 0xc1, 0x00, 0x00, 0x37
+};
+static const size_t bsm_eeprom_len = sizeof(bsm_eeprom);
+
static void catalina_bmc_i2c_init(AspeedMachineState *bmc)
{
/* Reference from v6.16-rc2 aspeed-bmc-facebook-catalina.dts */
@@ -147,7 +185,7 @@ static void catalina_bmc_i2c_init(AspeedMachineState *bmc)
/* eeprom@50 */
at24c_eeprom_init(i2c[9], 0x50, 8 * KiB);
/* eeprom@56 */
- at24c_eeprom_init(i2c[9], 0x56, 8 * KiB);
+ at24c_eeprom_init_rom(i2c[9], 0x56, 8 * KiB, bsm_eeprom, bsm_eeprom_len);
/* &i2c10 */
/* temperature-sensor@1f - tpm421 */