From ca8e84c6ff55640aef94d25a86a25778a542bfc2 Mon Sep 17 00:00:00 2001 From: Elliott Hughes Date: Thu, 23 Oct 2014 19:10:23 -0700 Subject: [PATCH] Add mkfifoat(3). Looks like I missed one of the *at functions when I added the rest. Change-Id: If16de82dbf6f9a3ea7bfdcba406ca1c74a3f2279 --- libc/bionic/mkfifo.cpp | 8 +++++++- libc/include/sys/stat.h | 1 + tests/sys_stat_test.cpp | 13 +++++++++++++ 3 files changed, 21 insertions(+), 1 deletion(-) diff --git a/libc/bionic/mkfifo.cpp b/libc/bionic/mkfifo.cpp index 08ffad1d6..a98b35008 100644 --- a/libc/bionic/mkfifo.cpp +++ b/libc/bionic/mkfifo.cpp @@ -28,6 +28,12 @@ #include +#include + int mkfifo(const char* path, mode_t mode) { - return mknod(path, (mode & ~S_IFMT) | S_IFIFO, 0); + return mkfifoat(AT_FDCWD, path, mode); +} + +int mkfifoat(int fd, const char* path, mode_t mode) { + return mknodat(fd, path, (mode & ~S_IFMT) | S_IFIFO, 0); } diff --git a/libc/include/sys/stat.h b/libc/include/sys/stat.h index 77d7cac5b..4900e849f 100644 --- a/libc/include/sys/stat.h +++ b/libc/include/sys/stat.h @@ -181,6 +181,7 @@ mode_t umask(mode_t mode) { #endif /* defined(__BIONIC_FORTIFY) */ extern int mkfifo(const char*, mode_t); +extern int mkfifoat(int, const char*, mode_t); extern int fchmodat(int, const char*, mode_t, int); extern int mkdirat(int, const char*, mode_t); diff --git a/tests/sys_stat_test.cpp b/tests/sys_stat_test.cpp index 64049ab61..e46577469 100644 --- a/tests/sys_stat_test.cpp +++ b/tests/sys_stat_test.cpp @@ -55,6 +55,18 @@ TEST(sys_stat, futimens_EBADF) { ASSERT_EQ(EBADF, errno); } +TEST(sys_stat, mkfifo_failure) { + errno = 0; + ASSERT_EQ(-1, mkfifo("/", 0666)); + ASSERT_EQ(EEXIST, errno); +} + +TEST(sys_stat, mkfifoat_failure) { + errno = 0; + ASSERT_EQ(-1, mkfifoat(-2, "x", 0666)); + ASSERT_EQ(EBADF, errno); +} + TEST(sys_stat, mkfifo) { if (getuid() == 0) { // Racy but probably sufficient way to get a suitable filename. @@ -70,6 +82,7 @@ TEST(sys_stat, mkfifo) { ASSERT_TRUE(S_ISFIFO(sb.st_mode)); unlink(path.c_str()); } else { + // SELinux policy forbids us from creating FIFOs. http://b/17646702. GTEST_LOG_(INFO) << "This test only performs a test when run as root."; } }