From: Anand Jain Date: Thu, 10 Nov 2022 06:06:31 +0000 (+0530) Subject: btrfs: free btrfs_path before copying subvol info to userspace X-Git-Tag: v5.15.81~10 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=d88bf6be02defd763e919440d313df190851db72;p=users%2Fdwmw2%2Flinux.git btrfs: free btrfs_path before copying subvol info to userspace commit 013c1c5585ebcfb19c88efe79063d0463b1b6159 upstream. btrfs_ioctl_get_subvol_info() frees the search path after the userspace copy from the temp buffer @subvol_info. This can lead to a lock splat warning. Fix this by freeing the path before we copy it to userspace. CC: stable@vger.kernel.org # 4.19+ Signed-off-by: Anand Jain Reviewed-by: David Sterba Signed-off-by: David Sterba Signed-off-by: Greg Kroah-Hartman --- diff --git a/fs/btrfs/ioctl.c b/fs/btrfs/ioctl.c index ce669ed21d546..d9ff0697132b9 100644 --- a/fs/btrfs/ioctl.c +++ b/fs/btrfs/ioctl.c @@ -2788,6 +2788,8 @@ static int btrfs_ioctl_get_subvol_info(struct file *file, void __user *argp) } } + btrfs_free_path(path); + path = NULL; if (copy_to_user(argp, subvol_info, sizeof(*subvol_info))) ret = -EFAULT;