ifp->if_broot_bytes, dfp,
XFS_DFORK_SIZE(dip, ip->i_mount, XFS_DATA_FORK));
}
+
+/*
+ * Create a realtime refcount btree inode.
+ *
+ * Regardless of the return value, the caller must clean up @upd. If a new
+ * inode is returned through @upd->ip, the caller must finish setting up that
+ * incore inode and release it.
+ */
+int
+xfs_rtrefcountbt_create(
+ struct xfs_imeta_update *upd)
+{
+ struct xfs_mount *mp = upd->mp;
+ struct xfs_ifork *ifp;
+ int error;
+
+ error = xfs_imeta_create(upd, S_IFREG);
+ if (error)
+ return error;
+
+ ifp = xfs_ifork_ptr(upd->ip, XFS_DATA_FORK);
+ ifp->if_format = XFS_DINODE_FMT_REFCOUNT;
+ ASSERT(ifp->if_broot_bytes == 0);
+ ASSERT(ifp->if_bytes == 0);
+
+ /* Initialize the empty incore btree root. */
+ xfs_iroot_alloc(upd->ip, XFS_DATA_FORK,
+ xfs_rtrefcount_broot_space_calc(mp, 0, 0));
+ xfs_btree_init_block(mp, ifp->if_broot, &xfs_rtrefcountbt_ops,
+ 0, 0, upd->ip->i_ino);
+ xfs_trans_log_inode(upd->tp, upd->ip, XFS_ILOG_CORE | XFS_ILOG_DBROOT);
+ return 0;
+}
struct xfs_rtrefcount_root *dblock, int dblocklen);
void xfs_iflush_rtrefcount(struct xfs_inode *ip, struct xfs_dinode *dip);
+struct xfs_imeta_update;
+
+int xfs_rtrefcountbt_create(struct xfs_imeta_update *upd);
+
#endif /* __XFS_RTREFCOUNT_BTREE_H__ */