diff options
author | Filipe David Borba Manana <fdmanana@gmail.com> | 2013-10-14 19:12:27 -0400 |
---|---|---|
committer | Chris Mason <chris.mason@fusionio.com> | 2013-11-11 22:02:26 -0500 |
commit | e8b0d724d596f2ac1264ad830a04ef8e415be956 (patch) | |
tree | ffe440a82656dc8d50b4234d497e8db7a31d47e0 /fs/btrfs/ctree.c | |
parent | e93ae26fe1123e9077e79cc7af8a0d42adf4812f (diff) |
Btrfs: fix btrfs_prev_leaf() previous key computation
If we decrement the key type, we must reset its offset to the largest
possible offset (u64)-1. If we decrement the key's objectid, then we
must reset the key's type and offset to their largest possible values,
(u8)-1 and (u64)-1 respectively. Not doing so can make us miss an
items in the tree.
Signed-off-by: Filipe David Borba Manana <fdmanana@gmail.com>
Signed-off-by: Josef Bacik <jbacik@fusionio.com>
Signed-off-by: Chris Mason <chris.mason@fusionio.com>
Diffstat (limited to 'fs/btrfs/ctree.c')
-rw-r--r-- | fs/btrfs/ctree.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/fs/btrfs/ctree.c b/fs/btrfs/ctree.c index 8f3d6f893585..a749121203df 100644 --- a/fs/btrfs/ctree.c +++ b/fs/btrfs/ctree.c | |||
@@ -4827,14 +4827,18 @@ static int btrfs_prev_leaf(struct btrfs_root *root, struct btrfs_path *path) | |||
4827 | 4827 | ||
4828 | btrfs_item_key_to_cpu(path->nodes[0], &key, 0); | 4828 | btrfs_item_key_to_cpu(path->nodes[0], &key, 0); |
4829 | 4829 | ||
4830 | if (key.offset > 0) | 4830 | if (key.offset > 0) { |
4831 | key.offset--; | 4831 | key.offset--; |
4832 | else if (key.type > 0) | 4832 | } else if (key.type > 0) { |
4833 | key.type--; | 4833 | key.type--; |
4834 | else if (key.objectid > 0) | 4834 | key.offset = (u64)-1; |
4835 | } else if (key.objectid > 0) { | ||
4835 | key.objectid--; | 4836 | key.objectid--; |
4836 | else | 4837 | key.type = (u8)-1; |
4838 | key.offset = (u64)-1; | ||
4839 | } else { | ||
4837 | return 1; | 4840 | return 1; |
4841 | } | ||
4838 | 4842 | ||
4839 | btrfs_release_path(path); | 4843 | btrfs_release_path(path); |
4840 | ret = btrfs_search_slot(NULL, root, &key, path, 0, 0); | 4844 | ret = btrfs_search_slot(NULL, root, &key, path, 0, 0); |