summaryrefslogtreecommitdiff
path: root/src/or/control.c
diff options
context:
space:
mode:
authorKarsten Loesing <karsten.loesing@gmx.net>2013-05-25 12:21:09 +0200
committerKarsten Loesing <karsten.loesing@gmx.net>2013-05-25 19:51:38 +0200
commitef67077fba6061a6e5b9a76caf60a33d17a81ce6 (patch)
treed8d4c279b34401402e1044544dfae235860dfb47 /src/or/control.c
parent26b49f525d5b2a4781755d72738491c016dd15a9 (diff)
downloadtor-ef67077fba6061a6e5b9a76caf60a33d17a81ce6.tar.gz
tor-ef67077fba6061a6e5b9a76caf60a33d17a81ce6.zip
Tweak TB_EMPTY event based on comments by nickm.
- Avoid control_event_refill_global function with 13 arguments and increase code reuse factor by moving more code from control.c to connection.c. - Avoid an unsafe uint32_t -> int cast. - Add TestingEnableTbEmptyEvent option. - Prepare functions for testing. - Rename a few functions and improve documentation.
Diffstat (limited to 'src/or/control.c')
-rw-r--r--src/or/control.c102
1 files changed, 13 insertions, 89 deletions
diff --git a/src/or/control.c b/src/or/control.c
index c06a91182b..ac7be8d593 100644
--- a/src/or/control.c
+++ b/src/or/control.c
@@ -4155,99 +4155,23 @@ control_event_circuit_cell_stats(void)
return 0;
}
-/** Helper: return the time in millis that a given bucket was empty,
- * capped at the time in millis since last refilling that bucket. Return
- * 0 if the bucket was not empty during the last refill period. */
-static uint32_t
-bucket_millis_empty(int prev_tokens, uint32_t last_empty_time,
- uint32_t milliseconds_elapsed)
-{
- uint32_t result = 0, refilled;
- if (prev_tokens <= 0) {
- struct timeval tvnow;
- tor_gettimeofday_cached(&tvnow);
- refilled = (uint32_t)((tvnow.tv_sec % 86400L) * 1000L +
- (uint32_t)tvnow.tv_usec / (uint32_t)1000L);
- result = (uint32_t)((refilled + 86400L * 1000L - last_empty_time) %
- (86400L * 1000L));
- if (result > milliseconds_elapsed)
- result = milliseconds_elapsed;
- }
- return result;
-}
-
-/** Token buckets have been refilled: tell any interested control
- * connections how global and relay token buckets have changed. */
+/** Tokens in <b>bucket</b> have been refilled: the read bucket was empty
+ * for <b>read_empty_time</b> millis, the write bucket was empty for
+ * <b>write_empty_time</b> millis, and buckets were last refilled
+ * <b>milliseconds_elapsed</b> millis ago. Only emit TB_EMPTY event if
+ * either read or write bucket have been empty before. */
int
-control_event_refill_global(int global_read, int prev_global_read,
- uint32_t global_read_emptied_time,
- int global_write, int prev_global_write,
- uint32_t global_write_emptied_time,
- int relay_read, int prev_relay_read,
- uint32_t relay_read_emptied_time,
- int relay_write, int prev_relay_write,
- uint32_t relay_write_emptied_time,
- uint32_t milliseconds_elapsed)
+control_event_tb_empty(const char *bucket, uint32_t read_empty_time,
+ uint32_t write_empty_time,
+ int milliseconds_elapsed)
{
- uint32_t global_read_empty_time, global_write_empty_time,
- relay_read_empty_time, relay_write_empty_time;
- if (!get_options()->TestingTorNetwork ||
- !EVENT_IS_INTERESTING(EVENT_TB_EMPTY))
- return 0;
- if (prev_global_read == global_read &&
- prev_global_write == global_write &&
- prev_relay_read == relay_read &&
- prev_relay_write == relay_write)
- return 0;
- if (prev_global_read <= 0 && prev_global_write <= 0) {
- global_read_empty_time = bucket_millis_empty(prev_global_read,
- global_read_emptied_time, milliseconds_elapsed);
- global_write_empty_time = bucket_millis_empty(prev_global_write,
- global_write_emptied_time, milliseconds_elapsed);
+ if (get_options()->TestingEnableTbEmptyEvent &&
+ EVENT_IS_INTERESTING(EVENT_TB_EMPTY) &&
+ (read_empty_time > 0 || write_empty_time > 0)) {
send_control_event(EVENT_TB_EMPTY, ALL_FORMATS,
- "650 TB_EMPTY GLOBAL READ=%d WRITTEN=%d "
+ "650 TB_EMPTY %s READ=%d WRITTEN=%d "
"LAST=%d\r\n",
- global_read_empty_time, global_write_empty_time,
- milliseconds_elapsed);
- }
- if (prev_relay_read <= 0 && prev_relay_write <= 0) {
- relay_read_empty_time = bucket_millis_empty(prev_relay_read,
- relay_read_emptied_time, milliseconds_elapsed);
- relay_write_empty_time = bucket_millis_empty(prev_relay_write,
- relay_write_emptied_time, milliseconds_elapsed);
- send_control_event(EVENT_TB_EMPTY, ALL_FORMATS,
- "650 TB_EMPTY RELAY READ=%d WRITTEN=%d "
- "LAST=%d\r\n",
- relay_read_empty_time, relay_write_empty_time,
- milliseconds_elapsed);
- }
- return 0;
-}
-
-/** Token buckets of a connection have been refilled: tell any interested
- * control connections how per-connection token buckets have changed. */
-int
-control_event_refill_conn(or_connection_t *or_conn,
- int prev_read, int prev_write,
- uint32_t milliseconds_elapsed)
-{
- uint32_t read_bucket_empty_time, write_bucket_empty_time;
- if (!get_options()->TestingTorNetwork ||
- !EVENT_IS_INTERESTING(EVENT_TB_EMPTY))
- return 0;
- if (prev_read == or_conn->read_bucket &&
- prev_write == or_conn->write_bucket)
- return 0;
- if (prev_read <= 0 || prev_write <= 0) {
- read_bucket_empty_time = bucket_millis_empty(prev_read,
- or_conn->read_emptied_time, milliseconds_elapsed);
- write_bucket_empty_time = bucket_millis_empty(prev_write,
- or_conn->write_emptied_time, milliseconds_elapsed);
- send_control_event(EVENT_TB_EMPTY, ALL_FORMATS,
- "650 TB_EMPTY ORCONN ID="U64_FORMAT" READ=%d "
- "WRITTEN=%d LAST=%d\r\n",
- U64_PRINTF_ARG(or_conn->base_.global_identifier),
- read_bucket_empty_time, write_bucket_empty_time,
+ bucket, read_empty_time, write_empty_time,
milliseconds_elapsed);
}
return 0;