Loading...
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 | #ifndef _ALPHA_UNISTD_H #define _ALPHA_UNISTD_H #define __NR_exit 1 #define __NR_fork 2 #define __NR_read 3 #define __NR_write 4 #define __NR_close 6 #define __NR_wait4 7 #define __NR_link 9 #define __NR_unlink 10 #define __NR_chdir 12 #define __NR_fchdir 13 #define __NR_mknod 14 #define __NR_chmod 15 #define __NR_chown 16 #define __NR_brk 17 #define __NR_lseek 19 #define __NR_getxpid 20 #define __NR_setuid 23 #define __NR_getxuid 24 #define __NR_ptrace 26 #define __NR_access 33 #define __NR_sync 36 #define __NR_kill 37 #define __NR_setpgid 39 #define __NR_dup 41 #define __NR_pipe 42 #define __NR_open 45 #define __NR_getxgid 47 #define __NR_acct 51 #define __NR_sigpending 52 #define __NR_ioctl 54 #define __NR_symlink 57 #define __NR_readlink 58 #define __NR_execve 59 #define __NR_umask 60 #define __NR_chroot 61 #define __NR_getpgrp 63 #define __NR_getpagesize 64 #define __NR_stat 67 #define __NR_lstat 68 #define __NR_mmap 71 /* OSF/1 mmap is superset of Linux */ #define __NR_munmap 73 #define __NR_mprotect 74 #define __NR_madvise 75 #define __NR_vhangup 76 #define __NR_getgroups 79 #define __NR_setgroups 80 #define __NR_setpgrp 82 /* BSD alias for setpgid */ #define __NR_setitimer 83 #define __NR_getitimer 86 #define __NR_gethostname 87 #define __NR_sethostname 88 #define __NR_getdtablesize 89 #define __NR_dup2 90 #define __NR_fstat 91 #define __NR_fcntl 92 #define __NR_select 93 #define __NR_fsync 95 #define __NR_setpriority 96 #define __NR_socket 97 #define __NR_connect 98 #define __NR_accept 99 #define __NR_getpriority 100 #define __NR_send 101 #define __NR_recv 102 #define __NR_sigreturn 103 #define __NR_bind 104 #define __NR_setsockopt 105 #define __NR_listen 106 #define __NR_sigsuspend 111 #define __NR_recvmsg 113 #define __NR_sendmsg 114 #define __NR_gettimeofday 116 #define __NR_getrusage 117 #define __NR_getsockopt 118 #define __NR_readv 120 #define __NR_writev 121 #define __NR_settimeofday 122 #define __NR_fchown 123 #define __NR_fchmod 124 #define __NR_recvfrom 125 #define __NR_setreuid 126 #define __NR_setregid 127 #define __NR_rename 128 #define __NR_truncate 129 #define __NR_ftruncate 130 #define __NR_flock 131 #define __NR_setgid 132 #define __NR_sendto 133 #define __NR_shutdown 134 #define __NR_socketpair 135 #define __NR_mkdir 136 #define __NR_rmdir 137 #define __NR_utimes 138 #define __NR_getpeername 141 #define __NR_getrlimit 144 #define __NR_setrlimit 145 #define __NR_setsid 147 #define __NR_quotactl 148 #define __NR_getsockname 150 #define __NR_sigaction 156 #define __NR_setdomainname 166 #define __NR_msgctl 200 #define __NR_msgget 201 #define __NR_msgrcv 202 #define __NR_msgsnd 203 #define __NR_semctl 204 #define __NR_semget 205 #define __NR_semop 206 #define __NR_shmctl 210 #define __NR_shmdt 211 #define __NR_shmget 212 #define __NR_msync 217 #define __NR_getpgid 233 #define __NR_getsid 234 #define __NR_sysfs 254 /* * Linux-specific system calls begin at 300 */ #define __NR_bdflush 300 #define __NR_sethae 301 #define __NR_mount 302 #define __NR_adjtimex 303 #define __NR_swapoff 304 #define __NR_getdents 305 #define __NR_create_module 306 #define __NR_init_module 307 #define __NR_delete_module 308 #define __NR_get_kernel_syms 309 #define __NR_syslog 310 #define __NR_reboot 311 #define __NR_clone 312 #define __NR_uselib 313 #define __NR_mlock 314 #define __NR_munlock 315 #define __NR_mlockall 316 #define __NR_munlockall 317 #define __NR_sysinfo 318 #define __NR__sysctl 319 #define __NR_idle 320 #define __NR_umount 321 #define __NR_swapon 322 #define __NR_times 323 #define __NR_personality 324 #define __NR_setfsuid 325 #define __NR_setfsgid 326 #define __NR_ustat 327 #define __NR_statfs 328 #define __NR_fstatfs 329 #define __NR_sched_setparam 330 #define __NR_sched_getparam 331 #define __NR_sched_setscheduler 332 #define __NR_sched_getscheduler 333 #define __NR_sched_yield 334 #define __NR_sched_get_priority_max 335 #define __NR_sched_get_priority_min 336 #define __NR_sched_rr_get_interval 337 #define __NR_afs_syscall 338 #define __NR_uname 339 #define __NR_nanosleep 340 #define __NR_mremap 341 #define __NR_nfsctl 342 #if defined(__LIBRARY__) && defined(__GNUC__) /* XXX - _foo needs to be __foo, while __NR_bar could be _NR_bar. */ #define _syscall0(type, name) \ type name(void) \ { \ extern long syscall (int, ...); \ return syscall(__NR_##name)); \ } #define _syscall1(type,name,type1,arg1) \ type name(type1 arg1) \ { \ extern long syscall (int, ...); \ return syscall(__NR_##name, arg1); \ } #define _syscall2(type,name,type1,arg1,type2,arg2) \ type name(type1 arg1,type2 arg2) \ { \ extern long syscall (int, ...); \ return syscall(__NR_##name, arg1, arg2); \ } #define _syscall3(type,name,type1,arg1,type2,arg2,type3,arg3) \ type name(type1 arg1,type2 arg2,type3 arg3) \ { \ extern long syscall (int, ...); \ return syscall(__NR_##name, arg1, arg2, arg3); \ } #define _syscall4(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4) \ type name (type1 arg1, type2 arg2, type3 arg3, type4 arg4) \ { \ extern long syscall (int, ...); \ return syscall(__NR_##name, arg1, arg2, arg3, arg4); \ } #define _syscall5(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4, \ type5,arg5) \ type name (type1 arg1,type2 arg2,type3 arg3,type4 arg4,type5 arg5) \ { \ extern long syscall (int, ...); \ return syscall(__NR_##name, arg1, arg2, arg3, arg4); \ } #endif /* __LIBRARY__ && __GNUC__ */ #ifdef __KERNEL_SYSCALLS__ #include <linux/string.h> #include <linux/signal.h> extern long __kernel_thread(unsigned long, int (*)(void *), void *); static inline long kernel_thread(int (*fn)(void *), void * arg, unsigned long flags) { return __kernel_thread(flags | CLONE_VM, fn, arg); } extern void sys_idle(void); static inline void idle(void) { sys_idle(); } extern int sys_setup(void); static inline int setup(void) { return sys_setup(); } extern int sys_open(const char *, int, int); static inline int open(const char * name, int mode, int flags) { return sys_open(name, mode, flags); } extern int sys_dup(int); static inline int dup(int fd) { return sys_dup(fd); } static inline int close(int fd) { return sys_close(fd); } extern int sys_exit(int); static inline int _exit(int value) { return sys_exit(value); } #define exit(x) _exit(x) extern int sys_write(int, const char *, int); static inline int write(int fd, const char * buf, int nr) { return sys_write(fd, buf, nr); } extern int sys_read(int, char *, int); static inline int read(int fd, char * buf, int nr) { return sys_read(fd, buf, nr); } extern int do_execve(char *, char **, char **, struct pt_regs *); extern void ret_from_sys_call(void); static inline int execve(char * file, char ** argvp, char ** envp) { int i; struct pt_regs regs; memset(®s, 0, sizeof(regs)); i = do_execve(file, argvp, envp, ®s); if (!i) { __asm__ __volatile__("bis %0,%0,$30\n\t" "bis %1,%1,$26\n\t" "ret $31,($26),1\n\t" : :"r" (®s), "r" (ret_from_sys_call)); } return -1; } extern int sys_setsid(void); static inline int setsid(void) { return sys_setsid(); } extern int sys_sync(void); static inline int sync(void) { return sys_sync(); } extern int sys_wait4(int, int *, int, struct rusage *); static inline pid_t waitpid(int pid, int * wait_stat, int flags) { return sys_wait4(pid, wait_stat, flags, NULL); } static inline pid_t wait(int * wait_stat) { return waitpid(-1,wait_stat,0); } #endif #endif /* _ALPHA_UNISTD_H */ |