um: add extended processor state save/restore support
This patch extends save_fp_registers() and restore_fp_registers() to use
PTRACE_GETREGSET and PTRACE_SETREGSET with the XSTATE note type, adding
support for new processor state extensions between context switches.
When the new ptrace requests are unavailable, it falls back to the old
PTRACE_GETFPREGS and PTRACE_SETFPREGS methods, which have been renamed to
save_i387_registers() and restore_i387_registers().
Now these functions expect *fp_regs to have the space of an _xstate struct.
Thus, this also makes ptrace in UML responde to PTRACE_GETFPREGS/_SETFPREG
requests with a user_i387_struct (thus independent from HOST_FP_SIZE), and
by calling save_i387_registers() and restore_i387_registers() instead of
the extended save_fp_registers() and restore_fp_registers() functions.
Signed-off-by:
Eli Cooper <elicooper@gmx.com>
Showing
- arch/um/include/shared/registers.h 2 additions, 0 deletionsarch/um/include/shared/registers.h
- arch/um/kernel/process.c 1 addition, 1 deletionarch/um/kernel/process.c
- arch/x86/um/os-Linux/registers.c 47 additions, 2 deletionsarch/x86/um/os-Linux/registers.c
- arch/x86/um/ptrace_32.c 3 additions, 2 deletionsarch/x86/um/ptrace_32.c
- arch/x86/um/ptrace_64.c 8 additions, 8 deletionsarch/x86/um/ptrace_64.c
- arch/x86/um/shared/sysdep/ptrace_64.h 1 addition, 3 deletionsarch/x86/um/shared/sysdep/ptrace_64.h
Loading
Please register or sign in to comment