// Wait for X Event or a Timer
if (pselect(max_fd+1, &fdset, 0, 0, 0, &empty_mask) > 0) {
+ // we need to iterate over the whole timer list, since fd_set can only be checked with the
+ // brute force method FD_ISSET for every possible timer
+ timer_iter = timer_list;
+ while (timer_iter) {
+ timer = timer_iter->data;
+ if (FD_ISSET(timer->id, &fdset)) {
+ uint64_t dummy;
+ if ( -1 != read(timer->id, &dummy, sizeof(uint64_t)) )
+ timer->_callback();
+ }
+ timer_iter = timer_iter->next;
+ }
+
while (XPending (server.dsp)) {
XNextEvent(server.dsp, &e);
break;
}
}
-
- // we need to iterate over the whole timer list, since fd_set can only be checked with the
- // brute force method FD_ISSET for every possible timer
- timer_iter = timer_list;
- while (timer_iter) {
- timer = timer_iter->data;
- if (FD_ISSET(timer->id, &fdset)) {
- uint64_t dummy;
-//printf("reading from timer->id=%d\n", timer->id);
- read(timer->id, &dummy, sizeof(uint64_t));
-//printf("Callback timer->_callback\n");
- timer->_callback();
-//printf("Timer callback finished\n");
- }
- timer_iter = timer_iter->next;
- }
}
switch (signal_pending) {
#include <sys/timerfd.h>
#include <stdlib.h>
#include <unistd.h>
+#include <fcntl.h>
#include "timer.h"
t->id=timer_fd;
t->_callback = _callback;
timer_list = g_slist_prepend(timer_list, t);
+
+ int flags = fcntl( timer_fd, F_GETFL, 0 );
+ if( flags != -1 )
+ fcntl( timer_fd, F_SETFL, flags | O_NONBLOCK );
+
return timer_fd;
}