diff options
author | NeilBrown <neilb@suse.de> | 2009-11-12 12:08:04 +1100 |
---|---|---|
committer | NeilBrown <neilb@suse.de> | 2009-11-12 12:08:04 +1100 |
commit | 5e8651060cea6b44844521ddcac665e2c021f5d8 (patch) | |
tree | 56a2a3de85fae3f7e210c54a9cda305b0341c334 | |
parent | 8dee7211467a56b7eb4e4359efb0aa4a72e1b6f3 (diff) | |
download | kernel_samsung_smdk4412-5e8651060cea6b44844521ddcac665e2c021f5d8.zip kernel_samsung_smdk4412-5e8651060cea6b44844521ddcac665e2c021f5d8.tar.gz kernel_samsung_smdk4412-5e8651060cea6b44844521ddcac665e2c021f5d8.tar.bz2 |
md: factor out updating of 'recovery_offset'.
Each device has its own 'recovery_offset' showing how far
recovery has progressed on the device.
As the only real significance of this is that fact that it can
be stored in the metadata and recovered at restart, and as
only 1.x metadata can do this, we were only updating
'recovery_offset' to 'curr_resync_completed' when updating
v1.x metadata.
But this is wrong, and we will shortly make limited use of this
field in v0.90 metadata.
So move the update into common code.
Signed-off-by: NeilBrown <neilb@suse.de>
-rw-r--r-- | drivers/md/md.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/drivers/md/md.c b/drivers/md/md.c index e64c971..01b9a0f 100644 --- a/drivers/md/md.c +++ b/drivers/md/md.c @@ -1382,8 +1382,6 @@ static void super_1_sync(mddev_t *mddev, mdk_rdev_t *rdev) if (rdev->raid_disk >= 0 && !test_bit(In_sync, &rdev->flags)) { - if (mddev->curr_resync_completed > rdev->recovery_offset) - rdev->recovery_offset = mddev->curr_resync_completed; if (rdev->recovery_offset > 0) { sb->feature_map |= cpu_to_le32(MD_FEATURE_RECOVERY_OFFSET); @@ -1917,6 +1915,14 @@ static void sync_sbs(mddev_t * mddev, int nospares) */ mdk_rdev_t *rdev; + /* First make sure individual recovery_offsets are correct */ + list_for_each_entry(rdev, &mddev->disks, same_set) { + if (rdev->raid_disk >= 0 && + !test_bit(In_sync, &rdev->flags) && + mddev->curr_resync_completed > rdev->recovery_offset) + rdev->recovery_offset = mddev->curr_resync_completed; + + } list_for_each_entry(rdev, &mddev->disks, same_set) { if (rdev->sb_events == mddev->events || (nospares && |