summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2015-08-12 09:35:26 -0400
committerNick Mathewson <nickm@torproject.org>2015-08-18 08:56:23 -0400
commit81f3572467583c54eb2a22c3af93f7c819796563 (patch)
tree550d6b89b2125ef1e2b51f3e1ee03d3a62514b45
parente507f9bf4280d1462876c6a5bfeaf549b19306f4 (diff)
downloadtor-81f3572467583c54eb2a22c3af93f7c819796563.tar.gz
tor-81f3572467583c54eb2a22c3af93f7c819796563.zip
Refactor initialization logic for control-event-queue
This puts the init logic in a separate function, which we will need once we have locking.
-rw-r--r--src/or/config.c3
-rw-r--r--src/or/control.c38
-rw-r--r--src/or/control.h2
-rw-r--r--src/test/testing_common.c2
4 files changed, 30 insertions, 15 deletions
diff --git a/src/or/config.c b/src/or/config.c
index 011a36db17..9573b61dc4 100644
--- a/src/or/config.c
+++ b/src/or/config.c
@@ -1106,6 +1106,9 @@ options_act_reversible(const or_options_t *old_options, char **msg)
init_libevent(options);
libevent_initialized = 1;
+ /* This has to come up after libevent is initialized. */
+ control_initialize_event_queue();
+
/*
* Initialize the scheduler - this has to come after
* options_init_from_torrc() sets up libevent - why yes, that seems
diff --git a/src/or/control.c b/src/or/control.c
index 859c6600ae..4b8e9c1573 100644
--- a/src/or/control.c
+++ b/src/or/control.c
@@ -605,6 +605,24 @@ static smartlist_t *queued_control_events = NULL;
* queued_control_events. */
static struct event *flush_queued_events_event = NULL;
+void
+control_initialize_event_queue(void)
+{
+ if (queued_control_events == NULL) {
+ queued_control_events = smartlist_new();
+ }
+
+ if (flush_queued_events_event == NULL) {
+ struct event_base *b = tor_libevent_get_base();
+ if (b) {
+ flush_queued_events_event = tor_event_new(b,
+ -1, 0, flush_queued_events_cb,
+ NULL);
+ tor_assert(flush_queued_events_event);
+ }
+ }
+}
+
/** Helper: inserts an event on the list of events queued to be sent to
* one or more controllers, and schedules the events to be flushed if needed.
*
@@ -619,10 +637,6 @@ static struct event *flush_queued_events_event = NULL;
MOCK_IMPL(STATIC void,
queue_control_event_string,(uint16_t event, char *msg))
{
- if (PREDICT_UNLIKELY(queued_control_events == NULL)) {
- queued_control_events = smartlist_new();
- }
-
/* This is redundant with checks done elsewhere, but it's a last-ditch
* attempt to avoid queueing something we shouldn't have to queue. */
if (PREDICT_UNLIKELY( ! EVENT_IS_INTERESTING(event) )) {
@@ -634,27 +648,21 @@ queue_control_event_string,(uint16_t event, char *msg))
return;
}
- /* No queueing an event while queueing an event */
- ++block_event_queue;
-
queued_event_t *ev = tor_malloc(sizeof(*ev));
ev->event = event;
ev->msg = msg;
+ /* No queueing an event while queueing an event */
+ ++block_event_queue;
+
+ tor_assert(queued_control_events);
smartlist_add(queued_control_events, ev);
/* We just put the first event on the queue; mark the queue to be
* flushed.
*/
if (smartlist_len(queued_control_events) == 1) {
- if (PREDICT_UNLIKELY(flush_queued_events_event == NULL)) {
- struct event_base *b = tor_libevent_get_base();
- tor_assert(b);
- flush_queued_events_event = tor_event_new(b,
- -1, 0, flush_queued_events_cb,
- NULL);
- tor_assert(flush_queued_events_event);
- }
+ tor_assert(flush_queued_events_event);
event_active(flush_queued_events_event, EV_READ, 1);
}
diff --git a/src/or/control.h b/src/or/control.h
index 8aa4780b68..574dd85002 100644
--- a/src/or/control.h
+++ b/src/or/control.h
@@ -12,6 +12,8 @@
#ifndef TOR_CONTROL_H
#define TOR_CONTROL_H
+void control_initialize_event_queue(void);
+
void control_update_global_event_mask(void);
void control_adjust_event_log_severity(void);
diff --git a/src/test/testing_common.c b/src/test/testing_common.c
index 7f387c0b3d..441024bd7d 100644
--- a/src/test/testing_common.c
+++ b/src/test/testing_common.c
@@ -14,6 +14,7 @@ const char tor_git_revision[] = "";
#include "orconfig.h"
#include "or.h"
+#include "control.h"
#include "config.h"
#include "rephist.h"
#include "backtrace.h"
@@ -237,6 +238,7 @@ main(int c, const char **v)
update_approx_time(time(NULL));
options = options_new();
tor_threads_init();
+ control_initialize_event_queue();
init_logging(1);
configure_backtrace_handler(get_version());