|
@@ -3126,6 +3126,11 @@ static int raid_ctr(struct dm_target *ti, unsigned int argc, char **argv)
|
|
|
set_bit(RT_FLAG_UPDATE_SBS, &rs->runtime_flags);
|
|
set_bit(RT_FLAG_UPDATE_SBS, &rs->runtime_flags);
|
|
|
rs_set_new(rs);
|
|
rs_set_new(rs);
|
|
|
} else if (rs_is_recovering(rs)) {
|
|
} else if (rs_is_recovering(rs)) {
|
|
|
|
|
+ /* Rebuild particular devices */
|
|
|
|
|
+ if (test_bit(__CTR_FLAG_REBUILD, &rs->ctr_flags)) {
|
|
|
|
|
+ set_bit(RT_FLAG_UPDATE_SBS, &rs->runtime_flags);
|
|
|
|
|
+ rs_setup_recovery(rs, MaxSector);
|
|
|
|
|
+ }
|
|
|
/* A recovering raid set may be resized */
|
|
/* A recovering raid set may be resized */
|
|
|
; /* skip setup rs */
|
|
; /* skip setup rs */
|
|
|
} else if (rs_is_reshaping(rs)) {
|
|
} else if (rs_is_reshaping(rs)) {
|