summaryrefslogtreecommitdiff
path: root/src/or/rephist.c
diff options
context:
space:
mode:
authorKarsten Loesing <karsten.loesing@gmx.net>2011-08-03 13:33:48 +0200
committerKarsten Loesing <karsten.loesing@gmx.net>2011-08-04 21:04:44 +0200
commit8f4e5fa2b5e78d04ac8d656f58db22110f2e450d (patch)
tree243018da4b4c3cb4ed33b1b9dce8b62b19277746 /src/or/rephist.c
parenta6a127c833eace1100aca7ab8ad118862bb8a8b9 (diff)
downloadtor-8f4e5fa2b5e78d04ac8d656f58db22110f2e450d.tar.gz
tor-8f4e5fa2b5e78d04ac8d656f58db22110f2e450d.zip
Create cell-stats history even if we didn't see a single circuit.
So far, if we didn't see a single circuit, we refrained from generating a cell-stats string and logged a warning. Nobody will notice the warning, and people will wonder why there's no cell-stats string in the extra-info descriptor. The better behavior is to generate a cell-stats string with all zeros.
Diffstat (limited to 'src/or/rephist.c')
-rw-r--r--src/or/rephist.c35
1 files changed, 17 insertions, 18 deletions
diff --git a/src/or/rephist.c b/src/or/rephist.c
index 672e3f3daf..a5a828d5cf 100644
--- a/src/or/rephist.c
+++ b/src/or/rephist.c
@@ -2455,32 +2455,31 @@ rep_hist_buffer_stats_write(time_t now)
/* add current circuits to stats */
for (circ = _circuit_get_global_list(); circ; circ = circ->next)
rep_hist_buffer_stats_add_circ(circ, now);
- /* calculate deciles */
+
+ /* Calculate deciles if we saw at least one circuit. */
memset(processed_cells, 0, SHARES * sizeof(int));
memset(circs_in_share, 0, SHARES * sizeof(int));
memset(queued_cells, 0, SHARES * sizeof(double));
memset(time_in_queue, 0, SHARES * sizeof(double));
if (!circuits_for_buffer_stats)
circuits_for_buffer_stats = smartlist_create();
- smartlist_sort(circuits_for_buffer_stats,
- _buffer_stats_compare_entries);
number_of_circuits = smartlist_len(circuits_for_buffer_stats);
- if (number_of_circuits < 1) {
- log_info(LD_HIST, "Attempt to write cell statistics to disk failed. "
- "We haven't seen a single circuit to report about.");
- goto done;
- }
- i = 0;
- SMARTLIST_FOREACH_BEGIN(circuits_for_buffer_stats,
- circ_buffer_stats_t *, stat)
- {
- int share = i++ * SHARES / number_of_circuits;
- processed_cells[share] += stat->processed_cells;
- queued_cells[share] += stat->mean_num_cells_in_queue;
- time_in_queue[share] += stat->mean_time_cells_in_queue;
- circs_in_share[share]++;
+ if (number_of_circuits > 0) {
+ smartlist_sort(circuits_for_buffer_stats,
+ _buffer_stats_compare_entries);
+ i = 0;
+ SMARTLIST_FOREACH_BEGIN(circuits_for_buffer_stats,
+ circ_buffer_stats_t *, stat)
+ {
+ int share = i++ * SHARES / number_of_circuits;
+ processed_cells[share] += stat->processed_cells;
+ queued_cells[share] += stat->mean_num_cells_in_queue;
+ time_in_queue[share] += stat->mean_time_cells_in_queue;
+ circs_in_share[share]++;
+ }
+ SMARTLIST_FOREACH_END(stat);
}
- SMARTLIST_FOREACH_END(stat);
+
/* clear buffer stats history */
SMARTLIST_FOREACH(circuits_for_buffer_stats, circ_buffer_stats_t *,
stat, tor_free(stat));