Commit 2d58cc9a authored by Jeff Dike's avatar Jeff Dike Committed by Linus Torvalds

[PATCH] uml: x86_64 fixes

This fixes some x86_64 bugs -

- maybe_map returns -1 on error instead of 0, which is interpreted as
  physical address 0

- removed an include of ipc.h, which isn't needed

- fixed the calculation of signal frame location

- the signal delivery code is now immune to the stack expansion check

- added a missing include
Signed-off-by: default avatarJeff Dike <jdike@addtoit.com>
Cc: Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 0f7e663d
...@@ -29,9 +29,12 @@ static unsigned long maybe_map(unsigned long virt, int is_write) ...@@ -29,9 +29,12 @@ static unsigned long maybe_map(unsigned long virt, int is_write)
if(IS_ERR(phys) || (is_write && !pte_write(pte))){ if(IS_ERR(phys) || (is_write && !pte_write(pte))){
err = handle_page_fault(virt, 0, is_write, 1, &dummy_code); err = handle_page_fault(virt, 0, is_write, 1, &dummy_code);
if(err) if(err)
return(0); return(-1UL);
phys = um_virt_to_phys(current, virt, NULL); phys = um_virt_to_phys(current, virt, NULL);
} }
if(IS_ERR(phys))
phys = (void *) -1;
return((unsigned long) phys); return((unsigned long) phys);
} }
...@@ -42,7 +45,7 @@ static int do_op(unsigned long addr, int len, int is_write, ...@@ -42,7 +45,7 @@ static int do_op(unsigned long addr, int len, int is_write,
int n; int n;
addr = maybe_map(addr, is_write); addr = maybe_map(addr, is_write);
if(addr == -1) if(addr == -1UL)
return(-1); return(-1);
page = phys_to_page(addr); page = phys_to_page(addr);
......
...@@ -17,7 +17,6 @@ ...@@ -17,7 +17,6 @@
#include "linux/utime.h" #include "linux/utime.h"
#include "asm/mman.h" #include "asm/mman.h"
#include "asm/uaccess.h" #include "asm/uaccess.h"
#include "asm/ipc.h"
#include "kern_util.h" #include "kern_util.h"
#include "user_util.h" #include "user_util.h"
#include "sysdep/syscalls.h" #include "sysdep/syscalls.h"
......
...@@ -48,7 +48,7 @@ int handle_page_fault(unsigned long address, unsigned long ip, ...@@ -48,7 +48,7 @@ int handle_page_fault(unsigned long address, unsigned long ip,
goto good_area; goto good_area;
else if(!(vma->vm_flags & VM_GROWSDOWN)) else if(!(vma->vm_flags & VM_GROWSDOWN))
goto out; goto out;
else if(!ARCH_IS_STACKGROW(address)) else if(is_user && !ARCH_IS_STACKGROW(address))
goto out; goto out;
else if(expand_stack(vma, address)) else if(expand_stack(vma, address))
goto out; goto out;
......
...@@ -168,7 +168,7 @@ int setup_signal_stack_si(unsigned long stack_top, int sig, ...@@ -168,7 +168,7 @@ int setup_signal_stack_si(unsigned long stack_top, int sig,
frame = (struct rt_sigframe __user *) frame = (struct rt_sigframe __user *)
round_down(stack_top - sizeof(struct rt_sigframe), 16) - 8; round_down(stack_top - sizeof(struct rt_sigframe), 16) - 8;
frame -= 128; ((unsigned char *) frame) -= 128;
if (!access_ok(VERIFY_WRITE, fp, sizeof(struct _fpstate))) if (!access_ok(VERIFY_WRITE, fp, sizeof(struct _fpstate)))
goto out; goto out;
......
...@@ -44,6 +44,8 @@ long sys_modify_ldt_tt(int func, void *ptr, unsigned long bytecount) ...@@ -44,6 +44,8 @@ long sys_modify_ldt_tt(int func, void *ptr, unsigned long bytecount)
#ifdef CONFIG_MODE_SKAS #ifdef CONFIG_MODE_SKAS
extern int userspace_pid[]; extern int userspace_pid[];
#include "skas_ptrace.h"
long sys_modify_ldt_skas(int func, void *ptr, unsigned long bytecount) long sys_modify_ldt_skas(int func, void *ptr, unsigned long bytecount)
{ {
struct ptrace_ldt ldt; struct ptrace_ldt ldt;
......
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