diff options
| author | Nikos Tsironis <ntsironis@arrikto.com> | 2020-03-27 16:01:09 +0200 | 
|---|---|---|
| committer | Mike Snitzer <snitzer@redhat.com> | 2020-03-27 14:41:46 -0400 | 
| commit | cd481c12269b4d276f1a52eda0ebd419079bfe3a (patch) | |
| tree | ce0a92f40d99c7c2905bd1b6000e23632b5a8219 /lib/memory-notifier-error-inject.c | |
| parent | 4b5142905d4ff58a4b93f7c8eaa7ba829c0a53c9 (diff) | |
dm clone: Add overflow check for number of regions
Add overflow check for clone->nr_regions variable, which holds the
number of regions of the target.
The overflow can occur with sufficiently large devices, if BITS_PER_LONG
== 32. E.g., if the region size is 8 sectors (4K), the overflow would
occur for device sizes > 34359738360 sectors (~16TB).
This could result in multiple device sectors wrongly mapping to the same
region number, due to the truncation from 64 bits to 32 bits, which
would lead to data corruption.
Fixes: 7431b7835f55 ("dm: add clone target")
Cc: stable@vger.kernel.org # v5.4+
Signed-off-by: Nikos Tsironis <ntsironis@arrikto.com>
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
Diffstat (limited to 'lib/memory-notifier-error-inject.c')
0 files changed, 0 insertions, 0 deletions
