Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'newlib/libc/sys/linux/io.c')
-rw-r--r--newlib/libc/sys/linux/io.c46
1 files changed, 8 insertions, 38 deletions
diff --git a/newlib/libc/sys/linux/io.c b/newlib/libc/sys/linux/io.c
index 25dccc660..6187e701b 100644
--- a/newlib/libc/sys/linux/io.c
+++ b/newlib/libc/sys/linux/io.c
@@ -9,19 +9,16 @@
#include <unistd.h>
#include <fcntl.h>
#include <sys/types.h>
-#include <sys/uio.h>
#include <sys/stat.h>
#include <sys/ioctl.h>
-#include <poll.h>
-#include <machine/syscall.h>
+#include <sys/syscall.h>
#define __NR___ioctl __NR_ioctl
#define __NR___flock __NR_flock
-#define __NR___mknod __NR_mknod
-_syscall3(ssize_t,read,int,fd,void *,buf,size_t,count)
-_syscall3(ssize_t,write,int,fd,const void *,buf,size_t,count)
+_syscall3(int,read,int,fd,void *,buf,size_t,count)
+_syscall3(int,write,int,fd,const void *,buf,size_t,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)
@@ -29,22 +26,11 @@ _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)
-_syscall3(int,poll,struct pollfd *,fds,nfds_t,nfds,int,timeout)
-#if !defined(_ELIX_LEVEL) || _ELIX_LEVEL >= 2
-_syscall3(ssize_t,readv,int,fd,const struct iovec *,vec,int,count)
-_syscall3(ssize_t,writev,int,fd,const struct iovec *,buf,int,count)
-#endif
-
-#if !defined(_ELIX_LEVEL) || _ELIX_LEVEL >= 4
-_syscall2(int,ftruncate,int,fd,off_t,len)
-_syscall2(int,truncate,const char *,path,off_t,len)
-#endif
static _syscall3(int,__ioctl,int,fd,int,request,void *,arg)
+
int ioctl(int fd,int request,...)
{
va_list ap;
@@ -56,29 +42,13 @@ int ioctl(int fd,int request,...)
return res;
}
-static _syscall2(long,__flock,unsigned int,fd,unsigned int,cmd)
-int flock(int fd,int operation)
-{
- return __flock(fd,operation);
-}
+/* Why are all the types gratuituously different ? */
-#if !defined(_ELIX_LEVEL) || _ELIX_LEVEL >= 3
+static _syscall2(long,__flock,unsigned int,fd,unsigned int,cmd)
-static _syscall3(int,__mknod,const char *,path,mode_t,mode,dev_t,dev)
-int mkfifo(const char *path, mode_t mode)
+int flock(int fd,int operation)
{
- dev_t dev = 0;
- return __mknod(path, mode | S_IFIFO, dev);
+ return __flock(fd,operation);
}
-#endif
-
-weak_alias(__libc_close,__close);
-weak_alias(__libc_fcntl,__fcntl);
-weak_alias(__libc_lseek,__lseek);
-weak_alias(__libc_open,__open);
-weak_alias(__libc_read,__read);
-weak_alias(__libc_write,__write);
-weak_alias(__libc_poll,__poll);
-