summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2006-12-17 16:37:46 +0000
committerNick Mathewson <nickm@torproject.org>2006-12-17 16:37:46 +0000
commit952b34d610bdcbe56b25a3af734a0ae32f9f10e7 (patch)
tree88f0205209199a706dae5763235d6896d4efcaa4
parent06914b5e00023ae88368461f3cfd1c2b1e12f834 (diff)
downloadtor-952b34d610bdcbe56b25a3af734a0ae32f9f10e7.tar.gz
tor-952b34d610bdcbe56b25a3af734a0ae32f9f10e7.zip
r11627@Kushana: nickm | 2006-12-17 11:37:39 -0500
Remove an artificial upper bound on expected bandwidth. More immediately, fix a VC warning. svn:r9146
-rw-r--r--ChangeLog3
-rw-r--r--src/or/hibernate.c15
2 files changed, 12 insertions, 6 deletions
diff --git a/ChangeLog b/ChangeLog
index 35cf67e35d..0c526dc1f5 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -56,6 +56,9 @@ Changes in version 0.1.2.5-xxxx - 200?-??-??
- Routers no longer ever list themselves in their "family" line,
even if configured to do so. This makes it easier to configure
family lists efficiently.
+ - Remove an artificial (but quite high) restriction on expected
+ bandwidth, so that accounting won't break once we all have gigabit
+ connections to our homes.
o Controller features:
- Have GETINFO dir/status/* work on hosts with DirPort disabled.
diff --git a/src/or/hibernate.c b/src/or/hibernate.c
index 9a1d808572..2be95cb3c4 100644
--- a/src/or/hibernate.c
+++ b/src/or/hibernate.c
@@ -82,7 +82,7 @@ static time_t interval_end_time = 0;
static time_t interval_wakeup_time = 0;
/** How much bandwidth do we 'expect' to use per minute? (0 if we have no
* info from the last period.) */
-static uint32_t expected_bandwidth_usage = 0;
+static uint64_t expected_bandwidth_usage = 0;
/** What unit are we using for our accounting? */
static time_unit_t cfg_unit = UNIT_MONTH;
/** How many days,hours,minutes into each unit does our accounting interval
@@ -366,9 +366,7 @@ update_expected_bandwidth(void)
if (expected > max_configured)
expected = max_configured;
}
- if (expected > UINT32_MAX)
- expected = UINT32_MAX;
- expected_bandwidth_usage = (uint32_t) expected;
+ expected_bandwidth_usage = expected;
}
/** Called at the start of a new accounting interval: reset our
@@ -545,6 +543,7 @@ accounting_record_bandwidth_usage(time_t now, or_state_t *state)
char *cp = buf;
time_t tmp;
int r;
+ uint64_t expected;
/* First, update bw_accounting. Until 0.1.2.5-x, this was the only place
* we stored this information. The format is:
@@ -558,6 +557,10 @@ accounting_record_bandwidth_usage(time_t now, or_state_t *state)
log_warn(LD_ACCT, "Created a time that we refused to parse.");
return -1;
}
+ expected = expected_bandwidth_usage;
+ /* Cap this value, since older versions won't parse a uint64_t here. */
+ if (expected > UINT32_MAX)
+ expected = UINT32_MAX;
tor_snprintf(cp, sizeof(buf),
"%d\n%s\n%s\n"U64_FORMAT"\n"U64_FORMAT"\n%lu\n%lu\n",
BW_ACCOUNTING_VERSION,
@@ -566,7 +569,7 @@ accounting_record_bandwidth_usage(time_t now, or_state_t *state)
U64_PRINTF_ARG(ROUND_UP(n_bytes_read_in_interval)),
U64_PRINTF_ARG(ROUND_UP(n_bytes_written_in_interval)),
(unsigned long)n_seconds_active_in_interval,
- (unsigned long)expected_bandwidth_usage);
+ (unsigned long)expected);
tor_snprintf(fname, sizeof(fname), "%s/bw_accounting",
get_options()->DataDirectory);
r = write_str_to_file(fname, buf, 0);
@@ -685,7 +688,7 @@ read_bandwidth_usage(void)
(char*)smartlist_get(elts,2),
(char*)smartlist_get(elts,1),
(unsigned long)n_seconds_active_in_interval,
- (unsigned long)((uint64_t)expected_bandwidth_usage*1024/60),
+ (unsigned long)(expected_bandwidth_usage*1024/60),
U64_PRINTF_ARG(n_bytes_read_in_interval),
U64_PRINTF_ARG(n_bytes_written_in_interval));