aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sparc/kernel/ptrace_32.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/sparc/kernel/ptrace_32.c')
-rw-r--r--arch/sparc/kernel/ptrace_32.c54
1 files changed, 20 insertions, 34 deletions
diff --git a/arch/sparc/kernel/ptrace_32.c b/arch/sparc/kernel/ptrace_32.c
index e08ba4a46acd..27b9e93d0121 100644
--- a/arch/sparc/kernel/ptrace_32.c
+++ b/arch/sparc/kernel/ptrace_32.c
@@ -323,19 +323,35 @@ const struct user_regset_view *task_user_regset_view(struct task_struct *task)
323 return &user_sparc32_view; 323 return &user_sparc32_view;
324} 324}
325 325
326struct fps {
327 unsigned long regs[32];
328 unsigned long fsr;
329 unsigned long flags;
330 unsigned long extra;
331 unsigned long fpqd;
332 struct fq {
333 unsigned long *insnaddr;
334 unsigned long insn;
335 } fpq[16];
336};
337
326long arch_ptrace(struct task_struct *child, long request, 338long arch_ptrace(struct task_struct *child, long request,
327 unsigned long addr, unsigned long data) 339 unsigned long addr, unsigned long data)
328{ 340{
329 unsigned long addr2 = current->thread.kregs->u_regs[UREG_I4]; 341 unsigned long addr2 = current->thread.kregs->u_regs[UREG_I4];
342 void __user *addr2p;
330 const struct user_regset_view *view; 343 const struct user_regset_view *view;
344 struct pt_regs __user *pregs;
345 struct fps __user *fps;
331 int ret; 346 int ret;
332 347
333 view = task_user_regset_view(current); 348 view = task_user_regset_view(current);
349 addr2p = (void __user *) addr2;
350 pregs = (struct pt_regs __user *) addr;
351 fps = (struct fps __user *) addr;
334 352
335 switch(request) { 353 switch(request) {
336 case PTRACE_GETREGS: { 354 case PTRACE_GETREGS: {
337 struct pt_regs __user *pregs = (struct pt_regs __user *) addr;
338
339 ret = copy_regset_to_user(child, view, REGSET_GENERAL, 355 ret = copy_regset_to_user(child, view, REGSET_GENERAL,
340 32 * sizeof(u32), 356 32 * sizeof(u32),
341 4 * sizeof(u32), 357 4 * sizeof(u32),
@@ -349,8 +365,6 @@ long arch_ptrace(struct task_struct *child, long request,
349 } 365 }
350 366
351 case PTRACE_SETREGS: { 367 case PTRACE_SETREGS: {
352 struct pt_regs __user *pregs = (struct pt_regs __user *) addr;
353
354 ret = copy_regset_from_user(child, view, REGSET_GENERAL, 368 ret = copy_regset_from_user(child, view, REGSET_GENERAL,
355 32 * sizeof(u32), 369 32 * sizeof(u32),
356 4 * sizeof(u32), 370 4 * sizeof(u32),
@@ -364,19 +378,6 @@ long arch_ptrace(struct task_struct *child, long request,
364 } 378 }
365 379
366 case PTRACE_GETFPREGS: { 380 case PTRACE_GETFPREGS: {
367 struct fps {
368 unsigned long regs[32];
369 unsigned long fsr;
370 unsigned long flags;
371 unsigned long extra;
372 unsigned long fpqd;
373 struct fq {
374 unsigned long *insnaddr;
375 unsigned long insn;
376 } fpq[16];
377 };
378 struct fps __user *fps = (struct fps __user *) addr;
379
380 ret = copy_regset_to_user(child, view, REGSET_FP, 381 ret = copy_regset_to_user(child, view, REGSET_FP,
381 0 * sizeof(u32), 382 0 * sizeof(u32),
382 32 * sizeof(u32), 383 32 * sizeof(u32),
@@ -398,19 +399,6 @@ long arch_ptrace(struct task_struct *child, long request,
398 } 399 }
399 400
400 case PTRACE_SETFPREGS: { 401 case PTRACE_SETFPREGS: {
401 struct fps {
402 unsigned long regs[32];
403 unsigned long fsr;
404 unsigned long flags;
405 unsigned long extra;
406 unsigned long fpqd;
407 struct fq {
408 unsigned long *insnaddr;
409 unsigned long insn;
410 } fpq[16];
411 };
412 struct fps __user *fps = (struct fps __user *) addr;
413
414 ret = copy_regset_from_user(child, view, REGSET_FP, 402 ret = copy_regset_from_user(child, view, REGSET_FP,
415 0 * sizeof(u32), 403 0 * sizeof(u32),
416 32 * sizeof(u32), 404 32 * sizeof(u32),
@@ -425,8 +413,7 @@ long arch_ptrace(struct task_struct *child, long request,
425 413
426 case PTRACE_READTEXT: 414 case PTRACE_READTEXT:
427 case PTRACE_READDATA: 415 case PTRACE_READDATA:
428 ret = ptrace_readdata(child, addr, 416 ret = ptrace_readdata(child, addr, addr2p, data);
429 (void __user *) addr2, data);
430 417
431 if (ret == data) 418 if (ret == data)
432 ret = 0; 419 ret = 0;
@@ -436,8 +423,7 @@ long arch_ptrace(struct task_struct *child, long request,
436 423
437 case PTRACE_WRITETEXT: 424 case PTRACE_WRITETEXT:
438 case PTRACE_WRITEDATA: 425 case PTRACE_WRITEDATA:
439 ret = ptrace_writedata(child, (void __user *) addr2, 426 ret = ptrace_writedata(child, addr2p, addr, data);
440 addr, data);
441 427
442 if (ret == data) 428 if (ret == data)
443 ret = 0; 429 ret = 0;