xfs: support xrep_require_rtext_inuse on zoned file systems
authorChristoph Hellwig <hch@lst.de>
Mon, 22 Jul 2024 13:31:28 +0000 (06:31 -0700)
committerChristoph Hellwig <hch@lst.de>
Mon, 3 Mar 2025 15:17:08 +0000 (08:17 -0700)
Space usage is tracked by the rmap, which already is separately
cross-referenced.  But on top of that we have the write pointer and can
do a basic sanity check here that the block is not beyond the write
pointer.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: "Darrick J. Wong" <djwong@kernel.org>
fs/xfs/scrub/repair.c

index c2705c3cba0d7e3014137362cad36303b061a9ff..f8f9ed30f56b03c151f63de7985448d1505f4741 100644 (file)
@@ -43,6 +43,7 @@
 #include "xfs_rtalloc.h"
 #include "xfs_metafile.h"
 #include "xfs_rtrefcount_btree.h"
+#include "xfs_zone_alloc.h"
 #include "scrub/scrub.h"
 #include "scrub/common.h"
 #include "scrub/trace.h"
@@ -1050,7 +1051,13 @@ xrep_require_rtext_inuse(
        xfs_rtxnum_t            startrtx;
        xfs_rtxnum_t            endrtx;
        bool                    is_free = false;
-       int                     error;
+       int                     error = 0;
+
+       if (xfs_has_zoned(mp)) {
+               if (!xfs_zone_rgbno_is_valid(sc->sr.rtg, rgbno + len - 1))
+                       return -EFSCORRUPTED;
+               return 0;
+       }
 
        startrtx = xfs_rgbno_to_rtx(mp, rgbno);
        endrtx = xfs_rgbno_to_rtx(mp, rgbno + len - 1);