aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorRuss Cox <rsc@swtch.com>2007-08-23 19:02:35 -0400
committerRuss Cox <rsc@swtch.com>2007-08-23 19:02:35 -0400
commitdb1cda12aeacb3fde97b8a88120c9f8d1eaa7e44 (patch)
treed61666a66fca0c15707be3a718848357b8848a37 /src
parent2432b7b1e57ccc8d204ba99e004d6fb1e1093373 (diff)
downloadplan9port-db1cda12aeacb3fde97b8a88120c9f8d1eaa7e44.tar.gz
plan9port-db1cda12aeacb3fde97b8a88120c9f8d1eaa7e44.tar.bz2
plan9port-db1cda12aeacb3fde97b8a88120c9f8d1eaa7e44.zip
venti: seal arenas without bypassing dcache
Diffstat (limited to 'src')
-rw-r--r--src/cmd/venti/srv/arena.c21
1 files changed, 9 insertions, 12 deletions
diff --git a/src/cmd/venti/srv/arena.c b/src/cmd/venti/srv/arena.c
index cc3ac62c..7cd2eb73 100644
--- a/src/cmd/venti/srv/arena.c
+++ b/src/cmd/venti/srv/arena.c
@@ -65,7 +65,7 @@ initarena(Part *part, u64int base, u64int size, u32int blocksize)
}
if(arena->diskstats.sealed && scorecmp(zeroscore, arena->score)==0)
- backsumarena(arena);
+ sealarena(arena);
return arena;
}
@@ -516,6 +516,7 @@ sumarena(Arena *arena)
/*
* read & sum all blocks except the last one
*/
+ flushdcache();
memset(&s, 0, sizeof s);
b = alloczblock(bs, 0, arena->part->blocksize);
e = arena->base + arena->size;
@@ -551,24 +552,19 @@ ReadErr:
sha1(b->data, bs-VtScoreSize, nil, &s);
sha1(zeroscore, VtScoreSize, nil, &s);
sha1(nil, 0, score, &s);
-
+
/*
* check for no checksum or the same
- *
- * the writepart is okay because we flushed the dcache in sealarena
*/
- if(scorecmp(score, &b->data[bs - VtScoreSize]) != 0){
- if(scorecmp(zeroscore, &b->data[bs - VtScoreSize]) != 0)
- logerr(EOk, "overwriting mismatched checksums for arena=%s, found=%V calculated=%V",
- arena->name, &b->data[bs - VtScoreSize], score);
- scorecp(&b->data[bs - VtScoreSize], score);
- if(writepart(arena->part, e, b->data, bs) < 0)
- logerr(EOk, "sumarena can't write sum for %s: %r", arena->name);
- }
+ if(scorecmp(score, &b->data[bs - VtScoreSize]) != 0
+ && scorecmp(zeroscore, &b->data[bs - VtScoreSize]) != 0)
+ logerr(EOk, "overwriting mismatched checksums for arena=%s, found=%V calculated=%V",
+ arena->name, &b->data[bs - VtScoreSize], score);
freezblock(b);
qlock(&arena->lock);
scorecp(arena->score, score);
+ wbarena(arena);
qunlock(&arena->lock);
}
@@ -587,6 +583,7 @@ wbarena(Arena *arena)
}
dirtydblock(b, DirtyArenaTrailer);
bad = okarena(arena)<0 || packarena(arena, b->data)<0;
+ scorecp(b->data + arena->blocksize - VtScoreSize, arena->score);
putdblock(b);
if(bad)
return -1;