aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Perry <mikeperry-git@torproject.org>2018-04-02 07:16:19 +0000
committerMike Perry <mikeperry-git@torproject.org>2018-04-16 21:46:31 +0000
commitf921fd771ae51a82d971be064edca86b11f6004b (patch)
treea2838fca74089ba725113afd64b02aad842b46b6
parent0e06a9c3e76620881db95718f60441ce7de0f3c9 (diff)
downloadtor-f921fd771ae51a82d971be064edca86b11f6004b.tar.gz
tor-f921fd771ae51a82d971be064edca86b11f6004b.zip
Use u32 add helper for CIRC_BW accounting.
There are quite a few other places this could be used, but keeping it simple for now.
-rw-r--r--src/or/command.c7
-rw-r--r--src/or/relay.c7
2 files changed, 4 insertions, 10 deletions
diff --git a/src/or/command.c b/src/or/command.c
index 18cbbca25e..4fa05a18b4 100644
--- a/src/or/command.c
+++ b/src/or/command.c
@@ -504,11 +504,8 @@ command_process_relay_cell(cell_t *cell, channel_t *chan)
origin_circuit_t *ocirc = TO_ORIGIN_CIRCUIT(circ);
/* Count the payload bytes only. We don't care about cell headers */
- if (PREDICT_LIKELY(UINT32_MAX - ocirc->n_read_circ_bw >
- CELL_PAYLOAD_SIZE))
- ocirc->n_read_circ_bw += (int)CELL_PAYLOAD_SIZE;
- else
- ocirc->n_read_circ_bw = UINT32_MAX;
+ ocirc->n_read_circ_bw = tor_add_u32_nowrap(ocirc->n_read_circ_bw,
+ CELL_PAYLOAD_SIZE);
}
if (!CIRCUIT_IS_ORIGIN(circ) &&
diff --git a/src/or/relay.c b/src/or/relay.c
index d437204787..472e73b759 100644
--- a/src/or/relay.c
+++ b/src/or/relay.c
@@ -374,11 +374,8 @@ circuit_package_relay_cell(cell_t *cell, circuit_t *circ,
/* Update circ written totals for control port */
origin_circuit_t *ocirc = TO_ORIGIN_CIRCUIT(circ);
- if (PREDICT_LIKELY(UINT32_MAX - ocirc->n_written_circ_bw
- > CELL_PAYLOAD_SIZE))
- ocirc->n_written_circ_bw += (int)CELL_PAYLOAD_SIZE;
- else
- ocirc->n_written_circ_bw = UINT32_MAX;
+ ocirc->n_written_circ_bw = tor_add_u32_nowrap(ocirc->n_written_circ_bw,
+ CELL_PAYLOAD_SIZE);
} else { /* incoming cell */
if (CIRCUIT_IS_ORIGIN(circ)) {