diff options
| author | Neil Brown <neilb@cse.unsw.edu.au> | 2003-08-30 22:44:06 -0700 |
|---|---|---|
| committer | Linus Torvalds <torvalds@home.osdl.org> | 2003-08-30 22:44:06 -0700 |
| commit | 505ec28de70e7b97a1aba11e1c3342822b8ae089 (patch) | |
| tree | a5ab07a24b3d1d91c09016c28002bc98f4c295ea | |
| parent | f556ef000efc90a45a285f4f0b4fd70bb70fa952 (diff) | |
[PATCH] Fix md superblock incompatabilities with 2.4 kernels.
2.4 kernels are very fussy about some values in the superblock, and
2.6 got them wrong. This fixes it.
| -rw-r--r-- | drivers/md/md.c | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/drivers/md/md.c b/drivers/md/md.c index 8c2df2953cbb..0dd0eb719161 100644 --- a/drivers/md/md.c +++ b/drivers/md/md.c @@ -638,14 +638,13 @@ static void super_90_sync(mddev_t *mddev, mdk_rdev_t *rdev) /* make rdev->sb match mddev data.. * * 1/ zero out disks - * 2/ Add info for each disk, keeping track of highest desc_nr - * 3/ any empty disks < highest become removed + * 2/ Add info for each disk, keeping track of highest desc_nr (next_spare); + * 3/ any empty disks < next_spare become removed * * disks[0] gets initialised to REMOVED because * we cannot be sure from other fields if it has * been initialised or not. */ - int highest = 0; int i; int active=0, working=0,failed=0,spare=0,nr_disks=0; @@ -716,17 +715,17 @@ static void super_90_sync(mddev_t *mddev, mdk_rdev_t *rdev) spare++; working++; } - if (rdev2->desc_nr > highest) - highest = rdev2->desc_nr; } - /* now set the "removed" bit on any non-trailing holes */ - for (i=0; i<highest; i++) { + /* now set the "removed" and "faulty" bits on any missing devices */ + for (i=0 ; i < mddev->raid_disks ; i++) { mdp_disk_t *d = &sb->disks[i]; if (d->state == 0 && d->number == 0) { d->number = i; d->raid_disk = i; d->state = (1<<MD_DISK_REMOVED); + d->state |= (1<<MD_DISK_FAULTY); + failed++; } } sb->nr_disks = nr_disks; |
