DM RAID: Fix for "sync" directive ineffectiveness
authorJonathan Brassow <jbrassow@redhat.com>
Thu, 11 Oct 2012 02:42:19 +0000 (13:42 +1100)
committerNeilBrown <neilb@suse.de>
Thu, 11 Oct 2012 02:42:19 +0000 (13:42 +1100)
commit761becff016b82a6a7a1b2ef224248da5f46bae9
treebf9e1b479b85c659c9f54cb479bed9804484c011
parent7386199c471f70526bbcc629f072a5a8effe218f
DM RAID: Fix for "sync" directive ineffectiveness

There are two table arguments that can be given to a DM RAID target
that control whether the array is forced to (re)synchronize or skip
initialization: "sync" and "nosync".  When "sync" is given, we set
mddev->recovery_cp to 0 in order to cause the device to resynchronize.
This is insufficient if there is a bitmap in use, because the array
will simply look at the bitmap and see that there is no recovery
necessary.

The fix is to skip over the loading of the superblocks when "sync" is
given, causing new superblocks to be written that will force the array
to go through initialization (i.e. synchronization).

Signed-off-by: Jonathan Brassow <jbrassow@redhat.com>
Signed-off-by: NeilBrown <neilb@suse.de>
drivers/md/dm-raid.c