From 46515e94efd22f96d7452ea8875095940cc7431c Mon Sep 17 00:00:00 2001 From: Hiroshi Shimamoto Date: Fri, 27 Feb 2009 10:29:09 -0800 Subject: [PATCH] --- yaml --- r: 137063 b: refs/heads/master c: 36a4526583ad61fe7cb7432f53bce52ea198813a h: refs/heads/master i: 137061: 8b5512bbe22e0ea99ff345c2d8cb5ad09c5028bd 137059: 5e55098a1b4b6cdcb9544b998f697573a7df541b 137055: c6cb075cb88e3e2b1682df83f8355df82d6e92e6 v: v3 --- [refs] | 2 +- trunk/arch/x86/kernel/signal.c | 6 ++---- 2 files changed, 3 insertions(+), 5 deletions(-) diff --git a/[refs] b/[refs] index 39fae051e8f1..cb3977f48f6c 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 97286a2b64725aac2d584ddd1f94871f9991d5a1 +refs/heads/master: 36a4526583ad61fe7cb7432f53bce52ea198813a diff --git a/trunk/arch/x86/kernel/signal.c b/trunk/arch/x86/kernel/signal.c index 82d37c77b0fb..89ef90df985f 100644 --- a/trunk/arch/x86/kernel/signal.c +++ b/trunk/arch/x86/kernel/signal.c @@ -409,15 +409,13 @@ get_sigframe(struct k_sigaction *ka, struct pt_regs *regs, size_t frame_size, if (used_math()) { sp -= sig_xstate_size; *fpstate = (void __user *)round_down(sp, 64); + if (save_i387_xstate(*fpstate) < 0) return (void __user *) -1L; - - sp -= frame_size; - return (void __user *)round_down(sp, 16) - 8; } sp -= frame_size; - return (void __user *)round_down(sp, 64) - 8; + return (void __user *)round_down(sp, 16) - 8; } static int __setup_rt_frame(int sig, struct k_sigaction *ka, siginfo_t *info,