imsm: FIX: Restore critical section on degraded array
When during assembly degradation occurs restoring metadata critical section fails whole assembly. Allow for degradation during assembly and not restore data on degraded disk. Signed-off-by: Adam Kwolek <adam.kwolek@intel.com> Signed-off-by: NeilBrown <neilb@suse.de>
This commit is contained in:
parent
3f510843b1
commit
f627f5ad43
|
@ -7983,6 +7983,10 @@ static void imsm_delete(struct intel_super *super, struct dl **dlp, unsigned ind
|
|||
int open_backup_targets(struct mdinfo *info, int raid_disks, int *raid_fds)
|
||||
{
|
||||
struct mdinfo *sd;
|
||||
int i;
|
||||
|
||||
for (i = 0; i < raid_disks; i++)
|
||||
raid_fds[i] = -1;
|
||||
|
||||
for (sd = info->devs ; sd ; sd = sd->next) {
|
||||
char *dn;
|
||||
|
@ -8292,7 +8296,11 @@ int recover_backup_imsm(struct supertype *st, struct mdinfo *info)
|
|||
if (!targets)
|
||||
goto abort;
|
||||
|
||||
open_backup_targets(info, new_disks, targets);
|
||||
if (open_backup_targets(info, new_disks, targets)) {
|
||||
fprintf(stderr,
|
||||
Name ": Cannot open some devices belonging to array.\n");
|
||||
goto abort;
|
||||
}
|
||||
|
||||
for (i = 0; i < new_disks; i++) {
|
||||
if (targets[i] < 0) {
|
||||
|
|
Loading…
Reference in New Issue