From a3134eb8d84bf18f2892f254c1341d437e7de971 Mon Sep 17 00:00:00 2001 From: Philipp Reisner Date: Thu, 1 Apr 2010 09:57:40 +0200 Subject: [PATCH] --- yaml --- r: 196847 b: refs/heads/master c: fd76438c2421324fa2fb9303e760ec5332ff0b58 h: refs/heads/master i: 196845: f2b7fd44a4b63bfcf17f2f89b987fa386f4080bb 196843: cacc340a8f6f34515800cbc70da6b90cc8296582 196839: 0b41a46a1a92282745721fb1ff1fc64be3fdf57f 196831: 2bdd1738771dcc702d102a73822d77b4f1965067 v: v3 --- [refs] | 2 +- trunk/drivers/block/drbd/drbd_bitmap.c | 6 ++++++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index 4f21a5890561..d1e4bb7d8470 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: e89b591c3aba0af87f5248b15f56ce7a4f439c16 +refs/heads/master: fd76438c2421324fa2fb9303e760ec5332ff0b58 diff --git a/trunk/drivers/block/drbd/drbd_bitmap.c b/trunk/drivers/block/drbd/drbd_bitmap.c index 695fb64cba00..178cf1642b2d 100644 --- a/trunk/drivers/block/drbd/drbd_bitmap.c +++ b/trunk/drivers/block/drbd/drbd_bitmap.c @@ -84,6 +84,9 @@ struct drbd_bitmap { #define BM_MD_IO_ERROR 1 #define BM_P_VMALLOCED 2 +int __bm_change_bits_to(struct drbd_conf *mdev, const unsigned long s, + unsigned long e, int val, const enum km_type km); + static int bm_is_locked(struct drbd_bitmap *b) { return test_bit(BM_LOCKED, &b->bm_flags); @@ -529,6 +532,9 @@ 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);