提交 7b9ea627 编写于 作者: S Shailendra Verma 提交者: David Sterba

btrfs: return early from failed memory allocations in ioctl handlers

There is no need to call kfree() if memdup_user() fails, as no memory
was allocated and the error in the error-valued pointer should be returned.
Signed-off-by: NShailendra Verma <shailendra.v@samsung.com>
[ edit subject ]
Signed-off-by: NDavid Sterba <dsterba@suse.com>
上级 58e8012c
...@@ -4569,11 +4569,8 @@ static long btrfs_ioctl_logical_to_ino(struct btrfs_root *root, ...@@ -4569,11 +4569,8 @@ static long btrfs_ioctl_logical_to_ino(struct btrfs_root *root,
return -EPERM; return -EPERM;
loi = memdup_user(arg, sizeof(*loi)); loi = memdup_user(arg, sizeof(*loi));
if (IS_ERR(loi)) { if (IS_ERR(loi))
ret = PTR_ERR(loi); return PTR_ERR(loi);
loi = NULL;
goto out;
}
path = btrfs_alloc_path(); path = btrfs_alloc_path();
if (!path) { if (!path) {
...@@ -5200,11 +5197,8 @@ static long btrfs_ioctl_set_received_subvol_32(struct file *file, ...@@ -5200,11 +5197,8 @@ static long btrfs_ioctl_set_received_subvol_32(struct file *file,
int ret = 0; int ret = 0;
args32 = memdup_user(arg, sizeof(*args32)); args32 = memdup_user(arg, sizeof(*args32));
if (IS_ERR(args32)) { if (IS_ERR(args32))
ret = PTR_ERR(args32); return PTR_ERR(args32);
args32 = NULL;
goto out;
}
args64 = kmalloc(sizeof(*args64), GFP_KERNEL); args64 = kmalloc(sizeof(*args64), GFP_KERNEL);
if (!args64) { if (!args64) {
...@@ -5252,11 +5246,8 @@ static long btrfs_ioctl_set_received_subvol(struct file *file, ...@@ -5252,11 +5246,8 @@ static long btrfs_ioctl_set_received_subvol(struct file *file,
int ret = 0; int ret = 0;
sa = memdup_user(arg, sizeof(*sa)); sa = memdup_user(arg, sizeof(*sa));
if (IS_ERR(sa)) { if (IS_ERR(sa))
ret = PTR_ERR(sa); return PTR_ERR(sa);
sa = NULL;
goto out;
}
ret = _btrfs_ioctl_set_received_subvol(file, sa); ret = _btrfs_ioctl_set_received_subvol(file, sa);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册