Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 5223671b authored by Philipp Reisner's avatar Philipp Reisner
Browse files

drbd: Fixed bitmap in case of online-grow without resync



The "surplus" bits of the old (smaller) bitmap must be clean
in case of online-grow without resync.

Note: Reverted 67ae8b80d4a116ab3b7094eb3723506b20c06dff as
well, since the lines added by this patch are redundant. The
bits get set by the bm_set_surplus(b) call before that.

Signed-off-by: default avatarPhilipp Reisner <philipp.reisner@linbit.com>
Signed-off-by: default avatarLars Ellenberg <lars.ellenberg@linbit.com>
parent 6b4388ac
Loading
Loading
Loading
Loading
+1 −4
Original line number Diff line number Diff line
@@ -519,7 +519,7 @@ int drbd_bm_resize(struct drbd_conf *mdev, sector_t capacity, int set_new_bits)
	obits  = b->bm_bits;

	growing = bits > obits;
	if (opages)
	if (opages && growing && set_new_bits)
		bm_set_surplus(b);

	b->bm_pages = npages;
@@ -532,9 +532,6 @@ int drbd_bm_resize(struct drbd_conf *mdev, sector_t capacity, int set_new_bits)
		if (set_new_bits) {
			bm_memset(b, owords, 0xff, words-owords);
			b->bm_set += bits - obits;
			__bm_change_bits_to(mdev, obits,
					    ALIGN(obits, BITS_PER_LONG),
					    1, KM_IRQ1);
		} else
			bm_memset(b, owords, 0x00, words-owords);