add posix_close, accepted for inclusion in the next issue of POSIX
authorRich Felker <dalias@aerifal.cx>
Sat, 7 Dec 2013 02:59:01 +0000 (21:59 -0500)
committerRich Felker <dalias@aerifal.cx>
Sat, 7 Dec 2013 02:59:01 +0000 (21:59 -0500)
this is purely a wrapper for close since Linux does not support EINTR
semantics for the close syscall.

include/unistd.h
src/unistd/posix_close.c [new file with mode: 0644]

index 9f2fac96ddab92944ea5657be2cf5d5c0c181628..bf10a6d12705742ca0c42584e8df361f1c11c22f 100644 (file)
@@ -35,6 +35,7 @@ extern "C" {
 int pipe(int [2]);
 int pipe2(int [2], int);
 int close(int);
+int posix_close(int, int);
 int dup(int);
 int dup2(int, int);
 int dup3(int, int, int);
@@ -200,6 +201,8 @@ int eaccess(const char *, int);
 #define off64_t off_t
 #endif
 
+#define POSIX_CLOSE_RESTART     0
+
 #define _XOPEN_VERSION          700
 #define _XOPEN_UNIX             1
 #define _XOPEN_ENH_I18N         1
diff --git a/src/unistd/posix_close.c b/src/unistd/posix_close.c
new file mode 100644 (file)
index 0000000..90f51a8
--- /dev/null
@@ -0,0 +1,6 @@
+#include <unistd.h>
+
+int posix_close(int fd, int flags)
+{
+       return close(fd);
+}