cvs commit: src/sys/vfs/hammer hammer.h hammer_alist.c hammer_alist.h hammer_btree.c hammer_cursor.c hammer_cursor.h hammer_disk.h hammer_inode.c hammer_io.c hammer_object.c hammer_ondisk.c hammer_recover.c hammer_spike.c hammer_vfsops.c
Matthew Dillon
dillon at crater.dragonflybsd.org
Wed Jan 23 18:16:32 PST 2008
dillon 2008/01/23 18:14:45 PST
DragonFly src repository
Modified files:
sys/vfs/hammer hammer.h hammer_alist.c hammer_alist.h
hammer_btree.c hammer_cursor.c
hammer_cursor.h hammer_disk.h
hammer_inode.c hammer_io.c
hammer_object.c hammer_ondisk.c
hammer_recover.c hammer_spike.c
hammer_vfsops.c
Log:
HAMMER 23/many: Recovery, B-Tree, spike, I/O work.
Warning: filesystem structures have changed, recompile newfs_hammer too.
* Correct a couple more edge cases with historical lookups. We have to
flag the need for an iteration anywhere the edge case is hit as we
recurse down, not just on the terminal B-Tree node.
* Get rid of the kludge record buffer bitmap in the cluster header. Augment
the A-List recovery and scanning code to locate record buffers. This
required adding some unfortunate complexity to the A-list search and
recovery routines due to the fact that we ran out of bit codes and
couldn't represent an all-free/initialized AND an all-free/uninitialized
case.
* Go back to making the SPIKE_END elements range-inclusive instead of
range-exclusive. It turns out that making them range-exclusive caused
a few too many collisions with adjacent records in the B-Tree.
* Excellent progress on the recovery code. It still has numerous issues
(there are lots of recovery cases I still have to implement), but
it survives much longer now. Add a sysctl to disable/enable/force
cluster recovery (default disabled, since its still buggy).
* When creating a spike be sure to properly assign the cluster record's
rec_offset.
* When removing a spike be sure to also free the related cluster record.
* Spike code progress. Implement the last case it couldn't handle (spiking
a spike) and add a very simple starter heuristic which generates a
better spike topology (doesn't create long chains of end-range spikes).
* Add a huge number of new assertions to ease the tracking down of bugs.
* Address some IO sequencing issues that could result in io.modified
getting prematurely cleared. io.modified can only be cleared on write
initiation on the last ref to a HAMMER structure.
* Add a hack to pre-reserve enough B-Tree buffers to guarantee the recovery
code can regenerate the B-Tree without having to pack it. This ultimately
needs to be fixed (the recovery code really needs to pack the tree).
Revision Changes Path
1.28 +27 -4 src/sys/vfs/hammer/hammer.h
1.11 +142 -27 src/sys/vfs/hammer/hammer_alist.c
1.7 +11 -3 src/sys/vfs/hammer/hammer_alist.h
1.23 +291 -128 src/sys/vfs/hammer/hammer_btree.c
1.15 +21 -5 src/sys/vfs/hammer/hammer_cursor.c
1.10 +8 -0 src/sys/vfs/hammer/hammer_cursor.h
1.19 +18 -9 src/sys/vfs/hammer/hammer_disk.h
1.24 +3 -1 src/sys/vfs/hammer/hammer_inode.c
1.17 +70 -28 src/sys/vfs/hammer/hammer_io.c
1.23 +128 -32 src/sys/vfs/hammer/hammer_object.c
1.24 +165 -93 src/sys/vfs/hammer/hammer_ondisk.c
1.6 +189 -82 src/sys/vfs/hammer/hammer_recover.c
1.11 +157 -46 src/sys/vfs/hammer/hammer_spike.c
1.14 +3 -0 src/sys/vfs/hammer/hammer_vfsops.c
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer.h.diff?r1=1.27&r2=1.28&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer_alist.c.diff?r1=1.10&r2=1.11&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer_alist.h.diff?r1=1.6&r2=1.7&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer_btree.c.diff?r1=1.22&r2=1.23&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer_cursor.c.diff?r1=1.14&r2=1.15&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer_cursor.h.diff?r1=1.9&r2=1.10&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer_disk.h.diff?r1=1.18&r2=1.19&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer_inode.c.diff?r1=1.23&r2=1.24&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer_io.c.diff?r1=1.16&r2=1.17&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer_object.c.diff?r1=1.22&r2=1.23&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer_ondisk.c.diff?r1=1.23&r2=1.24&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer_recover.c.diff?r1=1.5&r2=1.6&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer_spike.c.diff?r1=1.10&r2=1.11&f=u
http://www.dragonflybsd.org/cvsweb/src/sys/vfs/hammer/hammer_vfsops.c.diff?r1=1.13&r2=1.14&f=u
More information about the Commits
mailing list