From: "Alex Bennée" <alex.bennee@linaro.org>
To: qemu-devel@nongnu.org
Cc: "Halil Pasic" <pasic@linux.ibm.com>,
"Aurelien Jarno" <aurelien@aurel32.net>,
qemu-riscv@nongnu.org, "Radoslaw Biernacki" <rad@semihalf.com>,
"Daniel Henrique Barboza" <danielhb413@gmail.com>,
"Alex Bennée" <alex.bennee@linaro.org>,
"Marcel Apfelbaum" <marcel.apfelbaum@gmail.com>,
"Richard Henderson" <richard.henderson@linaro.org>,
"Beraldo Leal" <bleal@redhat.com>,
"Fabiano Rosas" <farosas@suse.de>,
"Mark Cave-Ayland" <mark.cave-ayland@ilande.co.uk>,
"Laurent Vivier" <lvivier@redhat.com>,
"Nicholas Piggin" <npiggin@gmail.com>,
"Marcin Juszkiewicz" <marcin.juszkiewicz@linaro.org>,
"Christian Borntraeger" <borntraeger@linux.ibm.com>,
"Wainer dos Santos Moschetta" <wainersm@redhat.com>,
"Marc-André Lureau" <marcandre.lureau@redhat.com>,
"Ed Maste" <emaste@freebsd.org>,
"Jiaxun Yang" <jiaxun.yang@flygoat.com>,
"Bernhard Beschow" <shentey@gmail.com>,
"Bin Meng" <bmeng.cn@gmail.com>,
qemu-ppc@nongnu.org, qemu-arm@nongnu.org,
"Laurent Vivier" <laurent@vivier.eu>,
"Joel Stanley" <joel@jms.id.au>,
"Philippe Mathieu-Daudé" <philmd@linaro.org>,
"John Snow" <jsnow@redhat.com>,
"Michael S. Tsirkin" <mst@redhat.com>,
"Pavel Dovgalyuk" <pavel.dovgaluk@ispras.ru>,
"Alistair Francis" <alistair.francis@wdc.com>,
"Liu Zhiwei" <zhiwei_liu@linux.alibaba.com>,
"Harsh Prateek Bora" <harshpb@linux.ibm.com>,
"Leif Lindholm" <quic_llindhol@quicinc.com>,
"Cleber Rosa" <crosa@redhat.com>,
"Thomas Huth" <thuth@redhat.com>,
"Paolo Bonzini" <pbonzini@redhat.com>,
qemu-s390x@nongnu.org, "Eric Farman" <farman@linux.ibm.com>,
"Weiwei Li" <liwei1518@gmail.com>,
"Daniel P. Berrangé" <berrange@redhat.com>,
"Markus Armbruster" <armbru@redhat.com>,
"Daniel Henrique Barboza" <dbarboza@ventanamicro.com>,
"Palmer Dabbelt" <palmer@dabbelt.com>,
"Peter Maydell" <peter.maydell@linaro.org>,
"Li-Wen Hsu" <lwhsu@freebsd.org>
Subject: [PATCH v4 23/32] tests/functional: extend test_aarch64_virt with vulkan test
Date: Wed, 8 Jan 2025 12:10:45 +0000 [thread overview]
Message-ID: <20250108121054.1126164-24-alex.bennee@linaro.org> (raw)
In-Reply-To: <20250108121054.1126164-1-alex.bennee@linaro.org>
Now that we have virtio-gpu Vulkan support, let's add a test for it.
Currently this is using images build by buildroot:
https://lists.buildroot.org/pipermail/buildroot/2024-December/768196.html
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
---
v2
- use decorator for has_cmd(zstd)
- un-handled->unhandled
- drop extra - from --snapshot
- drop unneeded virtualization=on
- only show 1s of each scene
- fix long lines
v3
- move set_machine/require_accelerator to top of test
- use uncompress utility function
- remove extra ()'s from ASSETS
v4
- split misc fixups into earlier commits
- don't swallow leading newlines before class
- fixup commit message
---
tests/functional/test_aarch64_virt.py | 74 ++++++++++++++++++++++++++-
1 file changed, 72 insertions(+), 2 deletions(-)
diff --git a/tests/functional/test_aarch64_virt.py b/tests/functional/test_aarch64_virt.py
index 201c5ed023..6b2336a28d 100755
--- a/tests/functional/test_aarch64_virt.py
+++ b/tests/functional/test_aarch64_virt.py
@@ -13,10 +13,12 @@
import logging
from subprocess import check_call, DEVNULL
+from qemu.machine.machine import VMLaunchFailure
+
from qemu_test import QemuSystemTest, Asset
-from qemu_test import exec_command_and_wait_for_pattern
+from qemu_test import exec_command, exec_command_and_wait_for_pattern
from qemu_test import wait_for_console_pattern
-from qemu_test import get_qemu_img
+from qemu_test import skipIfMissingCommands, get_qemu_img
class Aarch64VirtMachine(QemuSystemTest):
@@ -132,5 +134,73 @@ def test_aarch64_virt_gicv2(self):
self.common_aarch64_virt("virt,gic-version=2")
+ ASSET_VIRT_GPU_KERNEL = Asset(
+ 'https://fileserver.linaro.org/s/ce5jXBFinPxtEdx/'
+ 'download?path=%2F&files='
+ 'Image',
+ '89e5099d26166204cc5ca4bb6d1a11b92c217e1f82ec67e3ba363d09157462f6')
+
+ ASSET_VIRT_GPU_ROOTFS = Asset(
+ 'https://fileserver.linaro.org/s/ce5jXBFinPxtEdx/'
+ 'download?path=%2F&files='
+ 'rootfs.ext4.zstd',
+ '792da7573f5dc2913ddb7c638151d4a6b2d028a4cb2afb38add513c1924bdad4')
+
+ @skipIfMissingCommands('zstd')
+ def test_aarch64_virt_with_gpu(self):
+ # This tests boots with a buildroot test image that contains
+ # vkmark and other GPU exercising tools. We run a headless
+ # weston that nevertheless still exercises the virtio-gpu
+ # backend.
+
+ self.set_machine('virt')
+ self.require_accelerator("tcg")
+
+ kernel_path = self.ASSET_VIRT_GPU_KERNEL.fetch()
+ image_path = self.uncompress(self.ASSET_VIRT_GPU_ROOTFS, format="zstd")
+
+ self.vm.set_console()
+ kernel_command_line = (self.KERNEL_COMMON_COMMAND_LINE +
+ 'console=ttyAMA0 root=/dev/vda')
+
+ self.vm.add_args("-accel", "tcg")
+ self.vm.add_args("-cpu", "neoverse-v1,pauth-impdef=on")
+ self.vm.add_args("-machine", "virt,gic-version=max",
+ '-kernel', kernel_path,
+ '-append', kernel_command_line)
+ self.vm.add_args("-smp", "2", "-m", "2048")
+ self.vm.add_args("-device",
+ "virtio-gpu-gl-pci,hostmem=4G,blob=on,venus=on")
+ self.vm.add_args("-display", "egl-headless")
+ self.vm.add_args("-display", "dbus,gl=on")
+ self.vm.add_args("-device", "virtio-blk-device,drive=hd0")
+ self.vm.add_args("-blockdev",
+ "driver=raw,file.driver=file,"
+ "node-name=hd0,read-only=on,"
+ f"file.filename={image_path}")
+ self.vm.add_args("-snapshot")
+
+ try:
+ self.vm.launch()
+ except VMLaunchFailure as excp:
+ if "old virglrenderer, blob resources unsupported" in excp.output:
+ self.skipTest("No blob support for virtio-gpu")
+ elif "old virglrenderer, venus unsupported" in excp.output:
+ self.skipTest("No venus support for virtio-gpu")
+ else:
+ self.log.info("unhandled launch failure: {excp.output}")
+ raise excp
+
+ self.wait_for_console_pattern('buildroot login:')
+ exec_command(self, 'root')
+ exec_command(self, 'export XDG_RUNTIME_DIR=/tmp')
+ exec_command_and_wait_for_pattern(self,
+ "weston -B headless "
+ "--renderer gl "
+ "--shell kiosk "
+ "-- vkmark -b:duration=1.0",
+ "vkmark Score")
+
+
if __name__ == '__main__':
QemuSystemTest.main()
--
2.39.5
next prev parent reply other threads:[~2025-01-08 12:18 UTC|newest]
Thread overview: 46+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-01-08 12:10 [PATCH v4 00/32] testing/next: functional tests, qtest clocks, vm and keymaps (pre-PR-FINAL) Alex Bennée
2025-01-08 12:10 ` [PATCH v4 01/32] tests/functional: update the arm tuxrun tests Alex Bennée
2025-01-08 12:10 ` [PATCH v4 02/32] tests/functional: update the i386 " Alex Bennée
2025-01-08 12:10 ` [PATCH v4 03/32] tests/functional: add a m68k " Alex Bennée
2025-01-08 12:29 ` Daniel P. Berrangé
2025-01-08 12:10 ` [PATCH v4 04/32] tests/functional: update the mips32 " Alex Bennée
2025-01-08 12:10 ` [PATCH v4 05/32] tests/functional: update the mips32el " Alex Bennée
2025-01-08 12:10 ` [PATCH v4 06/32] tests/functional: update the mips64 " Alex Bennée
2025-01-08 12:10 ` [PATCH v4 07/32] tests/functional: update the mips64el " Alex Bennée
2025-01-08 12:10 ` [PATCH v4 08/32] tests/functional: update the ppc32 " Alex Bennée
2025-01-08 12:10 ` [PATCH v4 09/32] tests/functional: update the ppc64 " Alex Bennée
2025-01-08 12:10 ` [PATCH v4 10/32] tests/functional: update the riscv32 " Alex Bennée
2025-01-08 12:10 ` [PATCH v4 11/32] tests/functional: update the riscv64 " Alex Bennée
2025-01-08 12:10 ` [PATCH v4 12/32] tests/functional: update the s390x " Alex Bennée
2025-01-08 12:10 ` [PATCH v4 13/32] tests/functional: update the sparc64 " Alex Bennée
2025-01-08 12:10 ` [PATCH v4 14/32] tests/functional: update the x86_64 " Alex Bennée
2025-01-08 12:10 ` [PATCH v4 15/32] tests/functional/aarch64: add tests for FEAT_RME Alex Bennée
2025-01-08 12:10 ` [PATCH v4 16/32] tests/qtest: remove clock_steps from virtio tests Alex Bennée
2025-01-08 12:10 ` [PATCH v4 17/32] system/qtest: properly feedback results of clock_[step|set] Alex Bennée
2025-01-13 15:22 ` Michael Tokarev
2025-01-13 16:26 ` Alex Bennée
2025-01-13 17:52 ` Michael Tokarev
2025-01-08 12:10 ` [PATCH v4 18/32] tests/functional: remove hacky sleep from the tests Alex Bennée
2025-01-08 12:10 ` [PATCH v4 19/32] tests/functional: add zstd support to uncompress utility Alex Bennée
2025-01-08 12:32 ` Daniel P. Berrangé
2025-01-08 14:08 ` Thomas Huth
2025-01-08 12:10 ` [PATCH v4 20/32] tests/functional: update tuxruntest to use " Alex Bennée
2025-01-08 14:09 ` Thomas Huth
2025-01-08 12:10 ` [PATCH v4 21/32] tests/functional: remove unused kernel_command_line Alex Bennée
2025-01-08 14:15 ` Thomas Huth
2025-01-08 12:10 ` [PATCH v4 22/32] tests/functional: bail aarch64_virt tests early if missing TCG Alex Bennée
2025-01-08 14:16 ` Thomas Huth
2025-01-08 12:10 ` Alex Bennée [this message]
2025-01-08 14:17 ` [PATCH v4 23/32] tests/functional: extend test_aarch64_virt with vulkan test Thomas Huth
2025-01-08 12:10 ` [PATCH v4 24/32] tests/lcitool: bump to latest version of libvirt-ci Alex Bennée
2025-01-08 12:10 ` [PATCH v4 25/32] tests/docker: move riscv64 cross container from sid to trixie Alex Bennée
2025-01-08 12:10 ` [PATCH v4 26/32] tests/lcitool: remove temp workaround for debian mips64el Alex Bennée
2025-01-08 12:10 ` [PATCH v4 27/32] tests/vm: fix build_path based path Alex Bennée
2025-01-08 12:10 ` [PATCH v4 28/32] tests/vm: partially un-tabify help output Alex Bennée
2025-01-08 14:23 ` Thomas Huth
2025-01-08 12:10 ` [PATCH v4 29/32] tests/vm: allow interactive login as root Alex Bennée
2025-01-08 14:25 ` Thomas Huth
2025-01-08 12:10 ` [PATCH v4 30/32] pc-bios: ensure keymaps dependencies set vnc tests Alex Bennée
2025-01-09 12:13 ` Paolo Bonzini
2025-01-08 12:10 ` [PATCH v4 31/32] dockerfiles: Remove 'MAINTAINER' entry in debian-tricore-cross.docker Alex Bennée
2025-01-08 12:10 ` [PATCH v4 32/32] MAINTAINERS: Remove myself from reviewers Alex Bennée
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250108121054.1126164-24-alex.bennee@linaro.org \
--to=alex.bennee@linaro.org \
--cc=alistair.francis@wdc.com \
--cc=armbru@redhat.com \
--cc=aurelien@aurel32.net \
--cc=berrange@redhat.com \
--cc=bleal@redhat.com \
--cc=bmeng.cn@gmail.com \
--cc=borntraeger@linux.ibm.com \
--cc=crosa@redhat.com \
--cc=danielhb413@gmail.com \
--cc=dbarboza@ventanamicro.com \
--cc=emaste@freebsd.org \
--cc=farman@linux.ibm.com \
--cc=farosas@suse.de \
--cc=harshpb@linux.ibm.com \
--cc=jiaxun.yang@flygoat.com \
--cc=joel@jms.id.au \
--cc=jsnow@redhat.com \
--cc=laurent@vivier.eu \
--cc=liwei1518@gmail.com \
--cc=lvivier@redhat.com \
--cc=lwhsu@freebsd.org \
--cc=marcandre.lureau@redhat.com \
--cc=marcel.apfelbaum@gmail.com \
--cc=marcin.juszkiewicz@linaro.org \
--cc=mark.cave-ayland@ilande.co.uk \
--cc=mst@redhat.com \
--cc=npiggin@gmail.com \
--cc=palmer@dabbelt.com \
--cc=pasic@linux.ibm.com \
--cc=pavel.dovgaluk@ispras.ru \
--cc=pbonzini@redhat.com \
--cc=peter.maydell@linaro.org \
--cc=philmd@linaro.org \
--cc=qemu-arm@nongnu.org \
--cc=qemu-devel@nongnu.org \
--cc=qemu-ppc@nongnu.org \
--cc=qemu-riscv@nongnu.org \
--cc=qemu-s390x@nongnu.org \
--cc=quic_llindhol@quicinc.com \
--cc=rad@semihalf.com \
--cc=richard.henderson@linaro.org \
--cc=shentey@gmail.com \
--cc=thuth@redhat.com \
--cc=wainersm@redhat.com \
--cc=zhiwei_liu@linux.alibaba.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).