aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86')
-rw-r--r--arch/x86/kernel/signal_32.c21
-rw-r--r--arch/x86/kernel/signal_64.c19
2 files changed, 14 insertions, 26 deletions
diff --git a/arch/x86/kernel/signal_32.c b/arch/x86/kernel/signal_32.c
index 545448b7aeb..d6dd057d0f2 100644
--- a/arch/x86/kernel/signal_32.c
+++ b/arch/x86/kernel/signal_32.c
@@ -142,6 +142,8 @@ static int
142restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc, 142restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc,
143 unsigned long *pax) 143 unsigned long *pax)
144{ 144{
145 void __user *buf;
146 unsigned int tmpflags;
145 unsigned int err = 0; 147 unsigned int err = 0;
146 148
147 /* Always make any pending restarted system calls return -EINTR */ 149 /* Always make any pending restarted system calls return -EINTR */
@@ -156,21 +158,12 @@ restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc,
156 COPY_SEG_STRICT(cs); 158 COPY_SEG_STRICT(cs);
157 COPY_SEG_STRICT(ss); 159 COPY_SEG_STRICT(ss);
158 160
159 { 161 err |= __get_user(tmpflags, &sc->flags);
160 unsigned int tmpflags; 162 regs->flags = (regs->flags & ~FIX_EFLAGS) | (tmpflags & FIX_EFLAGS);
163 regs->orig_ax = -1; /* disable syscall checks */
161 164
162 err |= __get_user(tmpflags, &sc->flags); 165 err |= __get_user(buf, &sc->fpstate);
163 regs->flags = (regs->flags & ~FIX_EFLAGS) | 166 err |= restore_i387_xstate(buf);
164 (tmpflags & FIX_EFLAGS);
165 regs->orig_ax = -1; /* disable syscall checks */
166 }
167
168 {
169 void __user *buf;
170
171 err |= __get_user(buf, &sc->fpstate);
172 err |= restore_i387_xstate(buf);
173 }
174 167
175 err |= __get_user(*pax, &sc->ax); 168 err |= __get_user(*pax, &sc->ax);
176 return err; 169 return err;
diff --git a/arch/x86/kernel/signal_64.c b/arch/x86/kernel/signal_64.c
index feff4a91d09..a5c9627f4db 100644
--- a/arch/x86/kernel/signal_64.c
+++ b/arch/x86/kernel/signal_64.c
@@ -69,6 +69,8 @@ static int
69restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc, 69restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc,
70 unsigned long *pax) 70 unsigned long *pax)
71{ 71{
72 void __user *buf;
73 unsigned int tmpflags;
72 unsigned int err = 0; 74 unsigned int err = 0;
73 75
74 /* Always make any pending restarted system calls return -EINTR */ 76 /* Always make any pending restarted system calls return -EINTR */
@@ -90,19 +92,12 @@ restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc,
90 * App's signal handler can save/restore other segments if needed. */ 92 * App's signal handler can save/restore other segments if needed. */
91 COPY_SEG_STRICT(cs); 93 COPY_SEG_STRICT(cs);
92 94
93 { 95 err |= __get_user(tmpflags, &sc->flags);
94 unsigned int tmpflags; 96 regs->flags = (regs->flags & ~FIX_EFLAGS) | (tmpflags & FIX_EFLAGS);
95 err |= __get_user(tmpflags, &sc->flags); 97 regs->orig_ax = -1; /* disable syscall checks */
96 regs->flags = (regs->flags & ~FIX_EFLAGS) | (tmpflags & FIX_EFLAGS);
97 regs->orig_ax = -1; /* disable syscall checks */
98 }
99
100 {
101 void __user *buf;
102 98
103 err |= __get_user(buf, &sc->fpstate); 99 err |= __get_user(buf, &sc->fpstate);
104 err |= restore_i387_xstate(buf); 100 err |= restore_i387_xstate(buf);
105 }
106 101
107 err |= __get_user(*pax, &sc->ax); 102 err |= __get_user(*pax, &sc->ax);
108 return err; 103 return err;