diff options
-rw-r--r-- | include/unistd.h | 1 | ||||
-rw-r--r-- | libc/sysdeps/linux/common/unlink.c | 8 | ||||
-rw-r--r-- | libc/sysdeps/linux/common/unlinkat.c | 1 |
3 files changed, 10 insertions, 0 deletions
diff --git a/include/unistd.h b/include/unistd.h index 90d345972..ed77ce928 100644 --- a/include/unistd.h +++ b/include/unistd.h @@ -923,6 +923,7 @@ libc_hidden_proto(unlink) /* Remove the link NAME relative to FD. */ extern int unlinkat (int __fd, const char *__name, int __flag) __THROW __nonnull ((2)); +libc_hidden_proto(unlinkat) #endif /* Remove the directory PATH. */ diff --git a/libc/sysdeps/linux/common/unlink.c b/libc/sysdeps/linux/common/unlink.c index d4504d4df..317bc5da8 100644 --- a/libc/sysdeps/linux/common/unlink.c +++ b/libc/sysdeps/linux/common/unlink.c @@ -10,5 +10,13 @@ #include <sys/syscall.h> #include <unistd.h> +#if defined __NR_unlinkat && !defined __NR_unlink +# include <fcntl.h> +int unlink(const char *pathname) +{ + return unlinkat(AT_FDCWD, pathname, 0); +} +#else _syscall1(int, unlink, const char *, pathname) +#endif libc_hidden_def(unlink) diff --git a/libc/sysdeps/linux/common/unlinkat.c b/libc/sysdeps/linux/common/unlinkat.c index 0eaf2b670..432af1b75 100644 --- a/libc/sysdeps/linux/common/unlinkat.c +++ b/libc/sysdeps/linux/common/unlinkat.c @@ -11,6 +11,7 @@ #ifdef __NR_unlinkat _syscall3(int, unlinkat, int, fd, const char *, file, int, flag) +libc_hidden_def(unlinkat) #else /* should add emulation with unlink() and /proc/self/fd/ ... */ #endif |