forked from Minki/linux
drbd: fix decoding of bitmap vli rle for device sizes > 64 TB
Symptoms: disconnect after bitmap exchange due to bitmap overflow (e:49731075554) while decoding bm RLE packet In the decoding step of the variable length integer run length encoding there was potentially an uncatched bitshift by wordsize (variable >> 64). The result of which is "undefined" :( (only "sometimes" the result is the desired 0) Fix: don't do any bit shift magic for shift == 64, just assign. Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com> Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com> Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
57737adc96
commit
d2da5b0cb5
@ -4125,7 +4125,11 @@ recv_bm_rle_bits(struct drbd_conf *mdev,
|
|||||||
(unsigned int)bs.buf_len);
|
(unsigned int)bs.buf_len);
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
look_ahead >>= bits;
|
/* if we consumed all 64 bits, assign 0; >> 64 is "undefined"; */
|
||||||
|
if (likely(bits < 64))
|
||||||
|
look_ahead >>= bits;
|
||||||
|
else
|
||||||
|
look_ahead = 0;
|
||||||
have -= bits;
|
have -= bits;
|
||||||
|
|
||||||
bits = bitstream_get_bits(&bs, &tmp, 64 - have);
|
bits = bitstream_get_bits(&bs, &tmp, 64 - have);
|
||||||
|
Loading…
Reference in New Issue
Block a user