Commit 214e61d0 authored by Nikolay Borisov's avatar Nikolay Borisov Committed by David Sterba

btrfs: perform data management operations outside of inode lock

btrfs_alloc_data_chunk_ondemand and btrfs_free_reserved_data_space_noquota
don't really use the guts of the inodes being passed to them. This
implies it's not required to call them under extent lock. Move code
around in prealloc_file_extent_cluster to do the heavy, data alloc/free
operations outside of the lock. This also makes the 'out' label
unnecessary, so remove it.
Reviewed-by: default avatarJohannes Thumshirn <johannes.thumshirn@wdc.com>
Signed-off-by: default avatarNikolay Borisov <nborisov@suse.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent c171edd5
...@@ -2584,17 +2584,15 @@ int prealloc_file_extent_cluster(struct inode *inode, ...@@ -2584,17 +2584,15 @@ int prealloc_file_extent_cluster(struct inode *inode,
int ret = 0; int ret = 0;
u64 prealloc_start = cluster->start - offset; u64 prealloc_start = cluster->start - offset;
u64 prealloc_end = cluster->end - offset; u64 prealloc_end = cluster->end - offset;
u64 cur_offset; u64 cur_offset = prealloc_start;
BUG_ON(cluster->start != cluster->boundary[0]); BUG_ON(cluster->start != cluster->boundary[0]);
inode_lock(inode);
ret = btrfs_alloc_data_chunk_ondemand(BTRFS_I(inode), ret = btrfs_alloc_data_chunk_ondemand(BTRFS_I(inode),
prealloc_end + 1 - prealloc_start); prealloc_end + 1 - prealloc_start);
if (ret) if (ret)
goto out; return ret;
cur_offset = prealloc_start; inode_lock(inode);
while (nr < cluster->nr) { while (nr < cluster->nr) {
start = cluster->boundary[nr] - offset; start = cluster->boundary[nr] - offset;
if (nr + 1 < cluster->nr) if (nr + 1 < cluster->nr)
...@@ -2613,11 +2611,11 @@ int prealloc_file_extent_cluster(struct inode *inode, ...@@ -2613,11 +2611,11 @@ int prealloc_file_extent_cluster(struct inode *inode,
break; break;
nr++; nr++;
} }
inode_unlock(inode);
if (cur_offset < prealloc_end) if (cur_offset < prealloc_end)
btrfs_free_reserved_data_space_noquota(inode, btrfs_free_reserved_data_space_noquota(inode,
prealloc_end + 1 - cur_offset); prealloc_end + 1 - cur_offset);
out:
inode_unlock(inode);
return ret; return ret;
} }
......
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