Commit cbce6863 authored by Guoqing Jiang's avatar Guoqing Jiang Committed by Shaohua Li

md-cluster/bitmap: don't call md_bitmap_sync_with_cluster during reshaping stage

When reshape is happening in one node, other nodes could receive
lots of RESYNCING messages, so md_bitmap_sync_with_cluster is called.

Since the resyncing window is typically small in these RESYNCING
messages, so WARN is always triggered, so we should not call the
func when reshape is happening.
Reviewed-by: default avatarNeilBrown <neilb@suse.com>
Signed-off-by: default avatarGuoqing Jiang <gqjiang@suse.com>
Signed-off-by: default avatarShaohua Li <shli@fb.com>
parent ca1e98e0
...@@ -457,12 +457,13 @@ static void remove_suspend_info(struct mddev *mddev, int slot) ...@@ -457,12 +457,13 @@ static void remove_suspend_info(struct mddev *mddev, int slot)
mddev->pers->quiesce(mddev, 0); mddev->pers->quiesce(mddev, 0);
} }
static void process_suspend_info(struct mddev *mddev, static void process_suspend_info(struct mddev *mddev,
int slot, sector_t lo, sector_t hi) int slot, sector_t lo, sector_t hi)
{ {
struct md_cluster_info *cinfo = mddev->cluster_info; struct md_cluster_info *cinfo = mddev->cluster_info;
struct suspend_info *s; struct suspend_info *s;
struct mdp_superblock_1 *sb = NULL;
struct md_rdev *rdev;
if (!hi) { if (!hi) {
/* /*
...@@ -476,6 +477,12 @@ static void process_suspend_info(struct mddev *mddev, ...@@ -476,6 +477,12 @@ static void process_suspend_info(struct mddev *mddev,
return; return;
} }
rdev_for_each(rdev, mddev)
if (rdev->raid_disk > -1 && !test_bit(Faulty, &rdev->flags)) {
sb = page_address(rdev->sb_page);
break;
}
/* /*
* The bitmaps are not same for different nodes * The bitmaps are not same for different nodes
* if RESYNCING is happening in one node, then * if RESYNCING is happening in one node, then
...@@ -488,12 +495,18 @@ static void process_suspend_info(struct mddev *mddev, ...@@ -488,12 +495,18 @@ static void process_suspend_info(struct mddev *mddev,
* sync_low/hi is used to record the region which * sync_low/hi is used to record the region which
* arrived in the previous RESYNCING message, * arrived in the previous RESYNCING message,
* *
* Call bitmap_sync_with_cluster to clear * Call md_bitmap_sync_with_cluster to clear NEEDED_MASK
* NEEDED_MASK and set RESYNC_MASK since * and set RESYNC_MASK since resync thread is running
* resync thread is running in another node, * in another node, so we don't need to do the resync
* so we don't need to do the resync again * again with the same section.
* with the same section */ *
md_bitmap_sync_with_cluster(mddev, cinfo->sync_low, cinfo->sync_hi, lo, hi); * Skip md_bitmap_sync_with_cluster in case reshape
* happening, because reshaping region is small and
* we don't want to trigger lots of WARN.
*/
if (sb && !(le32_to_cpu(sb->feature_map) & MD_FEATURE_RESHAPE_ACTIVE))
md_bitmap_sync_with_cluster(mddev, cinfo->sync_low,
cinfo->sync_hi, lo, hi);
cinfo->sync_low = lo; cinfo->sync_low = lo;
cinfo->sync_hi = hi; cinfo->sync_hi = hi;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment