{"id":2175332,"url":"http://patchwork.ozlabs.org/api/1.0/patches/2175332/?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-7-dc7b276efd57@stwcx.xyz>","date":"2025-12-17T19:11:34","name":"[07/11] hw/arm/aspeed: catalina: add GB200 FRU EEPROM","commit_ref":null,"pull_url":null,"state":"new","archived":false,"hash":"d4551465b014a02e0d1e3140777c5f652fd12596","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-7-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/2175332/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=ESm4D5Mf;\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=ALWKsjBq;\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 4dWk3b2mpXz1y0P\n\tfor <incoming@patchwork.ozlabs.org>; Thu, 18 Dec 2025 06:13:31 +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 1vVww2-0005gg-Lu; Wed, 17 Dec 2025 14:11:42 -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 1vVwvz-0005ex-Tv; Wed, 17 Dec 2025 14:11:39 -0500","from fhigh-a1-smtp.messagingengine.com ([103.168.172.152])\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 1vVwvy-00016H-8p; Wed, 17 Dec 2025 14:11:39 -0500","from phl-compute-01.internal (phl-compute-01.internal [10.202.2.41])\n by mailfhigh.phl.internal (Postfix) with ESMTP id 63CCA140014F;\n Wed, 17 Dec 2025 14:11:37 -0500 (EST)","from phl-frontend-03 ([10.202.2.162])\n by phl-compute-01.internal (MEProxy); Wed, 17 Dec 2025 14:11:37 -0500","by mail.messagingengine.com (Postfix) with ESMTPA; Wed,\n 17 Dec 2025 14:11:36 -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=1765998697;\n x=1766085097; bh=qfeYsXVWAamQv+Ll4jDPpTtSNBLztoYOt1G2d/WxGMw=; b=\n ESm4D5MflflwbPYfpx039023JlPMGl0mcfzK8q04182ZONcUjhOLsB9uGqZmwOfa\n VK5QROVFOVkYjWLSJK4n+jYwXwAmJPURnsbAPKlX9ClvXMx69GXs5LpnrfjRa858\n 4AvVQ0CEr+e1U2avSZxpt7//mp1umQmH5abLNhNS18B7aWyk67HpQ6t1xwrj6VHd\n wOuQYY/zbZbk8+v2BmwXvPSUQYcDEKIRkFDwOzWu18BCrL4VFW5Pb9t1QALggkVI\n W5XFB22cUwOaQ03GPU94/DfO+//j3HJQgGjVQ6erTO45RIXiUBE9R759VL7Uz5fu\n S30tEZIRP2JnOiElr6IHqA==","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=1765998697; x=\n 1766085097; bh=qfeYsXVWAamQv+Ll4jDPpTtSNBLztoYOt1G2d/WxGMw=; b=A\n LWKsjBqtV0etHttVzo3KFtufdWi+qElNvi3E88Hubi/AQYT8glKDUAo8XMdXkXo6\n S+K6P5CSFEaSFM0bkQULAfItJAnivYrm85ctiMLLEJlZy+n/tP1J8dKwIu/lligD\n Q/MzFd3pdknpBnh9/qu0uRehBxt2650PXnKyOxwbJTtzR/Ocm6dRGHEUshkoVfZv\n XdaqAcQdeaCMUPUoG0ZulNi+C0IrYYbYD0XzJyjlwKzWd1mYbz4Wgujdkdz0tghR\n UNGnbXD081Vj5bZWcNr7kteGAGGwWsu/gXFU92xoeC3k/Q9qvsqcoLw8FRWCwQAD\n ToVqysCxlAwVRP8J4efDQ=="],"X-ME-Sender":"<xms:aQBDaSmuabNT_oUXMWHCuRng_QMzUpxvtIq8BuljxKQunvU672EcHg>\n <xme:aQBDac7-uKL8v4Mr0PAojdeybnU_MhPKRgT9YbRwsQjGz68_7jOxSqCiTv8xmRTAd\n rRd3tAaU4CqpkMLL3x_hsgsOqNIZ6JNfUO1V3HMJnN7KUlGFkQluKes>","X-ME-Received":"\n <xmr:aQBDabRpt2P2UPXG6uacURhyVHIOqV3cuhdKHLkItLzWQVoTghIcA5c-uLo>","X-ME-Proxy-Cause":"\n gggruggvucftvghtrhhoucdtuddrgeefgedrtddtgdegfeefjecutefuodetggdotefrod\n ftvfcurfhrohhfihhlvgemucfhrghsthforghilhdpuffrtefokffrpgfnqfghnecuuegr\n ihhlohhuthemuceftddtnecusecvtfgvtghiphhivghnthhsucdlqddutddtmdenfghrlh\n cuvffnffculdejtddmnecujfgurhephfffufggtgfgkfhfjgfvvefosehtjeertdertdej\n necuhfhrohhmpefrrghtrhhitghkucghihhllhhirghmshcuoehprghtrhhitghksehsth\n iftgigrdighiiiqeenucggtffrrghtthgvrhhnpeehjeejhfektedtuedtgfegjeekvdej\n gfehveelhedtfffhudevjeeikeehgfeltdenucevlhhushhtvghrufhiiigvpedtnecurf\n grrhgrmhepmhgrihhlfhhrohhmpehprghtrhhitghksehsthiftgigrdighiiipdhnsggp\n rhgtphhtthhopedutddpmhhouggvpehsmhhtphhouhhtpdhrtghpthhtohepphgrthhrih\n gtkhesshhtfigtgidrgiihiidprhgtphhtthhopehpvghtvghrrdhmrgihuggvlhhlsehl\n ihhnrghrohdrohhrghdprhgtphhtthhopehsthgvvhgvnhgplhgvvgesrghsphgvvgguth\n gvtghhrdgtohhmpdhrtghpthhtohepqhgvmhhuqdgrrhhmsehnohhnghhnuhdrohhrghdp\n rhgtphhtthhopehjrghmihhnpghlihhnsegrshhpvggvughtvggthhdrtghomhdprhgtph\n htthhopegrnhgurhgvfiestghouggvtghonhhsthhruhgtthdrtghomhdrrghupdhrtghp\n thhtoheplhgvvghtrhhohiesghhmrghilhdrtghomhdprhgtphhtthhopehqvghmuhdqug\n gvvhgvlhesnhhonhhgnhhurdhorhhgpdhrtghpthhtohepjhhovghlsehjmhhsrdhiugdr\n rghu","X-ME-Proxy":"<xmx:aQBDaSwxAqH6uAAY3MlDZYW088uSCMbooPZ3ddB400z32aBqRf2NCg>\n <xmx:aQBDabrgbJb3QSPJHf372zj3z2rkOAdaEgTk_iKPYg4pom6tFNqwKw>\n <xmx:aQBDad3bLBgGYeN3ZxyuVaJSQubwiBBgp5iV6pC3qD6vi0rLxgjlpQ>\n <xmx:aQBDaTzt2HfuWFaEIEnH_oMmiws_Mlxq8L8kPjeV2hoWSw1bH5Qhtg>\n <xmx:aQBDaXmwXbVTxzfIW86YNaPdmyYJKNPXCNVR8fiYYurCRCVzCMG918k9>","Feedback-ID":"i68a1478a:Fastmail","From":"Patrick Williams <patrick@stwcx.xyz>","Date":"Wed, 17 Dec 2025 14:11:34 -0500","Subject":"[PATCH 07/11] hw/arm/aspeed: catalina: add GB200 FRU EEPROM","MIME-Version":"1.0","Content-Type":"text/plain; charset=\"utf-8\"","Content-Transfer-Encoding":"7bit","Message-Id":"<20251217-catalina-eeproms-v1-7-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=3130; i=patrick@stwcx.xyz;\n h=from:subject:message-id;\n bh=JSq4Zf5ecxblPDZJopak/nNSkZ7TP5kw4S/wVk7Xn+I=;\n b=owEBbQKS/ZANAwAIAasDR8wtAMEZAcsmYgBpQwBg1Cxzk5WdrFOAW4SAbefiXgygHvdAYdhXr\n o8hGGexiA2JAjMEAAEIAB0WIQQEYP2KLgsT1w1uokGrA0fMLQDBGQUCaUMAYAAKCRCrA0fMLQDB\n GdFlD/45Thcd2ccfOvRpeq8AVnjEvCdGDz/JwtZhDgVq2Mf51qkjY6ZDV9u19J0u6pJsj+VTmYz\n AbxfMXpz/EgdvGR40d2ltqWq6ECIGn6AJrk7g2eLI2EO0AzzLtB+WmLh3jDETFEGejjmfQ1VXHx\n VkJtngO2rUj347cFAtLd5xDG5IXCztXwJ9OYKD8N7PkaP7gtJYhLCOX4UA/qnGMdvRoSXfAE4Lw\n XaMNwYJqjwMTR4ErYkarVpbL970naW/nBF+rIig5HOshSkMY3PLE3N3czwcTL+uHQiS089DlrWl\n /F/Jg1OU/6PhVjyxW31Hdc3/BWbCwZJZnr6uy8c23Cr1mTTnC8L9VNokamFvp38Wu3SoqBTnapK\n nthVw7aMx85/PjXHWVdqD18p+Mdj6rgjtBzqjmp30ScsjTeotYjoowMbYORT8f+CR/FsZWJvizD\n 0iJkOGRKEh0vyU7DodX3B6yBUnuS/1j9JaE7Nl32whEVsCCjE1bfSe6RTua1XKvU7nDQ4PmUntM\n Kc00zhNbrV7SrYlZUD11tAiE9DiQorFs8XaihxUXB4ZUO/WW9GJBJ/9o9dCweALIjq1nCYqBc0S\n MgHYjugE18akhtQhTwfNZ5tkaQOVhTRLdgdlJOYWjdsDg0Naufh1Ac8E5vYQOvNPovfnxNOXCQe\n fJ+yu1CfHsuR3FA==","X-Developer-Key":"i=patrick@stwcx.xyz; a=openpgp;\n fpr=0460FD8A2E0B13D70D6EA241AB0347CC2D00C119","Received-SPF":"pass client-ip=103.168.172.152; envelope-from=patrick@stwcx.xyz;\n helo=fhigh-a1-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 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 | 45 ++++++++++++++++++++++++++++++++++++++--\n 1 file changed, 43 insertions(+), 2 deletions(-)","diff":"diff --git a/hw/arm/aspeed_ast2600_catalina.c b/hw/arm/aspeed_ast2600_catalina.c\nindex 4cfde870af..4dd72c615d 100644\n--- a/hw/arm/aspeed_ast2600_catalina.c\n+++ b/hw/arm/aspeed_ast2600_catalina.c\n@@ -265,6 +265,45 @@ static const uint8_t hdd_eeprom[] = {\n };\n static const size_t hdd_eeprom_len = sizeof(hdd_eeprom);\n \n+/*\n+ * GB200 CPU/GPU Board FRU data. Generated with frugen.\n+ *\n+ *    {\n+ *        \"board\": {\n+ *            \"mfg\": \"NVIDIA\",\n+ *            \"pname\": \"PG548 (QEMU)\",\n+ *            \"pn\": \"000-00000-0000-000\",\n+ *            \"serial\": \"0000000000000\",\n+ *            \"date\": \"01/12/2025 00:00\",\n+ *            \"custom\": [\"Version: A\", \"Rework:\"]\n+ *        },\n+ *        \"product\": {\n+ *            \"mfg\": \"NVIDIA\",\n+ *            \"pname\": \"GB200 1CPU:1GPU Board PC\",\n+ *            \"pn\": \"100-00000-0000-001\",\n+ *            \"ver\": \"E01\",\n+ *            \"serial\": \"1000000000001\",\n+ *            \"atag\": \"QEMU\"\n+ *        }\n+ *    }\n+ */\n+static const uint8_t gb200_eeprom[] = {\n+    0x01, 0x00, 0x00, 0x01, 0x0a, 0x00, 0x00, 0xf4, 0x01, 0x09, 0x19, 0x8c,\n+    0x19, 0xf0, 0x85, 0xae, 0x9d, 0x92, 0x69, 0x08, 0x89, 0xf0, 0x59, 0x51,\n+    0x18, 0x80, 0xc4, 0x65, 0x5b, 0x27, 0x8a, 0x10, 0x04, 0x41, 0x10, 0x04,\n+    0x41, 0x10, 0x04, 0x41, 0x10, 0x8e, 0x10, 0x04, 0x35, 0x10, 0x04, 0x41,\n+    0x50, 0x03, 0x41, 0x10, 0xd4, 0x40, 0x10, 0x04, 0xc0, 0xca, 0x56, 0x65,\n+    0x72, 0x73, 0x69, 0x6f, 0x6e, 0x3a, 0x20, 0x41, 0xc7, 0x52, 0x65, 0x77,\n+    0x6f, 0x72, 0x6b, 0x3a, 0xc1, 0x00, 0x00, 0x37, 0x01, 0x09, 0x19, 0x85,\n+    0xae, 0x9d, 0x92, 0x69, 0x08, 0xd8, 0x47, 0x42, 0x32, 0x30, 0x30, 0x20,\n+    0x31, 0x43, 0x50, 0x55, 0x3a, 0x31, 0x47, 0x50, 0x55, 0x20, 0x42, 0x6f,\n+    0x61, 0x72, 0x64, 0x20, 0x50, 0x43, 0x8e, 0x11, 0x04, 0x35, 0x10, 0x04,\n+    0x41, 0x50, 0x03, 0x41, 0x10, 0xd4, 0x40, 0x50, 0x04, 0x83, 0x25, 0x14,\n+    0x01, 0x8a, 0x11, 0x04, 0x41, 0x10, 0x04, 0x41, 0x10, 0x04, 0x41, 0x11,\n+    0x83, 0x71, 0xd9, 0xd6, 0xc0, 0xc1, 0x00, 0x17\n+};\n+static const size_t gb200_eeprom_len = sizeof(gb200_eeprom);\n+\n static void catalina_bmc_i2c_init(AspeedMachineState *bmc)\n {\n     /* Reference from v6.16-rc2 aspeed-bmc-facebook-catalina.dts */\n@@ -403,11 +442,13 @@ static void catalina_bmc_i2c_init(AspeedMachineState *bmc)\n \n     /* &i2c12 */\n     /* eeprom@50 */\n-    at24c_eeprom_init(i2c[12], 0x50, 8 * KiB);\n+    at24c_eeprom_init_rom(i2c[12], 0x50, 8 * KiB,\n+                          gb200_eeprom, gb200_eeprom_len);\n \n     /* &i2c13 */\n     /* eeprom@50 */\n-    at24c_eeprom_init(i2c[13], 0x50, 8 * KiB);\n+    at24c_eeprom_init_rom(i2c[13], 0x50, 8 * KiB,\n+                          gb200_eeprom, gb200_eeprom_len);\n     /* eeprom@54 */\n     at24c_eeprom_init(i2c[13], 0x54, 256);\n     /* eeprom@55 */\n","prefixes":["07/11"]}