diff options
Diffstat (limited to 'fs/btrfs/ioctl.c')
| -rw-r--r-- | fs/btrfs/ioctl.c | 12 | 
1 files changed, 9 insertions, 3 deletions
| diff --git a/fs/btrfs/ioctl.c b/fs/btrfs/ioctl.c index a18ee7b5a166..8e7d03bc1b56 100644 --- a/fs/btrfs/ioctl.c +++ b/fs/btrfs/ioctl.c @@ -1958,6 +1958,13 @@ static int btrfs_search_path_in_tree_user(struct mnt_idmap *idmap,  				goto out_put;  			} +			/* +			 * We don't need the path anymore, so release it and +			 * avoid deadlocks and lockdep warnings in case +			 * btrfs_iget() needs to lookup the inode from its root +			 * btree and lock the same leaf. +			 */ +			btrfs_release_path(path);  			temp_inode = btrfs_iget(sb, key2.objectid, root);  			if (IS_ERR(temp_inode)) {  				ret = PTR_ERR(temp_inode); @@ -1978,7 +1985,6 @@ static int btrfs_search_path_in_tree_user(struct mnt_idmap *idmap,  				goto out_put;  			} -			btrfs_release_path(path);  			key.objectid = key.offset;  			key.offset = (u64)-1;  			dirid = key.objectid; @@ -2972,7 +2978,7 @@ static void get_block_group_info(struct list_head *groups_list,  static long btrfs_ioctl_space_info(struct btrfs_fs_info *fs_info,  				   void __user *arg)  { -	struct btrfs_ioctl_space_args space_args; +	struct btrfs_ioctl_space_args space_args = { 0 };  	struct btrfs_ioctl_space_info space;  	struct btrfs_ioctl_space_info *dest;  	struct btrfs_ioctl_space_info *dest_orig; @@ -4332,7 +4338,7 @@ static int _btrfs_ioctl_send(struct inode *inode, void __user *argp, bool compat  	if (compat) {  #if defined(CONFIG_64BIT) && defined(CONFIG_COMPAT) -		struct btrfs_ioctl_send_args_32 args32; +		struct btrfs_ioctl_send_args_32 args32 = { 0 };  		ret = copy_from_user(&args32, argp, sizeof(args32));  		if (ret) | 
