Commit 8ed0a521 authored by Neil Brown's avatar Neil Brown

Enable setting of 'offset' and 'size' of a hot-added spare.

offset_store and rdev_size_store allow control of the region of a
device which is to be using in an md/raid array.
They only allow these values to be set when an array is being assembled,
as changing them on an active array could be dangerous.
However when adding a spare device to an array, we might need to
set the offset and size before starting recovery.  So allow
these values to be set also if "->raid_disk < 0" which indicates that
the device is still a spare.
Signed-off-by: default avatarNeil Brown <neilb@suse.de>
parent 1a0fd497
...@@ -1984,7 +1984,7 @@ offset_store(mdk_rdev_t *rdev, const char *buf, size_t len) ...@@ -1984,7 +1984,7 @@ offset_store(mdk_rdev_t *rdev, const char *buf, size_t len)
unsigned long long offset = simple_strtoull(buf, &e, 10); unsigned long long offset = simple_strtoull(buf, &e, 10);
if (e==buf || (*e && *e != '\n')) if (e==buf || (*e && *e != '\n'))
return -EINVAL; return -EINVAL;
if (rdev->mddev->pers) if (rdev->mddev->pers && rdev->raid_disk >= 0)
return -EBUSY; return -EBUSY;
if (rdev->size && rdev->mddev->external) if (rdev->size && rdev->mddev->external)
/* Must set offset before size, so overlap checks /* Must set offset before size, so overlap checks
...@@ -2023,7 +2023,7 @@ rdev_size_store(mdk_rdev_t *rdev, const char *buf, size_t len) ...@@ -2023,7 +2023,7 @@ rdev_size_store(mdk_rdev_t *rdev, const char *buf, size_t len)
if (e==buf || (*e && *e != '\n')) if (e==buf || (*e && *e != '\n'))
return -EINVAL; return -EINVAL;
if (my_mddev->pers) if (my_mddev->pers && rdev->raid_disk >= 0)
return -EBUSY; return -EBUSY;
rdev->size = size; rdev->size = size;
if (size > oldsize && rdev->mddev->external) { if (size > oldsize && rdev->mddev->external) {
......
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