|
@@ -4159,6 +4159,9 @@ static noinline int push_for_double_split(struct btrfs_trans_handle *trans,
|
|
|
|
|
|
/* try to push all the items before our slot into the next leaf */
|
|
|
slot = path->slots[0];
|
|
|
+ space_needed = data_size;
|
|
|
+ if (slot > 0)
|
|
|
+ space_needed -= btrfs_leaf_free_space(fs_info, path->nodes[0]);
|
|
|
ret = push_leaf_left(trans, root, path, 1, space_needed, 0, slot);
|
|
|
if (ret < 0)
|
|
|
return ret;
|
|
@@ -4214,6 +4217,10 @@ static noinline int split_leaf(struct btrfs_trans_handle *trans,
|
|
|
if (wret < 0)
|
|
|
return wret;
|
|
|
if (wret) {
|
|
|
+ space_needed = data_size;
|
|
|
+ if (slot > 0)
|
|
|
+ space_needed -= btrfs_leaf_free_space(fs_info,
|
|
|
+ l);
|
|
|
wret = push_leaf_left(trans, root, path, space_needed,
|
|
|
space_needed, 0, (u32)-1);
|
|
|
if (wret < 0)
|