Commit d6b212f4 authored by Jonathan Brassow's avatar Jonathan Brassow Committed by NeilBrown

MD: raid5 do not set fullsync

Add check to determine if a device needs full resync or if partial resync will do

RAID 5 was assuming that if a device was not In_sync, it must undergo a full
resync.  We add a check to see if 'saved_raid_disk' is the same as 'raid_disk'.
If it is, we can safely skip the full resync and rely on the bitmap for
partial recovery instead.  This is the legitimate purpose of 'saved_raid_disk',
from md.h:
int saved_raid_disk;            /* role that device used to have in the
                                 * array and could again if we did a partial
                                 * resync from the bitmap
                                 */
Signed-off-by: default avatarJonathan Brassow <jbrassow@redhat.com>
Signed-off-by: default avatarNeilBrown <neilb@suse.de>
parent 9c81075f
...@@ -4858,7 +4858,7 @@ static raid5_conf_t *setup_conf(mddev_t *mddev) ...@@ -4858,7 +4858,7 @@ static raid5_conf_t *setup_conf(mddev_t *mddev)
printk(KERN_INFO "md/raid:%s: device %s operational as raid" printk(KERN_INFO "md/raid:%s: device %s operational as raid"
" disk %d\n", " disk %d\n",
mdname(mddev), bdevname(rdev->bdev, b), raid_disk); mdname(mddev), bdevname(rdev->bdev, b), raid_disk);
} else } else if (rdev->saved_raid_disk != raid_disk)
/* Cannot rely on bitmap to complete recovery */ /* Cannot rely on bitmap to complete recovery */
conf->fullsync = 1; conf->fullsync = 1;
} }
......
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