2005-04-21 16:53:53 +02:00
|
|
|
/* This file contains the table used to map system call numbers onto the
|
|
|
|
* routines that perform them.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define _TABLE
|
|
|
|
|
|
|
|
#include "fs.h"
|
|
|
|
#include <minix/callnr.h>
|
|
|
|
#include <minix/com.h>
|
|
|
|
#include "buf.h"
|
|
|
|
#include "file.h"
|
|
|
|
#include "fproc.h"
|
|
|
|
#include "inode.h"
|
|
|
|
#include "lock.h"
|
|
|
|
#include "super.h"
|
|
|
|
|
|
|
|
PUBLIC _PROTOTYPE (int (*call_vec[]), (void) ) = {
|
|
|
|
no_sys, /* 0 = unused */
|
|
|
|
do_exit, /* 1 = exit */
|
|
|
|
do_fork, /* 2 = fork */
|
|
|
|
do_read, /* 3 = read */
|
|
|
|
do_write, /* 4 = write */
|
|
|
|
do_open, /* 5 = open */
|
|
|
|
do_close, /* 6 = close */
|
|
|
|
no_sys, /* 7 = wait */
|
|
|
|
do_creat, /* 8 = creat */
|
|
|
|
do_link, /* 9 = link */
|
|
|
|
do_unlink, /* 10 = unlink */
|
|
|
|
no_sys, /* 11 = waitpid */
|
|
|
|
do_chdir, /* 12 = chdir */
|
2005-05-31 11:50:51 +02:00
|
|
|
no_sys, /* 13 = time */
|
2005-04-21 16:53:53 +02:00
|
|
|
do_mknod, /* 14 = mknod */
|
|
|
|
do_chmod, /* 15 = chmod */
|
|
|
|
do_chown, /* 16 = chown */
|
|
|
|
no_sys, /* 17 = break */
|
|
|
|
do_stat, /* 18 = stat */
|
|
|
|
do_lseek, /* 19 = lseek */
|
|
|
|
no_sys, /* 20 = getpid */
|
|
|
|
do_mount, /* 21 = mount */
|
|
|
|
do_umount, /* 22 = umount */
|
|
|
|
do_set, /* 23 = setuid */
|
|
|
|
no_sys, /* 24 = getuid */
|
|
|
|
do_stime, /* 25 = stime */
|
|
|
|
no_sys, /* 26 = ptrace */
|
|
|
|
no_sys, /* 27 = alarm */
|
|
|
|
do_fstat, /* 28 = fstat */
|
|
|
|
no_sys, /* 29 = pause */
|
|
|
|
do_utime, /* 30 = utime */
|
|
|
|
no_sys, /* 31 = (stty) */
|
|
|
|
no_sys, /* 32 = (gtty) */
|
|
|
|
do_access, /* 33 = access */
|
|
|
|
no_sys, /* 34 = (nice) */
|
|
|
|
no_sys, /* 35 = (ftime) */
|
|
|
|
do_sync, /* 36 = sync */
|
|
|
|
no_sys, /* 37 = kill */
|
|
|
|
do_rename, /* 38 = rename */
|
|
|
|
do_mkdir, /* 39 = mkdir */
|
|
|
|
do_unlink, /* 40 = rmdir */
|
|
|
|
do_dup, /* 41 = dup */
|
|
|
|
do_pipe, /* 42 = pipe */
|
2005-05-31 11:50:51 +02:00
|
|
|
no_sys, /* 43 = times */
|
2005-04-21 16:53:53 +02:00
|
|
|
no_sys, /* 44 = (prof) */
|
2005-12-20 15:23:44 +01:00
|
|
|
do_slink, /* 45 = symlink */
|
2005-04-21 16:53:53 +02:00
|
|
|
do_set, /* 46 = setgid */
|
|
|
|
no_sys, /* 47 = getgid */
|
|
|
|
no_sys, /* 48 = (signal)*/
|
2005-12-20 15:23:44 +01:00
|
|
|
do_rdlink, /* 49 = readlink*/
|
|
|
|
do_lstat, /* 50 = lstat */
|
2005-04-21 16:53:53 +02:00
|
|
|
no_sys, /* 51 = (acct) */
|
|
|
|
no_sys, /* 52 = (phys) */
|
|
|
|
no_sys, /* 53 = (lock) */
|
|
|
|
do_ioctl, /* 54 = ioctl */
|
|
|
|
do_fcntl, /* 55 = fcntl */
|
|
|
|
no_sys, /* 56 = (mpx) */
|
|
|
|
no_sys, /* 57 = unused */
|
|
|
|
no_sys, /* 58 = unused */
|
|
|
|
do_exec, /* 59 = execve */
|
|
|
|
do_umask, /* 60 = umask */
|
|
|
|
do_chroot, /* 61 = chroot */
|
|
|
|
do_setsid, /* 62 = setsid */
|
|
|
|
no_sys, /* 63 = getpgrp */
|
|
|
|
|
|
|
|
no_sys, /* 64 = KSIG: signals originating in the kernel */
|
|
|
|
do_unpause, /* 65 = UNPAUSE */
|
|
|
|
no_sys, /* 66 = unused */
|
|
|
|
do_revive, /* 67 = REVIVE */
|
|
|
|
no_sys, /* 68 = TASK_REPLY */
|
|
|
|
no_sys, /* 69 = unused */
|
|
|
|
no_sys, /* 70 = unused */
|
|
|
|
no_sys, /* 71 = si */
|
|
|
|
no_sys, /* 72 = sigsuspend */
|
|
|
|
no_sys, /* 73 = sigpending */
|
|
|
|
no_sys, /* 74 = sigprocmask */
|
|
|
|
no_sys, /* 75 = sigreturn */
|
|
|
|
do_reboot, /* 76 = reboot */
|
|
|
|
do_svrctl, /* 77 = svrctl */
|
|
|
|
|
2005-08-04 21:23:03 +02:00
|
|
|
no_sys, /* 78 = unused */
|
2005-04-21 16:53:53 +02:00
|
|
|
do_getsysinfo, /* 79 = getsysinfo */
|
|
|
|
no_sys, /* 80 = unused */
|
2005-08-02 17:29:17 +02:00
|
|
|
do_devctl, /* 81 = devctl */
|
2005-04-21 16:53:53 +02:00
|
|
|
do_fstatfs, /* 82 = fstatfs */
|
2005-06-02 14:43:21 +02:00
|
|
|
no_sys, /* 83 = memalloc */
|
|
|
|
no_sys, /* 84 = memfree */
|
2005-06-06 13:40:32 +02:00
|
|
|
do_select, /* 85 = select */
|
2005-06-29 21:28:26 +02:00
|
|
|
do_fchdir, /* 86 = fchdir */
|
2005-07-01 19:58:29 +02:00
|
|
|
do_fsync, /* 87 = fsync */
|
|
|
|
no_sys, /* 88 = getpriority */
|
|
|
|
no_sys, /* 89 = setpriority */
|
2005-07-06 09:08:36 +02:00
|
|
|
no_sys, /* 90 = gettimeofday */
|
2005-12-13 10:48:29 +01:00
|
|
|
no_sys, /* 91 = seteuid */
|
|
|
|
no_sys, /* 92 = setegid */
|
2006-01-11 18:14:51 +01:00
|
|
|
do_truncate, /* 93 = truncate */
|
|
|
|
do_ftruncate, /* 94 = truncate */
|
2005-04-21 16:53:53 +02:00
|
|
|
};
|
|
|
|
/* This should not fail with "array size is negative": */
|
|
|
|
extern int dummy[sizeof(call_vec) == NCALLS * sizeof(call_vec[0]) ? 1 : -1];
|
|
|
|
|