Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 7a5d24b1 authored by Chris Mason's avatar Chris Mason
Browse files

Merge branch 'master' of...

parents ebfee3d7 3a1abec9
Loading
Loading
Loading
Loading
+9 −4
Original line number Original line Diff line number Diff line
@@ -5802,23 +5802,23 @@ static int prealloc_file_range(struct inode *inode, u64 start, u64 end,
	while (num_bytes > 0) {
	while (num_bytes > 0) {
		alloc_size = min(num_bytes, root->fs_info->max_extent);
		alloc_size = min(num_bytes, root->fs_info->max_extent);


		trans = btrfs_start_transaction(root, 1);

		ret = btrfs_reserve_extent(trans, root, alloc_size,
		ret = btrfs_reserve_extent(trans, root, alloc_size,
					   root->sectorsize, 0, alloc_hint,
					   root->sectorsize, 0, alloc_hint,
					   (u64)-1, &ins, 1);
					   (u64)-1, &ins, 1);
		if (ret) {
		if (ret) {
			WARN_ON(1);
			WARN_ON(1);
			break;
			goto stop_trans;
		}
		}


		ret = btrfs_reserve_metadata_space(root, 3);
		ret = btrfs_reserve_metadata_space(root, 3);
		if (ret) {
		if (ret) {
			btrfs_free_reserved_extent(root, ins.objectid,
			btrfs_free_reserved_extent(root, ins.objectid,
						   ins.offset);
						   ins.offset);
			break;
			goto stop_trans;
		}
		}


		trans = btrfs_start_transaction(root, 1);

		ret = insert_reserved_file_extent(trans, inode,
		ret = insert_reserved_file_extent(trans, inode,
						  cur_offset, ins.objectid,
						  cur_offset, ins.objectid,
						  ins.offset, ins.offset,
						  ins.offset, ins.offset,
@@ -5847,6 +5847,11 @@ static int prealloc_file_range(struct inode *inode, u64 start, u64 end,
		btrfs_unreserve_metadata_space(root, 3);
		btrfs_unreserve_metadata_space(root, 3);
	}
	}
	return ret;
	return ret;

stop_trans:
	btrfs_end_transaction(trans, root);
	return ret;

}
}


static long btrfs_fallocate(struct inode *inode, int mode,
static long btrfs_fallocate(struct inode *inode, int mode,