Commit 6fe55c27 authored by Namjae Jeon's avatar Namjae Jeon Committed by Steve French
Browse files

ksmbd: call putname after using the last component



last component point filename struct. Currently putname is called after
vfs_path_parent_lookup(). And then last component is used for
lookup_one_qstr_excl(). name in last component is freed by previous
calling putname(). And It cause file lookup failure when testing
generic/464 test of xfstest.

Fixes: 74d7970f ("ksmbd: fix racy issue from using ->d_parent and ->d_name")
Signed-off-by: default avatarNamjae Jeon <linkinjeon@kernel.org>
Signed-off-by: default avatarSteve French <stfrench@microsoft.com>
parent 6cc2268f
Loading
Loading
Loading
Loading
+6 −2
Original line number Diff line number Diff line
@@ -86,12 +86,14 @@ static int ksmbd_vfs_path_lookup_locked(struct ksmbd_share_config *share_conf,
	err = vfs_path_parent_lookup(filename, flags,
				     &parent_path, &last, &type,
				     root_share_path);
	if (err) {
		putname(filename);
	if (err)
		return err;
	}

	if (unlikely(type != LAST_NORM)) {
		path_put(&parent_path);
		putname(filename);
		return -ENOENT;
	}

@@ -108,12 +110,14 @@ static int ksmbd_vfs_path_lookup_locked(struct ksmbd_share_config *share_conf,
	path->dentry = d;
	path->mnt = share_conf->vfs_path.mnt;
	path_put(&parent_path);
	putname(filename);

	return 0;

err_out:
	inode_unlock(parent_path.dentry->d_inode);
	path_put(&parent_path);
	putname(filename);
	return -ENOENT;
}