diff options
-rw-r--r-- | arch/x86/kernel/signal_32.c | 12 | ||||
-rw-r--r-- | arch/x86/kernel/signal_64.c | 5 |
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 | |||
111 | static int | 110 | static int |
112 | restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc, int *peax) | 111 | restore_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 | ||
171 | badframe: | 171 | badframe: |
172 | return 1; | 172 | return 1; |
173 | } | 173 | } |
174 | 174 | ||
175 | asmlinkage int sys_sigreturn(unsigned long __unused) | 175 | asmlinkage 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 | */ |
62 | static int | 62 | static int |
63 | restore_sigcontext(struct pt_regs *regs, struct sigcontext __user *sc, unsigned long *prax) | 63 | restore_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 | ||
119 | badframe: | 120 | badframe: |