mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-12-01 08:03:31 +01:00
Expose a new function to make the event loop exit once and for all.
Instead of calling tor_cleanup(), exit(x), we can now call tor_shutdown_event_loop_and_exit.
This commit is contained in:
parent
78cbced45c
commit
f0c3b62381
@ -30,6 +30,7 @@ periodic_timer_t *periodic_timer_new(struct event_base *base,
|
|||||||
void periodic_timer_free(periodic_timer_t *);
|
void periodic_timer_free(periodic_timer_t *);
|
||||||
|
|
||||||
#define tor_event_base_loopexit event_base_loopexit
|
#define tor_event_base_loopexit event_base_loopexit
|
||||||
|
#define tor_event_base_loopbreak event_base_loopbreak
|
||||||
|
|
||||||
/** Defines a configuration for using libevent with Tor: passed as an argument
|
/** Defines a configuration for using libevent with Tor: passed as an argument
|
||||||
* to tor_libevent_initialize() to describe how we want to set up. */
|
* to tor_libevent_initialize() to describe how we want to set up. */
|
||||||
|
@ -192,6 +192,14 @@ static smartlist_t *active_linked_connection_lst = NULL;
|
|||||||
* <b>loop_once</b>. If so, there's no need to trigger a loopexit in order
|
* <b>loop_once</b>. If so, there's no need to trigger a loopexit in order
|
||||||
* to handle linked connections. */
|
* to handle linked connections. */
|
||||||
static int called_loop_once = 0;
|
static int called_loop_once = 0;
|
||||||
|
/** Flag: if true, it's time to shut down, so the main loop should exit as
|
||||||
|
* soon as possible.
|
||||||
|
*/
|
||||||
|
static int main_loop_should_exit = 0;
|
||||||
|
/** The return value that the main loop should yield when it exits, if
|
||||||
|
* main_loop_should_exit is true.
|
||||||
|
*/
|
||||||
|
static int main_loop_exit_value = 0;
|
||||||
|
|
||||||
/** We set this to 1 when we've opened a circuit, so we can print a log
|
/** We set this to 1 when we've opened a circuit, so we can print a log
|
||||||
* entry to inform the user that Tor is working. We set it to 0 when
|
* entry to inform the user that Tor is working. We set it to 0 when
|
||||||
@ -648,6 +656,30 @@ tell_event_loop_to_run_external_code(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* After finishing the current callback (if any), shut down the main loop,
|
||||||
|
* clean up the process, and exit with <b>exitcode</b>.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
tor_shutdown_event_loop_and_exit(int exitcode)
|
||||||
|
{
|
||||||
|
if (main_loop_should_exit)
|
||||||
|
return; /* Ignore multiple calls to this function. */
|
||||||
|
|
||||||
|
main_loop_should_exit = 1;
|
||||||
|
main_loop_exit_value = exitcode;
|
||||||
|
|
||||||
|
/* Unlike loopexit, loopbreak prevents other callbacks from running. */
|
||||||
|
tor_event_base_loopbreak(tor_libevent_get_base());
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Return true iff tor_shutdown_event_loop_and_exit() has been called. */
|
||||||
|
int
|
||||||
|
tor_event_loop_shutdown_is_pending(void)
|
||||||
|
{
|
||||||
|
return main_loop_should_exit;
|
||||||
|
}
|
||||||
|
|
||||||
/** Helper: Tell the main loop to begin reading bytes into <b>conn</b> from
|
/** Helper: Tell the main loop to begin reading bytes into <b>conn</b> from
|
||||||
* its linked connection, if it is not doing so already. Called by
|
* its linked connection, if it is not doing so already. Called by
|
||||||
* connection_start_reading and connection_start_writing as appropriate. */
|
* connection_start_reading and connection_start_writing as appropriate. */
|
||||||
@ -2595,6 +2627,9 @@ do_main_loop(void)
|
|||||||
}
|
}
|
||||||
#endif /* defined(HAVE_SYSTEMD) */
|
#endif /* defined(HAVE_SYSTEMD) */
|
||||||
|
|
||||||
|
main_loop_should_exit = 0;
|
||||||
|
main_loop_exit_value = 0;
|
||||||
|
|
||||||
return run_main_loop_until_done();
|
return run_main_loop_until_done();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2610,6 +2645,9 @@ run_main_loop_once(void)
|
|||||||
if (nt_service_is_stopping())
|
if (nt_service_is_stopping())
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
if (main_loop_should_exit)
|
||||||
|
return 0;
|
||||||
|
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
/* Make it easier to tell whether libevent failure is our fault or not. */
|
/* Make it easier to tell whether libevent failure is our fault or not. */
|
||||||
errno = 0;
|
errno = 0;
|
||||||
@ -2656,6 +2694,9 @@ run_main_loop_once(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (main_loop_should_exit)
|
||||||
|
return 0;
|
||||||
|
|
||||||
/* And here is where we put callbacks that happen "every time the event loop
|
/* And here is where we put callbacks that happen "every time the event loop
|
||||||
* runs." They must be very fast, or else the whole Tor process will get
|
* runs." They must be very fast, or else the whole Tor process will get
|
||||||
* slowed down.
|
* slowed down.
|
||||||
@ -2684,6 +2725,10 @@ run_main_loop_until_done(void)
|
|||||||
do {
|
do {
|
||||||
loop_result = run_main_loop_once();
|
loop_result = run_main_loop_once();
|
||||||
} while (loop_result == 1);
|
} while (loop_result == 1);
|
||||||
|
|
||||||
|
if (main_loop_should_exit)
|
||||||
|
return main_loop_exit_value;
|
||||||
|
else
|
||||||
return loop_result;
|
return loop_result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -46,6 +46,8 @@ MOCK_DECL(void,connection_stop_writing,(connection_t *conn));
|
|||||||
MOCK_DECL(void,connection_start_writing,(connection_t *conn));
|
MOCK_DECL(void,connection_start_writing,(connection_t *conn));
|
||||||
|
|
||||||
void tell_event_loop_to_run_external_code(void);
|
void tell_event_loop_to_run_external_code(void);
|
||||||
|
void tor_shutdown_event_loop_and_exit(int exitcode);
|
||||||
|
int tor_event_loop_shutdown_is_pending(void);
|
||||||
|
|
||||||
void connection_stop_reading_from_linked_conn(connection_t *conn);
|
void connection_stop_reading_from_linked_conn(connection_t *conn);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user