ceph: cleanup traceless reply handling for rename
authorYan, Zheng <zyan@redhat.com>
Fri, 24 Nov 2017 03:51:32 +0000 (11:51 +0800)
committerIlya Dryomov <idryomov@gmail.com>
Mon, 29 Jan 2018 17:36:06 +0000 (18:36 +0100)
ceph_fill_trace() already calls ceph_invalidate_dir_request() for
traceless reply. No need to duplicate the code in ceph_rename().

Signed-off-by: "Yan, Zheng" <zyan@redhat.com>
Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
fs/ceph/dir.c
fs/ceph/mds_client.c

index 9fde02c..64afa46 100644 (file)
@@ -1107,16 +1107,7 @@ static int ceph_rename(struct inode *old_dir, struct dentry *old_dentry,
                 * do_request, above).  If there is no trace, we need
                 * to do it here.
                 */
-
-               /* d_move screws up sibling dentries' offsets */
-               ceph_dir_clear_complete(old_dir);
-               ceph_dir_clear_complete(new_dir);
-
                d_move(old_dentry, new_dentry);
-
-               /* ensure target dentry is invalidated, despite
-                  rehashing bug in vfs_rename_dir */
-               ceph_invalidate_dentry_lease(new_dentry);
        }
        ceph_mdsc_put_request(req);
        return err;
index 1b46825..251dc44 100644 (file)
@@ -2438,11 +2438,14 @@ out:
  */
 void ceph_invalidate_dir_request(struct ceph_mds_request *req)
 {
-       struct inode *inode = req->r_parent;
+       struct inode *dir = req->r_parent;
+       struct inode *old_dir = req->r_old_dentry_dir;
 
-       dout("invalidate_dir_request %p (complete, lease(s))\n", inode);
+       dout("invalidate_dir_request %p %p (complete, lease(s))\n", dir, old_dir);
 
-       ceph_dir_clear_complete(inode);
+       ceph_dir_clear_complete(dir);
+       if (old_dir)
+               ceph_dir_clear_complete(old_dir);
        if (req->r_dentry)
                ceph_invalidate_dentry_lease(req->r_dentry);
        if (req->r_old_dentry)