From nobody Sat Nov 15 16:38:22 2025 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass(p=none dis=none) header.from=nongnu.org ARC-Seal: i=1; a=rsa-sha256; t=1750315401; cv=none; d=zohomail.com; s=zohoarc; b=Tu784NLLTFoORUi4L39ZfFlVFnhf8nxNRlmgj/V1joRjiDGmjcq/BOoQmRXfprH6Pu3dNIJC9F8w1DHn+5fS5zy3yNJL3IusZpG5qQ3ON2Bk7eCtdXB3hGsUn+4dzWx5EiTgl2VO7KUZ/sbqx1m3YB075jPQrKSCHQtolEhPOZg= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1750315401; h=Content-Type:Content-Transfer-Encoding:Cc:Cc:Date:Date:From:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:Reply-To:Reply-To:References:Sender:Subject:Subject:To:To:Message-Id; bh=hvO/8YNJPKDGoGQeJYTTwlggRsuJhO87KEMX95dz3bw=; b=Tmd2GTp0JGNEesL9YHesPp0YG4jBO8rBnMcHT1rjFaJyRd/wESO5knduKKLGiw6AZlm6yf9dSS3InPwIIraz9kb3/jmE6rnt7IJshglzi/fmp2c8Fp399fAX2UTHUSw7OvQ2ToavK2aBisKlPTNHs6sQRkcoHuJ5wHVEXwB7pXo= ARC-Authentication-Results: i=1; mx.zohomail.com; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=pass header.from= (p=none dis=none) Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1750315401410688.631106361197; Wed, 18 Jun 2025 23:43:21 -0700 (PDT) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1uS8y4-0002YV-Ro; Thu, 19 Jun 2025 02:41:48 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1uS8xz-0002Xa-AH; Thu, 19 Jun 2025 02:41:46 -0400 Received: from mail.aspeedtech.com ([211.20.114.72] helo=TWMBX01.aspeed.com) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1uS8xx-0001s1-3q; Thu, 19 Jun 2025 02:41:42 -0400 Received: from TWMBX01.aspeed.com (192.168.0.62) by TWMBX01.aspeed.com (192.168.0.62) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1748.10; Thu, 19 Jun 2025 14:41:17 +0800 Received: from mail.aspeedtech.com (192.168.10.10) by TWMBX01.aspeed.com (192.168.0.62) with Microsoft SMTP Server id 15.2.1748.10 via Frontend Transport; Thu, 19 Jun 2025 14:41:17 +0800 To: =?UTF-8?q?C=C3=A9dric=20Le=20Goater?= , Peter Maydell , Steven Lee , Troy Lee , Jamin Lin , Andrew Jeffery , Joel Stanley , "open list:ASPEED BMCs" , "open list:All patches CC here" CC: , Kane-Chen-AS Subject: [RFC v5 4/4] tests/functional: Add integration tests for ASPEED OTP memory model Date: Thu, 19 Jun 2025 14:41:13 +0800 Message-ID: <20250619064115.4182202-5-kane_chen@aspeedtech.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20250619064115.4182202-1-kane_chen@aspeedtech.com> References: <20250619064115.4182202-1-kane_chen@aspeedtech.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Received-SPF: pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=211.20.114.72; envelope-from=kane_chen@aspeedtech.com; helo=TWMBX01.aspeed.com X-Spam_score_int: -18 X-Spam_score: -1.9 X-Spam_bar: - X-Spam_report: (-1.9 / 5.0 requ) BAYES_00=-1.9, RCVD_IN_VALIDITY_CERTIFIED_BLOCKED=0.001, RCVD_IN_VALIDITY_RPBL_BLOCKED=0.001, SPF_HELO_FAIL=0.001, SPF_PASS=-0.001 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Reply-to: Kane Chen From: Kane Chen via Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: qemu-devel-bounces+importer=patchew.org@nongnu.org X-ZM-MESSAGEID: 1750315402473116600 Content-Type: text/plain; charset="utf-8" From: Kane-Chen-AS Introduce a functional test suite to validate the ASPEED OTP memory device integration under different machine configurations. The following cases are covered: - AST2600 with blockdev + device + machine parameter (full binding) - AST2600 fallback with no machine parameter - AST2600 with only blockdev + device (no machine param) - AST2600 with only machine parameter (no backend/device) - AST1030 fallback test with Zephyr-based image The tests ensure that the OTP model behaves correctly across boot-time binding variations and fallback paths, and that firmware boot is successful under each condition. Signed-off-by: Kane-Chen-AS --- tests/functional/meson.build | 1 + tests/functional/test_aspeed_otpmem.py | 82 ++++++++++++++++++++++++++ 2 files changed, 83 insertions(+) create mode 100644 tests/functional/test_aspeed_otpmem.py diff --git a/tests/functional/meson.build b/tests/functional/meson.build index e9f19d54a2..ce999eeab1 100644 --- a/tests/functional/meson.build +++ b/tests/functional/meson.build @@ -41,6 +41,7 @@ test_timeouts =3D { 'arm_replay' : 240, 'arm_tuxrun' : 240, 'arm_sx1' : 360, + 'aspeed_otpmem': 1200, 'intel_iommu': 300, 'mips_malta' : 480, 'mipsel_malta' : 420, diff --git a/tests/functional/test_aspeed_otpmem.py b/tests/functional/test= _aspeed_otpmem.py new file mode 100644 index 0000000000..67d2a7ecf6 --- /dev/null +++ b/tests/functional/test_aspeed_otpmem.py @@ -0,0 +1,82 @@ + +import os +import time +import tempfile +import subprocess + +from qemu_test import LinuxKernelTest, Asset +from aspeed import AspeedTest +from qemu_test import exec_command_and_wait_for_pattern, skipIfMissingComm= ands + +class AspeedOtpMemoryTest(AspeedTest): + # AST2600 SDK image + ASSET_SDK_V906_AST2600 =3D Asset( + 'https://github.com/AspeedTech-BMC/openbmc/releases/download/v09.0= 6/ast2600-default-obmc.tar.gz', + '768d76e247896ad78c154b9cff4f766da2ce65f217d620b286a4a03a8a4f68f5') + + # AST1030 Zephyr image + ASSET_ZEPHYR_3_00 =3D Asset( + ('https://github.com/AspeedTech-BMC' + '/zephyr/releases/download/v00.03.00/ast1030-evb-demo.zip'), + '37fe3ecd4a1b9d620971a15b96492a81093435396eeac69b6f3e384262ff555f') + def generate_otpmem_image(self): + path =3D self.scratch_file("otpmem.img") + pattern =3D b'\x00\x00\x00\x00\xff\xff\xff\xff' * (16 * 1024 // 8) + with open(path, "wb") as f: + f.write(pattern) + return path + + def test_ast2600_otp_fallback(self): + image_path =3D self.archive_extract(self.ASSET_SDK_V906_AST2600) + bmc_image =3D self.scratch_file("ast2600-default", "image-bmc") + self.vm.set_machine("ast2600-evb") + self.vm.set_console() + self.do_test_arm_aspeed_sdk_start( + self.scratch_file("ast2600-default", "image-bmc")) + self.wait_for_console_pattern('ast2600-default login:') + + def test_ast2600_otp_blockdev_device(self): + image_path =3D self.archive_extract(self.ASSET_SDK_V906_AST2600) + otp_img =3D self.generate_otpmem_image() + self.vm.set_console() + self.vm.add_args( + "-blockdev", f"node-name=3Dotpmem,driver=3Dfile,filename=3D{ot= p_img}", + "-device", "aspeed.otpmem,drive=3Dotpmem,id=3Dotpmem-drive", + "-machine", "ast2600-evb,otpmem=3Dotpmem-drive" + ) + self.do_test_arm_aspeed_sdk_start(self.scratch_file("ast2600-defau= lt", "image-bmc")) + self.wait_for_console_pattern("ast2600-default login:") + + def test_ast2600_otp_only_blockdev(self): + image_path =3D self.archive_extract(self.ASSET_SDK_V906_AST2600) + otp_img =3D self.generate_otpmem_image() + self.vm.set_machine("ast2600-evb") + self.vm.set_console() + self.vm.add_args( + "-blockdev", f"node-name=3Dotpmem,driver=3Dfile,filename=3D{ot= p_img}", + "-device", "aspeed.otpmem,drive=3Dotpmem,id=3Dotpmem-drive", + ) + self.do_test_arm_aspeed_sdk_start(self.scratch_file("ast2600-defau= lt", "image-bmc")) + self.wait_for_console_pattern("ast2600-default login:") + + def test_ast2600_otp_only_machine_param(self): + image_path =3D self.archive_extract(self.ASSET_SDK_V906_AST2600) + self.vm.set_console() + self.vm.add_args( + "-machine", "ast2600-evb,otpmem=3Dotpmem-drive" + ) + self.do_test_arm_aspeed_sdk_start(self.scratch_file("ast2600-defau= lt", "image-bmc")) + self.wait_for_console_pattern("ast2600-default login:") + + def test_ast1030_otp_fallback(self): + kernel_name =3D "ast1030-evb-demo/zephyr.elf" + kernel_file =3D self.archive_extract(self.ASSET_ZEPHYR_3_00, membe= r=3Dkernel_name) + + self.vm.set_machine("ast1030-evb") + self.vm.set_console() + self.vm.add_args("-kernel", kernel_file) + self.vm.launch() + self.wait_for_console_pattern("Booting Zephyr OS") + +if __name__ =3D=3D '__main__': + AspeedTest.main() \ No newline at end of file --=20 2.43.0