diff mbox series

dm verity fec: fix hash block number in verity_fec_decode

Message ID b8de2c4b-d8cf-2bdb-f4cf-5b10faf48955@samsung.com (mailing list archive)
State Accepted, archived
Delegated to: Mike Snitzer
Headers show
Series dm verity fec: fix hash block number in verity_fec_decode | expand

Commit Message

Sunwook Eom April 10, 2020, 3:54 a.m. UTC
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@samsung.com>
---
  drivers/md/dm-verity-fec.c | 2 +-
  1 file changed, 1 insertion(+), 1 deletion(-)

       * For RS(M, N), the continuous FEC data is divided into blocks of N

Comments

Sunwook Eom April 13, 2020, 4:31 a.m. UTC | #1
On 20. 4. 11. 오전 12:41, Sami Tolvanen wrote:
> On Thu, Apr 9, 2020 at 8:54 PM Sunwook Eom <speed.eom@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@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@google.com>
>
> Sami
>
>
Add CC : LKML <linux-kernel@vger.kernel.org>


--
dm-devel mailing list
dm-devel@redhat.com
https://www.redhat.com/mailman/listinfo/dm-devel
diff mbox series

Patch

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;

      /*