diff options
author | NeilBrown <neilb@suse.de> | 2009-12-29 20:08:50 -0500 |
---|---|---|
committer | NeilBrown <neilb@suse.de> | 2009-12-29 23:20:12 -0500 |
commit | 0f9552b5dc4fe10da37fa3f4a4ca185d90fa41c9 (patch) | |
tree | 14f29af551fc226dc4451f1089d4f08dc2611c0d | |
parent | cbd1998377504df005302ac90d49db72a48552a6 (diff) |
md: fix small irregularity with start_ro module parameter
The start_ro modules parameter can be used to force arrays to be
started in 'auto-readonly' in which they are read-only until the first
write. This ensures that no resync/recovery happens until something
else writes to the device. This is important for resume-from-disk
off an md array.
However if an array is started 'readonly' (by writing 'readonly' to
the 'array_state' sysfs attribute) we want it to be really 'readonly',
not 'auto-readonly'.
So strengthen the condition to only set auto-readonly if the
array is not already read-only.
Signed-off-by: NeilBrown <neilb@suse.de>
-rw-r--r-- | drivers/md/md.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/md/md.c b/drivers/md/md.c index 7862231a0750..d2aff7209070 100644 --- a/drivers/md/md.c +++ b/drivers/md/md.c | |||
@@ -4357,7 +4357,7 @@ static int do_md_run(mddev_t * mddev) | |||
4357 | mddev->barriers_work = 1; | 4357 | mddev->barriers_work = 1; |
4358 | mddev->ok_start_degraded = start_dirty_degraded; | 4358 | mddev->ok_start_degraded = start_dirty_degraded; |
4359 | 4359 | ||
4360 | if (start_readonly) | 4360 | if (start_readonly && mddev->ro == 0) |
4361 | mddev->ro = 2; /* read-only, but switch on first write */ | 4361 | mddev->ro = 2; /* read-only, but switch on first write */ |
4362 | 4362 | ||
4363 | err = mddev->pers->run(mddev); | 4363 | err = mddev->pers->run(mddev); |