]> www.infradead.org Git - users/dwmw2/linux.git/commit
um: switch to regset API and depend on XSTATE
authorBenjamin Berg <benjamin.berg@intel.com>
Wed, 23 Oct 2024 09:41:20 +0000 (11:41 +0200)
committerJohannes Berg <johannes.berg@intel.com>
Wed, 23 Oct 2024 10:13:16 +0000 (12:13 +0200)
commit3f17fed2149192c7d3b76a45a6a87b4ff22cd586
tree6c76ac37c9db356076f5540230b84635a8b90efd
parent0b8b2668f9981c1fefc2ef892bd915288ef01f33
um: switch to regset API and depend on XSTATE

The PTRACE_GETREGSET API has now existed since Linux 2.6.33. The XSAVE
CPU feature should also be sufficiently common to be able to rely on it.

With this, define our internal FP state to be the hosts XSAVE data. Add
discovery for the hosts XSAVE size and place the FP registers at the end
of task_struct so that we can adjust the size at runtime.

Next we can implement the regset API on top and update the signal
handling as well as ptrace APIs to use them. Also switch coredump
creation to use the regset API and finally set HAVE_ARCH_TRACEHOOK.

This considerably improves the signal frames. Previously they might not
have contained all the registers (i386) and also did not have the
sizes and magic values set to the correct values to permit userspace to
decode the frame.

As a side effect, this will permit UML to run on hosts with newer CPU
extensions (such as AMX) that need even more register state.

Signed-off-by: Benjamin Berg <benjamin.berg@intel.com>
Link: https://patch.msgid.link/20241023094120.4083426-1-benjamin@sipsolutions.net
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
18 files changed:
arch/um/Kconfig
arch/um/include/asm/processor-generic.h
arch/um/kernel/process.c
arch/um/kernel/um_arch.c
arch/um/os-Linux/registers.c
arch/x86/um/Makefile
arch/x86/um/asm/elf.h
arch/x86/um/asm/ptrace.h
arch/x86/um/os-Linux/registers.c
arch/x86/um/ptrace.c [new file with mode: 0644]
arch/x86/um/ptrace_32.c
arch/x86/um/ptrace_64.c
arch/x86/um/shared/sysdep/ptrace.h
arch/x86/um/shared/sysdep/ptrace_32.h
arch/x86/um/shared/sysdep/ptrace_64.h
arch/x86/um/shared/sysdep/ptrace_user.h
arch/x86/um/signal.c
arch/x86/um/user-offsets.c