/* libc/sys/linux/io.c - Basic input/output system calls */ /* Written 2000 by Werner Almesberger */ #define __KERNEL_PROTOTYPES #include #include #include #include #include #include #include #include #define __NR___ioctl __NR_ioctl #define __NR___flock __NR_flock #define __NR___mknod __NR_mknod _syscall3(int,read,int,fd,void *,buf,size_t,count) _syscall3(ssize_t,readv,int,fd,const struct iovec *,vec,int,count) _syscall3(int,write,int,fd,const void *,buf,size_t,count) _syscall3(ssize_t,writev,int,fd,const struct iovec *,buf,int,count) _syscall3(int,open,const char *,file,int,flag,mode_t,mode) _syscall1(int,close,int,fd) _syscall3(off_t,lseek,int,fd,off_t,offset,int,count) _syscall0(int,sync) _syscall1(int,dup,int,fd) _syscall2(int,dup2,int,oldfd,int,newfd) _syscall3(int,fcntl,int,fd,int,cmd,long,arg) _syscall1(int,fdatasync,int,fd) _syscall1(int,fsync,int,fd) static _syscall2(long,__flock,unsigned int,fd,unsigned int,cmd) static _syscall3(int,__ioctl,int,fd,int,request,void *,arg) static _syscall3(int,__mknod,const char *,path,mode_t,mode,dev_t *,dev) int ioctl(int fd,int request,...) { va_list ap; int res; va_start(ap,request); res = __ioctl(fd,request,va_arg(ap,void *)); va_end(ap); return res; } int flock(int fd,int operation) { return __flock(fd,operation); } int mkfifo(const char *path, mode_t mode) { dev_t dev = 0; return __mknod(path, mode | S_IFIFO, &dev); }