]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
dm-verity-fec: simplify computation of ileaved
authorEric Biggers <ebiggers@kernel.org>
Fri, 6 Feb 2026 04:59:33 +0000 (20:59 -0800)
committerMikulas Patocka <mpatocka@redhat.com>
Mon, 9 Mar 2026 14:12:53 +0000 (15:12 +0100)
fec_read_bufs() just iterates over a sequence of message blocks with
step size region_blocks.  At each step, 'ileaved' is just the offset (in
bytes) to one of these blocks.  Compute it in the straightforward way,
eliminating fec_interleave().

In more detail, previously the code computed
'ileaved = (n / k) + (n % k) * (region_blocks * block_size)'
where n = rsb * k + i and 0 <= i < k.  Substituting 'n' gives:

    ileaved = ((rsb * k + i) / k) + ((rsb * k + i) % k) * region_blocks * block_size
            = rsb + (i * region_blocks * block_size)

The result is more efficient and easier to understand.

Signed-off-by: Eric Biggers <ebiggers@kernel.org>
Signed-off-by: Mikulas Patocka <mpatocka@redhat.com>
drivers/md/dm-verity-fec.c

index d2c55896e6f7035835be046761d2d2dfd161ba7c..baf988c297618c7ea5add13ec3ebe277c56331b9 100644 (file)
@@ -23,17 +23,6 @@ static inline unsigned int fec_max_nbufs(struct dm_verity *v)
        return 1 << (v->data_dev_block_bits - DM_VERITY_FEC_BUF_RS_BITS);
 }
 
-/*
- * Return an interleaved offset for a byte in RS block.
- */
-static inline u64 fec_interleave(struct dm_verity *v, u64 offset)
-{
-       u32 mod;
-
-       mod = do_div(offset, v->fec->rs_k);
-       return offset + mod * (v->fec->region_blocks << v->data_dev_block_bits);
-}
-
 /* Loop over each allocated buffer. */
 #define fec_for_each_buffer(io, __i) \
        for (__i = 0; __i < (io)->nbufs; __i++)
@@ -204,7 +193,7 @@ static int fec_read_bufs(struct dm_verity *v, struct dm_verity_io *io,
         * interleave contents to available bufs
         */
        for (i = 0; i < v->fec->rs_k; i++) {
-               ileaved = fec_interleave(v, rsb * v->fec->rs_k + i);
+               ileaved = rsb + i * (v->fec->region_blocks << v->data_dev_block_bits);
 
                /*
                 * target is the data block we want to correct, target_index is