[PATCH] node local per-cpu-pages
[GitHub/mt8127/android_kernel_alcatel_ttab.git] / arch / x86_64 / kernel / sys_x86_64.c
CommitLineData
1da177e4
LT
1/*
2 * linux/arch/x86_64/kernel/sys_x86_64.c
3 */
4
5#include <linux/errno.h>
6#include <linux/sched.h>
7#include <linux/syscalls.h>
8#include <linux/mm.h>
9#include <linux/smp.h>
10#include <linux/smp_lock.h>
11#include <linux/sem.h>
12#include <linux/msg.h>
13#include <linux/shm.h>
14#include <linux/stat.h>
15#include <linux/mman.h>
16#include <linux/file.h>
17#include <linux/utsname.h>
18#include <linux/personality.h>
19
20#include <asm/uaccess.h>
21#include <asm/ia32.h>
22
23/*
24 * sys_pipe() is the normal C calling standard for creating
25 * a pipe. It's not the way Unix traditionally does this, though.
26 */
27asmlinkage long sys_pipe(int __user *fildes)
28{
29 int fd[2];
30 int error;
31
32 error = do_pipe(fd);
33 if (!error) {
34 if (copy_to_user(fildes, fd, 2*sizeof(int)))
35 error = -EFAULT;
36 }
37 return error;
38}
39
40asmlinkage long sys_mmap(unsigned long addr, unsigned long len, unsigned long prot, unsigned long flags,
41 unsigned long fd, unsigned long off)
42{
43 long error;
44 struct file * file;
45
46 error = -EINVAL;
47 if (off & ~PAGE_MASK)
48 goto out;
49
50 error = -EBADF;
51 file = NULL;
52 flags &= ~(MAP_EXECUTABLE | MAP_DENYWRITE);
53 if (!(flags & MAP_ANONYMOUS)) {
54 file = fget(fd);
55 if (!file)
56 goto out;
57 }
58 down_write(&current->mm->mmap_sem);
59 error = do_mmap_pgoff(file, addr, len, prot, flags, off >> PAGE_SHIFT);
60 up_write(&current->mm->mmap_sem);
61
62 if (file)
63 fput(file);
64out:
65 return error;
66}
67
68static void find_start_end(unsigned long flags, unsigned long *begin,
69 unsigned long *end)
70{
84929801 71 if (!test_thread_flag(TIF_IA32) && (flags & MAP_32BIT)) {
1da177e4
LT
72 /* This is usually used needed to map code in small
73 model, so it needs to be in the first 31bit. Limit
74 it to that. This means we need to move the
75 unmapped base down for this case. This can give
76 conflicts with the heap, but we assume that glibc
77 malloc knows how to fall back to mmap. Give it 1GB
78 of playground for now. -AK */
79 *begin = 0x40000000;
80 *end = 0x80000000;
84929801
SS
81 } else {
82 *begin = TASK_UNMAPPED_BASE;
1da177e4 83 *end = TASK_SIZE;
84929801 84 }
1da177e4
LT
85}
86
87unsigned long
88arch_get_unmapped_area(struct file *filp, unsigned long addr,
89 unsigned long len, unsigned long pgoff, unsigned long flags)
90{
91 struct mm_struct *mm = current->mm;
92 struct vm_area_struct *vma;
93 unsigned long start_addr;
94 unsigned long begin, end;
95
96 find_start_end(flags, &begin, &end);
97
98 if (len > end)
99 return -ENOMEM;
100
101 if (addr) {
102 addr = PAGE_ALIGN(addr);
103 vma = find_vma(mm, addr);
104 if (end - len >= addr &&
105 (!vma || addr + len <= vma->vm_start))
106 return addr;
107 }
108 addr = mm->free_area_cache;
109 if (addr < begin)
110 addr = begin;
111 start_addr = addr;
112
113full_search:
114 for (vma = find_vma(mm, addr); ; vma = vma->vm_next) {
115 /* At this point: (!vma || addr < vma->vm_end). */
116 if (end - len < addr) {
117 /*
118 * Start a new search - just in case we missed
119 * some holes.
120 */
121 if (start_addr != begin) {
122 start_addr = addr = begin;
123 goto full_search;
124 }
125 return -ENOMEM;
126 }
127 if (!vma || addr + len <= vma->vm_start) {
128 /*
129 * Remember the place where we stopped the search:
130 */
131 mm->free_area_cache = addr + len;
132 return addr;
133 }
134 addr = vma->vm_end;
135 }
136}
137
138asmlinkage long sys_uname(struct new_utsname __user * name)
139{
140 int err;
141 down_read(&uts_sem);
142 err = copy_to_user(name, &system_utsname, sizeof (*name));
143 up_read(&uts_sem);
144 if (personality(current->personality) == PER_LINUX32)
145 err |= copy_to_user(&name->machine, "i686", 5);
146 return err ? -EFAULT : 0;
147}
148
1da177e4
LT
149asmlinkage long sys_time64(long __user * tloc)
150{
151 struct timeval now;
152 int i;
153
154 do_gettimeofday(&now);
155 i = now.tv_sec;
156 if (tloc) {
157 if (put_user(i,tloc))
158 i = -EFAULT;
159 }
160 return i;
161}