Commit 9e1cb206 authored by Namhyung Kim's avatar Namhyung Kim Committed by Linus Torvalds

ptrace: cleanup arch_ptrace() on sh

Remove unnecessary castings and get rid of dummy pointer in favor of
offsetof() macro in ptrace_32.c. Also use temporary variables and
break long lines in order to improve readability.
Signed-off-by: default avatarNamhyung Kim <namhyung@gmail.com>
Cc: Paul Mundt <lethal@linux-sh.org>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 41a2437e
...@@ -368,7 +368,6 @@ const struct user_regset_view *task_user_regset_view(struct task_struct *task) ...@@ -368,7 +368,6 @@ const struct user_regset_view *task_user_regset_view(struct task_struct *task)
long arch_ptrace(struct task_struct *child, long request, long arch_ptrace(struct task_struct *child, long request,
unsigned long addr, unsigned long data) unsigned long addr, unsigned long data)
{ {
struct user * dummy = NULL;
unsigned long __user *datap = (unsigned long __user *)data; unsigned long __user *datap = (unsigned long __user *)data;
int ret; int ret;
...@@ -384,17 +383,20 @@ long arch_ptrace(struct task_struct *child, long request, ...@@ -384,17 +383,20 @@ long arch_ptrace(struct task_struct *child, long request,
if (addr < sizeof(struct pt_regs)) if (addr < sizeof(struct pt_regs))
tmp = get_stack_long(child, addr); tmp = get_stack_long(child, addr);
else if (addr >= (unsigned long) &dummy->fpu && else if (addr >= offsetof(struct user, fpu) &&
addr < (unsigned long) &dummy->u_fpvalid) { addr < offsetof(struct user, u_fpvalid)) {
if (!tsk_used_math(child)) { if (!tsk_used_math(child)) {
if (addr == (unsigned long)&dummy->fpu.fpscr) if (addr == offsetof(struct user, fpu.fpscr))
tmp = FPSCR_INIT; tmp = FPSCR_INIT;
else else
tmp = 0; tmp = 0;
} else } else {
unsigned long index;
index = addr - offsetof(struct user, fpu);
tmp = ((unsigned long *)child->thread.xstate) tmp = ((unsigned long *)child->thread.xstate)
[(addr - (long)&dummy->fpu) >> 2]; [index >> 2];
} else if (addr == (unsigned long) &dummy->u_fpvalid) }
} else if (addr == offsetof(struct user, u_fpvalid))
tmp = !!tsk_used_math(child); tmp = !!tsk_used_math(child);
else if (addr == PT_TEXT_ADDR) else if (addr == PT_TEXT_ADDR)
tmp = child->mm->start_code; tmp = child->mm->start_code;
...@@ -418,13 +420,15 @@ long arch_ptrace(struct task_struct *child, long request, ...@@ -418,13 +420,15 @@ long arch_ptrace(struct task_struct *child, long request,
if (addr < sizeof(struct pt_regs)) if (addr < sizeof(struct pt_regs))
ret = put_stack_long(child, addr, data); ret = put_stack_long(child, addr, data);
else if (addr >= (unsigned long) &dummy->fpu && else if (addr >= offsetof(struct user, fpu) &&
addr < (unsigned long) &dummy->u_fpvalid) { addr < offsetof(struct user, u_fpvalid)) {
unsigned long index;
index = addr - offsetof(struct user, fpu);
set_stopped_child_used_math(child); set_stopped_child_used_math(child);
((unsigned long *)child->thread.xstate) ((unsigned long *)child->thread.xstate)
[(addr - (long)&dummy->fpu) >> 2] = data; [index >> 2] = data;
ret = 0; ret = 0;
} else if (addr == (unsigned long) &dummy->u_fpvalid) { } else if (addr == offsetof(struct user, u_fpvalid)) {
conditional_stopped_child_used_math(data, child); conditional_stopped_child_used_math(data, child);
ret = 0; ret = 0;
} }
...@@ -434,35 +438,35 @@ long arch_ptrace(struct task_struct *child, long request, ...@@ -434,35 +438,35 @@ long arch_ptrace(struct task_struct *child, long request,
return copy_regset_to_user(child, &user_sh_native_view, return copy_regset_to_user(child, &user_sh_native_view,
REGSET_GENERAL, REGSET_GENERAL,
0, sizeof(struct pt_regs), 0, sizeof(struct pt_regs),
(void __user *)data); datap);
case PTRACE_SETREGS: case PTRACE_SETREGS:
return copy_regset_from_user(child, &user_sh_native_view, return copy_regset_from_user(child, &user_sh_native_view,
REGSET_GENERAL, REGSET_GENERAL,
0, sizeof(struct pt_regs), 0, sizeof(struct pt_regs),
(const void __user *)data); datap);
#ifdef CONFIG_SH_FPU #ifdef CONFIG_SH_FPU
case PTRACE_GETFPREGS: case PTRACE_GETFPREGS:
return copy_regset_to_user(child, &user_sh_native_view, return copy_regset_to_user(child, &user_sh_native_view,
REGSET_FPU, REGSET_FPU,
0, sizeof(struct user_fpu_struct), 0, sizeof(struct user_fpu_struct),
(void __user *)data); datap);
case PTRACE_SETFPREGS: case PTRACE_SETFPREGS:
return copy_regset_from_user(child, &user_sh_native_view, return copy_regset_from_user(child, &user_sh_native_view,
REGSET_FPU, REGSET_FPU,
0, sizeof(struct user_fpu_struct), 0, sizeof(struct user_fpu_struct),
(const void __user *)data); datap);
#endif #endif
#ifdef CONFIG_SH_DSP #ifdef CONFIG_SH_DSP
case PTRACE_GETDSPREGS: case PTRACE_GETDSPREGS:
return copy_regset_to_user(child, &user_sh_native_view, return copy_regset_to_user(child, &user_sh_native_view,
REGSET_DSP, REGSET_DSP,
0, sizeof(struct pt_dspregs), 0, sizeof(struct pt_dspregs),
(void __user *)data); datap);
case PTRACE_SETDSPREGS: case PTRACE_SETDSPREGS:
return copy_regset_from_user(child, &user_sh_native_view, return copy_regset_from_user(child, &user_sh_native_view,
REGSET_DSP, REGSET_DSP,
0, sizeof(struct pt_dspregs), 0, sizeof(struct pt_dspregs),
(const void __user *)data); datap);
#endif #endif
default: default:
ret = ptrace_request(child, request, addr, data); ret = ptrace_request(child, request, addr, data);
......
...@@ -387,6 +387,7 @@ long arch_ptrace(struct task_struct *child, long request, ...@@ -387,6 +387,7 @@ long arch_ptrace(struct task_struct *child, long request,
unsigned long addr, unsigned long data) unsigned long addr, unsigned long data)
{ {
int ret; int ret;
unsigned long __user *datap = (unsigned long __user *) data;
switch (request) { switch (request) {
/* read the word at location addr in the USER area. */ /* read the word at location addr in the USER area. */
...@@ -401,13 +402,15 @@ long arch_ptrace(struct task_struct *child, long request, ...@@ -401,13 +402,15 @@ long arch_ptrace(struct task_struct *child, long request,
tmp = get_stack_long(child, addr); tmp = get_stack_long(child, addr);
else if ((addr >= offsetof(struct user, fpu)) && else if ((addr >= offsetof(struct user, fpu)) &&
(addr < offsetof(struct user, u_fpvalid))) { (addr < offsetof(struct user, u_fpvalid))) {
tmp = get_fpu_long(child, addr - offsetof(struct user, fpu)); unsigned long index;
index = addr - offsetof(struct user, fpu);
tmp = get_fpu_long(child, index);
} else if (addr == offsetof(struct user, u_fpvalid)) { } else if (addr == offsetof(struct user, u_fpvalid)) {
tmp = !!tsk_used_math(child); tmp = !!tsk_used_math(child);
} else { } else {
break; break;
} }
ret = put_user(tmp, (unsigned long *)data); ret = put_user(tmp, datap);
break; break;
} }
...@@ -438,7 +441,9 @@ long arch_ptrace(struct task_struct *child, long request, ...@@ -438,7 +441,9 @@ long arch_ptrace(struct task_struct *child, long request,
} }
else if ((addr >= offsetof(struct user, fpu)) && else if ((addr >= offsetof(struct user, fpu)) &&
(addr < offsetof(struct user, u_fpvalid))) { (addr < offsetof(struct user, u_fpvalid))) {
ret = put_fpu_long(child, addr - offsetof(struct user, fpu), data); unsigned long index;
index = addr - offsetof(struct user, fpu);
ret = put_fpu_long(child, index, data);
} }
break; break;
...@@ -446,23 +451,23 @@ long arch_ptrace(struct task_struct *child, long request, ...@@ -446,23 +451,23 @@ long arch_ptrace(struct task_struct *child, long request,
return copy_regset_to_user(child, &user_sh64_native_view, return copy_regset_to_user(child, &user_sh64_native_view,
REGSET_GENERAL, REGSET_GENERAL,
0, sizeof(struct pt_regs), 0, sizeof(struct pt_regs),
(void __user *)data); datap);
case PTRACE_SETREGS: case PTRACE_SETREGS:
return copy_regset_from_user(child, &user_sh64_native_view, return copy_regset_from_user(child, &user_sh64_native_view,
REGSET_GENERAL, REGSET_GENERAL,
0, sizeof(struct pt_regs), 0, sizeof(struct pt_regs),
(const void __user *)data); datap);
#ifdef CONFIG_SH_FPU #ifdef CONFIG_SH_FPU
case PTRACE_GETFPREGS: case PTRACE_GETFPREGS:
return copy_regset_to_user(child, &user_sh64_native_view, return copy_regset_to_user(child, &user_sh64_native_view,
REGSET_FPU, REGSET_FPU,
0, sizeof(struct user_fpu_struct), 0, sizeof(struct user_fpu_struct),
(void __user *)data); datap);
case PTRACE_SETFPREGS: case PTRACE_SETFPREGS:
return copy_regset_from_user(child, &user_sh64_native_view, return copy_regset_from_user(child, &user_sh64_native_view,
REGSET_FPU, REGSET_FPU,
0, sizeof(struct user_fpu_struct), 0, sizeof(struct user_fpu_struct),
(const void __user *)data); datap);
#endif #endif
default: default:
ret = ptrace_request(child, request, addr, data); ret = ptrace_request(child, request, addr, data);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment