xfs: fix 32-bit truncation in xfs_compute_rextslog
authorDarrick J. Wong <djwong@kernel.org>
Sun, 3 Dec 2023 17:19:44 +0000 (09:19 -0800)
committerDarrick J. Wong <djwong@kernel.org>
Thu, 7 Dec 2023 02:45:17 +0000 (18:45 -0800)
It's quite reasonable that some customer somewhere will want to
configure a realtime volume with more than 2^32 extents.  If they try to
do this, the highbit32() call will truncate the upper bits of the
xfs_rtbxlen_t and produce the wrong value for rextslog.  This in turn
causes the rsumlevels to be wrong, which results in a realtime summary
file that is the wrong length.  Fix that.

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

index 1c9fed76a356a42f5ce23ea645f1b6f353ec3293..30a2844f62e30f2359e2fcff79350d8bce5aaf46 100644 (file)
@@ -1132,14 +1132,16 @@ xfs_rtbitmap_blockcount(
 
 /*
  * Compute the maximum level number of the realtime summary file, as defined by
- * mkfs.  The use of highbit32 on a 64-bit quantity is a historic artifact that
- * prohibits correct use of rt volumes with more than 2^32 extents.
+ * mkfs.  The historic use of highbit32 on a 64-bit quantity prohibited correct
+ * use of rt volumes with more than 2^32 extents.
  */
 uint8_t
 xfs_compute_rextslog(
        xfs_rtbxlen_t           rtextents)
 {
-       return rtextents ? xfs_highbit32(rtextents) : 0;
+       if (!rtextents)
+               return 0;
+       return xfs_highbit64(rtextents);
 }
 
 /*