mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-10 23:29:46 +00:00
Merge branch 'for-linus-4.3' of git://git.kernel.org/pub/scm/linux/kernel/git/mason/linux-btrfs
Pull btrfs fixes from Chris Mason: "I have two more small fixes this week: Qu's fix avoids unneeded COW during fallocate, and Christian found a memory leak in the error handling of an earlier fix" * 'for-linus-4.3' of git://git.kernel.org/pub/scm/linux/kernel/git/mason/linux-btrfs: btrfs: fix possible leak in btrfs_ioctl_balance() btrfs: Avoid truncate tailing page if fallocate range doesn't exceed inode size
This commit is contained in:
commit
37902bc190
@ -2584,7 +2584,7 @@ static long btrfs_fallocate(struct file *file, int mode,
|
|||||||
alloc_start);
|
alloc_start);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto out;
|
goto out;
|
||||||
} else {
|
} else if (offset + len > inode->i_size) {
|
||||||
/*
|
/*
|
||||||
* If we are fallocating from the end of the file onward we
|
* If we are fallocating from the end of the file onward we
|
||||||
* need to zero out the end of the page if i_size lands in the
|
* need to zero out the end of the page if i_size lands in the
|
||||||
|
@ -4641,7 +4641,7 @@ locked:
|
|||||||
|
|
||||||
if (bctl->flags & ~(BTRFS_BALANCE_ARGS_MASK | BTRFS_BALANCE_TYPE_MASK)) {
|
if (bctl->flags & ~(BTRFS_BALANCE_ARGS_MASK | BTRFS_BALANCE_TYPE_MASK)) {
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
goto out_bargs;
|
goto out_bctl;
|
||||||
}
|
}
|
||||||
|
|
||||||
do_balance:
|
do_balance:
|
||||||
@ -4655,12 +4655,15 @@ do_balance:
|
|||||||
need_unlock = false;
|
need_unlock = false;
|
||||||
|
|
||||||
ret = btrfs_balance(bctl, bargs);
|
ret = btrfs_balance(bctl, bargs);
|
||||||
|
bctl = NULL;
|
||||||
|
|
||||||
if (arg) {
|
if (arg) {
|
||||||
if (copy_to_user(arg, bargs, sizeof(*bargs)))
|
if (copy_to_user(arg, bargs, sizeof(*bargs)))
|
||||||
ret = -EFAULT;
|
ret = -EFAULT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
out_bctl:
|
||||||
|
kfree(bctl);
|
||||||
out_bargs:
|
out_bargs:
|
||||||
kfree(bargs);
|
kfree(bargs);
|
||||||
out_unlock:
|
out_unlock:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user