btrfs: btrfs_truncate_free_space_cache always allocates path

btrfs_truncate_free_space_cache always allocates a btrfs_path structure
but only uses it when the caller passes a block group.  Let's move the
allocation and free into the conditional.

Signed-off-by: Jeff Mahoney <jeffm@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
Jeff Mahoney 2017-02-15 16:28:32 -05:00 committed by David Sterba
parent 77ab86bf1c
commit 21e75ffe3c

View File

@ -232,15 +232,15 @@ int btrfs_truncate_free_space_cache(struct btrfs_trans_handle *trans,
{ {
struct btrfs_root *root = BTRFS_I(inode)->root; struct btrfs_root *root = BTRFS_I(inode)->root;
int ret = 0; int ret = 0;
struct btrfs_path *path = btrfs_alloc_path();
bool locked = false; bool locked = false;
if (block_group) {
struct btrfs_path *path = btrfs_alloc_path();
if (!path) { if (!path) {
ret = -ENOMEM; ret = -ENOMEM;
goto fail; goto fail;
} }
if (block_group) {
locked = true; locked = true;
mutex_lock(&trans->transaction->cache_write_mutex); mutex_lock(&trans->transaction->cache_write_mutex);
if (!list_empty(&block_group->io_list)) { if (!list_empty(&block_group->io_list)) {
@ -257,8 +257,8 @@ int btrfs_truncate_free_space_cache(struct btrfs_trans_handle *trans,
spin_lock(&block_group->lock); spin_lock(&block_group->lock);
block_group->disk_cache_state = BTRFS_DC_CLEAR; block_group->disk_cache_state = BTRFS_DC_CLEAR;
spin_unlock(&block_group->lock); spin_unlock(&block_group->lock);
}
btrfs_free_path(path); btrfs_free_path(path);
}
btrfs_i_size_write(inode, 0); btrfs_i_size_write(inode, 0);
truncate_pagecache(inode, 0); truncate_pagecache(inode, 0);