From: Chris Mason Date: Fri, 4 Jan 2008 14:34:54 +0000 (-0500) Subject: Properly call btrfs_search_slot while shrinking X-Git-Tag: v2.6.29-rc1~27^2~9^2~55^2~56^2~30^2~353 X-Git-Url: http://pilppa.com/gitweb/?a=commitdiff_plain;h=1372f8e609d260c2352bf74e125614eef7aee8ef;p=linux-2.6-omap-h63xx.git Properly call btrfs_search_slot while shrinking The shrinking code used btrfs_next_leaf to find the next item, but this does not cow the blocks it touches. This fix calls search_slot after finding the next item to do appropriate cow and balancing. Signed-off-by: Chris Mason --- diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index 426a0222e12..c390fd847a2 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c @@ -2434,7 +2434,15 @@ bg_next: break; } leaf = path->nodes[0]; - nritems = btrfs_header_nritems(leaf); + btrfs_item_key_to_cpu(leaf, &found_key, path->slots[0]); + + /* + * btrfs_next_leaf doesn't cow buffers, we have to + * do the search again + */ + memcpy(&key, &found_key, sizeof(key)); + btrfs_release_path(root, path); + continue; } btrfs_item_key_to_cpu(leaf, &found_key, path->slots[0]);