diff options
Diffstat (limited to 'newlib/libc/sys/linux/inode.c')
-rw-r--r-- | newlib/libc/sys/linux/inode.c | 36 |
1 files changed, 25 insertions, 11 deletions
diff --git a/newlib/libc/sys/linux/inode.c b/newlib/libc/sys/linux/inode.c index 280d55876..ed468c19b 100644 --- a/newlib/libc/sys/linux/inode.c +++ b/newlib/libc/sys/linux/inode.c @@ -14,7 +14,6 @@ #define _LIBC 1 #include <sys/lock.h> -__LOCK_INIT(static, umask_lock); #define __NR___umask __NR_umask @@ -22,25 +21,33 @@ _syscall2(int,link,const char *,oldpath,const char *,newpath) _syscall1(int,unlink,const char *,pathname) _syscall1(int,chdir,const char *,path) _syscall1(int,fchdir,int,fd) -_syscall3(int,mknod,const char *,pathname,mode_t,mode,dev_t,dev) -_syscall2(int,chmod,const char *,path,mode_t,mode) -_syscall2(int,fchmod,int,filedes,mode_t,mode) -_syscall3(int,chown,const char *,path,uid_t,owner,gid_t,group) -_syscall2(int,utime,const char *,filename,const struct utimbuf *,buf) _syscall2(int,access,const char *,filename,int,mode) _syscall2(int,mkdir,const char *,pathname,mode_t,mode) _syscall1(int,rmdir,const char *,pathname) -_syscall1(int,pipe,int *,filedes) _syscall1(int,chroot,const char *,path) -_syscall2(int,symlink,const char *,oldpath,const char *,newpath) -_syscall3(int,readlink,const char *,path,char *,buf,size_t,bufsiz) _syscall2(int,stat,const char *,file_name,struct stat *,buf) _syscall2(int,statfs,const char *,file_name,struct statfs *,buf) -_syscall2(int,lstat,const char *,file_name,struct stat *,buf) _syscall2(int,fstat,int,filedes,struct stat *,buf) _syscall2(int,fstatfs,int,filedes,struct statfs *,buf) _syscall3(int,getdents,int,fd,struct dirent *,dirp,unsigned int,count) -_syscall1(mode_t,__umask,mode_t,mask) + +#if !defined(_ELIX_LEVEL) || _ELIX_LEVEL >= 2 +_syscall2(int,chmod,const char *,path,mode_t,mode) +_syscall3(int,chown,const char *,path,uid_t,owner,gid_t,group) +_syscall2(int,fchmod,int,filedes,mode_t,mode) +_syscall2(int,lstat,const char *,file_name,struct stat *,buf) +_syscall3(int,readlink,const char *,path,char *,buf,size_t,bufsiz) +_syscall2(int,symlink,const char *,oldpath,const char *,newpath) +_syscall2(int,utime,const char *,filename,const struct utimbuf *,buf) +#endif + +#if !defined(_ELIX_LEVEL) || _ELIX_LEVEL >= 3 +_syscall1(int,pipe,int *,filedes) +#endif + +#if !defined(_ELIX_LEVEL) || _ELIX_LEVEL >= 4 +_syscall3(int,mknod,const char *,pathname,mode_t,mode,dev_t,dev) +#endif weak_alias(__libc_statfs,__statfs) weak_alias(__libc_fstatfs,__fstatfs) @@ -53,6 +60,12 @@ fchown (int fd, uid_t owner, gid_t group) return __libc_fchown32 (fd, owner, group); } +#if !defined(_ELIX_LEVEL) || _ELIX_LEVEL >= 2 + +__LOCK_INIT(static, umask_lock); + +_syscall1(mode_t,__umask,mode_t,mask) + mode_t umask (mode_t mask) { @@ -81,3 +94,4 @@ getumask (void) return mask; } +#endif /* !_ELIX_LEVEL || _ELIX_LEVEL >= 2 */ |