diff options
author | Suresh Siddha <suresh.b.siddha@intel.com> | 2008-07-29 13:29:25 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-07-30 13:49:27 -0400 |
commit | c37b5efea43f9e500363f9973dd00e3d2cdcc685 (patch) | |
tree | 9ce635f1672099dafcd78e535b4ea18d80235d8f /arch/x86/kernel/signal_32.c | |
parent | bdd8caba5ed5bb7ee21c9f061597284ffeb280bf (diff) |
x86, xsave: save/restore the extended state context in sigframe
On cpu's supporting xsave/xrstor, fpstate pointer in the sigcontext, will
include the extended state information along with fpstate information. Presence
of extended state information is indicated by the presence
of FP_XSTATE_MAGIC1 at fpstate.sw_reserved.magic1 and FP_XSTATE_MAGIC2
at fpstate + (fpstate.sw_reserved.extended_size - FP_XSTATE_MAGIC2_SIZE).
Extended feature bit mask that is saved in the memory layout is represented
by the fpstate.sw_reserved.xstate_bv
For RT signal frames, UC_FP_XSTATE in the uc_flags also indicate the
presence of extended state information in the sigcontext's fpstate
pointer.
Signed-off-by: Suresh Siddha <suresh.b.siddha@intel.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/kernel/signal_32.c')
-rw-r--r-- | arch/x86/kernel/signal_32.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/arch/x86/kernel/signal_32.c b/arch/x86/kernel/signal_32.c index 690cc616ac07..0f98d69fbdb0 100644 --- a/arch/x86/kernel/signal_32.c +++ b/arch/x86/kernel/signal_32.c | |||
@@ -441,7 +441,10 @@ static int setup_rt_frame(int sig, struct k_sigaction *ka, siginfo_t *info, | |||
441 | goto give_sigsegv; | 441 | goto give_sigsegv; |
442 | 442 | ||
443 | /* Create the ucontext. */ | 443 | /* Create the ucontext. */ |
444 | err |= __put_user(0, &frame->uc.uc_flags); | 444 | if (cpu_has_xsave) |
445 | err |= __put_user(UC_FP_XSTATE, &frame->uc.uc_flags); | ||
446 | else | ||
447 | err |= __put_user(0, &frame->uc.uc_flags); | ||
445 | err |= __put_user(0, &frame->uc.uc_link); | 448 | err |= __put_user(0, &frame->uc.uc_link); |
446 | err |= __put_user(current->sas_ss_sp, &frame->uc.uc_stack.ss_sp); | 449 | err |= __put_user(current->sas_ss_sp, &frame->uc.uc_stack.ss_sp); |
447 | err |= __put_user(sas_ss_flags(regs->sp), | 450 | err |= __put_user(sas_ss_flags(regs->sp), |