aboutsummaryrefslogtreecommitdiffstats
path: root/lib/events_libevent.c
diff options
context:
space:
mode:
authorWilmer van der Gaast <wilmer@gaast.net>2007-11-28 23:24:26 +0000
committerWilmer van der Gaast <wilmer@gaast.net>2007-11-28 23:24:26 +0000
commitb6a2373c2c9a98594a87c54a4644f3c0e985e420 (patch)
tree30f5bc8dace53475b4726e4e613e0aefb95640fb /lib/events_libevent.c
parent221a27346f768b9626f2a0281ff774790858a0c2 (diff)
Fixed the epoll+ForkDaemon combination. The libevent event handling
didn't work very well on Linux 2.6 (and possibly others) in ForkDaemon mode.
Diffstat (limited to 'lib/events_libevent.c')
-rw-r--r--lib/events_libevent.c49
1 files changed, 41 insertions, 8 deletions
diff --git a/lib/events_libevent.c b/lib/events_libevent.c
index f2b4d15c..d02ad6a6 100644
--- a/lib/events_libevent.c
+++ b/lib/events_libevent.c
@@ -36,7 +36,9 @@
#include <sys/time.h>
#include <event.h>
-static guint id_next;
+static void b_main_restart();
+
+static guint id_next = 1;
static GHashTable *id_hash;
static int quitting = 0;
@@ -47,6 +49,9 @@ static int quitting = 0;
static GHashTable *read_hash;
static GHashTable *write_hash;
+struct event_base *leh;
+struct event_base *old_leh;
+
struct b_event_data
{
guint id;
@@ -58,9 +63,16 @@ struct b_event_data
void b_main_init()
{
- event_init();
+ if( leh != NULL )
+ {
+ /* Clean up the hash tables? */
+
+ b_main_restart();
+ old_leh = leh;
+ }
+
+ leh = event_init();
- id_next = 1;
id_hash = g_hash_table_new( g_int_hash, g_int_equal );
read_hash = g_hash_table_new( g_int_hash, g_int_equal );
write_hash = g_hash_table_new( g_int_hash, g_int_equal );
@@ -68,19 +80,40 @@ void b_main_init()
void b_main_run()
{
- event_dispatch();
+ /* This while loop is necessary to exit the event loop and start a
+ different one (necessary for ForkDaemon mode). */
+ while( event_base_dispatch( leh ) == 0 && !quitting )
+ {
+ if( old_leh != NULL )
+ {
+ /* For some reason this just isn't allowed...
+ Possibly a bug in older versions, will see later.
+ event_base_free( old_leh ); */
+ old_leh = NULL;
+ }
+
+ printf( "New event loop.\n" );
+ }
}
-void b_main_quit()
+static void b_main_restart()
{
struct timeval tv;
- /* libevent sometimes generates events before really quitting,
+ memset( &tv, 0, sizeof( struct timeval ) );
+ event_base_loopexit( leh, &tv );
+
+ printf( "b_main_restart()\n" );
+}
+
+void b_main_quit()
+{
+ /* Tell b_main_run() that it shouldn't restart the loop. Also,
+ libevent sometimes generates events before really quitting,
we want to stop them. */
quitting = 1;
- memset( &tv, 0, sizeof( struct timeval ) );
- event_loopexit( &tv );
+ b_main_restart();
}
static void b_event_passthrough( int fd, short event, void *data )