aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fs/btrfs/ctree.c16
-rw-r--r--fs/btrfs/extent-tree.c47
2 files changed, 44 insertions, 19 deletions
diff --git a/fs/btrfs/ctree.c b/fs/btrfs/ctree.c
index c8529b394d5f..bbb632291709 100644
--- a/fs/btrfs/ctree.c
+++ b/fs/btrfs/ctree.c
@@ -34,7 +34,7 @@ void btrfs_release_path(struct btrfs_root *root, struct btrfs_path *p)
34 memset(p, 0, sizeof(*p)); 34 memset(p, 0, sizeof(*p));
35} 35}
36 36
37int btrfs_cow_block(struct btrfs_root *root, 37static int btrfs_cow_block(struct btrfs_root *root,
38 struct btrfs_buffer *buf, 38 struct btrfs_buffer *buf,
39 struct btrfs_buffer *parent, 39 struct btrfs_buffer *parent,
40 int parent_slot, 40 int parent_slot,
@@ -96,7 +96,7 @@ int btrfs_leaf_free_space(struct btrfs_leaf *leaf)
96/* 96/*
97 * compare two keys in a memcmp fashion 97 * compare two keys in a memcmp fashion
98 */ 98 */
99int comp_keys(struct btrfs_disk_key *disk, struct btrfs_key *k2) 99static int comp_keys(struct btrfs_disk_key *disk, struct btrfs_key *k2)
100{ 100{
101 struct btrfs_key k1; 101 struct btrfs_key k1;
102 102
@@ -117,7 +117,7 @@ int comp_keys(struct btrfs_disk_key *disk, struct btrfs_key *k2)
117 return 0; 117 return 0;
118} 118}
119 119
120int check_node(struct btrfs_path *path, int level) 120static int check_node(struct btrfs_path *path, int level)
121{ 121{
122 int i; 122 int i;
123 struct btrfs_node *parent = NULL; 123 struct btrfs_node *parent = NULL;
@@ -146,7 +146,7 @@ int check_node(struct btrfs_path *path, int level)
146 return 0; 146 return 0;
147} 147}
148 148
149int check_leaf(struct btrfs_path *path, int level) 149static int check_leaf(struct btrfs_path *path, int level)
150{ 150{
151 int i; 151 int i;
152 struct btrfs_leaf *leaf = &path->nodes[level]->leaf; 152 struct btrfs_leaf *leaf = &path->nodes[level]->leaf;
@@ -186,7 +186,7 @@ int check_leaf(struct btrfs_path *path, int level)
186 return 0; 186 return 0;
187} 187}
188 188
189int check_block(struct btrfs_path *path, int level) 189static int check_block(struct btrfs_path *path, int level)
190{ 190{
191 if (level == 0) 191 if (level == 0)
192 return check_leaf(path, level); 192 return check_leaf(path, level);
@@ -202,7 +202,7 @@ int check_block(struct btrfs_path *path, int level)
202 * 202 *
203 * slot may point to max if the key is bigger than all of the keys 203 * slot may point to max if the key is bigger than all of the keys
204 */ 204 */
205int generic_bin_search(char *p, int item_size, struct btrfs_key *key, 205static int generic_bin_search(char *p, int item_size, struct btrfs_key *key,
206 int max, int *slot) 206 int max, int *slot)
207{ 207{
208 int low = 0; 208 int low = 0;
@@ -233,7 +233,7 @@ int generic_bin_search(char *p, int item_size, struct btrfs_key *key,
233 * simple bin_search frontend that does the right thing for 233 * simple bin_search frontend that does the right thing for
234 * leaves vs nodes 234 * leaves vs nodes
235 */ 235 */
236int bin_search(struct btrfs_node *c, struct btrfs_key *key, int *slot) 236static int bin_search(struct btrfs_node *c, struct btrfs_key *key, int *slot)
237{ 237{
238 if (btrfs_is_leaf(c)) { 238 if (btrfs_is_leaf(c)) {
239 struct btrfs_leaf *l = (struct btrfs_leaf *)c; 239 struct btrfs_leaf *l = (struct btrfs_leaf *)c;
@@ -250,7 +250,7 @@ int bin_search(struct btrfs_node *c, struct btrfs_key *key, int *slot)
250 return -1; 250 return -1;
251} 251}
252 252
253struct btrfs_buffer *read_node_slot(struct btrfs_root *root, 253static struct btrfs_buffer *read_node_slot(struct btrfs_root *root,
254 struct btrfs_buffer *parent_buf, 254 struct btrfs_buffer *parent_buf,
255 int slot) 255 int slot)
256{ 256{
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c
index 4a4f2d810d9f..a6969538bca2 100644
--- a/fs/btrfs/extent-tree.c
+++ b/fs/btrfs/extent-tree.c
@@ -365,8 +365,9 @@ error:
365 * 365 *
366 * returns 0 if everything worked, non-zero otherwise. 366 * returns 0 if everything worked, non-zero otherwise.
367 */ 367 */
368int alloc_extent(struct btrfs_root *root, u64 num_blocks, u64 search_start, 368static int alloc_extent(struct btrfs_root *root, u64 num_blocks,
369 u64 search_end, u64 owner, struct btrfs_key *ins) 369 u64 search_start, u64 search_end, u64 owner,
370 struct btrfs_key *ins)
370{ 371{
371 int ret; 372 int ret;
372 int pending_ret; 373 int pending_ret;
@@ -425,7 +426,12 @@ struct btrfs_buffer *btrfs_alloc_free_block(struct btrfs_root *root)
425 return buf; 426 return buf;
426} 427}
427 428
428int walk_down_tree(struct btrfs_root *root, struct btrfs_path *path, int *level) 429/*
430 * helper function for drop_snapshot, this walks down the tree dropping ref
431 * counts as it goes.
432 */
433static int walk_down_tree(struct btrfs_root *root,
434 struct btrfs_path *path, int *level)
429{ 435{
430 struct btrfs_buffer *next; 436 struct btrfs_buffer *next;
431 struct btrfs_buffer *cur; 437 struct btrfs_buffer *cur;
@@ -437,6 +443,9 @@ int walk_down_tree(struct btrfs_root *root, struct btrfs_path *path, int *level)
437 BUG_ON(ret); 443 BUG_ON(ret);
438 if (refs > 1) 444 if (refs > 1)
439 goto out; 445 goto out;
446 /*
447 * walk down to the last node level and free all the leaves
448 */
440 while(*level > 0) { 449 while(*level > 0) {
441 cur = path->nodes[*level]; 450 cur = path->nodes[*level];
442 if (path->slots[*level] >= 451 if (path->slots[*level] >=
@@ -467,7 +476,13 @@ out:
467 return 0; 476 return 0;
468} 477}
469 478
470int walk_up_tree(struct btrfs_root *root, struct btrfs_path *path, int *level) 479/*
480 * helper for dropping snapshots. This walks back up the tree in the path
481 * to find the first node higher up where we haven't yet gone through
482 * all the slots
483 */
484static int walk_up_tree(struct btrfs_root *root, struct btrfs_path *path,
485 int *level)
471{ 486{
472 int i; 487 int i;
473 int slot; 488 int slot;
@@ -491,9 +506,15 @@ int walk_up_tree(struct btrfs_root *root, struct btrfs_path *path, int *level)
491 return 1; 506 return 1;
492} 507}
493 508
509/*
510 * drop the reference count on the tree rooted at 'snap'. This traverses
511 * the tree freeing any blocks that have a ref count of zero after being
512 * decremented.
513 */
494int btrfs_drop_snapshot(struct btrfs_root *root, struct btrfs_buffer *snap) 514int btrfs_drop_snapshot(struct btrfs_root *root, struct btrfs_buffer *snap)
495{ 515{
496 int ret; 516 int ret = 0;;
517 int wret;
497 int level; 518 int level;
498 struct btrfs_path path; 519 struct btrfs_path path;
499 int i; 520 int i;
@@ -506,18 +527,22 @@ int btrfs_drop_snapshot(struct btrfs_root *root, struct btrfs_buffer *snap)
506 path.nodes[level] = snap; 527 path.nodes[level] = snap;
507 path.slots[level] = 0; 528 path.slots[level] = 0;
508 while(1) { 529 while(1) {
509 ret = walk_down_tree(root, &path, &level); 530 wret = walk_down_tree(root, &path, &level);
510 if (ret > 0) 531 if (wret > 0)
511 break; 532 break;
512 ret = walk_up_tree(root, &path, &level); 533 if (wret < 0)
513 if (ret > 0) 534 ret = wret;
535
536 wret = walk_up_tree(root, &path, &level);
537 if (wret > 0)
514 break; 538 break;
539 if (wret < 0)
540 ret = wret;
515 } 541 }
516 for (i = 0; i <= orig_level; i++) { 542 for (i = 0; i <= orig_level; i++) {
517 if (path.nodes[i]) { 543 if (path.nodes[i]) {
518 btrfs_block_release(root, path.nodes[i]); 544 btrfs_block_release(root, path.nodes[i]);
519 } 545 }
520 } 546 }
521 547 return ret;
522 return 0;
523} 548}