diff options
author | Eric Andersen <andersen@codepoet.org> | 2000-10-25 07:12:13 +0000 |
---|---|---|
committer | Eric Andersen <andersen@codepoet.org> | 2000-10-25 07:12:13 +0000 |
commit | 539adfd7c7cbc7d6d3bea94eb1aa2a7103ca71c0 (patch) | |
tree | 69b3a3e6727a2ed28608acc0a2f41f32787404a6 /libc/sysdeps/linux | |
parent | b7aed1d7020298382852a718726b218afe7dfcc7 (diff) |
Move syscalls to sysdeps/linux/common (since they are common).
Remove _start.S since I now have a portable C version.
Diffstat (limited to 'libc/sysdeps/linux')
-rw-r--r-- | libc/sysdeps/linux/arm/Makefile | 7 | ||||
-rw-r--r-- | libc/sysdeps/linux/common/Makefile | 9 | ||||
-rwxr-xr-x | libc/sysdeps/linux/common/list_syscalls.sh | 4 | ||||
-rw-r--r-- | libc/sysdeps/linux/common/syscalls.c | 1024 | ||||
-rw-r--r-- | libc/sysdeps/linux/i386/Makefile | 10 |
5 files changed, 1037 insertions, 17 deletions
diff --git a/libc/sysdeps/linux/arm/Makefile b/libc/sysdeps/linux/arm/Makefile index 2146ef053..afa9dbbf5 100644 --- a/libc/sysdeps/linux/arm/Makefile +++ b/libc/sysdeps/linux/arm/Makefile @@ -28,9 +28,6 @@ ASFLAGS=$(CFLAGS) SSRC=_start.S SOBJS=$(patsubst %.S,%.o, $(SSRC)) -MSRC=syscalls.c -MOBJ=$(shell ./list_syscalls.sh) - CSRC=divsi3.c COBJS=$(patsubst %.c,%.o, $(CSRC)) @@ -48,10 +45,6 @@ $(SOBJS): $(CC) $(CFLAGS) $< -c $*.S -o $*.o $(STRIPTOOL) -x -R .note -R .comment $*.o -$(MOBJ): $(MSRC) - $(CC) $(CFLAGS) -DL_$* $< -c -o $*.o - $(STRIPTOOL) -x -R .note -R .comment $*.o - $(COBJS): $(CC) $(CFLAGS) $< -c $*.c -o $*.o $(STRIPTOOL) -x -R .note -R .comment $*.o diff --git a/libc/sysdeps/linux/common/Makefile b/libc/sysdeps/linux/common/Makefile index 06f4651b9..dd891d176 100644 --- a/libc/sysdeps/linux/common/Makefile +++ b/libc/sysdeps/linux/common/Makefile @@ -28,7 +28,10 @@ LIBC=$(TOPDIR)libc.a #The file makefile.objs defines $(COBJS) include makefile.objs -OBJ=$(COBJS) +MSRC=syscalls.c +MOBJ=$(shell ./list_syscalls.sh) + +OBJ=$(COBJS) $(MOBJ) all: $(OBJ) $(LIBC) @@ -37,6 +40,10 @@ $(LIBC): ar-target ar-target: $(OBJ) $(AR) $(ARFLAGS) $(LIBC) $(OBJ) +$(MOBJ): $(MSRC) + $(CC) $(CFLAGS) -DL_$* $< -c -o $*.o + $(STRIPTOOL) -x -R .note -R .comment $*.o + $(COBJS): $(CC) $(CFLAGS) $< -c $*.c -o $*.o $(STRIPTOOL) -x -R .note -R .comment $*.o diff --git a/libc/sysdeps/linux/common/list_syscalls.sh b/libc/sysdeps/linux/common/list_syscalls.sh new file mode 100755 index 000000000..a354f4413 --- /dev/null +++ b/libc/sysdeps/linux/common/list_syscalls.sh @@ -0,0 +1,4 @@ +#!/bin/sh +sed -ne 's/^.*_syscall[0-9].*([^,]*,\([^,)]*\).*/\1.o/gp' syscalls.c + + diff --git a/libc/sysdeps/linux/common/syscalls.c b/libc/sysdeps/linux/common/syscalls.c new file mode 100644 index 000000000..c1b119336 --- /dev/null +++ b/libc/sysdeps/linux/common/syscalls.c @@ -0,0 +1,1024 @@ +/* vi: set sw=4 ts=4: */ +/* + * Syscalls for uC-Libc + * + * Copyright (C) 2000 by Lineo, inc. Written by Erik Andersen + * <andersen@lineo.com>, <andersee@debian.org> + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU Library General Public License as published by + * the Free Software Foundation; either version 2 of the License, or (at your + * option) any later version. + * + * This program is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for + * more details. + * + * You should have received a copy of the GNU Library General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * + */ + +#include <errno.h> +#include <features.h> +#include <sys/types.h> +#include <sys/syscall.h> + + +//#define __NR_exit 1 +#ifdef L__exit +/* Do not include unistd.h, so gcc doesn't whine about + * _exit returning. It really doesn't return... */ +#define __NR__exit __NR_exit +_syscall1(void,_exit,int,status); +#endif + +//#define __NR_fork 2 +#ifdef L_fork +#include <unistd.h> +_syscall0(pid_t,fork); +#endif + +//#define __NR_read 3 +#ifdef L_read +#include <unistd.h> +_syscall3(size_t,read,int,fd,char *,buf,size_t,count); +#endif + +//#define __NR_write 4 +#ifdef L_write +#include <unistd.h> +_syscall3(size_t,write,int,fd,const char *,buf,size_t,count); +#endif + +//#define __NR_open 5 +#ifdef L___open +#include <stdarg.h> +#include <fcntl.h> +#define __NR___open __NR_open +_syscall3(int,__open,const char *,fn,int,flags,mode_t,mode); + +int open (const char *file, int oflag, ...) +{ + int mode=0; + if (oflag & O_CREAT) + { + va_list args; + va_start(args, oflag); + mode = va_arg(args, int); + va_end(args); + } + + return __open(file, oflag, mode); +} +#endif + +//#define __NR_close 6 +#ifdef L_close +#include <unistd.h> +_syscall1(int,close,int,fd); +#endif + +//#define __NR_waitpid 7 +#include <sys/wait.h> +#ifdef L_waitpid +_syscall3(pid_t,waitpid,pid_t,pid,int *,status,int,options); +#endif + +//#define __NR_creat 8 +#ifdef L_creat +#include <fcntl.h> +_syscall2(int,creat,const char *,file,mode_t,mode); +#endif + +//#define __NR_link 9 +#ifdef L_link +#include <unistd.h> +_syscall2(int,link,const char *,oldpath,const char *,newpath); +#endif + +//#define __NR_unlink 10 +#ifdef L_unlink +#include <unistd.h> +_syscall1(int,unlink,const char *,pathname); +#endif + +//#define __NR_execve 11 +#ifdef L_execve +#include <unistd.h> +_syscall3(int,execve,const char *,filename, char *const *, argv, char *const *, envp); +#endif + +//#define __NR_chdir 12 +#ifdef L_chdir +#include <unistd.h> +_syscall1(int,chdir,const char *,path); +#endif + +//#define __NR_time 13 +#ifdef L_time +#include <time.h> +_syscall1(time_t,time,time_t *,t); +#endif + +//#define __NR_mknod 14 +#ifdef L_mknod +#include <unistd.h> +_syscall3(int,mknod,const char *,pathname, mode_t, mode, dev_t, dev); +#endif + +//#define __NR_chmod 15 +#ifdef L_chmod +#include <sys/stat.h> +_syscall2(int, chmod,const char *,path, mode_t,mode); +#endif + +//#define __NR_lchown 16 +#ifdef L_lchown +#include <unistd.h> +_syscall3(int,lchown,const char *,path, uid_t,owner, gid_t,group); +#endif + + +//#define __NR_break 17 + +//#define __NR_oldstat 18 + +//#define __NR_lseek 19 +#ifdef L_lseek +#include <unistd.h> +_syscall3(off_t,lseek,int,fildes, off_t,offset, int,whence); +#endif + +//#define __NR_getpid 20 +#ifdef L_getpid +#include <unistd.h> +_syscall0(pid_t,getpid); +#endif + +//#define __NR_mount 21 +#ifdef L_mount +#include <sys/mount.h> +_syscall5(int,mount,const char *,specialfile,const char *,dir, + const char *,filesystemtype, unsigned long,rwflag, + const void *,data); +#endif + +//#define __NR_umount 22 +#ifdef L_umount +#include <sys/mount.h> +_syscall1(int,umount,const char *,specialfile); +#endif + +//#define __NR_setuid 23 +#ifdef L_setuid +#include <unistd.h> +_syscall1(int,setuid,uid_t,uid); +#endif + +//#define __NR_getuid 24 +#ifdef L_getuid +#include <unistd.h> +_syscall0(gid_t,getuid); +#endif + +//#define __NR_stime 25 +#ifdef L_stime +#include <time.h> +_syscall1(int,stime,time_t *,t); +#endif + +//#define __NR_ptrace 26 + +//#define __NR_alarm 27 +#ifdef L_alarm +#include <unistd.h> +_syscall1(unsigned int,alarm,unsigned int,seconds); +#endif + +//#define __NR_oldfstat 28 + +//#define __NR_pause 29 +#ifdef L_pause +#include <unistd.h> +_syscall0(int,pause); +#endif + +//#define __NR_utime 30 +#ifdef L_utime +#include <utime.h> +_syscall2(int,utime,const char *,filename, struct utimbuf *,buf); +#endif + +//#define __NR_stty 31 + +//#define __NR_gtty 32 + +//#define __NR_access 33 +#ifdef L_access +#include <unistd.h> +_syscall2(int,access,const char *,pathname, int,mode); +#endif + +//#define __NR_nice 34 +#ifdef L_nice +#include <unistd.h> +_syscall1(int,nice,int,inc); +#endif + +//#define __NR_ftime 35 + +//#define __NR_sync 36 +#ifdef L_sync +#include <unistd.h> +_syscall0(int,sync); +#endif + +//#define __NR_kill 37 +#ifdef L_kill +#include <signal.h> +_syscall2(int,kill,pid_t,pid,int,sig); +#endif + +//#define __NR_rename 38 +#ifdef L_rename +#include <stdio.h> +_syscall2(int,rename,const char *,oldpath, const char *,newpath); +#endif + +//#define __NR_mkdir 39 +#ifdef L_mkdir +#include <sys/stat.h> +_syscall2(int,mkdir,const char *,pathname, mode_t,mode); +#endif + +//#define __NR_rmdir 40 +#ifdef L_rmdir +#include <unistd.h> +_syscall1(int,rmdir,const char *,pathname); +#endif + +//#define __NR_dup 41 +#ifdef L_dup + +#include <unistd.h> +_syscall1(int,dup,int,oldfd); +#endif + +//#define __NR_pipe 42 +#ifdef L_pipe +#include <unistd.h> +_syscall1(int,pipe,int*,filedes); +#endif + +//#define __NR_times 43 +#ifdef L_times +#include <sys/times.h> +_syscall1(clock_t,times,struct tms *,buf); +#endif + +//#define __NR_prof 44 + +//#define __NR_brk 45 + +//#define __NR_setgid 46 +#ifdef L_setgid +#include <unistd.h> +_syscall1(int,setgid,gid_t,gid); +#endif + +//#define __NR_getgid 47 +#ifdef L_getgid +#include <unistd.h> +_syscall0(gid_t,getgid); +#endif + +//#define __NR_signal 48 + +//#define __NR_geteuid 49 +#ifdef L_geteuid +#ifdef SYS_geteuid +#include <unistd.h> +_syscall0(uid_t,geteuid); +#else +uid_t geteuid(void) +{ + return(getuid()); +} +#endif +#endif + +//#define __NR_getegid 50 +#ifdef L_getegid +#ifdef SYS_getegid +#include <unistd.h> +_syscall0(gid_t,getegid); +#else +gid_t getegid(void) +{ + return(getgid()); +} +#endif +#endif + +//#define __NR_acct 51 + +//#define __NR_umount2 52 +#ifdef L_umount2 +#include <sys/mount.h> +_syscall2(int,umount2,const char *,special_file,int,flags); +#endif + +//#define __NR_lock 53 + +//#define __NR_ioctl 54 +#ifdef L__ioctl +#include <stdarg.h> +#include <sys/ioctl.h> +#define __NR__ioctl __NR_ioctl +_syscall3(int,_ioctl,int,fd,int,request,void *,arg); + +int ioctl (int fd, unsigned long int request, ...) +{ + void * arg; + va_list list; + + va_start(list, request); + arg = va_arg(list, void *); + va_end(list); + return _ioctl(fd, request, arg); +} + +#endif + +//#define __NR_fcntl 55 +#ifdef L__fcntl +#include <stdarg.h> +#include <fcntl.h> +#define __NR__fcntl __NR_fcntl +_syscall3(int,_fcntl,int,fd,int,cmd,long,arg); + +int fcntl(int fd, int command, ...) +{ + long arg; + va_list list; + + va_start(list, command); + arg = va_arg(list, long); + va_end(list); + return _fcntl(fd, command, arg); +} +#endif + +//#define __NR_mpx 56 + +//#define __NR_setpgid 57 +#ifdef L_setpgid +#include <unistd.h> +_syscall2(int,setpgid,pid_t,pid,pid_t,pgid); +#endif + +//#define __NR_ulimit 58 + +//#define __NR_oldolduname 59 + +//#define __NR_umask 60 +#ifdef L_umask +#include <sys/stat.h> +_syscall1(mode_t,umask,mode_t,mask); +#endif + +//#define __NR_chroot 61 +#ifdef L_chroot +#include <unistd.h> +_syscall1(int,chroot,const char *,path); +#endif + +//#define __NR_ustat 62 + +//#define __NR_dup2 63 +#ifdef L_dup2 +#include <unistd.h> +_syscall2(int,dup2,int,oldfd,int,newfd); +#endif + +//#define __NR_getppid 64 +#ifdef L_getppid +#include <unistd.h> +#ifdef SYS_getppid +_syscall0(pid_t,getppid); +#else +pid_t getppid(void) +{ + return(getpid()); +} +#endif +#endif + +//#define __NR_getpgrp 65 +#ifdef L_getpgrp +#include <unistd.h> +_syscall0(pid_t,getpgrp); +#endif + +//#define __NR_setsid 66 +#ifdef L_setsid +#include <unistd.h> +_syscall0(pid_t,setsid); +#endif + +//#define __NR_sigaction 67 +#ifdef L_sigaction +#include <signal.h> +_syscall3(int,sigaction,int,signum, const struct sigaction *,act, struct sigaction *,oldact); +#endif + +//#define __NR_sgetmask 68 + +//#define __NR_ssetmask 69 + +//#define __NR_setreuid 70 +#ifdef L_setreuid +#include <unistd.h> +_syscall2(int,setreuid,uid_t,ruid,uid_t,euid); +#endif + +//#define __NR_setregid 71 +#ifdef L_setregid +#include <unistd.h> +_syscall2(int,setregid,gid_t,rgid,gid_t,egid); +#endif + +//#define __NR_sigsuspend 72 +#ifdef L_sigsuspend +#include <signal.h> +_syscall1(int,sigsuspend,const sigset_t *,mask); +#endif + +//#define __NR_sigpending 73 +#ifdef L_sigpending +#include <signal.h> +_syscall1(int,sigpending,sigset_t *,set); +#endif + +//#define __NR_sethostname 74 +#ifdef L_sethostname +#include <unistd.h> +_syscall2(int,sethostname,const char *,name, size_t,len); +#endif + +//#define __NR_setrlimit 75 +#ifdef L_setrlimit +#include <unistd.h> +#include <sys/resource.h> +_syscall2(int,setrlimit,int,resource,const struct rlimit *,rlim); +#endif + +//#define __NR_getrlimit 76 +#ifdef L_getrlimit +#include <unistd.h> +#include <sys/resource.h> +_syscall2(int,getrlimit,int,resource,struct rlimit *,rlim); +#endif + +//#define __NR_getrusage 77 +#ifdef L_getrusage +#include <unistd.h> +_syscall2(int,getrusage,int,who,struct rusage *,usage); +#endif + +//#define __NR_gettimeofday 78 +#ifdef L_gettimeofday +#include <unistd.h> +_syscall2(int,gettimeofday,struct timeval *,tv, struct timezone *,tz); +#endif + +//#define __NR_settimeofday 79 +#ifdef L_settimeofday +#include <unistd.h> +_syscall2(int,settimeofday,const struct timeval *,tv, const struct timezone *,tz); +#endif + +//#define __NR_getgroups 80 +#ifdef L_getgroups +#include <unistd.h> +_syscall2(int,getgroups,int,size,gid_t *,list); +#endif + +//#define __NR_setgroups 81 +#ifdef L_setgroups +#include <unistd.h> +#include <grp.h> +_syscall2(int,setgroups,size_t,size,const gid_t *,list); +#endif + +//#define __NR_select 82 +#ifdef L_select +#include <unistd.h> +_syscall5(int,select,int, n, fd_set *,readfds, fd_set *,writefds, + fd_set *,exceptfds, struct timeval *,timeout); +#endif + +//#define __NR_symlink 83 +#ifdef L_symlink +#include <unistd.h> +_syscall2(int,symlink,const char *,oldpath,const char *,newpath); +#endif + +//#define __NR_oldlstat 84 + +//#define __NR_readlink 85 +#ifdef L_readlink +#include <unistd.h> +_syscall3(int,readlink,const char *,path, char *,buf, size_t,bufsiz); +#endif + +//#define __NR_uselib 86 +#ifdef L_uselib +#include <unistd.h> +_syscall1(int,uselib,const char *,library); +#endif + +//#define __NR_swapon 87 +#ifdef L_swapon +#include <sys/swap.h> +_syscall2(int,swapon,const char *,path,int,swapflags); +#endif + +//#define __NR_reboot 88 +#ifdef L__reboot +#define __NR__reboot __NR_reboot +_syscall3(int,_reboot,int,magic,int,magic2,int,flag); + +int reboot (int flag) +{ + return (_reboot( (int)0xfee1dead, 672274793, flag)); +} +#endif + +//#define __NR_readdir 89 + +//#define __NR_mmap 90 +#ifdef L__mmap +#define __NR__mmap __NR_mmap +#include <unistd.h> +#include <sys/mman.h> + +_syscall1(__ptr_t,_mmap,unsigned long *,buffer); + +__ptr_t mmap(__ptr_t addr, size_t len, int prot, + int flags, int fd, __off_t offset) +{ + unsigned long buffer[6]; + + buffer[0] = (unsigned long)addr; + buffer[1] = (unsigned long)len; + buffer[2] = (unsigned long)prot; + buffer[3] = (unsigned long)flags; + buffer[4] = (unsigned long)fd; + buffer[5] = (unsigned long)offset; + return (__ptr_t) _mmap(buffer); +} +#endif + +//#define __NR_munmap 91 +#ifdef L_munmap +#include <unistd.h> +#include <sys/mman.h> +_syscall2(int,munmap,void *,start,size_t,length); +#endif + +//#define __NR_truncate 92 +#ifdef L_truncate +#include <unistd.h> +_syscall2(int,truncate,const char *,path, off_t,length); +#endif + +//#define __NR_ftruncate 93 +#ifdef L_ftruncate +#include <unistd.h> +_syscall2(int,ftruncate,int,fd,off_t,length); +#endif + +//#define __NR_fchmod 94 +#ifdef L_fchmod +#include <sys/stat.h> +_syscall2(int,fchmod,int,fildes, mode_t,mode); +#endif + +//#define __NR_fchown 95 +#ifdef L_fchown +#include <unistd.h> +_syscall3(int,fchown,int,fd,uid_t,owner, gid_t,group); +#endif + +//#define __NR_getpriority 96 +#ifdef L_getpriority +#include <sys/resource.h> +_syscall2(int,getpriority,int,which, int,who); +#endif + +//#define __NR_setpriority 97 +#ifdef L_setpriority +#include <sys/resource.h> +_syscall3(int,setpriority,int,which, int,who, int,prio); +#endif + +//#define __NR_profil 98 + +//#define __NR_statfs 99 +#ifdef L_statfs +#include <sys/vfs.h> +_syscall2(int,statfs,const char *,path, struct statfs *,buf); +#endif + +//#define __NR_fstatfs 100 +#ifdef L_fstatfs +#include <sys/vfs.h> +_syscall2(int,fstatfs,int,fd, struct statfs *,buf); +#endif + +//#define __NR_ioperm 101 +#ifdef L_ioperm +#include <sys/io.h> +syscall3(int,ioperm,unsigned,long,from,unsigned long, num, int, turn_on); +#endif + +//#define __NR_socketcall 102 +#ifdef L_socketcall +_syscall2(int,socketcall,int,call,unsigned long *,args); +#endif + +//#define __NR_syslog 103 +#ifdef L_syslog +#include <unistd.h> +#define __NR__syslog __NR_syslog +_syscall3(int,_syslog,int, type, char *, buf, int, len); +#endif + +//#define __NR_setitimer 104 +#ifdef L_setitimer +#include <sys/time.h> +_syscall3(int,setitimer,enum __itimer_which,which, const struct itimerval *,new, struct itimerval *,old); +#endif + +//#define __NR_getitimer 105 +#ifdef L_getitimer +#include <sys/time.h> +_syscall2(int,getitimer,enum __itimer_which,which, struct itimerval *,value); +#endif + +//#define __NR_stat 106 +#ifdef L_stat +#include <sys/stat.h> +#include <unistd.h> +_syscall2(int,stat,const char *,file_name, struct stat *,buf); +#endif + +//#define __NR_lstat 107 +#ifdef L_lstat +#include <sys/stat.h> +#include <unistd.h> +_syscall2(int,lstat,const char *,file_name, struct stat *,buf); +#endif + +//#define __NR_fstat 108 +#ifdef L_fstat +#include <sys/stat.h> +#include <unistd.h> +_syscall2(int,fstat,int,filedes, struct stat *,buf); +#endif + +//#define __NR_olduname 109 + +//#define __NR_iopl 110 +#ifdef L_iopl +#include <sys/io.h> +_syscall1(int,iopl,int,level); +#endif + +//#define __NR_vhangup 111 +#ifdef L_vhangup +#include <unistd.h> +_syscall0(int,vhangup); +#endif + +//#define __NR_idle 112 +//int idle(void); + +//#define __NR_vm86old 113 + +//#define __NR_wait4 114 +#ifdef L_wait4 +#include <sys/wait.h> +_syscall4(pid_t,wait4,pid_t,pid, int *,status, int,options, struct rusage *,rusage); +#endif + +//#define __NR_swapoff 115 +#ifdef L_swapoff +#include <sys/swap.h> +_syscall1(int,swapoff,const char *,path); +#endif + +//#define __NR_sysinfo 116 +#ifdef L_sysinfo +#include <sys/sysinfo.h> +_sysinfo(int,sysinfo,struct sysinfo *,info); +#endif + +//#define __NR_ipc 117 +#ifdef L_ipc +//_syscall6(int,ipc,unsigned int,call, int,first, int,second, int,third, void *,ptr, long, fifth); +#endif + +//#define __NR_fsync 118 +#ifdef L_fsync +#include <unistd.h> +_syscall1(int,fsync,int,fd); +#endif + +//#define __NR_sigreturn 119 +//int sigreturn(unsigned long __unused); + +//#define __NR_clone 120 + +//#define __NR_setdomainname 121 +#ifdef L_setdomainname +#include <unistd.h> +_syscall2(int,setdomainname,const char *,name, size_t,len); +#endif + +//#define __NR_uname 122 +#ifdef L_uname +#include <sys/utsname.h> +_syscall1(int,uname,struct utsname *,buf); +#endif + +//#define __NR_modify_ldt 123 + +//#define __NR_adjtimex 124 +#ifdef L_adjtimex +#include <sys/timex.h> +_syscall1(int,adjtimex,struct timex *,buf); +#endif + +//#define __NR_mprotect 125 +#ifdef L_mprotect +#include <sys/mman.h> +_syscall3(int,mprotect,const void *,addr, size_t,len, int,prot); +#endif + +//#define __NR_sigprocmask 126 +#ifdef L_sigprocmask +#include <signal.h> +_syscall3(int,sigprocmask,int,how, const sigset_t *,set, sigset_t *,oldset); +#endif + +//#define __NR_create_module 127 + +//#define __NR_init_module 128 + +//#define __NR_delete_module 129 + +//#define __NR_get_kernel_syms 130 + +//#define __NR_quotactl 131 + +//#define __NR_getpgid 132 +#ifdef L_getpgid +_syscall1(pid_t,getpgid,pid_t,pid); +#endif + +//#define __NR_fchdir 133 +#ifdef L_fchdir +#include <unistd.h> +_syscall1(int,fchdir,int,fd); +#endif + +//#define __NR_bdflush 134 + +//#define __NR_sysfs 135 + +//#define __NR_personality 136 + +//#define __NR_afs_syscall 137 + +//#define __NR_setfsuid 138 +#ifdef L_setfsuid +SYSCALL__ (setfsuid, 1) + ret +#endif + +//#define __NR_setfsgid 139 +#ifdef L_setfsgid +SYSCALL__ (setfsgid, 1) + ret +#endif + +//#define __NR__llseek 140 +#ifdef L__llseek +_syscall5(int,_llseek,int,fd,off_t,hoff,off_t,loff,loff_t*,res,int,whence); + +loff_t llseek (int fd, loff_t offset, int whence) +{ + int ret; + loff_t result; + + ret = _llseek (fd, (off_t) (offset >> 32), + (off_t) (offset & 0xffffffff), &result, whence); + + return ret ? (loff_t) ret : result; +} +#endif + +//#define __NR_getdents 141 +#ifdef L_getdents +SYSCALL__ (getdents, 3) + ret +#endif + +//#define __NR__newselect 142 + +//#define __NR_flock 143 +#ifdef L_flock +SYSCALL__ (flock, 2) + ret +#endif + +//#define __NR_msync 144 +#ifdef L_msync +SYSCALL__ (msync, 3) + ret +#endif + +//#define __NR_readv 145 +#ifdef L_readv +#include <sys/uio.h> +_syscall3(ssize_t,readv,int,filedes, const struct iovec *,vector, int,count); +#endif + +//#define __NR_writev 146 +#ifdef L_writev +#include <sys/uio.h> +_syscall3(ssize_t,writev,int,filedes, const struct iovec *,vector, int,count); +#endif + +//#define __NR_getsid 147 +#ifdef L_getsid +SYSCALL__ (getsid, 1) + ret +#endif + +//#define __NR_fdatasync 148 +#ifdef L_fdatasync +SYSCALL__ (fdatasync, 1) + ret +#endif + +//#define __NR__sysctl 149 + +//#define __NR_mlock 150 +#ifdef L_mlock +SYSCALL__ (mlock, 2) + ret +#endif + +//#define __NR_munlock 151 +#ifdef L_munlock +SYSCALL__ (munlock, 2) + ret +#endif + +//#define __NR_mlockall 152 +#ifdef L_mlockall +SYSCALL__ (mlockall, 1) + ret +#endif + +//#define __NR_munlockall 153 +#ifdef L_munlockall +SYSCALL__ (munlockall, 0) + ret +#endif + +//#define __NR_sched_setparam 154 +#ifdef L_sched_setparam +SYSCALL__ (sched_setparam, 2) + ret +#endif + +//#define __NR_sched_getparam 155 +#ifdef L_sched_getparam +SYSCALL__ (sched_getparam, 2) + ret +#endif + +//#define __NR_sched_setscheduler 156 +#ifdef L_sched_setscheduler +SYSCALL__ (sched_setscheduler, 3) + ret +#endif + +//#define __NR_sched_getscheduler 157 +#ifdef L_sched_getscheduler +SYSCALL__ (sched_getscheduler, 1) + ret +#endif + +//#define __NR_sched_yield 158 +#ifdef L_sched_yield +SYSCALL__ (sched_yield, 0) + ret +#endif + +//#define __NR_sched_get_priority_max 159 +#ifdef L_sched_get_priority_max +SYSCALL__ (sched_get_priority_max, 1) + ret +#endif + +//#define __NR_sched_get_priority_min 160 +#ifdef L_sched_get_priority_min +SYSCALL__ (sched_get_priority_min, 1) + ret +#endif + +//#define __NR_sched_rr_get_interval 161 +#ifdef L_sched_rr_get_interval +SYSCALL__ (sched_rr_get_interval, 2) + ret +#endif + +//#define __NR_nanosleep 162 +#ifdef L_nanosleep +SYSCALL__ (nanosleep, 2) + ret +#endif + +//#define __NR_mremap 163 +#ifdef L_mremap +#include <unistd.h> +#include <sys/mman.h> +_syscall4(__ptr_t,mremap,__ptr_t,old_address,size_t,old_size , size_t,new_size,int,may_move); +#endif + +//#define __NR_setresuid 164 + +//#define __NR_getresuid 165 + +//#define __NR_vm86 166 + +//#define __NR_query_module 167 + +//#define __NR_poll 168 +#ifdef L_poll +SYSCALL__ (poll, 3) + ret +#endif + +//#define __NR_nfsservctl 169 + +//#define __NR_setresgid 170 + +//#define __NR_getresgid 171 + +//#define __NR_prctl 172 + +//#define __NR_rt_sigreturn 173 +//#define __NR_rt_sigaction 174 +//#define __NR_rt_sigprocmask 175 +//#define __NR_rt_sigpending 176 +//#define __NR_rt_sigtimedwait 177 +//#define __NR_rt_sigqueueinfo 178 +//#define __NR_rt_sigsuspend 179 + + +//#define __NR_pread 180 + +//#define __NR_pwrite 181 + +//#define __NR_chown 182 +#ifdef L_chown +#include <unistd.h> +_syscall3(int,chown,const char *,path, uid_t,owner, gid_t,group); +#endif + +//#define __NR_getcwd 183 + +//#define __NR_capget 184 + +//#define __NR_capset 185 + +//#define __NR_sigaltstack 186 + +//#define __NR_sendfile 187 + +//#define __NR_getpmsg 188 + +//#define __NR_putpmsg 189 + +//#define __NR_vfork 190 + + diff --git a/libc/sysdeps/linux/i386/Makefile b/libc/sysdeps/linux/i386/Makefile index 868de2e6b..566bd47d0 100644 --- a/libc/sysdeps/linux/i386/Makefile +++ b/libc/sysdeps/linux/i386/Makefile @@ -28,13 +28,10 @@ ASFLAGS=$(CFLAGS) SSRC=longjmp.S setjmp.S #_start.S #fork.S #clone.S SOBJS=$(patsubst %.S,%.o, $(SSRC)) -MSRC=syscalls.c -MOBJ=$(shell ./list_syscalls.sh) - CSRC=readdir.c #select.c COBJS=$(patsubst %.c,%.o, $(CSRC)) -OBJS=$(SOBJS) $(COBJS) $(MOBJ) +OBJS=$(SOBJS) $(COBJS) all: $(OBJS) $(LIBC) @@ -48,11 +45,6 @@ $(SOBJS): $(CC) $(CFLAGS) $< -c $*.S -o $*.o $(STRIPTOOL) -x -R .note -R .comment $*.o - -$(MOBJ): $(MSRC) - $(CC) $(CFLAGS) -DL_$* $< -c -o $*.o - $(STRIPTOOL) -x -R .note -R .comment $*.o - $(COBJS): $(CC) $(CFLAGS) $< -c $*.c -o $*.o $(STRIPTOOL) -x -R .note -R .comment $*.o |