mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-17 22:05:08 +00:00
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:
parent
77ab86bf1c
commit
21e75ffe3c
@ -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 (!path) {
|
|
||||||
ret = -ENOMEM;
|
|
||||||
goto fail;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (block_group) {
|
if (block_group) {
|
||||||
|
struct btrfs_path *path = btrfs_alloc_path();
|
||||||
|
|
||||||
|
if (!path) {
|
||||||
|
ret = -ENOMEM;
|
||||||
|
goto fail;
|
||||||
|
}
|
||||||
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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user