summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPekka Paalanen <ppaalanen@gmail.com>2012-05-30 15:53:43 +0300
committerKristian Høgsberg <krh@bitplanet.net>2012-05-31 13:53:51 -0400
commit647f2bfd2a9214e5bebb2290252d013ccbbb290c (patch)
tree7a3e771586b5dc8098ab6d4fccec49e5bbae0a1e
parent200019c0c66ec757353ffaaea8d9c98da37f26c8 (diff)
window: add wrapper for EPOLL_CLOEXEC
Android does not have EPOLL_CLOEXEC, so add a fallback. Signed-off-by: Pekka Paalanen <ppaalanen@gmail.com>
-rw-r--r--clients/window.c3
-rw-r--r--shared/os-compatibility.c17
-rw-r--r--shared/os-compatibility.h3
3 files changed, 22 insertions, 1 deletions
diff --git a/clients/window.c b/clients/window.c
index 3ef648e..ae8792e 100644
--- a/clients/window.c
+++ b/clients/window.c
@@ -62,6 +62,7 @@
#include <wayland-client.h>
#include "../shared/cairo-util.h"
#include "text-cursor-position-client-protocol.h"
+#include "../shared/os-compatibility.h"
#include "window.h"
@@ -3299,7 +3300,7 @@ display_create(int argc, char *argv[])
return NULL;
}
- d->epoll_fd = epoll_create1(EPOLL_CLOEXEC);
+ d->epoll_fd = os_epoll_create_cloexec();
d->display_fd = wl_display_get_fd(d->display, event_mask_update, d);
d->display_task.run = handle_display_data;
display_watch_fd(d, d->display_fd, EPOLLIN, &d->display_task);
diff --git a/shared/os-compatibility.c b/shared/os-compatibility.c
index b79aa1f..3c065e8 100644
--- a/shared/os-compatibility.c
+++ b/shared/os-compatibility.c
@@ -25,6 +25,7 @@
#include <unistd.h>
#include <fcntl.h>
#include <errno.h>
+#include <sys/epoll.h>
#include "os-compatibility.h"
@@ -76,3 +77,19 @@ os_socketpair_cloexec(int domain, int type, int protocol, int *sv)
return -1;
}
+int
+os_epoll_create_cloexec(void)
+{
+ int fd;
+
+#ifdef EPOLL_CLOEXEC
+ fd = epoll_create1(EPOLL_CLOEXEC);
+ if (fd >= 0)
+ return fd;
+ if (errno != EINVAL)
+ return -1;
+#endif
+
+ fd = epoll_create(1);
+ return set_cloexec_or_close(fd);
+}
diff --git a/shared/os-compatibility.h b/shared/os-compatibility.h
index ca753b6..6ada7b6 100644
--- a/shared/os-compatibility.h
+++ b/shared/os-compatibility.h
@@ -36,4 +36,7 @@ backtrace(void **buffer, int size)
int
os_socketpair_cloexec(int domain, int type, int protocol, int *sv);
+int
+os_epoll_create_cloexec(void);
+
#endif /* OS_COMPATIBILITY_H */