md: allow a reshape operation to be reversed.
authorNeilBrown <neilb@suse.de>
Sun, 20 May 2012 23:27:00 +0000 (09:27 +1000)
committerNeilBrown <neilb@suse.de>
Sun, 20 May 2012 23:27:00 +0000 (09:27 +1000)
commit2c810cddc44d6f95cef75df3f07fc0850ff92417
tree185b35ce06656a53327dd66343f0926aa5a910d7
parentb5e1b8cee7ad58a15d2fa79bcd7946acb592602d
md: allow a reshape operation to be reversed.

Currently a reshape operation always progresses from the start
of the array to the end unless the number of devices is being
reduced, in which case it progressed in the opposite direction.

To reverse a partial reshape which changes the number of devices
you can stop the array and re-assemble with the raid-disks numbers
reversed and it will undo.

However for a reshape that does not change the number of devices
it is not possible to reverse the reshape in the middle - you have to
wait until it completes.

So add a 'reshape_direction' attribute with is either 'forwards' or
'backwards' and can be explicitly set when delta_disks is zero.

This will become more important when we allow the data_offset to
change in a reshape.  Then the explicit statement of what direction is
being used will be more useful.

This can be enabled in raid5 trivially as it already supports
reverse reshape and just needs to use a different trigger to request it.

Signed-off-by: NeilBrown <neilb@suse.de>
drivers/md/md.c
drivers/md/md.h
drivers/md/raid5.c
include/linux/raid/md_p.h