| #ifndef _ALPHA_UNISTD_H |
| #define _ALPHA_UNISTD_H |
| |
| #define __NR_osf_syscall 0 /* not implemented */ |
| #define __NR_exit 1 |
| #define __NR_fork 2 |
| #define __NR_read 3 |
| #define __NR_write 4 |
| #define __NR_osf_old_open 5 /* not implemented */ |
| #define __NR_close 6 |
| #define __NR_osf_wait4 7 |
| #define __NR_osf_old_creat 8 /* not implemented */ |
| #define __NR_link 9 |
| #define __NR_unlink 10 |
| #define __NR_osf_execve 11 /* not implemented */ |
| #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_osf_getfsstat 18 /* not implemented */ |
| #define __NR_lseek 19 |
| #define __NR_getxpid 20 |
| #define __NR_osf_mount 21 |
| #define __NR_umount 22 |
| #define __NR_setuid 23 |
| #define __NR_getxuid 24 |
| #define __NR_exec_with_loader 25 /* not implemented */ |
| #define __NR_ptrace 26 |
| #define __NR_osf_nrecvmsg 27 /* not implemented */ |
| #define __NR_osf_nsendmsg 28 /* not implemented */ |
| #define __NR_osf_nrecvfrom 29 /* not implemented */ |
| #define __NR_osf_naccept 30 /* not implemented */ |
| #define __NR_osf_ngetpeername 31 /* not implemented */ |
| #define __NR_osf_ngetsockname 32 /* not implemented */ |
| #define __NR_access 33 |
| #define __NR_osf_chflags 34 /* not implemented */ |
| #define __NR_osf_fchflags 35 /* not implemented */ |
| #define __NR_sync 36 |
| #define __NR_kill 37 |
| #define __NR_osf_old_stat 38 /* not implemented */ |
| #define __NR_setpgid 39 |
| #define __NR_osf_old_lstat 40 /* not implemented */ |
| #define __NR_dup 41 |
| #define __NR_pipe 42 |
| #define __NR_osf_set_program_attributes 43 |
| #define __NR_osf_profil 44 /* not implemented */ |
| #define __NR_open 45 |
| #define __NR_osf_old_sigaction 46 /* not implemented */ |
| #define __NR_getxgid 47 |
| #define __NR_osf_sigprocmask 48 |
| #define __NR_osf_getlogin 49 /* not implemented */ |
| #define __NR_osf_setlogin 50 /* not implemented */ |
| #define __NR_acct 51 |
| #define __NR_sigpending 52 |
| |
| #define __NR_ioctl 54 |
| #define __NR_osf_reboot 55 /* not implemented */ |
| #define __NR_osf_revoke 56 /* not implemented */ |
| #define __NR_symlink 57 |
| #define __NR_readlink 58 |
| #define __NR_execve 59 |
| #define __NR_umask 60 |
| #define __NR_chroot 61 |
| #define __NR_osf_old_fstat 62 /* not implemented */ |
| #define __NR_getpgrp 63 |
| #define __NR_getpagesize 64 |
| #define __NR_osf_mremap 65 /* not implemented */ |
| #define __NR_vfork 66 |
| #define __NR_stat 67 |
| #define __NR_lstat 68 |
| #define __NR_osf_sbrk 69 /* not implemented */ |
| #define __NR_osf_sstk 70 /* not implemented */ |
| #define __NR_mmap 71 /* OSF/1 mmap is superset of Linux */ |
| #define __NR_osf_old_vadvise 72 /* not implemented */ |
| #define __NR_munmap 73 |
| #define __NR_mprotect 74 |
| #define __NR_madvise 75 |
| #define __NR_vhangup 76 |
| #define __NR_osf_kmodcall 77 /* not implemented */ |
| #define __NR_osf_mincore 78 /* not implemented */ |
| #define __NR_getgroups 79 |
| #define __NR_setgroups 80 |
| #define __NR_osf_old_getpgrp 81 /* not implemented */ |
| #define __NR_setpgrp 82 /* BSD alias for setpgid */ |
| #define __NR_osf_setitimer 83 |
| #define __NR_osf_old_wait 84 /* not implemented */ |
| #define __NR_osf_table 85 /* not implemented */ |
| #define __NR_osf_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_osf_select 93 |
| #define __NR_poll 94 |
| #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_osf_plock 107 /* not implemented */ |
| #define __NR_osf_old_sigvec 108 /* not implemented */ |
| #define __NR_osf_old_sigblock 109 /* not implemented */ |
| #define __NR_osf_old_sigsetmask 110 /* not implemented */ |
| #define __NR_sigsuspend 111 |
| #define __NR_osf_sigstack 112 |
| #define __NR_recvmsg 113 |
| #define __NR_sendmsg 114 |
| #define __NR_osf_old_vtrace 115 /* not implemented */ |
| #define __NR_osf_gettimeofday 116 |
| #define __NR_osf_getrusage 117 |
| #define __NR_getsockopt 118 |
| |
| #define __NR_readv 120 |
| #define __NR_writev 121 |
| #define __NR_osf_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_osf_utimes 138 |
| #define __NR_osf_old_sigreturn 139 /* not implemented */ |
| #define __NR_osf_adjtime 140 /* not implemented */ |
| #define __NR_getpeername 141 |
| #define __NR_osf_gethostid 142 /* not implemented */ |
| #define __NR_osf_sethostid 143 /* not implemented */ |
| #define __NR_getrlimit 144 |
| #define __NR_setrlimit 145 |
| #define __NR_osf_old_killpg 146 /* not implemented */ |
| #define __NR_setsid 147 |
| #define __NR_quotactl 148 |
| #define __NR_osf_oldquota 149 /* not implemented */ |
| #define __NR_getsockname 150 |
| |
| #define __NR_osf_pid_block 153 /* not implemented */ |
| #define __NR_osf_pid_unblock 154 /* not implemented */ |
| |
| #define __NR_sigaction 156 |
| #define __NR_osf_sigwaitprim 157 /* not implemented */ |
| #define __NR_osf_nfssvc 158 /* not implemented */ |
| #define __NR_osf_getdirentries 159 |
| #define __NR_osf_statfs 160 |
| #define __NR_osf_fstatfs 161 |
| |
| #define __NR_osf_asynch_daemon 163 /* not implemented */ |
| #define __NR_osf_getfh 164 /* not implemented */ |
| #define __NR_osf_getdomainname 165 |
| #define __NR_setdomainname 166 |
| |
| #define __NR_osf_exportfs 169 /* not implemented */ |
| |
| #define __NR_osf_alt_plock 181 /* not implemented */ |
| |
| #define __NR_osf_getmnt 184 /* not implemented */ |
| |
| #define __NR_osf_alt_sigpending 187 /* not implemented */ |
| #define __NR_osf_alt_setsid 188 /* not implemented */ |
| |
| #define __NR_osf_swapon 199 |
| #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_osf_utsname 207 |
| #define __NR_lchown 208 |
| #define __NR_osf_shmat 209 |
| #define __NR_shmctl 210 |
| #define __NR_shmdt 211 |
| #define __NR_shmget 212 |
| #define __NR_osf_mvalid 213 /* not implemented */ |
| #define __NR_osf_getaddressconf 214 /* not implemented */ |
| #define __NR_osf_msleep 215 /* not implemented */ |
| #define __NR_osf_mwakeup 216 /* not implemented */ |
| #define __NR_msync 217 |
| #define __NR_osf_signal 218 /* not implemented */ |
| #define __NR_osf_utc_gettime 219 /* not implemented */ |
| #define __NR_osf_utc_adjtime 220 /* not implemented */ |
| |
| #define __NR_osf_security 222 /* not implemented */ |
| #define __NR_osf_kloadcall 223 /* not implemented */ |
| |
| #define __NR_getpgid 233 |
| #define __NR_getsid 234 |
| #define __NR_sigaltstack 235 |
| #define __NR_osf_waitid 236 /* not implemented */ |
| #define __NR_osf_priocntlset 237 /* not implemented */ |
| #define __NR_osf_sigsendset 238 /* not implemented */ |
| #define __NR_osf_set_speculative 239 /* not implemented */ |
| #define __NR_osf_msfs_syscall 240 /* not implemented */ |
| #define __NR_osf_sysinfo 241 |
| #define __NR_osf_uadmin 242 /* not implemented */ |
| #define __NR_osf_fuser 243 /* not implemented */ |
| #define __NR_osf_proplist_syscall 244 |
| #define __NR_osf_ntp_adjtime 245 /* not implemented */ |
| #define __NR_osf_ntp_gettime 246 /* not implemented */ |
| #define __NR_osf_pathconf 247 /* not implemented */ |
| #define __NR_osf_fpathconf 248 /* not implemented */ |
| |
| #define __NR_osf_uswitch 250 /* not implemented */ |
| #define __NR_osf_usleep_thread 251 |
| #define __NR_osf_audcntl 252 /* not implemented */ |
| #define __NR_osf_audgen 253 /* not implemented */ |
| #define __NR_sysfs 254 |
| #define __NR_osf_subsys_info 255 /* not implemented */ |
| #define __NR_osf_getsysinfo 256 |
| #define __NR_osf_setsysinfo 257 |
| #define __NR_osf_afs_syscall 258 /* not implemented */ |
| #define __NR_osf_swapctl 259 /* not implemented */ |
| #define __NR_osf_memcntl 260 /* not implemented */ |
| #define __NR_osf_fdatasync 261 /* not implemented */ |
| |
| |
| /* |
| * Linux-specific system calls begin at 300 |
| */ |
| #define __NR_bdflush 300 |
| #define __NR_sethae 301 |
| #define __NR_mount 302 |
| #define __NR_old_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 |
| /* 320 was sys_idle. */ |
| #define __NR_oldumount 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_nfsservctl 342 |
| #define __NR_setresuid 343 |
| #define __NR_getresuid 344 |
| #define __NR_pciconfig_read 345 |
| #define __NR_pciconfig_write 346 |
| #define __NR_query_module 347 |
| #define __NR_prctl 348 |
| #define __NR_pread64 349 |
| #define __NR_pwrite64 350 |
| #define __NR_rt_sigreturn 351 |
| #define __NR_rt_sigaction 352 |
| #define __NR_rt_sigprocmask 353 |
| #define __NR_rt_sigpending 354 |
| #define __NR_rt_sigtimedwait 355 |
| #define __NR_rt_sigqueueinfo 356 |
| #define __NR_rt_sigsuspend 357 |
| #define __NR_select 358 |
| #define __NR_gettimeofday 359 |
| #define __NR_settimeofday 360 |
| #define __NR_getitimer 361 |
| #define __NR_setitimer 362 |
| #define __NR_utimes 363 |
| #define __NR_getrusage 364 |
| #define __NR_wait4 365 |
| #define __NR_adjtimex 366 |
| #define __NR_getcwd 367 |
| #define __NR_capget 368 |
| #define __NR_capset 369 |
| #define __NR_sendfile 370 |
| #define __NR_setresgid 371 |
| #define __NR_getresgid 372 |
| #define __NR_dipc 373 |
| #define __NR_pivot_root 374 |
| #define __NR_mincore 375 |
| #define __NR_pciconfig_iobase 376 |
| #define __NR_getdents64 377 |
| #define __NR_gettid 378 |
| #define __NR_readahead 379 |
| /* 380 is unused */ |
| #define __NR_tkill 381 |
| #define __NR_setxattr 382 |
| #define __NR_lsetxattr 383 |
| #define __NR_fsetxattr 384 |
| #define __NR_getxattr 385 |
| #define __NR_lgetxattr 386 |
| #define __NR_fgetxattr 387 |
| #define __NR_listxattr 388 |
| #define __NR_llistxattr 389 |
| #define __NR_flistxattr 390 |
| #define __NR_removexattr 391 |
| #define __NR_lremovexattr 392 |
| #define __NR_fremovexattr 393 |
| #define __NR_futex 394 |
| #define __NR_sched_setaffinity 395 |
| #define __NR_sched_getaffinity 396 |
| #define __NR_tuxcall 397 |
| #define __NR_io_setup 398 |
| #define __NR_io_destroy 399 |
| #define __NR_io_getevents 400 |
| #define __NR_io_submit 401 |
| #define __NR_io_cancel 402 |
| #define __NR_exit_group 405 |
| #define __NR_lookup_dcookie 406 |
| #define __NR_sys_epoll_create 407 |
| #define __NR_sys_epoll_ctl 408 |
| #define __NR_sys_epoll_wait 409 |
| #define __NR_remap_file_pages 410 |
| #define __NR_set_tid_address 411 |
| #define __NR_restart_syscall 412 |
| #define __NR_fadvise64 413 |
| #define __NR_timer_create 414 |
| #define __NR_timer_settime 415 |
| #define __NR_timer_gettime 416 |
| #define __NR_timer_getoverrun 417 |
| #define __NR_timer_delete 418 |
| #define __NR_clock_settime 419 |
| #define __NR_clock_gettime 420 |
| #define __NR_clock_getres 421 |
| #define __NR_clock_nanosleep 422 |
| #define __NR_semtimedop 423 |
| #define __NR_tgkill 424 |
| #define __NR_stat64 425 |
| #define __NR_lstat64 426 |
| #define __NR_fstat64 427 |
| #define __NR_vserver 428 |
| #define __NR_mbind 429 |
| #define __NR_get_mempolicy 430 |
| #define __NR_set_mempolicy 431 |
| #define __NR_mq_open 432 |
| #define __NR_mq_unlink 433 |
| #define __NR_mq_timedsend 434 |
| #define __NR_mq_timedreceive 435 |
| #define __NR_mq_notify 436 |
| #define __NR_mq_getsetattr 437 |
| #define __NR_waitid 438 |
| #define __NR_add_key 439 |
| #define __NR_request_key 440 |
| #define __NR_keyctl 441 |
| |
| #define NR_SYSCALLS 442 |
| |
| #if defined(__GNUC__) |
| |
| #define _syscall_return(type) \ |
| return (_sc_err ? errno = _sc_ret, _sc_ret = -1L : 0), (type) _sc_ret |
| |
| #define _syscall_clobbers \ |
| "$1", "$2", "$3", "$4", "$5", "$6", "$7", "$8", \ |
| "$22", "$23", "$24", "$25", "$27", "$28" \ |
| |
| #define _syscall0(type, name) \ |
| type name(void) \ |
| { \ |
| long _sc_ret, _sc_err; \ |
| { \ |
| register long _sc_0 __asm__("$0"); \ |
| register long _sc_19 __asm__("$19"); \ |
| \ |
| _sc_0 = __NR_##name; \ |
| __asm__("callsys # %0 %1 %2" \ |
| : "=r"(_sc_0), "=r"(_sc_19) \ |
| : "0"(_sc_0) \ |
| : _syscall_clobbers); \ |
| _sc_ret = _sc_0, _sc_err = _sc_19; \ |
| } \ |
| _syscall_return(type); \ |
| } |
| |
| #define _syscall1(type,name,type1,arg1) \ |
| type name(type1 arg1) \ |
| { \ |
| long _sc_ret, _sc_err; \ |
| { \ |
| register long _sc_0 __asm__("$0"); \ |
| register long _sc_16 __asm__("$16"); \ |
| register long _sc_19 __asm__("$19"); \ |
| \ |
| _sc_0 = __NR_##name; \ |
| _sc_16 = (long) (arg1); \ |
| __asm__("callsys # %0 %1 %2 %3" \ |
| : "=r"(_sc_0), "=r"(_sc_19) \ |
| : "0"(_sc_0), "r"(_sc_16) \ |
| : _syscall_clobbers); \ |
| _sc_ret = _sc_0, _sc_err = _sc_19; \ |
| } \ |
| _syscall_return(type); \ |
| } |
| |
| #define _syscall2(type,name,type1,arg1,type2,arg2) \ |
| type name(type1 arg1,type2 arg2) \ |
| { \ |
| long _sc_ret, _sc_err; \ |
| { \ |
| register long _sc_0 __asm__("$0"); \ |
| register long _sc_16 __asm__("$16"); \ |
| register long _sc_17 __asm__("$17"); \ |
| register long _sc_19 __asm__("$19"); \ |
| \ |
| _sc_0 = __NR_##name; \ |
| _sc_16 = (long) (arg1); \ |
| _sc_17 = (long) (arg2); \ |
| __asm__("callsys # %0 %1 %2 %3 %4" \ |
| : "=r"(_sc_0), "=r"(_sc_19) \ |
| : "0"(_sc_0), "r"(_sc_16), "r"(_sc_17) \ |
| : _syscall_clobbers); \ |
| _sc_ret = _sc_0, _sc_err = _sc_19; \ |
| } \ |
| _syscall_return(type); \ |
| } |
| |
| #define _syscall3(type,name,type1,arg1,type2,arg2,type3,arg3) \ |
| type name(type1 arg1,type2 arg2,type3 arg3) \ |
| { \ |
| long _sc_ret, _sc_err; \ |
| { \ |
| register long _sc_0 __asm__("$0"); \ |
| register long _sc_16 __asm__("$16"); \ |
| register long _sc_17 __asm__("$17"); \ |
| register long _sc_18 __asm__("$18"); \ |
| register long _sc_19 __asm__("$19"); \ |
| \ |
| _sc_0 = __NR_##name; \ |
| _sc_16 = (long) (arg1); \ |
| _sc_17 = (long) (arg2); \ |
| _sc_18 = (long) (arg3); \ |
| __asm__("callsys # %0 %1 %2 %3 %4 %5" \ |
| : "=r"(_sc_0), "=r"(_sc_19) \ |
| : "0"(_sc_0), "r"(_sc_16), "r"(_sc_17), \ |
| "r"(_sc_18) \ |
| : _syscall_clobbers); \ |
| _sc_ret = _sc_0, _sc_err = _sc_19; \ |
| } \ |
| _syscall_return(type); \ |
| } |
| |
| #define _syscall4(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4) \ |
| type name (type1 arg1, type2 arg2, type3 arg3, type4 arg4) \ |
| { \ |
| long _sc_ret, _sc_err; \ |
| { \ |
| register long _sc_0 __asm__("$0"); \ |
| register long _sc_16 __asm__("$16"); \ |
| register long _sc_17 __asm__("$17"); \ |
| register long _sc_18 __asm__("$18"); \ |
| register long _sc_19 __asm__("$19"); \ |
| \ |
| _sc_0 = __NR_##name; \ |
| _sc_16 = (long) (arg1); \ |
| _sc_17 = (long) (arg2); \ |
| _sc_18 = (long) (arg3); \ |
| _sc_19 = (long) (arg4); \ |
| __asm__("callsys # %0 %1 %2 %3 %4 %5 %6" \ |
| : "=r"(_sc_0), "=r"(_sc_19) \ |
| : "0"(_sc_0), "r"(_sc_16), "r"(_sc_17), \ |
| "r"(_sc_18), "1"(_sc_19) \ |
| : _syscall_clobbers); \ |
| _sc_ret = _sc_0, _sc_err = _sc_19; \ |
| } \ |
| _syscall_return(type); \ |
| } |
| |
| #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) \ |
| { \ |
| long _sc_ret, _sc_err; \ |
| { \ |
| register long _sc_0 __asm__("$0"); \ |
| register long _sc_16 __asm__("$16"); \ |
| register long _sc_17 __asm__("$17"); \ |
| register long _sc_18 __asm__("$18"); \ |
| register long _sc_19 __asm__("$19"); \ |
| register long _sc_20 __asm__("$20"); \ |
| \ |
| _sc_0 = __NR_##name; \ |
| _sc_16 = (long) (arg1); \ |
| _sc_17 = (long) (arg2); \ |
| _sc_18 = (long) (arg3); \ |
| _sc_19 = (long) (arg4); \ |
| _sc_20 = (long) (arg5); \ |
| __asm__("callsys # %0 %1 %2 %3 %4 %5 %6 %7" \ |
| : "=r"(_sc_0), "=r"(_sc_19) \ |
| : "0"(_sc_0), "r"(_sc_16), "r"(_sc_17), \ |
| "r"(_sc_18), "1"(_sc_19), "r"(_sc_20) \ |
| : _syscall_clobbers); \ |
| _sc_ret = _sc_0, _sc_err = _sc_19; \ |
| } \ |
| _syscall_return(type); \ |
| } |
| |
| #define _syscall6(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4, \ |
| type5,arg5,type6,arg6) \ |
| type name (type1 arg1,type2 arg2,type3 arg3,type4 arg4,type5 arg5, type6 arg6)\ |
| { \ |
| long _sc_ret, _sc_err; \ |
| { \ |
| register long _sc_0 __asm__("$0"); \ |
| register long _sc_16 __asm__("$16"); \ |
| register long _sc_17 __asm__("$17"); \ |
| register long _sc_18 __asm__("$18"); \ |
| register long _sc_19 __asm__("$19"); \ |
| register long _sc_20 __asm__("$20"); \ |
| register long _sc_21 __asm__("$21"); \ |
| \ |
| _sc_0 = __NR_##name; \ |
| _sc_16 = (long) (arg1); \ |
| _sc_17 = (long) (arg2); \ |
| _sc_18 = (long) (arg3); \ |
| _sc_19 = (long) (arg4); \ |
| _sc_20 = (long) (arg5); \ |
| _sc_21 = (long) (arg6); \ |
| __asm__("callsys # %0 %1 %2 %3 %4 %5 %6 %7 %8" \ |
| : "=r"(_sc_0), "=r"(_sc_19) \ |
| : "0"(_sc_0), "r"(_sc_16), "r"(_sc_17), \ |
| "r"(_sc_18), "1"(_sc_19), "r"(_sc_20), "r"(_sc_21) \ |
| : _syscall_clobbers); \ |
| _sc_ret = _sc_0, _sc_err = _sc_19; \ |
| } \ |
| _syscall_return(type); \ |
| } |
| |
| #endif /* __LIBRARY__ && __GNUC__ */ |
| |
| #ifdef __KERNEL__ |
| #define __ARCH_WANT_IPC_PARSE_VERSION |
| #define __ARCH_WANT_OLD_READDIR |
| #define __ARCH_WANT_STAT64 |
| #define __ARCH_WANT_SYS_GETHOSTNAME |
| #define __ARCH_WANT_SYS_SOCKETCALL |
| #define __ARCH_WANT_SYS_FADVISE64 |
| #define __ARCH_WANT_SYS_GETPGRP |
| #define __ARCH_WANT_SYS_OLD_GETRLIMIT |
| #define __ARCH_WANT_SYS_OLDUMOUNT |
| #define __ARCH_WANT_SYS_SIGPENDING |
| #endif |
| |
| #ifdef __KERNEL_SYSCALLS__ |
| |
| #include <linux/compiler.h> |
| #include <linux/types.h> |
| #include <linux/string.h> |
| #include <linux/signal.h> |
| #include <linux/syscalls.h> |
| #include <asm/ptrace.h> |
| |
| static inline long open(const char * name, int mode, int flags) |
| { |
| return sys_open(name, mode, flags); |
| } |
| |
| static inline long dup(int fd) |
| { |
| return sys_dup(fd); |
| } |
| |
| static inline long close(int fd) |
| { |
| return sys_close(fd); |
| } |
| |
| static inline off_t lseek(int fd, off_t off, int whence) |
| { |
| return sys_lseek(fd, off, whence); |
| } |
| |
| static inline void _exit(int value) |
| { |
| sys_exit(value); |
| } |
| |
| #define exit(x) _exit(x) |
| |
| static inline long write(int fd, const char * buf, size_t nr) |
| { |
| return sys_write(fd, buf, nr); |
| } |
| |
| static inline long read(int fd, char * buf, size_t nr) |
| { |
| return sys_read(fd, buf, nr); |
| } |
| |
| extern int execve(char *, char **, char **); |
| |
| static inline long setsid(void) |
| { |
| return sys_setsid(); |
| } |
| |
| static inline pid_t waitpid(int pid, int * wait_stat, int flags) |
| { |
| return sys_wait4(pid, wait_stat, flags, NULL); |
| } |
| |
| asmlinkage int sys_execve(char *ufilename, char **argv, char **envp, |
| unsigned long a3, unsigned long a4, unsigned long a5, |
| struct pt_regs regs); |
| asmlinkage long sys_rt_sigaction(int sig, |
| const struct sigaction __user *act, |
| struct sigaction __user *oact, |
| size_t sigsetsize, |
| void *restorer); |
| |
| #endif /* __KERNEL_SYSCALLS__ */ |
| |
| /* "Conditional" syscalls. What we want is |
| |
| __attribute__((weak,alias("sys_ni_syscall"))) |
| |
| but that raises the problem of what type to give the symbol. If we use |
| a prototype, it'll conflict with the definition given in this file and |
| others. If we use __typeof, we discover that not all symbols actually |
| have declarations. If we use no prototype, then we get warnings from |
| -Wstrict-prototypes. Ho hum. */ |
| |
| #define cond_syscall(x) asm(".weak\t" #x "\n" #x " = sys_ni_syscall") |
| |
| #endif /* _ALPHA_UNISTD_H */ |