aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/ia32/ia32_signal.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86/ia32/ia32_signal.c')
-rw-r--r--arch/x86/ia32/ia32_signal.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/arch/x86/ia32/ia32_signal.c b/arch/x86/ia32/ia32_signal.c
index 610a17774ea2..fe44c314c9c0 100644
--- a/arch/x86/ia32/ia32_signal.c
+++ b/arch/x86/ia32/ia32_signal.c
@@ -201,6 +201,12 @@ struct rt_sigframe
201 err |= __get_user(regs->x, &sc->x); \ 201 err |= __get_user(regs->x, &sc->x); \
202} 202}
203 203
204#define COPY_SEG_CPL3(seg) { \
205 unsigned short tmp; \
206 err |= __get_user(tmp, &sc->seg); \
207 regs->seg = tmp | 3; \
208}
209
204#define RELOAD_SEG(seg,mask) \ 210#define RELOAD_SEG(seg,mask) \
205 { unsigned int cur; \ 211 { unsigned int cur; \
206 unsigned short pre; \ 212 unsigned short pre; \
@@ -246,10 +252,8 @@ static int ia32_restore_sigcontext(struct pt_regs *regs,
246 COPY(dx); COPY(cx); COPY(ip); 252 COPY(dx); COPY(cx); COPY(ip);
247 /* Don't touch extended registers */ 253 /* Don't touch extended registers */
248 254
249 err |= __get_user(regs->cs, &sc->cs); 255 COPY_SEG_CPL3(cs);
250 regs->cs |= 3; 256 COPY_SEG_CPL3(ss);
251 err |= __get_user(regs->ss, &sc->ss);
252 regs->ss |= 3;
253 257
254 err |= __get_user(tmpflags, &sc->flags); 258 err |= __get_user(tmpflags, &sc->flags);
255 regs->flags = (regs->flags & ~FIX_EFLAGS) | (tmpflags & FIX_EFLAGS); 259 regs->flags = (regs->flags & ~FIX_EFLAGS) | (tmpflags & FIX_EFLAGS);