From: Thiago Jung Bauermann via Gdb <gdb@sourceware.org>
To: Peter Maydell <peter.maydell@linaro.org>
Cc: Luis <luis.machado.foss@gmail.com>,
gdb@sourceware.org,
Manos Pitsidianakis <manos.pitsidianakis@linaro.org>
Subject: Re: gdb support for SME-without-SVE ?
Date: Fri, 30 Jan 2026 04:28:08 +0000 [thread overview]
Message-ID: <87a4xvafmv.fsf@linaro.org> (raw)
In-Reply-To: <CAFEAcA8U48phwPk+PhBxJn7SPYffcQGjE8db_m09EfdejMWwTQ@mail.gmail.com> (Peter Maydell's message of "Thu, 29 Jan 2026 11:34:19 +0000")
Peter Maydell <peter.maydell@linaro.org> writes:
> On Thu, 29 Jan 2026 at 09:10, Peter Maydell <peter.maydell@linaro.org> wrote:
>>
>> On Thu, 29 Jan 2026 at 04:12, Thiago Jung Bauermann
>> <thiago.bauermann@linaro.org> wrote:
>> >
>> > Peter Maydell <peter.maydell@linaro.org> writes:
>> >
>> > > On Wed, 28 Jan 2026 at 04:24, Thiago Jung Bauermann
>> > > <thiago.bauermann@linaro.org> wrote:
>> > >> I'm currently implementing SME-only (i.e. without SVE) support in GDB
>> > >> for Linux userspace debugging. It's mostly done, I just need to test a
>> > >> few things, polish the code and prepare the patches. I'm hoping to send
>> > >> the patches next week.
>> > >
>> > > Let me know if a QEMU setup emulating "SME only" would be helpful
>> > > for you with that.
>> >
>> > It would indeed! If there's a branch I can build, it would make my
>> > testing quicker, and the regression testing more complete.
>>
>> I'll get one sorted out later today (the patches I have right now
>> have a few issues I need to fix).
>
> This branch:
>
> https://gitlab.com/pm215/qemu/-/commits/sme-no-sve
Thank you very much!
> should let you create an SME-only CPU with "-cpu max,sve=off".
> I have not given it much more than a very cursory testing, so
> let me know if you run into any problems with it.
Unfortunately I hit a kernel oops reliably when trying to run a GDB testcase:
[ 156.387143] Internal error: Oops - Undefined instruction: 0000000002000000 [#1] SMP
[ 156.389966] Modules linked in: sm3_ce tpm_tis tpm_tis_core sha256 cfg80211 rfkill fuse drm backlight dm_mod ipv6 btrfs blake2b libblake2b xor xor_neon raid6_pq zstd_compress
[ 156.391005] CPU: 0 UID: 1000 PID: 677 Comm: aarch64-sme-san Not tainted 6.19.0-rc5 #4 PREEMPT
[ 156.391244] Hardware name: QEMU QEMU Virtual Machine, BIOS edk2-stable202408-prebuilt.qemu.org 08/13/2024
[ 156.391475] pstate: 214020c5 (nzCv daIF +PAN -UAO -TCO +DIT -SSBS BTYPE=--)
[ 156.391657] pc : sve_get_vl+0x4/0xc
[ 156.392149] lr : fpsimd_save_user_state+0x100/0x1b8
[ 156.392270] sp : ffff800080cbbb80
[ 156.392329] x29: ffff800080cbbb80 x28: 0000000000000001 x27: fff00000c44b05e0
[ 156.392501] x26: ffff800080cbbdf0 x25: 0000000000000000 x24: 0000000000000000
[ 156.392627] x23: 0000000000000000 x22: fff05a09d4047000 x21: 0000000000000020
[ 156.392745] x20: fff00000ff5380f0 x19: ffffa5f72b4f10f0 x18: 0000000000000000
[ 156.392870] x17: 0000000000000000 x16: 0000000000000000 x15: 02ed5d640eed9128
[ 156.392994] x14: 0000b00e8e55cf08 x13: 000000000000033b x12: 000000000000033b
[ 156.393109] x11: 0000000000000000 x10: 0000000000000002 x9 : 0000000000000800
[ 156.393246] x8 : fff00000c36aac80 x7 : fff00000c36aac00 x6 : 00000007fb30b524
[ 156.393372] x5 : 0000000000000000 x4 : 0000000000000001 x3 : ffff800080cbbc60
[ 156.393491] x2 : 0000000000000000 x1 : fff00000c44b0000 x0 : 0000000000000001
[ 156.393681] Call trace:
[ 156.393853] sve_get_vl+0x4/0xc (P)
[ 156.394027] fpsimd_thread_switch+0x44/0x188
[ 156.394125] __switch_to+0x20/0x1a8
[ 156.394203] __schedule+0x368/0xcdc
[ 156.394270] schedule+0x34/0x110
[ 156.394328] ptrace_stop.part.0+0x12c/0x24c
[ 156.394409] get_signal+0x384/0x82c
[ 156.394471] arch_do_signal_or_restart+0x118/0x3c4
[ 156.394555] exit_to_user_mode_loop+0x104/0x16c
[ 156.394640] el0_undef+0x88/0x8c
[ 156.394704] el0t_64_sync_handler+0x70/0xe4
[ 156.394779] el0t_64_sync+0x198/0x19c
[ 156.394973] Code: b9400424 d51b4404 d65f03c0 d503245f (04bf5020)
[ 156.395301] ---[ end trace 0000000000000000 ]---
The same kernel and userspace binaries work fine in Arm FVP.
In case you want to try it, this is my GDB branch:
https://gitlab.com/bauermann/binutils-gdb/-/commits/sme-only
And you can run the testcase with:
$ cd /path/to/gdb/build/dir; make check-gdb TESTS=gdb.arch/aarch64-sme-sanity.exp
I can try to create a minimal reproducer if it will help.
My QEMU command line is:
$QEMU_PREFIX/bin/qemu-system-aarch64 \
-M virt \
-cpu max,sve=off \
-m 4g \
-drive if=none,file=$HOME/VMs/ubuntu-aarch64.img,id=hd1,format=raw,cache=writeback,discard=on \
-device virtio-blk-device,drive=hd1 \
-netdev user,id=mynet0,hostfwd=tcp::8022-:22 -device virtio-net-pci,netdev=mynet0 \
-bios $QEMU_PREFIX/share/qemu/edk2-aarch64-code.fd \
-nographic
--
Thiago
next prev parent reply other threads:[~2026-01-30 4:28 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-01-27 11:31 Peter Maydell via Gdb
2026-01-27 14:21 ` Simon Marchi via Gdb
2026-01-27 14:47 ` Peter Maydell via Gdb
2026-01-27 14:57 ` Simon Marchi via Gdb
2026-01-27 21:23 ` Peter Maydell via Gdb
2026-01-27 21:28 ` Simon Marchi via Gdb
2026-01-28 1:07 ` Luis via Gdb
2026-01-28 4:23 ` Thiago Jung Bauermann via Gdb
2026-01-28 8:02 ` Luis via Gdb
2026-01-28 16:20 ` Peter Maydell via Gdb
2026-01-29 4:12 ` Thiago Jung Bauermann via Gdb
2026-01-29 9:10 ` Peter Maydell via Gdb
2026-01-29 11:34 ` Peter Maydell via Gdb
2026-01-30 4:28 ` Thiago Jung Bauermann via Gdb [this message]
2026-01-30 9:41 ` Peter Maydell via Gdb
2026-01-30 12:29 ` Peter Maydell via Gdb
2026-01-30 16:16 ` Thiago Jung Bauermann via Gdb
2026-01-30 16:29 ` Peter Maydell via Gdb
2026-01-30 17:06 ` Thiago Jung Bauermann via Gdb
2026-01-30 17:17 ` Peter Maydell via Gdb
2026-01-30 18:18 ` Thiago Jung Bauermann via Gdb
2026-01-30 18:34 ` Peter Maydell via Gdb
2026-01-30 18:40 ` Thiago Jung Bauermann via Gdb
2026-01-30 18:59 ` Peter Maydell via Gdb
2026-01-30 18:59 ` Thiago Jung Bauermann via Gdb
2026-01-30 19:01 ` Peter Maydell via Gdb
2026-01-30 19:03 ` Thiago Jung Bauermann via Gdb
2026-02-02 11:01 ` Peter Maydell via Gdb
2026-02-02 14:06 ` Peter Maydell via Gdb
2026-02-02 20:43 ` Thiago Jung Bauermann via Gdb
2026-01-30 18:24 ` Luis via Gdb
2026-01-27 21:29 ` Andrew Pinski via Gdb
2026-01-28 0:42 ` Luis via Gdb
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=87a4xvafmv.fsf@linaro.org \
--to=gdb@sourceware.org \
--cc=luis.machado.foss@gmail.com \
--cc=manos.pitsidianakis@linaro.org \
--cc=peter.maydell@linaro.org \
--cc=thiago.bauermann@linaro.org \
/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