aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--changes/bug2230_part17
-rw-r--r--changes/bug2230_part25
-rw-r--r--src/or/microdesc.c6
3 files changed, 16 insertions, 2 deletions
diff --git a/changes/bug2230_part1 b/changes/bug2230_part1
new file mode 100644
index 0000000000..79f725410d
--- /dev/null
+++ b/changes/bug2230_part1
@@ -0,0 +1,7 @@
+ o Minor bugfixes
+ - When loading the microdesc journal, remember its current size.
+ In 0.2.2, this helps prevent the microdesc journal from growing
+ without limit on authorities (who are the only ones to use it in
+ 0.2.2). Fixes a part of bug 2230; bugfix on 0.2.2.6-alpha.
+ Fix posted by "cypherpunks."
+
diff --git a/changes/bug2230_part2 b/changes/bug2230_part2
new file mode 100644
index 0000000000..2664ecc1a0
--- /dev/null
+++ b/changes/bug2230_part2
@@ -0,0 +1,5 @@
+ o Minor bugfixes
+ - The microdesc journal is supposed to get rebuilt only if it is
+ at least _half_ the length of the store, not _twice_ the length
+ of the store. Bugfix on 0.2.2.6-alpha; fixes part of bug 2230.
+
diff --git a/src/or/microdesc.c b/src/or/microdesc.c
index 469c2fcadb..521ee07091 100644
--- a/src/or/microdesc.c
+++ b/src/or/microdesc.c
@@ -246,9 +246,10 @@ microdescs_add_list_to_cache(microdesc_cache_t *cache,
{
size_t old_content_len =
cache->cache_content ? cache->cache_content->size : 0;
- if ((cache->journal_len > 16384 + old_content_len &&
- cache->journal_len > old_content_len / 2))
+ if (cache->journal_len > 16384 + old_content_len &&
+ cache->journal_len > old_content_len / 2) {
microdesc_cache_rebuild(cache);
+ }
}
{
@@ -305,6 +306,7 @@ microdesc_cache_reload(microdesc_cache_t *cache)
journal_content = read_file_to_str(cache->journal_fname,
RFTS_IGNORE_MISSING, &st);
if (journal_content) {
+ cache->journal_len = (size_t) st.st_size;
added = microdescs_add_to_cache(cache, journal_content,
journal_content+st.st_size,
SAVED_IN_JOURNAL, 0, -1, NULL);