Commit a32e5baf authored by Jeff Dike's avatar Jeff Dike Committed by Linus Torvalds

[PATCH] uml: provide an arch-specific define for register file size

Replace FRAME_SIZE_OFFSET with MAX_REG_OFFSET because different arches have
Signed-off-by: default avatarJeff Dike <jdike@addtoit.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent d5ad622a
...@@ -33,6 +33,9 @@ ...@@ -33,6 +33,9 @@
#define FP_FRAME_SIZE (27) #define FP_FRAME_SIZE (27)
#define FPX_FRAME_SIZE (128) #define FPX_FRAME_SIZE (128)
#define MAX_REG_OFFSET (FRAME_SIZE_OFFSET)
#define MAX_REG_NR (FRAME_SIZE)
#ifdef PTRACE_GETREGS #ifdef PTRACE_GETREGS
#define UM_HAVE_GETREGS #define UM_HAVE_GETREGS
#endif #endif
......
...@@ -94,7 +94,7 @@ long sys_ptrace(long request, long pid, long addr, long data) ...@@ -94,7 +94,7 @@ long sys_ptrace(long request, long pid, long addr, long data)
break; break;
tmp = 0; /* Default return condition */ tmp = 0; /* Default return condition */
if(addr < FRAME_SIZE_OFFSET){ if(addr < MAX_REG_OFFSET){
tmp = getreg(child, addr); tmp = getreg(child, addr);
} }
else if((addr >= offsetof(struct user, u_debugreg[0])) && else if((addr >= offsetof(struct user, u_debugreg[0])) &&
...@@ -122,10 +122,11 @@ long sys_ptrace(long request, long pid, long addr, long data) ...@@ -122,10 +122,11 @@ long sys_ptrace(long request, long pid, long addr, long data)
if ((addr & 3) || addr < 0) if ((addr & 3) || addr < 0)
break; break;
if (addr < FRAME_SIZE_OFFSET) { if (addr < MAX_REG_OFFSET) {
ret = putreg(child, addr, data); ret = putreg(child, addr, data);
break; break;
} }
#if 0 /* XXX x86_64 */
else if((addr >= offsetof(struct user, u_debugreg[0])) && else if((addr >= offsetof(struct user, u_debugreg[0])) &&
(addr <= offsetof(struct user, u_debugreg[7]))){ (addr <= offsetof(struct user, u_debugreg[7]))){
addr -= offsetof(struct user, u_debugreg[0]); addr -= offsetof(struct user, u_debugreg[0]);
...@@ -134,6 +135,7 @@ long sys_ptrace(long request, long pid, long addr, long data) ...@@ -134,6 +135,7 @@ long sys_ptrace(long request, long pid, long addr, long data)
child->thread.arch.debugregs[addr] = data; child->thread.arch.debugregs[addr] = data;
ret = 0; ret = 0;
} }
#endif
break; break;
...@@ -196,11 +198,11 @@ long sys_ptrace(long request, long pid, long addr, long data) ...@@ -196,11 +198,11 @@ long sys_ptrace(long request, long pid, long addr, long data)
#ifdef PTRACE_GETREGS #ifdef PTRACE_GETREGS
case PTRACE_GETREGS: { /* Get all gp regs from the child. */ case PTRACE_GETREGS: { /* Get all gp regs from the child. */
if (!access_ok(VERIFY_WRITE, (unsigned long *)data, if (!access_ok(VERIFY_WRITE, (unsigned long *)data,
FRAME_SIZE_OFFSET)) { MAX_REG_OFFSET)) {
ret = -EIO; ret = -EIO;
break; break;
} }
for ( i = 0; i < FRAME_SIZE_OFFSET; i += sizeof(long) ) { for ( i = 0; i < MAX_REG_OFFSET; i += sizeof(long) ) {
__put_user(getreg(child, i), __put_user(getreg(child, i),
(unsigned long __user *) data); (unsigned long __user *) data);
data += sizeof(long); data += sizeof(long);
...@@ -213,11 +215,11 @@ long sys_ptrace(long request, long pid, long addr, long data) ...@@ -213,11 +215,11 @@ long sys_ptrace(long request, long pid, long addr, long data)
case PTRACE_SETREGS: { /* Set all gp regs in the child. */ case PTRACE_SETREGS: { /* Set all gp regs in the child. */
unsigned long tmp = 0; unsigned long tmp = 0;
if (!access_ok(VERIFY_READ, (unsigned *)data, if (!access_ok(VERIFY_READ, (unsigned *)data,
FRAME_SIZE_OFFSET)) { MAX_REG_OFFSET)) {
ret = -EIO; ret = -EIO;
break; break;
} }
for ( i = 0; i < FRAME_SIZE_OFFSET; i += sizeof(long) ) { for ( i = 0; i < MAX_REG_OFFSET; i += sizeof(long) ) {
__get_user(tmp, (unsigned long __user *) data); __get_user(tmp, (unsigned long __user *) data);
putreg(child, i, tmp); putreg(child, i, tmp);
data += sizeof(long); data += sizeof(long);
......
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