[LogFS] Move reserved segments with journal
authorJoern Engel <joern@logfs.org>
Mon, 29 Mar 2010 19:13:28 +0000 (21:13 +0200)
committerJoern Engel <joern@logfs.org>
Mon, 29 Mar 2010 19:13:28 +0000 (21:13 +0200)
Fixes a GC livelock.

Signed-off-by: Joern Engel <joern@logfs.org>
fs/logfs/journal.c

index 15454ac7bd934a6e5a5a110e493de46e2a018493..25b1345c4652433655436be0b3f1f11707db1714 100644 (file)
@@ -800,6 +800,7 @@ void do_logfs_journal_wl_pass(struct super_block *sb)
 {
        struct logfs_super *super = logfs_super(sb);
        struct logfs_area *area = super->s_journal_area;
+       struct btree_head32 *head = &super->s_reserved_segments;
        u32 segno, ec;
        int i, err;
 
@@ -807,6 +808,7 @@ void do_logfs_journal_wl_pass(struct super_block *sb)
        /* Drop old segments */
        journal_for_each(i)
                if (super->s_journal_seg[i]) {
+                       btree_remove32(head, super->s_journal_seg[i]);
                        logfs_set_segment_unreserved(sb,
                                        super->s_journal_seg[i],
                                        super->s_journal_ec[i]);
@@ -819,6 +821,8 @@ void do_logfs_journal_wl_pass(struct super_block *sb)
                super->s_journal_seg[i] = segno;
                super->s_journal_ec[i] = ec;
                logfs_set_segment_reserved(sb, segno);
+               err = btree_insert32(head, segno, (void *)1, GFP_KERNEL);
+               BUG_ON(err); /* mempool should prevent this */
        }
        /* Manually move journal_area */
        freeseg(sb, area->a_segno);