]> git.ipfire.org Git - thirdparty/xfsprogs-dev.git/commitdiff
xfs: create a ranged query function for refcount btrees
authorDarrick J. Wong <djwong@kernel.org>
Mon, 15 Apr 2024 23:07:39 +0000 (16:07 -0700)
committerDarrick J. Wong <djwong@kernel.org>
Wed, 17 Apr 2024 21:06:25 +0000 (14:06 -0700)
Source kernel commit: d12bf8bac87a0d93e6e5fab67f399d1e3d3d5767

Implement ranged queries for refcount records.  The next patch will use
this to scan refcount data.

Signed-off-by: Darrick J. Wong <djwong@kernel.org>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Bill O'Donnell <bodonnel@redhat.com>
libxfs/xfs_refcount.c
libxfs/xfs_refcount.h

index 3377fac1283b73dbc511a1bee35a1ed4f46e1158..de321ab9d91d46c5d4a0ffdb6ab162cedc32a0f2 100644 (file)
@@ -2030,6 +2030,47 @@ xfs_refcount_has_records(
        return xfs_btree_has_records(cur, &low, &high, NULL, outcome);
 }
 
+struct xfs_refcount_query_range_info {
+       xfs_refcount_query_range_fn     fn;
+       void                            *priv;
+};
+
+/* Format btree record and pass to our callback. */
+STATIC int
+xfs_refcount_query_range_helper(
+       struct xfs_btree_cur            *cur,
+       const union xfs_btree_rec       *rec,
+       void                            *priv)
+{
+       struct xfs_refcount_query_range_info    *query = priv;
+       struct xfs_refcount_irec        irec;
+       xfs_failaddr_t                  fa;
+
+       xfs_refcount_btrec_to_irec(rec, &irec);
+       fa = xfs_refcount_check_irec(cur->bc_ag.pag, &irec);
+       if (fa)
+               return xfs_refcount_complain_bad_rec(cur, fa, &irec);
+
+       return query->fn(cur, &irec, query->priv);
+}
+
+/* Find all refcount records between two keys. */
+int
+xfs_refcount_query_range(
+       struct xfs_btree_cur            *cur,
+       const struct xfs_refcount_irec  *low_rec,
+       const struct xfs_refcount_irec  *high_rec,
+       xfs_refcount_query_range_fn     fn,
+       void                            *priv)
+{
+       union xfs_btree_irec            low_brec = { .rc = *low_rec };
+       union xfs_btree_irec            high_brec = { .rc = *high_rec };
+       struct xfs_refcount_query_range_info query = { .priv = priv, .fn = fn };
+
+       return xfs_btree_query_range(cur, &low_brec, &high_brec,
+                       xfs_refcount_query_range_helper, &query);
+}
+
 int __init
 xfs_refcount_intent_init_cache(void)
 {
index 5c207f1c619c71ab3101c58823ab756cfb5bf564..9b56768a590c01f5adf132abf3a77f9bd67f90d8 100644 (file)
@@ -127,4 +127,14 @@ extern struct kmem_cache   *xfs_refcount_intent_cache;
 int __init xfs_refcount_intent_init_cache(void);
 void xfs_refcount_intent_destroy_cache(void);
 
+typedef int (*xfs_refcount_query_range_fn)(
+       struct xfs_btree_cur            *cur,
+       const struct xfs_refcount_irec  *rec,
+       void                            *priv);
+
+int xfs_refcount_query_range(struct xfs_btree_cur *cur,
+               const struct xfs_refcount_irec *low_rec,
+               const struct xfs_refcount_irec *high_rec,
+               xfs_refcount_query_range_fn fn, void *priv);
+
 #endif /* __XFS_REFCOUNT_H__ */