[dm-devel] [PATCH] dm verity fec: fix hash block number in verity_fec_decode
Sami Tolvanen
samitolvanen at google.com
Fri Apr 10 15:41:26 UTC 2020
On Thu, Apr 9, 2020 at 8:54 PM Sunwook Eom <speed.eom at samsung.com> wrote:
>
> The error correction data is computed as if data and hash blocks
> were concatenated. But hash block number is start from v->hash_start.
> So, we have to calculate hash block number based on that.
>
> Fixes: a739ff3f543af ("dm verity: add support for forward error correction")
> Signed-off-by: Sunwook Eom <speed.eom at samsung.com>
> ---
> drivers/md/dm-verity-fec.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/drivers/md/dm-verity-fec.c b/drivers/md/dm-verity-fec.c
> index 49147e634046..fb41b4f23c48 100644
> --- a/drivers/md/dm-verity-fec.c
> +++ b/drivers/md/dm-verity-fec.c
> @@ -435,7 +435,7 @@ int verity_fec_decode(struct dm_verity *v, struct
> dm_verity_io *io,
> fio->level++;
>
> if (type == DM_VERITY_BLOCK_TYPE_METADATA)
> - block += v->data_blocks;
> + block = block - v->hash_start + v->data_blocks;
>
> /*
> * For RS(M, N), the continuous FEC data is divided into blocks of N
Thank you for the patch!
Reviewed-by: Sami Tolvanen <samitolvanen at google.com>
Sami
More information about the dm-devel
mailing list