Hi all, This patchset enables use of the file data block sharing feature (i.e. reflink) on the realtime device. It follows the same basic sequence as the realtime rmap series -- first a few cleanups; then introduction of the new btree format and inode fork format. Next comes enabling CoW and remapping for the rt device; new scrub, repair, and health reporting code; and at the end we implement some code to lengthen write requests so that rt extents are always CoWed fully. If you're going to start using this code, I strongly recommend pulling from my git trees, which are linked below. This has been running on the djcloud for months with no problems. Enjoy! Comments and questions are, as always, welcome. --D kernel git tree: https://git.kernel.org/cgit/linux/kernel/git/djwong/xfs-linux.git/log/?h=realtime-reflink xfsprogs git tree: https://git.kernel.org/cgit/linux/kernel/git/djwong/xfsprogs-dev.git/log/?h=realtime-reflink fstests git tree: https://git.kernel.org/cgit/linux/kernel/git/djwong/xfstests-dev.git/log/?h=realtime-reflink xfsdocs git tree: https://git.kernel.org/cgit/linux/kernel/git/djwong/xfs-documentation.git/log/?h=realtime-reflink --- Commits in this patchset: * xfs: prepare refcount btree cursor tracepoints for realtime * xfs: namespace the maximum length/refcount symbols * xfs: introduce realtime refcount btree ondisk definitions * xfs: realtime refcount btree transaction reservations * xfs: add realtime refcount btree operations * xfs: prepare refcount functions to deal with rtrefcountbt * xfs: add a realtime flag to the refcount update log redo items * xfs: support recovering refcount intent items targetting realtime extents * xfs: add realtime refcount btree block detection to log recovery * xfs: add realtime refcount btree inode to metadata directory * xfs: add metadata reservations for realtime refcount btree * xfs: wire up a new metafile type for the realtime refcount * xfs: refactor xfs_reflink_find_shared * xfs: wire up realtime refcount btree cursors * xfs: create routine to allocate and initialize a realtime refcount btree inode * xfs: update rmap to allow cow staging extents in the rt rmap * xfs: compute rtrmap btree max levels when reflink enabled * xfs: refactor reflink quota updates * xfs: enable CoW for realtime data * xfs: enable sharing of realtime file blocks * xfs: allow inodes to have the realtime and reflink flags * xfs: recover CoW leftovers in the realtime volume * xfs: fix xfs_get_extsz_hint behavior with realtime alwayscow files * xfs: apply rt extent alignment constraints to CoW extsize hint * xfs: enable extent size hints for CoW operations * xfs: check that the rtrefcount maxlevels doesn't increase when growing fs * xfs: report realtime refcount btree corruption errors to the health system * xfs: scrub the realtime refcount btree * xfs: cross-reference checks with the rt refcount btree * xfs: allow overlapping rtrmapbt records for shared data extents * xfs: check reference counts of gaps between rt refcount records * xfs: allow dquot rt block count to exceed rt blocks on reflink fs * xfs: detect and repair misaligned rtinherit directory cowextsize hints * xfs: scrub the metadir path of rt refcount btree files * xfs: don't flag quota rt block usage on rtreflink filesystems * xfs: check new rtbitmap records against rt refcount btree * xfs: walk the rt reference count tree when rebuilding rmap * xfs: capture realtime CoW staging extents when rebuilding rt rmapbt * xfs: online repair of the realtime refcount btree * xfs: repair inodes that have a refcount btree in the data fork * xfs: check for shared rt extents when rebuilding rt file's data fork * xfs: fix CoW forks for realtime files * xfs: enable realtime reflink --- fs/xfs/Makefile | 3 fs/xfs/libxfs/xfs_bmap.c | 23 + fs/xfs/libxfs/xfs_btree.c | 5 fs/xfs/libxfs/xfs_btree.h | 2 fs/xfs/libxfs/xfs_defer.h | 1 fs/xfs/libxfs/xfs_format.h | 25 + fs/xfs/libxfs/xfs_fs.h | 7 fs/xfs/libxfs/xfs_health.h | 4 fs/xfs/libxfs/xfs_inode_buf.c | 33 + fs/xfs/libxfs/xfs_inode_fork.c | 6 fs/xfs/libxfs/xfs_log_format.h | 6 fs/xfs/libxfs/xfs_log_recover.h | 2 fs/xfs/libxfs/xfs_ondisk.h | 2 fs/xfs/libxfs/xfs_refcount.c | 276 ++++++++++-- fs/xfs/libxfs/xfs_refcount.h | 23 + fs/xfs/libxfs/xfs_rmap.c | 7 fs/xfs/libxfs/xfs_rtgroup.c | 19 + fs/xfs/libxfs/xfs_rtgroup.h | 11 fs/xfs/libxfs/xfs_rtrefcount_btree.c | 757 +++++++++++++++++++++++++++++++++ fs/xfs/libxfs/xfs_rtrefcount_btree.h | 189 ++++++++ fs/xfs/libxfs/xfs_rtrmap_btree.c | 28 + fs/xfs/libxfs/xfs_sb.c | 8 fs/xfs/libxfs/xfs_shared.h | 7 fs/xfs/libxfs/xfs_trans_resv.c | 25 + fs/xfs/scrub/agheader_repair.c | 2 fs/xfs/scrub/bmap.c | 30 + fs/xfs/scrub/bmap_repair.c | 21 + fs/xfs/scrub/common.c | 10 fs/xfs/scrub/common.h | 5 fs/xfs/scrub/cow_repair.c | 180 +++++++- fs/xfs/scrub/health.c | 1 fs/xfs/scrub/inode.c | 31 + fs/xfs/scrub/inode_repair.c | 57 ++ fs/xfs/scrub/metapath.c | 3 fs/xfs/scrub/quota.c | 8 fs/xfs/scrub/quota_repair.c | 2 fs/xfs/scrub/reap.c | 247 ++++++++++- fs/xfs/scrub/reap.h | 7 fs/xfs/scrub/refcount.c | 2 fs/xfs/scrub/refcount_repair.c | 6 fs/xfs/scrub/repair.c | 6 fs/xfs/scrub/repair.h | 7 fs/xfs/scrub/rgb_bitmap.h | 37 ++ fs/xfs/scrub/rmap_repair.c | 7 fs/xfs/scrub/rtb_bitmap.h | 37 ++ fs/xfs/scrub/rtbitmap.c | 2 fs/xfs/scrub/rtbitmap_repair.c | 24 + fs/xfs/scrub/rtrefcount.c | 661 +++++++++++++++++++++++++++++ fs/xfs/scrub/rtrefcount_repair.c | 783 ++++++++++++++++++++++++++++++++++ fs/xfs/scrub/rtrmap.c | 54 ++ fs/xfs/scrub/rtrmap_repair.c | 103 ++++ fs/xfs/scrub/scrub.c | 7 fs/xfs/scrub/scrub.h | 12 + fs/xfs/scrub/stats.c | 1 fs/xfs/scrub/trace.h | 54 +- fs/xfs/xfs_buf_item_recover.c | 4 fs/xfs/xfs_fsmap.c | 25 + fs/xfs/xfs_fsops.c | 2 fs/xfs/xfs_health.c | 1 fs/xfs/xfs_inode_item.c | 14 + fs/xfs/xfs_inode_item_recover.c | 4 fs/xfs/xfs_ioctl.c | 21 + fs/xfs/xfs_log_recover.c | 2 fs/xfs/xfs_mount.c | 7 fs/xfs/xfs_mount.h | 9 fs/xfs/xfs_refcount_item.c | 240 ++++++++++ fs/xfs/xfs_reflink.c | 325 ++++++++++---- fs/xfs/xfs_reflink.h | 4 fs/xfs/xfs_rtalloc.c | 24 + fs/xfs/xfs_rtalloc.h | 5 fs/xfs/xfs_stats.c | 3 fs/xfs/xfs_stats.h | 1 fs/xfs/xfs_super.c | 15 + fs/xfs/xfs_trace.h | 111 +++-- 74 files changed, 4340 insertions(+), 353 deletions(-) create mode 100644 fs/xfs/libxfs/xfs_rtrefcount_btree.c create mode 100644 fs/xfs/libxfs/xfs_rtrefcount_btree.h create mode 100644 fs/xfs/scrub/rgb_bitmap.h create mode 100644 fs/xfs/scrub/rtb_bitmap.h create mode 100644 fs/xfs/scrub/rtrefcount.c create mode 100644 fs/xfs/scrub/rtrefcount_repair.c