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 | |
| 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')
| -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 | 
