root->node->count++;
ret = btrfs_drop_snapshot(root, snap);
BUG_ON(ret);
- tree_block_release(root, snap);
+ // tree_block_release(root, snap);
}
write_ctree_super(root, s);
btrfs_finish_extent_commit(root);
}
BUG_ON(ret);
next = read_tree_block(root, blocknr);
- if (path->nodes[*level-1]) {
+ if (path->nodes[*level-1])
tree_block_release(root, path->nodes[*level-1]);
- }
path->nodes[*level-1] = next;
*level = node_level(next->node.header.flags);
path->slots[*level] = 0;
}
out:
ret = free_extent(root, path->nodes[*level]->blocknr, 1);
+ tree_block_release(root, path->nodes[*level]);
path->nodes[*level] = NULL;
*level += 1;
BUG_ON(ret);
} else {
ret = free_extent(root,
path->nodes[*level]->blocknr, 1);
+ tree_block_release(root, path->nodes[*level]);
+ path->nodes[*level] = NULL;
*level = i + 1;
BUG_ON(ret);
}
if (ret > 0)
break;
}
- for (i = 0; i < orig_level; i++) {
- if (path.nodes[i])
+ for (i = 0; i <= orig_level; i++) {
+ if (path.nodes[i]) {
tree_block_release(root, path.nodes[i]);
+ }
}
return 0;