summaryrefslogtreecommitdiffstats
path: root/src/tools/cephfs/DataScan.cc
diff options
context:
space:
mode:
authorPatrick Donnelly <pdonnell@redhat.com>2018-04-04 00:41:19 +0200
committerPatrick Donnelly <pdonnell@redhat.com>2018-04-04 00:41:19 +0200
commitebd0fcd0674e6bc527a7af548bd420db943f98a6 (patch)
tree7b9f4cb32f3ff4e0aa8360f7d8a0f8848ca16a19 /src/tools/cephfs/DataScan.cc
parentMerge PR #20915 into master (diff)
parentmds: cleanup MDCache::open_snaprealms() (diff)
downloadceph-ebd0fcd0674e6bc527a7af548bd420db943f98a6.tar.xz
ceph-ebd0fcd0674e6bc527a7af548bd420db943f98a6.zip
Merge PR #16779 into master
* refs/pull/16779/head: mds: cleanup MDCache::open_snaprealms() mds: make sure snaptable version > 0 mds: don't consider CEPH_INO_LOST_AND_FOUND as base inode mds: replace MAX() with std::max() tools/cephfs: make cephfs-data-scan create snaprealm for base inodes qa/cephfs: don't run TestSnapshots.test_kill_mdstable on kclient qa/cephfs: adjust check of 'cephfs-table-tool all show snap' output mds: don't warn unconnected snaplrealms in cluster log mds: update CInode/CDentry's first according to global snapshot seq qa/cephfs: add tests for snapclient cache qa/cephfs: add tests for snaptable transaction mds: add asok command that dumps cached snap infos qa/cephfs: add tests for multimds snapshot client: don't mark snap directory complete when its dirstat is empty qa/workunits/snaps: add snaprealm split test mds: make sure mds has uptodate mdsmap before checking 'allows_snaps' client: fix incorrect snaprealm when adding caps qa/workunits/snaps: add hardlink snapshot test mds: add incompat feature and bump protocol for snapshot changes mds: detach inode with single hardlink from global snaprealm mds: record hardlink snaps in inode's snaprealm mds: attach inode with multiple hardlinks to dummy global snaprealm mds: cleanup rename code mds: ensure xlocker has uptodate lock state mds: simplify SnapRealm::build_snap_{set,trace} mds: record global last_created/last_destroyed in snaptable mds: pop projected snaprealm before inode's parent changes mds: keep isnap lock in sync state mds: handle mksnap vs resolve_snapname race mds: cleanup snaprealm past parents open check mds: rollback snaprealms when rolling back slave request mds: send updated snaprealms along with slave requests mds: explict notification for snap update mds: send snap related messages centrally during mds recovery mds: synchronize snaptable caches when mds recovers mds: introduce MDCache::maybe_finish_slave_resolve() mds: notify all mds about prepared snaptable update mds: record snaps in old snaprealm when moving inode into new snaprealm mds: cache snaptable in snapclient mds: recover snaptable client when mds enters resolve state Reviewed-by: Patrick Donnelly <pdonnell@redhat.com>
Diffstat (limited to 'src/tools/cephfs/DataScan.cc')
-rw-r--r--src/tools/cephfs/DataScan.cc6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/tools/cephfs/DataScan.cc b/src/tools/cephfs/DataScan.cc
index e2e0233924e..ab64d1e38d9 100644
--- a/src/tools/cephfs/DataScan.cc
+++ b/src/tools/cephfs/DataScan.cc
@@ -364,6 +364,12 @@ int MetadataDriver::inject_unlinked_inode(
// be ignoring dirfrags that exist
inode.damage_flags |= (DAMAGE_STATS | DAMAGE_RSTATS | DAMAGE_FRAGTREE);
+ if (inono == MDS_INO_ROOT || MDS_INO_IS_MDSDIR(inono)) {
+ sr_t srnode;
+ srnode.seq = 1;
+ encode(srnode, inode.snap_blob);
+ }
+
// Serialize
bufferlist inode_bl;
encode(std::string(CEPH_FS_ONDISK_MAGIC), inode_bl);