summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog1
-rw-r--r--doc/TODO2
-rw-r--r--src/or/circuitbuild.c7
-rw-r--r--src/or/hibernate.c12
-rw-r--r--src/or/rephist.c10
-rw-r--r--src/or/router.c4
6 files changed, 25 insertions, 11 deletions
diff --git a/ChangeLog b/ChangeLog
index 32c5cd05d0..fd2081f5b0 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -43,6 +43,7 @@ Changes in version 0.1.2.5-xxxx - 200?-??-??
dirserver has given us a 503, we try not to use it until an hour
has gone by, or until we have no dirservers that haven't given us
a 503.
+ - The state file gets saved less often when AvoidDiskWrites is set.
o Security bugfixes:
- Stop sending the HttpProxyAuthenticator string to directory
diff --git a/doc/TODO b/doc/TODO
index 4267b68856..ab53436809 100644
--- a/doc/TODO
+++ b/doc/TODO
@@ -154,7 +154,7 @@ Nd- Have a mode that doesn't write to disk much, so we can run Tor on
flash memory (e.g. Linksys routers or USB keys).
o Add AvoidDiskWrites config option.
. only write state file when it's "changed"
- - crank up the numbers if avoiddiskwrites is on.
+ o crank up the numbers if avoiddiskwrites is on.
- some things may not want to get written at all.
- stop writing identity key / fingerprint / etc every restart
- more?
diff --git a/src/or/circuitbuild.c b/src/or/circuitbuild.c
index 5de96f670e..38135fb476 100644
--- a/src/or/circuitbuild.c
+++ b/src/or/circuitbuild.c
@@ -2412,10 +2412,12 @@ entry_guards_parse_state(or_state_t *state, int set, char **msg)
static void
entry_guards_changed(void)
{
+ time_t when;
entry_guards_dirty = 1;
/* or_state_save() will call entry_guards_update_state(). */
- or_state_mark_dirty(get_or_state(), time(NULL)+600);
+ when = get_options()->AvoidDiskWrites ? time(NULL) + 3600 : time(NULL)+600;
+ or_state_mark_dirty(get_or_state(), when);
}
/** If the entry guard info has not changed, do nothing and return.
@@ -2466,7 +2468,8 @@ entry_guards_update_state(or_state_t *state)
next = &(line->next);
}
});
- or_state_mark_dirty(get_or_state(), 0);
+ if (!get_options()->AvoidDiskWrites)
+ or_state_mark_dirty(get_or_state(), 0);
entry_guards_dirty = 0;
}
diff --git a/src/or/hibernate.c b/src/or/hibernate.c
index 2be95cb3c4..65ad4c80f3 100644
--- a/src/or/hibernate.c
+++ b/src/or/hibernate.c
@@ -581,7 +581,9 @@ accounting_record_bandwidth_usage(time_t now, or_state_t *state)
ROUND_UP(n_bytes_written_in_interval);
state->AccountingSecondsActive = n_seconds_active_in_interval;
state->AccountingExpectedUsage = expected_bandwidth_usage;
- or_state_mark_dirty(state, now+60);
+
+ or_state_mark_dirty(state,
+ now+(get_options()->AvoidDiskWrites ? 7200 : 60));
return r;
}
@@ -767,7 +769,9 @@ hibernate_begin(int new_state, time_t now)
hibernate_state = new_state;
accounting_record_bandwidth_usage(now, get_or_state());
- or_state_mark_dirty(get_or_state(), 0);
+
+ or_state_mark_dirty(get_or_state(),
+ get_options()->AvoidDiskWrites ? now+600 : 0);
}
/** Called when we've been hibernating and our timeout is reached. */
@@ -835,7 +839,9 @@ hibernate_go_dormant(time_t now)
}
accounting_record_bandwidth_usage(now, get_or_state());
- or_state_mark_dirty(get_or_state(), 0);
+
+ or_state_mark_dirty(get_or_state(),
+ get_options()->AvoidDiskWrites ? now+600 : 0);
}
/** Called when hibernate_end_time has arrived. */
diff --git a/src/or/rephist.c b/src/or/rephist.c
index c30583fe58..7b13d124bc 100644
--- a/src/or/rephist.c
+++ b/src/or/rephist.c
@@ -669,8 +669,11 @@ rep_hist_update_state(or_state_t *state)
* force these values to the defaults. */
/* FFFF we should pull the default out of config.c's state table,
* so we don't have two defaults. */
- if (*s_begins != 0 || *s_interval != 900)
- or_state_mark_dirty(get_or_state(), time(NULL)+600);
+ if (*s_begins != 0 || *s_interval != 900) {
+ time_t now = time(NULL);
+ time_t save_at = get_options()->AvoidDiskWrites ? now+3600 : now+600;
+ or_state_mark_dirty(state, save_at);
+ }
*s_begins = 0;
*s_interval = 900;
*s_values = smartlist_create();
@@ -687,8 +690,9 @@ rep_hist_update_state(or_state_t *state)
smartlist_split_string(*s_values, buf, ",", SPLIT_SKIP_SPACE, 0);
}
tor_free(buf);
- if (server_mode(get_options()))
+ if (server_mode(get_options())) {
or_state_mark_dirty(get_or_state(), time(NULL)+(2*3600));
+ }
}
/** Set bandwidth history from our saved state. */
diff --git a/src/or/router.c b/src/or/router.c
index a69cd180e3..a435842056 100644
--- a/src/or/router.c
+++ b/src/or/router.c
@@ -156,7 +156,7 @@ rotate_onion_key(void)
state->LastRotatedOnionKey = onionkey_set_at = now;
tor_mutex_release(key_lock);
mark_my_descriptor_dirty();
- or_state_mark_dirty(state, 0);
+ or_state_mark_dirty(state, get_options()->AvoidDiskWrites ? now+3600 : 0);
return;
error:
log_warn(LD_GENERAL, "Couldn't rotate onion key.");
@@ -308,7 +308,7 @@ init_keys(void)
* start the clock ticking now so that we will eventually rotate it even
* if we don't stay up for a full MIN_ONION_KEY_LIFETIME. */
state->LastRotatedOnionKey = time(NULL);
- or_state_mark_dirty(state, 0);
+ or_state_mark_dirty(state, options->AvoidDiskWrites ? time(NULL)+3600 : 0);
}
tor_snprintf(keydir,sizeof(keydir),"%s/keys/secret_onion_key.old",datadir);