forked from Minki/linux
btrfs: allocate btrfs_ioctl_quota_rescan_args on stack
Instead of using kmalloc() to allocate btrfs_ioctl_quota_rescan_args, allocate btrfs_ioctl_quota_rescan_args on stack, the size is reasonably small and ioctls are called in process context. sizeof(btrfs_ioctl_quota_rescan_args) = 64 Reviewed-by: Anand Jain <anand.jain@oracle.com> Signed-off-by: Goldwyn Rodrigues <rgoldwyn@suse.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
parent
98caf9531e
commit
0afb603afc
@ -4403,25 +4403,20 @@ drop_write:
|
||||
static long btrfs_ioctl_quota_rescan_status(struct btrfs_fs_info *fs_info,
|
||||
void __user *arg)
|
||||
{
|
||||
struct btrfs_ioctl_quota_rescan_args *qsa;
|
||||
struct btrfs_ioctl_quota_rescan_args qsa = {0};
|
||||
int ret = 0;
|
||||
|
||||
if (!capable(CAP_SYS_ADMIN))
|
||||
return -EPERM;
|
||||
|
||||
qsa = kzalloc(sizeof(*qsa), GFP_KERNEL);
|
||||
if (!qsa)
|
||||
return -ENOMEM;
|
||||
|
||||
if (fs_info->qgroup_flags & BTRFS_QGROUP_STATUS_FLAG_RESCAN) {
|
||||
qsa->flags = 1;
|
||||
qsa->progress = fs_info->qgroup_rescan_progress.objectid;
|
||||
qsa.flags = 1;
|
||||
qsa.progress = fs_info->qgroup_rescan_progress.objectid;
|
||||
}
|
||||
|
||||
if (copy_to_user(arg, qsa, sizeof(*qsa)))
|
||||
if (copy_to_user(arg, &qsa, sizeof(qsa)))
|
||||
ret = -EFAULT;
|
||||
|
||||
kfree(qsa);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user