aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/x86/kernel/signal_32.c12
-rw-r--r--arch/x86/kernel/signal_64.c5
2 files changed, 9 insertions, 8 deletions
diff --git a/arch/x86/kernel/signal_32.c b/arch/x86/kernel/signal_32.c
index 5447fa5ec52c..add9c6e9c44d 100644
--- a/arch/x86/kernel/signal_32.c
+++ b/arch/x86/kernel/signal_32.c
@@ -107,9 +107,9 @@ sys_sigaltstack(unsigned long bx)
107/* 107/*
108 * Do a signal return; undo the signal stack. 108 * Do a signal return; undo the signal stack.
109 */ 109 */
110
111static int 110static int
112restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc, int *peax) 111restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc,
112 unsigned long *pax)
113{ 113{
114 unsigned int err = 0; 114 unsigned int err = 0;
115 115
@@ -165,19 +165,19 @@ restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc, int *peax
165 } 165 }
166 } 166 }
167 167
168 err |= __get_user(*peax, &sc->ax); 168 err |= __get_user(*pax, &sc->ax);
169 return err; 169 return err;
170 170
171badframe: 171badframe:
172 return 1; 172 return 1;
173} 173}
174 174
175asmlinkage int sys_sigreturn(unsigned long __unused) 175asmlinkage unsigned long sys_sigreturn(unsigned long __unused)
176{ 176{
177 struct pt_regs *regs = (struct pt_regs *) &__unused; 177 struct pt_regs *regs = (struct pt_regs *) &__unused;
178 struct sigframe __user *frame = (struct sigframe __user *)(regs->sp - 8); 178 struct sigframe __user *frame = (struct sigframe __user *)(regs->sp - 8);
179 sigset_t set; 179 sigset_t set;
180 int ax; 180 unsigned long ax;
181 181
182 if (!access_ok(VERIFY_READ, frame, sizeof(*frame))) 182 if (!access_ok(VERIFY_READ, frame, sizeof(*frame)))
183 goto badframe; 183 goto badframe;
@@ -216,8 +216,8 @@ asmlinkage int sys_rt_sigreturn(unsigned long __unused)
216{ 216{
217 struct pt_regs *regs = (struct pt_regs *)&__unused; 217 struct pt_regs *regs = (struct pt_regs *)&__unused;
218 struct rt_sigframe __user *frame; 218 struct rt_sigframe __user *frame;
219 unsigned long ax;
219 sigset_t set; 220 sigset_t set;
220 int ax;
221 221
222 frame = (struct rt_sigframe __user *)(regs->sp - sizeof(long)); 222 frame = (struct rt_sigframe __user *)(regs->sp - sizeof(long));
223 if (!access_ok(VERIFY_READ, frame, sizeof(*frame))) 223 if (!access_ok(VERIFY_READ, frame, sizeof(*frame)))
diff --git a/arch/x86/kernel/signal_64.c b/arch/x86/kernel/signal_64.c
index 8bb1013eb62b..f3247d71edbc 100644
--- a/arch/x86/kernel/signal_64.c
+++ b/arch/x86/kernel/signal_64.c
@@ -60,7 +60,8 @@ sys_sigaltstack(const stack_t __user *uss, stack_t __user *uoss,
60 * Do a signal return; undo the signal stack. 60 * Do a signal return; undo the signal stack.
61 */ 61 */
62static int 62static int
63restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc, unsigned long *prax) 63restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc,
64 unsigned long *pax)
64{ 65{
65 unsigned int err = 0; 66 unsigned int err = 0;
66 67
@@ -113,7 +114,7 @@ restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc, unsigned
113 } 114 }
114 } 115 }
115 116
116 err |= __get_user(*prax, &sc->ax); 117 err |= __get_user(*pax, &sc->ax);
117 return err; 118 return err;
118 119
119badframe: 120badframe: