sh: Fix ptrace fpu state initialisation
Commit 0ea820cf
introduced the PTRACE_GETFPREGS/SETFPREGS cmds,
but gdb-server still accesses the FPU state using the
PTRACE_PEEKUSR/POKEUSR commands. In this case, xstate was not
initialised.
Signed-off-by: Phil Edworthy <phil.edworthy@renesas.com>
Cc: stable@kernel.org
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
This commit is contained in:
parent
3f4caa8157
commit
c49b6ecf08
|
@ -392,6 +392,9 @@ long arch_ptrace(struct task_struct *child, long request,
|
||||||
tmp = 0;
|
tmp = 0;
|
||||||
} else {
|
} else {
|
||||||
unsigned long index;
|
unsigned long index;
|
||||||
|
ret = init_fpu(child);
|
||||||
|
if (ret)
|
||||||
|
break;
|
||||||
index = addr - offsetof(struct user, fpu);
|
index = addr - offsetof(struct user, fpu);
|
||||||
tmp = ((unsigned long *)child->thread.xstate)
|
tmp = ((unsigned long *)child->thread.xstate)
|
||||||
[index >> 2];
|
[index >> 2];
|
||||||
|
@ -423,6 +426,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)) {
|
||||||
unsigned long index;
|
unsigned long index;
|
||||||
|
ret = init_fpu(child);
|
||||||
|
if (ret)
|
||||||
|
break;
|
||||||
index = addr - offsetof(struct user, fpu);
|
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)
|
||||||
|
|
|
@ -403,6 +403,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))) {
|
||||||
unsigned long index;
|
unsigned long index;
|
||||||
|
ret = init_fpu(child);
|
||||||
|
if (ret)
|
||||||
|
break;
|
||||||
index = addr - offsetof(struct user, fpu);
|
index = addr - offsetof(struct user, fpu);
|
||||||
tmp = get_fpu_long(child, index);
|
tmp = get_fpu_long(child, index);
|
||||||
} else if (addr == offsetof(struct user, u_fpvalid)) {
|
} else if (addr == offsetof(struct user, u_fpvalid)) {
|
||||||
|
@ -442,6 +445,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))) {
|
||||||
unsigned long index;
|
unsigned long index;
|
||||||
|
ret = init_fpu(child);
|
||||||
|
if (ret)
|
||||||
|
break;
|
||||||
index = addr - offsetof(struct user, fpu);
|
index = addr - offsetof(struct user, fpu);
|
||||||
ret = put_fpu_long(child, index, data);
|
ret = put_fpu_long(child, index, data);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue