Commit e349fd3b authored by Josef Bacik's avatar Josef Bacik Committed by David Sterba

btrfs: make tree_search_for_insert return extent_state

We use this to search for an extent state, or return the nodes we need
to insert a new extent state.  This means we have the following pattern

node = tree_search_for_insert();
if (!node) {
	/* alloc and insert. */
	goto again;
}
state = rb_entry(node, struct extent_state, rb_node);

we don't use the node for anything else.  Making
tree_search_for_insert() return the extent_state means we can drop the
rb_node and clean this up by eliminating the rb_entry.
Signed-off-by: default avatarJosef Bacik <josef@toxicpanda.com>
Reviewed-by: default avatarDavid Sterba <dsterba@suse.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent aa852dab
...@@ -221,15 +221,15 @@ static inline struct extent_state *next_state(struct extent_state *state) ...@@ -221,15 +221,15 @@ static inline struct extent_state *next_state(struct extent_state *state)
* If no such entry exists, return pointer to entry that ends before @offset * If no such entry exists, return pointer to entry that ends before @offset
* and fill parameters @node_ret and @parent_ret, ie. does not return NULL. * and fill parameters @node_ret and @parent_ret, ie. does not return NULL.
*/ */
static inline struct rb_node *tree_search_for_insert(struct extent_io_tree *tree, static inline struct extent_state *tree_search_for_insert(struct extent_io_tree *tree,
u64 offset, u64 offset,
struct rb_node ***node_ret, struct rb_node ***node_ret,
struct rb_node **parent_ret) struct rb_node **parent_ret)
{ {
struct rb_root *root = &tree->state; struct rb_root *root = &tree->state;
struct rb_node **node = &root->rb_node; struct rb_node **node = &root->rb_node;
struct rb_node *prev = NULL; struct rb_node *prev = NULL;
struct extent_state *entry; struct extent_state *entry = NULL;
while (*node) { while (*node) {
prev = *node; prev = *node;
...@@ -240,7 +240,7 @@ static inline struct rb_node *tree_search_for_insert(struct extent_io_tree *tree ...@@ -240,7 +240,7 @@ static inline struct rb_node *tree_search_for_insert(struct extent_io_tree *tree
else if (offset > entry->end) else if (offset > entry->end)
node = &(*node)->rb_right; node = &(*node)->rb_right;
else else
return *node; return entry;
} }
if (node_ret) if (node_ret)
...@@ -249,12 +249,10 @@ static inline struct rb_node *tree_search_for_insert(struct extent_io_tree *tree ...@@ -249,12 +249,10 @@ static inline struct rb_node *tree_search_for_insert(struct extent_io_tree *tree
*parent_ret = prev; *parent_ret = prev;
/* Search neighbors until we find the first one past the end */ /* Search neighbors until we find the first one past the end */
while (prev && offset > entry->end) { while (entry && offset > entry->end)
prev = rb_next(prev); entry = next_state(entry);
entry = rb_entry(prev, struct extent_state, rb_node);
}
return prev; return entry;
} }
/* /*
...@@ -318,9 +316,7 @@ static inline struct rb_node *tree_search_prev_next(struct extent_io_tree *tree, ...@@ -318,9 +316,7 @@ static inline struct rb_node *tree_search_prev_next(struct extent_io_tree *tree,
*/ */
static inline struct extent_state *tree_search(struct extent_io_tree *tree, u64 offset) static inline struct extent_state *tree_search(struct extent_io_tree *tree, u64 offset)
{ {
struct rb_node *node = tree_search_for_insert(tree, offset, NULL, NULL); return tree_search_for_insert(tree, offset, NULL, NULL);
return (node) ? rb_entry(node, struct extent_state, rb_node) : NULL;
} }
static void extent_io_tree_panic(struct extent_io_tree *tree, int err) static void extent_io_tree_panic(struct extent_io_tree *tree, int err)
...@@ -970,7 +966,6 @@ int set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, u32 bits, ...@@ -970,7 +966,6 @@ int set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, u32 bits,
{ {
struct extent_state *state; struct extent_state *state;
struct extent_state *prealloc = NULL; struct extent_state *prealloc = NULL;
struct rb_node *node;
struct rb_node **p; struct rb_node **p;
struct rb_node *parent; struct rb_node *parent;
int err = 0; int err = 0;
...@@ -1000,17 +995,15 @@ int set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, u32 bits, ...@@ -1000,17 +995,15 @@ int set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, u32 bits,
if (cached_state && *cached_state) { if (cached_state && *cached_state) {
state = *cached_state; state = *cached_state;
if (state->start <= start && state->end > start && if (state->start <= start && state->end > start &&
extent_state_in_tree(state)) { extent_state_in_tree(state))
node = &state->rb_node;
goto hit_next; goto hit_next;
}
} }
/* /*
* This search will find all the extents that end after our range * This search will find all the extents that end after our range
* starts. * starts.
*/ */
node = tree_search_for_insert(tree, start, &p, &parent); state = tree_search_for_insert(tree, start, &p, &parent);
if (!node) { if (!state) {
prealloc = alloc_extent_state_atomic(prealloc); prealloc = alloc_extent_state_atomic(prealloc);
BUG_ON(!prealloc); BUG_ON(!prealloc);
prealloc->start = start; prealloc->start = start;
...@@ -1020,7 +1013,6 @@ int set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, u32 bits, ...@@ -1020,7 +1013,6 @@ int set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, u32 bits,
prealloc = NULL; prealloc = NULL;
goto out; goto out;
} }
state = rb_entry(node, struct extent_state, rb_node);
hit_next: hit_next:
last_start = state->start; last_start = state->start;
last_end = state->end; last_end = state->end;
...@@ -1205,7 +1197,6 @@ int convert_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, ...@@ -1205,7 +1197,6 @@ int convert_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,
{ {
struct extent_state *state; struct extent_state *state;
struct extent_state *prealloc = NULL; struct extent_state *prealloc = NULL;
struct rb_node *node;
struct rb_node **p; struct rb_node **p;
struct rb_node *parent; struct rb_node *parent;
int err = 0; int err = 0;
...@@ -1235,18 +1226,16 @@ int convert_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, ...@@ -1235,18 +1226,16 @@ int convert_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,
if (cached_state && *cached_state) { if (cached_state && *cached_state) {
state = *cached_state; state = *cached_state;
if (state->start <= start && state->end > start && if (state->start <= start && state->end > start &&
extent_state_in_tree(state)) { extent_state_in_tree(state))
node = &state->rb_node;
goto hit_next; goto hit_next;
}
} }
/* /*
* This search will find all the extents that end after our range * This search will find all the extents that end after our range
* starts. * starts.
*/ */
node = tree_search_for_insert(tree, start, &p, &parent); state = tree_search_for_insert(tree, start, &p, &parent);
if (!node) { if (!state) {
prealloc = alloc_extent_state_atomic(prealloc); prealloc = alloc_extent_state_atomic(prealloc);
if (!prealloc) { if (!prealloc) {
err = -ENOMEM; err = -ENOMEM;
...@@ -1259,7 +1248,6 @@ int convert_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, ...@@ -1259,7 +1248,6 @@ int convert_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,
prealloc = NULL; prealloc = NULL;
goto out; goto out;
} }
state = rb_entry(node, struct extent_state, rb_node);
hit_next: hit_next:
last_start = state->start; last_start = state->start;
last_end = state->end; last_end = state->end;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment