Path: blob/master/arch/parisc/kernel/syscall_table.S
10817 views
/* System Call Table1*2* Copyright (C) 1999-2004 Matthew Wilcox <willy at parisc-linux.org>3* Copyright (C) 2000-2001 John Marvin <jsm at parisc-linux.org>4* Copyright (C) 2000 Alan Modra <amodra at parisc-linux.org>5* Copyright (C) 2000-2003 Paul Bame <bame at parisc-linux.org>6* Copyright (C) 2000 Philipp Rumpf <prumpf with tux.org>7* Copyright (C) 2000 Michael Ang <mang with subcarrier.org>8* Copyright (C) 2000 David Huggins-Daines <dhd with pobox.org>9* Copyright (C) 2000 Grant Grundler <grundler at parisc-linux.org>10* Copyright (C) 2001 Richard Hirst <rhirst with parisc-linux.org>11* Copyright (C) 2001-2002 Ryan Bradetich <rbrad at parisc-linux.org>12* Copyright (C) 2001-2007 Helge Deller <deller at parisc-linux.org>13* Copyright (C) 2000-2001 Thomas Bogendoerfer <tsbogend at parisc-linux.org>14* Copyright (C) 2002 Randolph Chung <tausq with parisc-linux.org>15* Copyright (C) 2005-2006 Kyle McMartin <kyle at parisc-linux.org>16*17* This program is free software; you can redistribute it and/or modify18* it under the terms of the GNU General Public License as published by19* the Free Software Foundation; either version 2 of the License, or20* (at your option) any later version.21*22* This program is distributed in the hope that it will be useful,23* but WITHOUT ANY WARRANTY; without even the implied warranty of24* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the25* GNU General Public License for more details.26*27* You should have received a copy of the GNU General Public License28* along with this program; if not, write to the Free Software29* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA30*/3132#if defined(CONFIG_64BIT) && !defined(SYSCALL_TABLE_64BIT)33/* Use ENTRY_SAME for 32-bit syscalls which are the same on wide and34* narrow palinux. Use ENTRY_DIFF for those where a 32-bit specific35* implementation is required on wide palinux. Use ENTRY_COMP where36* the compatibility layer has a useful 32-bit implementation.37*/38#define ENTRY_SAME(_name_) .dword sys_##_name_39#define ENTRY_DIFF(_name_) .dword sys32_##_name_40#define ENTRY_UHOH(_name_) .dword sys32_##unimplemented41#define ENTRY_OURS(_name_) .dword parisc_##_name_42#define ENTRY_COMP(_name_) .dword compat_sys_##_name_43#elif defined(CONFIG_64BIT) && defined(SYSCALL_TABLE_64BIT)44#define ENTRY_SAME(_name_) .dword sys_##_name_45#define ENTRY_DIFF(_name_) .dword sys_##_name_46#define ENTRY_UHOH(_name_) .dword sys_##_name_47#define ENTRY_OURS(_name_) .dword sys_##_name_48#define ENTRY_COMP(_name_) .dword sys_##_name_49#else50#define ENTRY_SAME(_name_) .word sys_##_name_51#define ENTRY_DIFF(_name_) .word sys_##_name_52#define ENTRY_UHOH(_name_) .word sys_##_name_53#define ENTRY_OURS(_name_) .word parisc_##_name_54#define ENTRY_COMP(_name_) .word sys_##_name_55#endif5657ENTRY_SAME(restart_syscall) /* 0 */58ENTRY_SAME(exit)59ENTRY_SAME(fork_wrapper)60ENTRY_SAME(read)61ENTRY_SAME(write)62ENTRY_SAME(open) /* 5 */63ENTRY_SAME(close)64ENTRY_SAME(waitpid)65ENTRY_SAME(creat)66ENTRY_SAME(link)67ENTRY_SAME(unlink) /* 10 */68ENTRY_DIFF(execve_wrapper)69ENTRY_SAME(chdir)70/* See comments in kernel/time.c!!! Maybe we don't need this? */71ENTRY_COMP(time)72ENTRY_SAME(mknod)73ENTRY_SAME(chmod) /* 15 */74ENTRY_SAME(lchown)75ENTRY_SAME(socket)76/* struct stat is MAYBE identical wide and narrow ?? */77ENTRY_COMP(newstat)78ENTRY_DIFF(lseek)79ENTRY_SAME(getpid) /* 20 */80/* the 'void * data' parameter may need re-packing in wide */81ENTRY_COMP(mount)82/* concerned about struct sockaddr in wide/narrow */83/* ---> I think sockaddr is OK unless the compiler packs the struct */84/* differently to align the char array */85ENTRY_SAME(bind)86ENTRY_SAME(setuid)87ENTRY_SAME(getuid)88ENTRY_COMP(stime) /* 25 */89ENTRY_COMP(ptrace)90ENTRY_SAME(alarm)91/* see stat comment */92ENTRY_COMP(newfstat)93ENTRY_SAME(pause)94/* struct utimbuf uses time_t which might vary */95ENTRY_COMP(utime) /* 30 */96/* struct sockaddr... */97ENTRY_SAME(connect)98ENTRY_SAME(listen)99ENTRY_SAME(access)100ENTRY_SAME(nice)101/* struct sockaddr... */102ENTRY_SAME(accept) /* 35 */103ENTRY_SAME(sync)104ENTRY_SAME(kill)105ENTRY_SAME(rename)106ENTRY_SAME(mkdir)107ENTRY_SAME(rmdir) /* 40 */108ENTRY_SAME(dup)109ENTRY_SAME(pipe)110ENTRY_COMP(times)111/* struct sockaddr... */112ENTRY_SAME(getsockname)113/* it seems possible brk() could return a >4G pointer... */114ENTRY_SAME(brk) /* 45 */115ENTRY_SAME(setgid)116ENTRY_SAME(getgid)117ENTRY_SAME(signal)118ENTRY_SAME(geteuid)119ENTRY_SAME(getegid) /* 50 */120ENTRY_SAME(acct)121ENTRY_SAME(umount)122/* struct sockaddr... */123ENTRY_SAME(getpeername)124ENTRY_COMP(ioctl)125ENTRY_COMP(fcntl) /* 55 */126ENTRY_SAME(socketpair)127ENTRY_SAME(setpgid)128ENTRY_SAME(send)129ENTRY_SAME(newuname)130ENTRY_SAME(umask) /* 60 */131ENTRY_SAME(chroot)132ENTRY_COMP(ustat)133ENTRY_SAME(dup2)134ENTRY_SAME(getppid)135ENTRY_SAME(getpgrp) /* 65 */136ENTRY_SAME(setsid)137ENTRY_SAME(pivot_root)138/* I don't like this */139ENTRY_UHOH(sgetmask)140ENTRY_UHOH(ssetmask)141ENTRY_SAME(setreuid) /* 70 */142ENTRY_SAME(setregid)143ENTRY_SAME(mincore)144ENTRY_COMP(sigpending)145ENTRY_SAME(sethostname)146/* Following 3 have linux-common-code structs containing longs -( */147ENTRY_COMP(setrlimit) /* 75 */148ENTRY_COMP(getrlimit)149ENTRY_COMP(getrusage)150/* struct timeval and timezone are maybe?? consistent wide and narrow */151ENTRY_COMP(gettimeofday)152ENTRY_COMP(settimeofday)153ENTRY_SAME(getgroups) /* 80 */154ENTRY_SAME(setgroups)155/* struct socketaddr... */156ENTRY_SAME(sendto)157ENTRY_SAME(symlink)158/* see stat comment */159ENTRY_COMP(newlstat)160ENTRY_SAME(readlink) /* 85 */161ENTRY_SAME(ni_syscall) /* was uselib */162ENTRY_SAME(swapon)163ENTRY_SAME(reboot)164ENTRY_SAME(mmap2)165ENTRY_SAME(mmap) /* 90 */166ENTRY_SAME(munmap)167ENTRY_SAME(truncate)168ENTRY_SAME(ftruncate)169ENTRY_SAME(fchmod)170ENTRY_SAME(fchown) /* 95 */171ENTRY_SAME(getpriority)172ENTRY_SAME(setpriority)173ENTRY_SAME(recv)174ENTRY_COMP(statfs)175ENTRY_COMP(fstatfs) /* 100 */176ENTRY_SAME(stat64)177ENTRY_SAME(ni_syscall) /* was socketcall */178ENTRY_SAME(syslog)179/* even though manpage says struct timeval contains longs, ours has180* time_t and suseconds_t -- both of which are safe wide/narrow */181ENTRY_COMP(setitimer)182ENTRY_COMP(getitimer) /* 105 */183ENTRY_SAME(capget)184ENTRY_SAME(capset)185ENTRY_OURS(pread64)186ENTRY_OURS(pwrite64)187ENTRY_SAME(getcwd) /* 110 */188ENTRY_SAME(vhangup)189ENTRY_SAME(fstat64)190ENTRY_SAME(vfork_wrapper)191/* struct rusage contains longs... */192ENTRY_COMP(wait4)193ENTRY_SAME(swapoff) /* 115 */194ENTRY_COMP(sysinfo)195ENTRY_SAME(shutdown)196ENTRY_SAME(fsync)197ENTRY_SAME(madvise)198ENTRY_SAME(clone_wrapper) /* 120 */199ENTRY_SAME(setdomainname)200ENTRY_DIFF(sendfile)201/* struct sockaddr... */202ENTRY_SAME(recvfrom)203/* struct timex contains longs */204ENTRY_COMP(adjtimex)205ENTRY_SAME(mprotect) /* 125 */206/* old_sigset_t forced to 32 bits. Beware glibc sigset_t */207ENTRY_COMP(sigprocmask)208ENTRY_SAME(ni_syscall) /* create_module */209ENTRY_SAME(init_module)210ENTRY_SAME(delete_module)211ENTRY_SAME(ni_syscall) /* 130: get_kernel_syms */212/* time_t inside struct dqblk */213ENTRY_SAME(quotactl)214ENTRY_SAME(getpgid)215ENTRY_SAME(fchdir)216ENTRY_SAME(bdflush)217ENTRY_SAME(sysfs) /* 135 */218ENTRY_OURS(personality)219ENTRY_SAME(ni_syscall) /* for afs_syscall */220ENTRY_SAME(setfsuid)221ENTRY_SAME(setfsgid)222/* I think this might work */223ENTRY_SAME(llseek) /* 140 */224ENTRY_COMP(getdents)225/* it is POSSIBLE that select will be OK because even though fd_set226* contains longs, the macros and sizes are clever. */227ENTRY_COMP(select)228ENTRY_SAME(flock)229ENTRY_SAME(msync)230/* struct iovec contains pointers */231ENTRY_COMP(readv) /* 145 */232ENTRY_COMP(writev)233ENTRY_SAME(getsid)234ENTRY_SAME(fdatasync)235/* struct __sysctl_args is a mess */236ENTRY_COMP(sysctl)237ENTRY_SAME(mlock) /* 150 */238ENTRY_SAME(munlock)239ENTRY_SAME(mlockall)240ENTRY_SAME(munlockall)241/* struct sched_param is ok for now */242ENTRY_SAME(sched_setparam)243ENTRY_SAME(sched_getparam) /* 155 */244ENTRY_SAME(sched_setscheduler)245ENTRY_SAME(sched_getscheduler)246ENTRY_SAME(sched_yield)247ENTRY_SAME(sched_get_priority_max)248ENTRY_SAME(sched_get_priority_min) /* 160 */249/* These 2 would've worked if someone had defined struct timespec250* carefully, like timeval for example (which is about the same).251* Unfortunately it contains a long :-( */252ENTRY_DIFF(sched_rr_get_interval)253ENTRY_COMP(nanosleep)254ENTRY_SAME(mremap)255ENTRY_SAME(setresuid)256ENTRY_SAME(getresuid) /* 165 */257ENTRY_DIFF(sigaltstack_wrapper)258ENTRY_SAME(ni_syscall) /* query_module */259ENTRY_SAME(poll)260/* structs contain pointers and an in_addr... */261ENTRY_COMP(nfsservctl)262ENTRY_SAME(setresgid) /* 170 */263ENTRY_SAME(getresgid)264ENTRY_SAME(prctl)265/* signals need a careful review */266ENTRY_SAME(rt_sigreturn_wrapper)267ENTRY_DIFF(rt_sigaction)268ENTRY_DIFF(rt_sigprocmask) /* 175 */269ENTRY_DIFF(rt_sigpending)270ENTRY_COMP(rt_sigtimedwait)271/* even though the struct siginfo_t is different, it appears like272* all the paths use values which should be same wide and narrow.273* Also the struct is padded to 128 bytes which means we don't have274* to worry about faulting trying to copy in a larger 64-bit275* struct from a 32-bit user-space app.276*/277ENTRY_COMP(rt_sigqueueinfo)278ENTRY_COMP(rt_sigsuspend)279ENTRY_SAME(chown) /* 180 */280/* setsockopt() used by iptables: SO_SET_REPLACE/SO_SET_ADD_COUNTERS */281ENTRY_COMP(setsockopt)282ENTRY_COMP(getsockopt)283ENTRY_COMP(sendmsg)284ENTRY_COMP(recvmsg)285ENTRY_SAME(semop) /* 185 */286ENTRY_SAME(semget)287ENTRY_DIFF(semctl)288ENTRY_DIFF(msgsnd)289ENTRY_DIFF(msgrcv)290ENTRY_SAME(msgget) /* 190 */291ENTRY_SAME(msgctl)292ENTRY_SAME(shmat)293ENTRY_SAME(shmdt)294ENTRY_SAME(shmget)295ENTRY_SAME(shmctl) /* 195 */296ENTRY_SAME(ni_syscall) /* streams1 */297ENTRY_SAME(ni_syscall) /* streams2 */298ENTRY_SAME(lstat64)299ENTRY_OURS(truncate64)300ENTRY_OURS(ftruncate64) /* 200 */301ENTRY_SAME(getdents64)302ENTRY_COMP(fcntl64)303ENTRY_SAME(ni_syscall) /* attrctl -- dead */304ENTRY_SAME(ni_syscall) /* acl_get -- dead */305ENTRY_SAME(ni_syscall) /* 205 (acl_set -- dead) */306ENTRY_SAME(gettid)307ENTRY_OURS(readahead)308ENTRY_SAME(tkill)309ENTRY_SAME(sendfile64)310ENTRY_COMP(futex) /* 210 */311ENTRY_COMP(sched_setaffinity)312ENTRY_COMP(sched_getaffinity)313ENTRY_SAME(ni_syscall) /* set_thread_area */314ENTRY_SAME(ni_syscall) /* get_thread_area */315ENTRY_SAME(io_setup) /* 215 */316ENTRY_SAME(io_destroy)317ENTRY_SAME(io_getevents)318ENTRY_SAME(io_submit)319ENTRY_SAME(io_cancel)320ENTRY_SAME(alloc_hugepages) /* 220 */321ENTRY_SAME(free_hugepages)322ENTRY_SAME(exit_group)323ENTRY_DIFF(lookup_dcookie)324ENTRY_SAME(epoll_create)325ENTRY_SAME(epoll_ctl) /* 225 */326ENTRY_SAME(epoll_wait)327ENTRY_SAME(remap_file_pages)328ENTRY_SAME(semtimedop)329ENTRY_SAME(mq_open)330ENTRY_SAME(mq_unlink) /* 230 */331ENTRY_SAME(mq_timedsend)332ENTRY_SAME(mq_timedreceive)333ENTRY_SAME(mq_notify)334ENTRY_SAME(mq_getsetattr)335ENTRY_COMP(waitid) /* 235 */336ENTRY_OURS(fadvise64_64)337ENTRY_SAME(set_tid_address)338ENTRY_SAME(setxattr)339ENTRY_SAME(lsetxattr)340ENTRY_SAME(fsetxattr) /* 240 */341ENTRY_SAME(getxattr)342ENTRY_SAME(lgetxattr)343ENTRY_SAME(fgetxattr)344ENTRY_SAME(listxattr)345ENTRY_SAME(llistxattr) /* 245 */346ENTRY_SAME(flistxattr)347ENTRY_SAME(removexattr)348ENTRY_SAME(lremovexattr)349ENTRY_SAME(fremovexattr)350ENTRY_COMP(timer_create) /* 250 */351ENTRY_COMP(timer_settime)352ENTRY_COMP(timer_gettime)353ENTRY_SAME(timer_getoverrun)354ENTRY_SAME(timer_delete)355ENTRY_COMP(clock_settime) /* 255 */356ENTRY_COMP(clock_gettime)357ENTRY_COMP(clock_getres)358ENTRY_COMP(clock_nanosleep)359ENTRY_SAME(tgkill)360ENTRY_COMP(mbind) /* 260 */361ENTRY_COMP(get_mempolicy)362ENTRY_COMP(set_mempolicy)363ENTRY_SAME(ni_syscall) /* 263: reserved for vserver */364ENTRY_SAME(add_key)365ENTRY_SAME(request_key) /* 265 */366ENTRY_SAME(keyctl)367ENTRY_SAME(ioprio_set)368ENTRY_SAME(ioprio_get)369ENTRY_SAME(inotify_init)370ENTRY_SAME(inotify_add_watch) /* 270 */371ENTRY_SAME(inotify_rm_watch)372ENTRY_SAME(migrate_pages)373ENTRY_COMP(pselect6)374ENTRY_COMP(ppoll)375ENTRY_COMP(openat) /* 275 */376ENTRY_SAME(mkdirat)377ENTRY_SAME(mknodat)378ENTRY_SAME(fchownat)379ENTRY_COMP(futimesat)380ENTRY_SAME(fstatat64) /* 280 */381ENTRY_SAME(unlinkat)382ENTRY_SAME(renameat)383ENTRY_SAME(linkat)384ENTRY_SAME(symlinkat)385ENTRY_SAME(readlinkat) /* 285 */386ENTRY_SAME(fchmodat)387ENTRY_SAME(faccessat)388ENTRY_SAME(unshare)389ENTRY_COMP(set_robust_list)390ENTRY_COMP(get_robust_list) /* 290 */391ENTRY_SAME(splice)392ENTRY_OURS(sync_file_range)393ENTRY_SAME(tee)394ENTRY_COMP(vmsplice)395ENTRY_COMP(move_pages) /* 295 */396ENTRY_SAME(getcpu)397ENTRY_SAME(epoll_pwait)398ENTRY_COMP(statfs64)399ENTRY_COMP(fstatfs64)400ENTRY_COMP(kexec_load) /* 300 */401ENTRY_COMP(utimensat)402ENTRY_COMP(signalfd)403ENTRY_SAME(ni_syscall) /* was timerfd */404ENTRY_SAME(eventfd)405ENTRY_COMP(fallocate) /* 305 */406ENTRY_SAME(timerfd_create)407ENTRY_COMP(timerfd_settime)408ENTRY_COMP(timerfd_gettime)409ENTRY_COMP(signalfd4)410ENTRY_SAME(eventfd2) /* 310 */411ENTRY_SAME(epoll_create1)412ENTRY_SAME(dup3)413ENTRY_SAME(pipe2)414ENTRY_SAME(inotify_init1)415ENTRY_COMP(preadv) /* 315 */416ENTRY_COMP(pwritev)417ENTRY_COMP(rt_tgsigqueueinfo)418ENTRY_SAME(perf_event_open)419ENTRY_COMP(recvmmsg)420ENTRY_SAME(accept4) /* 320 */421ENTRY_SAME(prlimit64)422ENTRY_SAME(fanotify_init)423ENTRY_COMP(fanotify_mark)424ENTRY_COMP(clock_adjtime)425ENTRY_SAME(name_to_handle_at) /* 325 */426ENTRY_COMP(open_by_handle_at)427ENTRY_SAME(syncfs)428ENTRY_SAME(setns)429430/* Nothing yet */431432#undef ENTRY_SAME433#undef ENTRY_DIFF434#undef ENTRY_UHOH435#undef ENTRY_COMP436#undef ENTRY_OURS437438439