2 #if defined(HAVE_EPOLL)
6 #if defined(HOST_WIN32)
7 /* We assume that epoll is not available on windows */
11 #define EPOLL_NEVENTS 128
14 static struct epoll_event *epoll_events;
17 epoll_init (gint wakeup_pipe_fd)
19 struct epoll_event event;
22 epoll_fd = epoll_create1 (EPOLL_CLOEXEC);
24 epoll_fd = epoll_create (256);
25 fcntl (epoll_fd, F_SETFD, FD_CLOEXEC);
30 g_error ("epoll_init: epoll (EPOLL_CLOEXEC) failed, error (%d) %s\n", errno, g_strerror (errno));
32 g_error ("epoll_init: epoll (256) failed, error (%d) %s\n", errno, g_strerror (errno));
37 event.events = EPOLLIN;
38 event.data.fd = wakeup_pipe_fd;
39 if (epoll_ctl (epoll_fd, EPOLL_CTL_ADD, event.data.fd, &event) == -1) {
40 g_error ("epoll_init: epoll_ctl () failed, error (%d) %s", errno, g_strerror (errno));
45 epoll_events = g_new0 (struct epoll_event, EPOLL_NEVENTS);
53 g_free (epoll_events);
58 epoll_register_fd (gint fd, gint events, gboolean is_new)
61 if (!is_new && epoll_ctl (epoll_fd, EPOLL_CTL_DEL, fd, NULL) == -1)
62 g_error ("epoll_register_fd: epoll_ctl (EPOLL_CTL_DEL) failed, error (%d) %s", errno, g_strerror (errno));
64 struct epoll_event event;
67 event.events = EPOLLONESHOT;
68 if ((events & MONO_POLLIN) != 0)
69 event.events |= EPOLLIN;
70 if ((events & MONO_POLLOUT) != 0)
71 event.events |= EPOLLOUT;
73 if (epoll_ctl (epoll_fd, is_new ? EPOLL_CTL_ADD : EPOLL_CTL_MOD, event.data.fd, &event) == -1)
74 g_error ("epoll_register_fd: epoll_ctl(%s) failed, error (%d) %s", is_new ? "EPOLL_CTL_ADD" : "EPOLL_CTL_MOD", errno, g_strerror (errno));
79 epoll_event_wait (void)
83 memset (epoll_events, 0, sizeof (struct epoll_event) * EPOLL_NEVENTS);
85 ready = epoll_wait (epoll_fd, epoll_events, EPOLL_NEVENTS, -1);
89 mono_thread_internal_check_for_interruption_critical (mono_thread_internal_current ());
93 g_error ("epoll_event_wait: epoll_wait () failed, error (%d) %s", errno, g_strerror (errno));
102 epoll_event_get_fd_max (void)
104 return EPOLL_NEVENTS;
108 epoll_event_get_fd_at (gint i, gint *events)
112 *events = ((epoll_events [i].events & (EPOLLIN | EPOLLERR | EPOLLHUP)) ? MONO_POLLIN : 0)
113 | ((epoll_events [i].events & (EPOLLOUT | EPOLLERR | EPOLLHUP)) ? MONO_POLLOUT : 0);
115 return epoll_events [i].data.fd;
118 static ThreadPoolIOBackend backend_epoll = {
120 .cleanup = epoll_cleanup,
121 .register_fd = epoll_register_fd,
122 .event_wait = epoll_event_wait,
123 .event_get_fd_max = epoll_event_get_fd_max,
124 .event_get_fd_at = epoll_event_get_fd_at,