{"id":2175326,"url":"http://patchwork.ozlabs.org/api/1.0/patches/2175326/?format=json","project":{"id":14,"url":"http://patchwork.ozlabs.org/api/1.0/projects/14/?format=json","name":"QEMU Development","link_name":"qemu-devel","list_id":"qemu-devel.nongnu.org","list_email":"qemu-devel@nongnu.org","web_url":"","scm_url":"","webscm_url":""},"msgid":"<20251217-catalina-eeproms-v1-8-dc7b276efd57@stwcx.xyz>","date":"2025-12-17T19:11:35","name":"[08/11] hw/arm/aspeed: catalina: add GB200-IO FRU EEPROM","commit_ref":null,"pull_url":null,"state":"new","archived":false,"hash":"31c3858ee5faba332a81e3897255cea83bdc3978","submitter":{"id":67046,"url":"http://patchwork.ozlabs.org/api/1.0/people/67046/?format=json","name":"Patrick Williams","email":"patrick@stwcx.xyz"},"delegate":null,"mbox":"http://patchwork.ozlabs.org/project/qemu-devel/patch/20251217-catalina-eeproms-v1-8-dc7b276efd57@stwcx.xyz/mbox/","series":[{"id":485752,"url":"http://patchwork.ozlabs.org/api/1.0/series/485752/?format=json","date":"2025-12-17T19:11:31","name":"hw/arm/aspeed: catalina: add eeproms images","version":1,"mbox":"http://patchwork.ozlabs.org/series/485752/mbox/"}],"check":"pending","checks":"http://patchwork.ozlabs.org/api/patches/2175326/checks/","tags":{},"headers":{"Return-Path":"<qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org>","X-Original-To":"incoming@patchwork.ozlabs.org","Delivered-To":"patchwork-incoming@legolas.ozlabs.org","Authentication-Results":["legolas.ozlabs.org;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=stwcx.xyz header.i=@stwcx.xyz header.a=rsa-sha256\n header.s=fm3 header.b=hlXDYetz;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=messagingengine.com header.i=@messagingengine.com\n header.a=rsa-sha256 header.s=fm1 header.b=L2TwPYtb;\n\tdkim-atps=neutral","legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=nongnu.org\n (client-ip=209.51.188.17; helo=lists.gnu.org;\n envelope-from=qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org;\n receiver=patchwork.ozlabs.org)"],"Received":["from lists.gnu.org (lists.gnu.org [209.51.188.17])\n\t(using TLSv1.2 with cipher ECDHE-ECDSA-AES256-GCM-SHA384 (256/256 bits))\n\t(No client certificate requested)\n\tby legolas.ozlabs.org (Postfix) with ESMTPS id 4dWk2j2WK8z1y0P\n\tfor <incoming@patchwork.ozlabs.org>; Thu, 18 Dec 2025 06:12:45 +1100 (AEDT)","from localhost ([::1] helo=lists1p.gnu.org)\n\tby lists.gnu.org with esmtp (Exim 4.90_1)\n\t(envelope-from <qemu-devel-bounces@nongnu.org>)\n\tid 1vVww4-0005iL-M0; Wed, 17 Dec 2025 14:11:44 -0500","from eggs.gnu.org ([2001:470:142:3::10])\n by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256)\n (Exim 4.90_1) (envelope-from <patrick@stwcx.xyz>)\n id 1vVww1-0005fq-2H; Wed, 17 Dec 2025 14:11:41 -0500","from fout-a8-smtp.messagingengine.com ([103.168.172.151])\n by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256)\n (Exim 4.90_1) (envelope-from <patrick@stwcx.xyz>)\n id 1vVwvz-00016a-5S; Wed, 17 Dec 2025 14:11:40 -0500","from phl-compute-03.internal (phl-compute-03.internal [10.202.2.43])\n by mailfout.phl.internal (Postfix) with ESMTP id 4289FEC016D;\n Wed, 17 Dec 2025 14:11:38 -0500 (EST)","from phl-frontend-03 ([10.202.2.162])\n by phl-compute-03.internal (MEProxy); Wed, 17 Dec 2025 14:11:38 -0500","by mail.messagingengine.com (Postfix) with ESMTPA; Wed,\n 17 Dec 2025 14:11:37 -0500 (EST)"],"DKIM-Signature":["v=1; a=rsa-sha256; c=relaxed/relaxed; d=stwcx.xyz; h=cc\n :cc:content-transfer-encoding:content-type:content-type:date\n :date:from:from:in-reply-to:in-reply-to:message-id:mime-version\n :references:reply-to:subject:subject:to:to; s=fm3; t=1765998698;\n x=1766085098; bh=e3tdTU5FgZzFrFyCe8/22sGzfbLFpKr2Ary/1eiPI3g=; b=\n hlXDYetzk/FXTDHwV8/7dpSZUkp7S7Ixzh6YaVh922XlIre16Z52B3ccADUsGOeC\n wgxoOeSrcrQYFsifku1rnvzdMlqrlAoQMHgcVKAPgKQROJ59saXGRnfxLDSiajnT\n ByCVZQJ5C4HnU1+NeQmJL7QW33Yu71AeLebGyi1zvNFNtLPz0rVc9qFfiQuXZorz\n rGI1GEIqz7+W5vRurul7aaBcFlf5xReZvrplSgrWLRTWYtNBrhEfpiZb3d3kLqMp\n REYRkZ4b7URgr239MQD6ujnEzHIVqEkwZ5XBGwH77/fEHvUoVDjPlmUecSOvpZQ9\n 4qPehObggeJJAdVsH3hj3Q==","v=1; a=rsa-sha256; c=relaxed/relaxed; d=\n messagingengine.com; h=cc:cc:content-transfer-encoding\n :content-type:content-type:date:date:feedback-id:feedback-id\n :from:from:in-reply-to:in-reply-to:message-id:mime-version\n :references:reply-to:subject:subject:to:to:x-me-proxy\n :x-me-sender:x-me-sender:x-sasl-enc; s=fm1; t=1765998698; x=\n 1766085098; bh=e3tdTU5FgZzFrFyCe8/22sGzfbLFpKr2Ary/1eiPI3g=; b=L\n 2TwPYtb2E1ytbo8H3Akr6N+luFipztkgVN/4QVDrVNTwNu714mUBcDRP994yeuYZ\n ujRV1tDJtv/VJ++xIfP/8dY3Yw5tE1cvhTAS8qjS2WA0SNSRWbT8N9esf+DTzinW\n +PTPWCpkZK/Yc85pMsxslUrbFvpPnDFMSxLSyXgYfcboyqbL2aXiipLytkxDUzFO\n ExWP3KEsxlPSwZK03HPA71kYXDTJLusQHW8lEUS55JlKU4pVv3aY2/kWvAXyXcsg\n KpKsCcjDVtZkKAiZ5++YQeD/ed7+U+IB8PvVf1fqWY58e8cAZFNqpF7uieKvF3tY\n gSnQHA4QsBcXHOUm88sKw=="],"X-ME-Sender":"<xms:agBDaUYqj82IBmje1XzjCaVuiiz3QOLi55ESLQwbSZWaJgnkWSWC3g>\n <xme:agBDaSfl7AJo0me5ywHWrcuyqzL3_xNxaWvmBlhL_La0dhl14dSSOkS4N9FHX0vHT\n w61trDNRdfP5S780YoF7qUBFxT6C9L6zWVsB0hLrN6IKc5mbw-nhPY>","X-ME-Received":"\n <xmr:agBDaZlz0IJkOnK6ZFLyVWhL6isiWs16bC5E0UDEwWg46NE45uBZ0pKZ_40>","X-ME-Proxy-Cause":"\n gggruggvucftvghtrhhoucdtuddrgeefgedrtddtgdegfeefjecutefuodetggdotefrod\n ftvfcurfhrohhfihhlvgemucfhrghsthforghilhdpuffrtefokffrpgfnqfghnecuuegr\n ihhlohhuthemuceftddtnecusecvtfgvtghiphhivghnthhsucdlqddutddtmdenfghrlh\n cuvffnffculdejtddmnecujfgurhephfffufggtgfgkfhfjgfvvefosehtjeertdertdej\n necuhfhrohhmpefrrghtrhhitghkucghihhllhhirghmshcuoehprghtrhhitghksehsth\n iftgigrdighiiiqeenucggtffrrghtthgvrhhnpeehjeejhfektedtuedtgfegjeekvdej\n gfehveelhedtfffhudevjeeikeehgfeltdenucevlhhushhtvghrufhiiigvpedunecurf\n grrhgrmhepmhgrihhlfhhrohhmpehprghtrhhitghksehsthiftgigrdighiiipdhnsggp\n rhgtphhtthhopedutddpmhhouggvpehsmhhtphhouhhtpdhrtghpthhtohepphgrthhrih\n gtkhesshhtfigtgidrgiihiidprhgtphhtthhopehpvghtvghrrdhmrgihuggvlhhlsehl\n ihhnrghrohdrohhrghdprhgtphhtthhopehsthgvvhgvnhgplhgvvgesrghsphgvvgguth\n gvtghhrdgtohhmpdhrtghpthhtohepqhgvmhhuqdgrrhhmsehnohhnghhnuhdrohhrghdp\n rhgtphhtthhopehjrghmihhnpghlihhnsegrshhpvggvughtvggthhdrtghomhdprhgtph\n htthhopegrnhgurhgvfiestghouggvtghonhhsthhruhgtthdrtghomhdrrghupdhrtghp\n thhtoheplhgvvghtrhhohiesghhmrghilhdrtghomhdprhgtphhtthhopehqvghmuhdqug\n gvvhgvlhesnhhonhhgnhhurdhorhhgpdhrtghpthhtohepjhhovghlsehjmhhsrdhiugdr\n rghu","X-ME-Proxy":"<xmx:agBDaa0lqxLwOT8nN9dseJrvq-lE0OGp-IvbKZOBOXUWaIHQfTlLKg>\n <xmx:agBDaafh9Atec16eq8F445Eh6WlSibekExG1dxOlMr7g8ClQX9Btxw>\n <xmx:agBDacYuZrTjwGbLPM1o3uhMBUMlOvTXFMWuHJDoHD-SnFgaoP8c7w>\n <xmx:agBDaXGQivlFxTB8C4KaYkHH8sPZ18o50_d3PnT34ttRkX8ISJad1A>\n <xmx:agBDaVybdAjfkN_vbQVmk8vceFXcaEbkrOao8ForUzHUerZxBnIbTlA0>","Feedback-ID":"i68a1478a:Fastmail","From":"Patrick Williams <patrick@stwcx.xyz>","Date":"Wed, 17 Dec 2025 14:11:35 -0500","Subject":"[PATCH 08/11] hw/arm/aspeed: catalina: add GB200-IO FRU EEPROM","MIME-Version":"1.0","Content-Type":"text/plain; charset=\"utf-8\"","Content-Transfer-Encoding":"7bit","Message-Id":"<20251217-catalina-eeproms-v1-8-dc7b276efd57@stwcx.xyz>","References":"<20251217-catalina-eeproms-v1-0-dc7b276efd57@stwcx.xyz>","In-Reply-To":"<20251217-catalina-eeproms-v1-0-dc7b276efd57@stwcx.xyz>","To":"qemu-devel@nongnu.org","Cc":"=?utf-8?q?C=C3=A9dric_Le_Goater?= <clg@kaod.org>,\n  Peter Maydell <peter.maydell@linaro.org>,\n  Steven Lee <steven_lee@aspeedtech.com>, Troy Lee <leetroy@gmail.com>,\n  Jamin Lin <jamin_lin@aspeedtech.com>,\n  Andrew Jeffery <andrew@codeconstruct.com.au>, Joel Stanley <joel@jms.id.au>,\n  qemu-arm@nongnu.org, Patrick Williams <patrick@stwcx.xyz>","X-Mailer":"b4 0.14.3","X-Developer-Signature":"v=1; a=openpgp-sha256; l=3520; i=patrick@stwcx.xyz;\n h=from:subject:message-id;\n bh=YEYbZFVnyrAhmT/IuKuOMQN6c9X+TkUpscRK8pFOgIQ=;\n b=owEBbQKS/ZANAwAIAasDR8wtAMEZAcsmYgBpQwBgbY1yG2MQ4rM3BakqeQFFpB1CYAPVLmZW8\n 8LTONm9moyJAjMEAAEIAB0WIQQEYP2KLgsT1w1uokGrA0fMLQDBGQUCaUMAYAAKCRCrA0fMLQDB\n GYXtD/9BztB5h8j++KXt3mg5quP0TgmrndTnvrgZ3wEDxa5+RCmPYucVmS2vcmapPnnptqFKEY9\n cNl63VdO4q4m5/T17+bnz7ip/l8avBk/ldSjQ58Tu4txpQm+pcrWOSr7/cRbAaADzJLzzzbtJV8\n trRX5maZIVoTQcOm9lVt4nnsgh88eX42XZPtKvj+yrymGawlKfGLemJlSD46fT8MtqNIyxEKibr\n zFiUCtW3NOcffcyHXdVPN4zXEr7CjHjzH5OWhxhBSi0cRBVr7MEoi3UdmzA7JisPvl3zE9INhUl\n UFk+3ZUl/DGQ28EUr5ujVs2Xqnk2MqtA13DOOyuBHVGQhQhV3hyRcfjtchvcgFc4Pbf8d0KF4+W\n Awo8Trd7FwxWUfQ0Tk/8Z0Fb6r/57ohS1peOLfJiEg2UmHWuoFEKG6afioiX8ozdTG98wSY1EDA\n HhwrEEZhpV6UIkUmBSws4/XTwDd8HhE1Rkm1IA6qnqpWS1clAbRQ7zvDhy1bJPS4Z0tCnGMH/2n\n VhT8V4ty2rXoMf2ud0xdXNlUDPFNH7Xm0c+RKMZznfNCH+cLCYmRDfblRihBaogsXEheYQgwYot\n u2c7SvQxqAPk4CICSSdWpdTzK12Jb9EqE7L5Cp/6+DUaNl1lGHmBfvHjWJ//Yd/l9TtLTiCOgG1\n ZOnj2Nep/ExhrqA==","X-Developer-Key":"i=patrick@stwcx.xyz; a=openpgp;\n fpr=0460FD8A2E0B13D70D6EA241AB0347CC2D00C119","Received-SPF":"pass client-ip=103.168.172.151; envelope-from=patrick@stwcx.xyz;\n helo=fout-a8-smtp.messagingengine.com","X-Spam_score_int":"-2","X-Spam_score":"-0.3","X-Spam_bar":"/","X-Spam_report":"(-0.3 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1,\n DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1,\n FROM_SUSPICIOUS_NTLD=0.498, PDS_OTHER_BAD_TLD=1.997, RCVD_IN_DNSWL_LOW=-0.7,\n RCVD_IN_VALIDITY_RPBL_BLOCKED=0.001, RCVD_IN_VALIDITY_SAFE_BLOCKED=0.001,\n SPF_HELO_PASS=-0.001, SPF_PASS=-0.001 autolearn=no autolearn_force=no","X-Spam_action":"no action","X-BeenThere":"qemu-devel@nongnu.org","X-Mailman-Version":"2.1.29","Precedence":"list","List-Id":"<qemu-devel.nongnu.org>","List-Unsubscribe":"<https://lists.nongnu.org/mailman/options/qemu-devel>,\n <mailto:qemu-devel-request@nongnu.org?subject=unsubscribe>","List-Archive":"<https://lists.nongnu.org/archive/html/qemu-devel>","List-Post":"<mailto:qemu-devel@nongnu.org>","List-Help":"<mailto:qemu-devel-request@nongnu.org?subject=help>","List-Subscribe":"<https://lists.nongnu.org/mailman/listinfo/qemu-devel>,\n <mailto:qemu-devel-request@nongnu.org?subject=subscribe>","Errors-To":"qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org","Sender":"qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org"},"content":"Use ipmitool/frugen tool to generate a GB200-IO image based on a\nsanitized set of data from a real device EEPROM.\n\nSigned-off-by: Patrick Williams <patrick@stwcx.xyz>\n---\n hw/arm/aspeed_ast2600_catalina.c | 43 ++++++++++++++++++++++++++++++++++++++--\n 1 file changed, 41 insertions(+), 2 deletions(-)","diff":"diff --git a/hw/arm/aspeed_ast2600_catalina.c b/hw/arm/aspeed_ast2600_catalina.c\nindex 4dd72c615d..37f0e1b65e 100644\n--- a/hw/arm/aspeed_ast2600_catalina.c\n+++ b/hw/arm/aspeed_ast2600_catalina.c\n@@ -304,6 +304,43 @@ static const uint8_t gb200_eeprom[] = {\n };\n static const size_t gb200_eeprom_len = sizeof(gb200_eeprom);\n \n+/*\n+ * GB200 IO Board FRU data. Generated with frugen.\n+ *\n+ *    {\n+ *        \"board\": {\n+ *            \"mfg\": \"Nvidia\",\n+ *            \"pname\": \"2x ConnectX-7 Mezz (QEMU)\",\n+ *            \"pn\": \"000-00000-0000-000\",\n+ *            \"serial\": \"000000000000\",\n+ *            \"date\": \"01/12/2025 00:00\"\n+ *        },\n+ *        \"product\": {\n+ *            \"mfg\": \"Nvidia\",\n+ *            \"pname\": \"2x ConnectX-7 Mezz\",\n+ *            \"pn\": \"100-00000-0000-001\",\n+ *            \"ver\": \"A1\",\n+ *            \"serial\": \"100000000001\",\n+ *            \"atag\": \"QEMU\"\n+ *        }\n+ *    }\n+ */\n+static const uint8_t gb200io_eeprom[] = {\n+    0x01, 0x00, 0x00, 0x01, 0x0a, 0x00, 0x00, 0xf4, 0x01, 0x09, 0x19, 0x8c,\n+    0x19, 0xf0, 0xc6, 0x4e, 0x76, 0x69, 0x64, 0x69, 0x61, 0xd9, 0x32, 0x78,\n+    0x20, 0x43, 0x6f, 0x6e, 0x6e, 0x65, 0x63, 0x74, 0x58, 0x2d, 0x37, 0x20,\n+    0x4d, 0x65, 0x7a, 0x7a, 0x20, 0x28, 0x51, 0x45, 0x4d, 0x55, 0x29, 0x89,\n+    0x10, 0x04, 0x41, 0x10, 0x04, 0x41, 0x10, 0x04, 0x41, 0x8e, 0x10, 0x04,\n+    0x35, 0x10, 0x04, 0x41, 0x50, 0x03, 0x41, 0x10, 0xd4, 0x40, 0x10, 0x04,\n+    0xc0, 0xc1, 0x00, 0x00, 0x00, 0x00, 0x00, 0x8e, 0x01, 0x08, 0x19, 0xc6,\n+    0x4e, 0x76, 0x69, 0x64, 0x69, 0x61, 0xd2, 0x32, 0x78, 0x20, 0x43, 0x6f,\n+    0x6e, 0x6e, 0x65, 0x63, 0x74, 0x58, 0x2d, 0x37, 0x20, 0x4d, 0x65, 0x7a,\n+    0x7a, 0x8e, 0x11, 0x04, 0x35, 0x10, 0x04, 0x41, 0x50, 0x03, 0x41, 0x10,\n+    0xd4, 0x40, 0x50, 0x04, 0x82, 0x61, 0x04, 0x89, 0x11, 0x04, 0x41, 0x10,\n+    0x04, 0x41, 0x10, 0x04, 0x45, 0x83, 0x71, 0xd9, 0xd6, 0xc0, 0xc1, 0x04\n+};\n+static const size_t gb200io_eeprom_len = sizeof(gb200io_eeprom);\n+\n static void catalina_bmc_i2c_init(AspeedMachineState *bmc)\n {\n     /* Reference from v6.16-rc2 aspeed-bmc-facebook-catalina.dts */\n@@ -329,7 +366,8 @@ static void catalina_bmc_i2c_init(AspeedMachineState *bmc)\n     i2c_slave_create_simple(pca954x_i2c_get_bus(i2c_mux, 1),\n                             TYPE_PCA9552, 0x20);\n     /* eeprom@50 */\n-    at24c_eeprom_init(pca954x_i2c_get_bus(i2c_mux, 1), 0x50, 8 * KiB);\n+    at24c_eeprom_init_rom(pca954x_i2c_get_bus(i2c_mux, 1), 0x50, 8 * KiB,\n+                          gb200io_eeprom, gb200io_eeprom_len);\n \n     /* i2c-mux@73 (PCA9546) on i2c0 */\n     i2c_slave_create_simple(i2c[0], TYPE_PCA9546, 0x73);\n@@ -345,7 +383,8 @@ static void catalina_bmc_i2c_init(AspeedMachineState *bmc)\n     i2c_slave_create_simple(pca954x_i2c_get_bus(i2c_mux, 1),\n                             TYPE_PCA9552, 0x21);\n     /* eeprom@50 */\n-    at24c_eeprom_init(pca954x_i2c_get_bus(i2c_mux, 1), 0x50, 8 * KiB);\n+    at24c_eeprom_init_rom(pca954x_i2c_get_bus(i2c_mux, 1), 0x50, 8 * KiB,\n+                          gb200io_eeprom, gb200io_eeprom_len);\n \n     /* i2c-mux@77 (PCA9546) on i2c0 */\n     i2c_slave_create_simple(i2c[0], TYPE_PCA9546, 0x77);\n","prefixes":["08/11"]}