Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

dm-verity: disable recursive forward error correction

There are two problems with the recursive correction:

1. It may cause denial-of-service. In fec_read_bufs, there is a loop that
has 253 iterations. For each iteration, we may call verity_hash_for_block
recursively. There is a limit of 4 nested recursions - that means that
there may be at most 253^4 (4 billion) iterations. Red Hat QE team
actually created an image that pushes dm-verity to this limit - and this
image just makes the udev-worker process get stuck in the 'D' state.

2. It doesn't work. In fec_read_bufs we store data into the variable
"fio->bufs", but fio bufs is shared between recursive invocations, if
"verity_hash_for_block" invoked correction recursively, it would
overwrite partially filled fio->bufs.

Signed-off-by: Mikulas Patocka <mpatocka@redhat.com>
Reported-by: Guangwu Zhang <guazhang@redhat.com>
Reviewed-by: Sami Tolvanen <samitolvanen@google.com>
Reviewed-by: Eric Biggers <ebiggers@kernel.org>

+2 -7
+1 -3
drivers/md/dm-verity-fec.c
··· 418 418 if (!verity_fec_is_enabled(v)) 419 419 return -EOPNOTSUPP; 420 420 421 - if (fio->level >= DM_VERITY_FEC_MAX_RECURSION) { 422 - DMWARN_LIMIT("%s: FEC: recursion too deep", v->data_dev->name); 421 + if (fio->level) 423 422 return -EIO; 424 - } 425 423 426 424 fio->level++; 427 425
-3
drivers/md/dm-verity-fec.h
··· 23 23 #define DM_VERITY_FEC_BUF_MAX \ 24 24 (1 << (PAGE_SHIFT - DM_VERITY_FEC_BUF_RS_BITS)) 25 25 26 - /* maximum recursion level for verity_fec_decode */ 27 - #define DM_VERITY_FEC_MAX_RECURSION 4 28 - 29 26 #define DM_VERITY_OPT_FEC_DEV "use_fec_from_device" 30 27 #define DM_VERITY_OPT_FEC_BLOCKS "fec_blocks" 31 28 #define DM_VERITY_OPT_FEC_START "fec_start"
+1 -1
drivers/md/dm-verity-target.c
··· 1789 1789 .name = "verity", 1790 1790 /* Note: the LSMs depend on the singleton and immutable features */ 1791 1791 .features = DM_TARGET_SINGLETON | DM_TARGET_IMMUTABLE, 1792 - .version = {1, 12, 0}, 1792 + .version = {1, 13, 0}, 1793 1793 .module = THIS_MODULE, 1794 1794 .ctr = verity_ctr, 1795 1795 .dtr = verity_dtr,