aboutsummaryrefslogtreecommitdiffstats
path: root/arch/mn10300
diff options
context:
space:
mode:
Diffstat (limited to 'arch/mn10300')
-rw-r--r--arch/mn10300/kernel/ptrace.c17
1 files changed, 8 insertions, 9 deletions
diff --git a/arch/mn10300/kernel/ptrace.c b/arch/mn10300/kernel/ptrace.c
index ec4b41439e9..5c0b07e6100 100644
--- a/arch/mn10300/kernel/ptrace.c
+++ b/arch/mn10300/kernel/ptrace.c
@@ -300,27 +300,26 @@ long arch_ptrace(struct task_struct *child, long request,
300{ 300{
301 unsigned long tmp; 301 unsigned long tmp;
302 int ret; 302 int ret;
303 unsigned long __user *datap = (unsigned long __user *) data;
303 304
304 switch (request) { 305 switch (request) {
305 /* read the word at location addr in the USER area. */ 306 /* read the word at location addr in the USER area. */
306 case PTRACE_PEEKUSR: 307 case PTRACE_PEEKUSR:
307 ret = -EIO; 308 ret = -EIO;
308 if ((addr & 3) || addr < 0 || 309 if ((addr & 3) || addr > sizeof(struct user) - 3)
309 addr > sizeof(struct user) - 3)
310 break; 310 break;
311 311
312 tmp = 0; /* Default return condition */ 312 tmp = 0; /* Default return condition */
313 if (addr < NR_PTREGS << 2) 313 if (addr < NR_PTREGS << 2)
314 tmp = get_stack_long(child, 314 tmp = get_stack_long(child,
315 ptrace_regid_to_frame[addr]); 315 ptrace_regid_to_frame[addr]);
316 ret = put_user(tmp, (unsigned long *) data); 316 ret = put_user(tmp, datap);
317 break; 317 break;
318 318
319 /* write the word at location addr in the USER area */ 319 /* write the word at location addr in the USER area */
320 case PTRACE_POKEUSR: 320 case PTRACE_POKEUSR:
321 ret = -EIO; 321 ret = -EIO;
322 if ((addr & 3) || addr < 0 || 322 if ((addr & 3) || addr > sizeof(struct user) - 3)
323 addr > sizeof(struct user) - 3)
324 break; 323 break;
325 324
326 ret = 0; 325 ret = 0;
@@ -333,25 +332,25 @@ long arch_ptrace(struct task_struct *child, long request,
333 return copy_regset_to_user(child, &user_mn10300_native_view, 332 return copy_regset_to_user(child, &user_mn10300_native_view,
334 REGSET_GENERAL, 333 REGSET_GENERAL,
335 0, NR_PTREGS * sizeof(long), 334 0, NR_PTREGS * sizeof(long),
336 (void __user *)data); 335 datap);
337 336
338 case PTRACE_SETREGS: /* Set all integer regs in the child. */ 337 case PTRACE_SETREGS: /* Set all integer regs in the child. */
339 return copy_regset_from_user(child, &user_mn10300_native_view, 338 return copy_regset_from_user(child, &user_mn10300_native_view,
340 REGSET_GENERAL, 339 REGSET_GENERAL,
341 0, NR_PTREGS * sizeof(long), 340 0, NR_PTREGS * sizeof(long),
342 (const void __user *)data); 341 datap);
343 342
344 case PTRACE_GETFPREGS: /* Get the child FPU state. */ 343 case PTRACE_GETFPREGS: /* Get the child FPU state. */
345 return copy_regset_to_user(child, &user_mn10300_native_view, 344 return copy_regset_to_user(child, &user_mn10300_native_view,
346 REGSET_FPU, 345 REGSET_FPU,
347 0, sizeof(struct fpu_state_struct), 346 0, sizeof(struct fpu_state_struct),
348 (void __user *)data); 347 datap);
349 348
350 case PTRACE_SETFPREGS: /* Set the child FPU state. */ 349 case PTRACE_SETFPREGS: /* Set the child FPU state. */
351 return copy_regset_from_user(child, &user_mn10300_native_view, 350 return copy_regset_from_user(child, &user_mn10300_native_view,
352 REGSET_FPU, 351 REGSET_FPU,
353 0, sizeof(struct fpu_state_struct), 352 0, sizeof(struct fpu_state_struct),
354 (const void __user *)data); 353 datap);
355 354
356 default: 355 default:
357 ret = ptrace_request(child, request, addr, data); 356 ret = ptrace_request(child, request, addr, data);