]> git.apps.os.sepia.ceph.com Git - ceph.git/commitdiff
mds: Fix the linkmerge assert check 52726/head
authorKotresh HR <khiremat@redhat.com>
Tue, 6 Jun 2023 07:39:00 +0000 (13:09 +0530)
committerKotresh HR <khiremat@redhat.com>
Tue, 1 Aug 2023 06:33:20 +0000 (12:03 +0530)
Let's say there is a hardlink created as below.

touch file1
ln file1 hl_file1

In this case 'file1' holds the primary inode and 'hl_file' holds
the remote inode (holds primary inode number and other required info).
Now, if the 'file1' is deleted first, it's moved to a stray directory
and can't be deleted because the hardlink 'hl_file1' still exists
which requires primary inode. So on straydn eval, this primary
inode is linked to 'hl_file1 and remote inode is removed. This is called
the linkmerge/stray reintegration. So in the linkmerge case, the srcdnl
is primary straydn and the destdnl is the remote.

Signed-off-by: Kotresh HR <khiremat@redhat.com>
Fixes: https://tracker.ceph.com/issues/61879
(cherry picked from commit 85279ac657832fd643ee2cc5f1f6a27f98e099f6)

src/mds/Server.cc

index 5e67d931fc3048acd75a0e8144704bed880ce10f..8796e166dc1b7fa4923767f44bafc6d4e9153392 100644 (file)
@@ -9571,7 +9571,7 @@ void Server::_rename_apply(MDRequestRef& mdr, CDentry *srcdn, CDentry *destdn, C
   // primary+remote link merge?
   bool linkmerge = (srcdnl->get_inode() == oldin);
   if (linkmerge)
-    ceph_assert(srcdnl->is_primary() || destdnl->is_remote());
+    ceph_assert(srcdnl->is_primary() && destdnl->is_remote());
 
   bool new_in_snaprealm = false;
   bool new_oldin_snaprealm = false;