[git commit] mkdir: Use mkdirat if arch does not have the mkdir syscall

Bernhard Reutner-Fischer rep.dot.nop at gmail.com
Wed Feb 20 12:45:11 UTC 2013


commit: http://git.uclibc.org/uClibc/commit/?id=ecb2be2c0a2f9c489663a4b01b97074dda2ceb1e
branch: http://git.uclibc.org/uClibc/commit/?id=refs/heads/master

Signed-off-by: Markos Chandras <markos.chandras at imgtec.com>

Signed-off-by: Bernhard Reutner-Fischer <rep.dot.nop at gmail.com>
---
 include/sys/stat.h                  |    1 +
 libc/sysdeps/linux/common/mkdir.c   |   10 +++++++++-
 libc/sysdeps/linux/common/mkdirat.c |    1 +
 3 files changed, 11 insertions(+), 1 deletions(-)

diff --git a/include/sys/stat.h b/include/sys/stat.h
index 1709cec..9283a89 100644
--- a/include/sys/stat.h
+++ b/include/sys/stat.h
@@ -335,6 +335,7 @@ libc_hidden_proto(mkdir)
    with FD.  */
 extern int mkdirat (int __fd, const char *__path, __mode_t __mode)
      __THROW __nonnull ((2));
+libc_hidden_proto(mkdirat)
 #endif
 
 /* Create a device file named PATH, with permission and special bits MODE
diff --git a/libc/sysdeps/linux/common/mkdir.c b/libc/sysdeps/linux/common/mkdir.c
index fbc587d..bee3e3e 100644
--- a/libc/sysdeps/linux/common/mkdir.c
+++ b/libc/sysdeps/linux/common/mkdir.c
@@ -10,8 +10,15 @@
 #include <sys/syscall.h>
 #include <sys/stat.h>
 
+#if defined __NR_mkdirat && !defined __NR_mkdir
+# include <fcntl.h>
+int mkdir(const char *pathname, mode_t mode)
+{
+	return mkdirat(AT_FDCWD, pathname, mode);
+}
 
-#define __NR___syscall_mkdir __NR_mkdir
+#else
+# define __NR___syscall_mkdir __NR_mkdir
 static __inline__ _syscall2(int, __syscall_mkdir, const char *, pathname,
 		__kernel_mode_t, mode)
 
@@ -19,4 +26,5 @@ int mkdir(const char *pathname, mode_t mode)
 {
 	return (__syscall_mkdir(pathname, mode));
 }
+#endif
 libc_hidden_def(mkdir)
diff --git a/libc/sysdeps/linux/common/mkdirat.c b/libc/sysdeps/linux/common/mkdirat.c
index 4da9468..871104b 100644
--- a/libc/sysdeps/linux/common/mkdirat.c
+++ b/libc/sysdeps/linux/common/mkdirat.c
@@ -11,6 +11,7 @@
 
 #ifdef __NR_mkdirat
 _syscall3(int, mkdirat, int, fd, const char *, path, mode_t, mode)
+libc_hidden_def(mkdirat)
 #else
 /* should add emulation with mkdir() and /proc/self/fd/ ... */
 #endif


More information about the uClibc-cvs mailing list