]> www.infradead.org Git - users/hch/xfsprogs.git/commitdiff
xfs: create routine to allocate and initialize a realtime rmap btree inode
authorDarrick J. Wong <djwong@kernel.org>
Fri, 9 Aug 2024 12:00:20 +0000 (14:00 +0200)
committerChristoph Hellwig <hch@lst.de>
Sun, 11 Aug 2024 06:35:55 +0000 (08:35 +0200)
Source kernel commit: 30e82ca461da5c3ee75c78678d943bfc39ad2544

Create a library routine to allocate and initialize an empty realtime
rmapbt inode.  We'll use this for mkfs and repair.

Signed-off-by: Darrick J. Wong <djwong@kernel.org>
Signed-off-by: Christoph Hellwig <hch@lst.de>
libxfs/xfs_rtgroup.c
libxfs/xfs_rtrmap_btree.c
libxfs/xfs_rtrmap_btree.h

index 7a7fa0fb364f8aeed63d41ef9faedfc70b3aeaa6..abeb9cf77b5dfee5292614f22c60c5a39f7a1880 100644 (file)
@@ -30,6 +30,7 @@
 #include "xfs_rtbitmap.h"
 #include "xfs_metafile.h"
 #include "xfs_metadir.h"
+#include "xfs_rtrmap_btree.h"
 
 /*
  * Passive reference counting access wrappers to the rtgroup structures.  If
@@ -381,6 +382,7 @@ static const struct xfs_rtginode_ops xfs_rtginode_ops[XFS_RTG_MAX] = {
                .name           = "rmap",
                .format         = XFS_DINODE_FMT_RMAP,
                .enabled        = xfs_has_rtrmapbt,
+               .create         = xfs_rtrmapbt_create,
        },
 };
 
index 2ef2fae68dbead2836cf8f8a796ec9320233b55d..19105df8d71ab9f831d9cdc2f25bd55776aa44e4 100644 (file)
@@ -803,3 +803,47 @@ xfs_iflush_rtrmap(
        xfs_rtrmapbt_to_disk(ip->i_mount, ifp->if_broot, ifp->if_broot_bytes,
                        dfp, XFS_DFORK_SIZE(dip, ip->i_mount, XFS_DATA_FORK));
 }
+
+/*
+ * Create a realtime rmap btree inode.
+ */
+int
+xfs_rtrmapbt_create(
+       struct xfs_rtgroup      *rtg,
+       struct xfs_inode        *ip,
+       struct xfs_trans        *tp,
+       bool                    init)
+{
+       struct xfs_ifork        *ifp = xfs_ifork_ptr(ip, XFS_DATA_FORK);
+       struct xfs_mount        *mp = ip->i_mount;
+       int                     error = 0;
+
+       ifp->if_format = XFS_DINODE_FMT_RMAP;
+       ASSERT(ifp->if_broot_bytes == 0);
+       ASSERT(ifp->if_bytes == 0);
+
+       /* Initialize the empty incore btree root. */
+       xfs_iroot_alloc(ip, XFS_DATA_FORK,
+                       xfs_rtrmap_broot_space_calc(mp, 0, 0));
+       xfs_btree_init_block(mp, ifp->if_broot, &xfs_rtrmapbt_ops, 0, 0,
+                       ip->i_ino);
+       xfs_trans_log_inode(tp, ip, XFS_ILOG_CORE | XFS_ILOG_DBROOT);
+
+       if (init && xfs_has_rtsb(mp) && rtg->rtg_rgno == 0) {
+               struct xfs_rmap_irec    rmap = {
+                       .rm_blockcount  = mp->m_sb.sb_rextsize,
+                       .rm_owner       = XFS_RMAP_OWN_FS,
+               };
+               struct xfs_btree_cur    *cur;
+
+               /*
+                * Add an rmap the rtgroup superblock; this had better
+                * fit in the data fork.
+                */
+               cur = xfs_rtrmapbt_init_cursor(mp, tp, rtg, ip);
+               error = xfs_rmap_map_raw(cur, &rmap);
+               xfs_btree_del_cursor(cur, error);
+       }
+
+       return error;
+}
index 39471df846abc19bca9009c2d8cd3704fa0cf797..33b79daa813ded846c1afa043dbebd44f58d20bc 100644 (file)
@@ -194,4 +194,7 @@ void xfs_rtrmapbt_to_disk(struct xfs_mount *mp, struct xfs_btree_block *rblock,
                unsigned int dblocklen);
 void xfs_iflush_rtrmap(struct xfs_inode *ip, struct xfs_dinode *dip);
 
+int xfs_rtrmapbt_create(struct xfs_rtgroup *rtg, struct xfs_inode *ip,
+               struct xfs_trans *tp, bool init);
+
 #endif /* __XFS_RTRMAP_BTREE_H__ */