+ /* Block SIGHUP & SIGALRM */
+ sigemptyset(&block_mask);
+ sigaddset(&block_mask, SIGHUP);
+ sigaddset(&block_mask, SIGALRM);
+ sigprocmask(SIG_BLOCK, &block_mask, &omask);
+#endif
+
+ running = true;
+
+ while(running) {
+#ifdef HAVE_PSELECT
+ next_event = last_ping_check + pingtimeout;
+
+ if(graph_dump && next_event > last_graph_dump + 60) {
+ next_event = last_graph_dump + 60;
+ }
+
+ if((event = peek_next_event()) && next_event > event->time) {
+ next_event = event->time;
+ }
+
+ if(next_event <= now) {
+ tv.tv_sec = 0;
+ } else {
+ tv.tv_sec = next_event - now;
+ }
+
+ tv.tv_nsec = 0;
+#else
+ tv.tv_sec = 1;
+ tv.tv_usec = 0;
+#endif
+
+ maxfd = build_fdset(&readset, &writeset);
+
+#ifdef HAVE_MINGW
+ LeaveCriticalSection(&mutex);
+#endif
+#ifdef HAVE_PSELECT
+ r = pselect(maxfd + 1, &readset, &writeset, NULL, &tv, &omask);
+#else
+ r = select(maxfd + 1, &readset, &writeset, NULL, &tv);
+#endif
+ now = time(NULL);
+#ifdef HAVE_MINGW
+ EnterCriticalSection(&mutex);
+#endif
+
+ if(r < 0) {
+ if(!sockwouldblock(sockerrno)) {
+ logger(LOG_ERR, "Error while waiting for input: %s", sockstrerror(sockerrno));
+ dump_connections();
+ return 1;
+ }
+ }
+
+ if(r > 0) {
+ check_network_activity(&readset, &writeset);
+ }
+
+ if(do_purge) {
+ purge();
+ do_purge = false;
+ }
+
+ /* Let's check if everybody is still alive */
+
+ if(last_ping_check + pingtimeout <= now) {
+ check_dead_connections();
+ last_ping_check = now;
+
+ if(routing_mode == RMODE_SWITCH) {
+ age_subnets();
+ }
+
+ age_past_requests();
+
+ /* Should we regenerate our key? */
+
+ if(keyexpires <= now) {
+ avl_node_t *node;
+ node_t *n;
+
+ ifdebug(STATUS) logger(LOG_INFO, "Expiring symmetric keys");
+
+ for(node = node_tree->head; node; node = node->next) {
+ n = node->data;
+
+ if(n->inkey) {
+ free(n->inkey);
+ n->inkey = NULL;
+ }
+ }