Merge branch 'merge' of git://git.kernel.org/pub/scm/linux/kernel/git/benh/powerpc
[pandora-kernel.git] / arch / um / kernel / syscall.c
1 /*
2  * Copyright (C) 2000 - 2007 Jeff Dike (jdike@{addtoit,linux.intel}.com)
3  * Licensed under the GPL
4  */
5
6 #include "linux/file.h"
7 #include "linux/fs.h"
8 #include "linux/mm.h"
9 #include "linux/sched.h"
10 #include "linux/utsname.h"
11 #include "linux/syscalls.h"
12 #include "asm/current.h"
13 #include "asm/mman.h"
14 #include "asm/uaccess.h"
15 #include "asm/unistd.h"
16 #include "internal.h"
17
18 long sys_fork(void)
19 {
20         long ret;
21
22         current->thread.forking = 1;
23         ret = do_fork(SIGCHLD, UPT_SP(&current->thread.regs.regs),
24                       &current->thread.regs, 0, NULL, NULL);
25         current->thread.forking = 0;
26         return ret;
27 }
28
29 long sys_vfork(void)
30 {
31         long ret;
32
33         current->thread.forking = 1;
34         ret = do_fork(CLONE_VFORK | CLONE_VM | SIGCHLD,
35                       UPT_SP(&current->thread.regs.regs),
36                       &current->thread.regs, 0, NULL, NULL);
37         current->thread.forking = 0;
38         return ret;
39 }
40
41 long old_mmap(unsigned long addr, unsigned long len,
42               unsigned long prot, unsigned long flags,
43               unsigned long fd, unsigned long offset)
44 {
45         long err = -EINVAL;
46         if (offset & ~PAGE_MASK)
47                 goto out;
48
49         err = sys_mmap_pgoff(addr, len, prot, flags, fd, offset >> PAGE_SHIFT);
50  out:
51         return err;
52 }
53
54 int kernel_execve(const char *filename, char *const argv[], char *const envp[])
55 {
56         mm_segment_t fs;
57         int ret;
58
59         fs = get_fs();
60         set_fs(KERNEL_DS);
61         ret = um_execve((char *)filename, (char __user *__user *)argv,
62                         (char __user *__user *) envp);
63         set_fs(fs);
64
65         return ret;
66 }