Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 38f340cc authored by Yan, Zheng's avatar Yan, Zheng Committed by Ilya Dryomov
Browse files

ceph: fix __choose_mds() for LSSNAP request



previous commit 5d37ca14 "ceph: send LSSNAP request to auth mds
of directory inode" is buggy. It makes __choose_mds() choose mds
base on hash of '.snap' dentry.

Signed-off-by: default avatar"Yan, Zheng" <zyan@redhat.com>
Signed-off-by: default avatarIlya Dryomov <idryomov@gmail.com>
parent 9f4057fc
Loading
Loading
Loading
Loading
+6 −5
Original line number Diff line number Diff line
@@ -734,12 +734,13 @@ static int __choose_mds(struct ceph_mds_client *mdsc,
			inode = req->r_inode;
			ihold(inode);
		} else {
			/* req->r_dentry is non-null for LSSNAP request.
			 * fall-thru */
			WARN_ON_ONCE(!req->r_dentry);
		}
			/* req->r_dentry is non-null for LSSNAP request */
			rcu_read_lock();
			inode = get_nonsnap_parent(req->r_dentry);
			rcu_read_unlock();
			dout("__choose_mds using snapdir's parent %p\n", inode);
		}
	if (!inode && req->r_dentry) {
	} else if (req->r_dentry) {
		/* ignore race with rename; old or new d_parent is okay */
		struct dentry *parent;
		struct inode *dir;