diff options
author | NeilBrown <neilb@suse.de> | 2007-05-09 05:35:36 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-05-09 15:30:57 -0400 |
commit | e11e93facc38fb264a5ff1e154ebb2f11dc5cffa (patch) | |
tree | 0128d05a5a3d51704f25ad4622b5dad4078d1430 | |
parent | c3f94b40e1676172dfa88abfffd8baffe7ac607c (diff) |
md: move test for whether level supports bitmap to correct place
We need to check for internal-consistency of superblock in load_super.
validate_super is for inter-device consistency.
With the test in the wrong place, a badly created array will confuse md rather
an produce sensible errors.
Signed-off-by: Neil Brown <neilb@suse.de>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | drivers/md/md.c | 42 |
1 files changed, 26 insertions, 16 deletions
diff --git a/drivers/md/md.c b/drivers/md/md.c index afff038ecf6f..64b35cbf3159 100644 --- a/drivers/md/md.c +++ b/drivers/md/md.c | |||
@@ -695,6 +695,17 @@ static int super_90_load(mdk_rdev_t *rdev, mdk_rdev_t *refdev, int minor_version | |||
695 | rdev->data_offset = 0; | 695 | rdev->data_offset = 0; |
696 | rdev->sb_size = MD_SB_BYTES; | 696 | rdev->sb_size = MD_SB_BYTES; |
697 | 697 | ||
698 | if (sb->state & (1<<MD_SB_BITMAP_PRESENT)) { | ||
699 | if (sb->level != 1 && sb->level != 4 | ||
700 | && sb->level != 5 && sb->level != 6 | ||
701 | && sb->level != 10) { | ||
702 | /* FIXME use a better test */ | ||
703 | printk(KERN_WARNING | ||
704 | "md: bitmaps not supported for this level.\n"); | ||
705 | goto abort; | ||
706 | } | ||
707 | } | ||
708 | |||
698 | if (sb->level == LEVEL_MULTIPATH) | 709 | if (sb->level == LEVEL_MULTIPATH) |
699 | rdev->desc_nr = -1; | 710 | rdev->desc_nr = -1; |
700 | else | 711 | else |
@@ -793,16 +804,8 @@ static int super_90_validate(mddev_t *mddev, mdk_rdev_t *rdev) | |||
793 | mddev->max_disks = MD_SB_DISKS; | 804 | mddev->max_disks = MD_SB_DISKS; |
794 | 805 | ||
795 | if (sb->state & (1<<MD_SB_BITMAP_PRESENT) && | 806 | if (sb->state & (1<<MD_SB_BITMAP_PRESENT) && |
796 | mddev->bitmap_file == NULL) { | 807 | mddev->bitmap_file == NULL) |
797 | if (mddev->level != 1 && mddev->level != 4 | ||
798 | && mddev->level != 5 && mddev->level != 6 | ||
799 | && mddev->level != 10) { | ||
800 | /* FIXME use a better test */ | ||
801 | printk(KERN_WARNING "md: bitmaps not supported for this level.\n"); | ||
802 | return -EINVAL; | ||
803 | } | ||
804 | mddev->bitmap_offset = mddev->default_bitmap_offset; | 808 | mddev->bitmap_offset = mddev->default_bitmap_offset; |
805 | } | ||
806 | 809 | ||
807 | } else if (mddev->pers == NULL) { | 810 | } else if (mddev->pers == NULL) { |
808 | /* Insist on good event counter while assembling */ | 811 | /* Insist on good event counter while assembling */ |
@@ -1059,6 +1062,18 @@ static int super_1_load(mdk_rdev_t *rdev, mdk_rdev_t *refdev, int minor_version) | |||
1059 | bdevname(rdev->bdev,b)); | 1062 | bdevname(rdev->bdev,b)); |
1060 | return -EINVAL; | 1063 | return -EINVAL; |
1061 | } | 1064 | } |
1065 | if ((le32_to_cpu(sb->feature_map) & MD_FEATURE_BITMAP_OFFSET)) { | ||
1066 | if (sb->level != cpu_to_le32(1) && | ||
1067 | sb->level != cpu_to_le32(4) && | ||
1068 | sb->level != cpu_to_le32(5) && | ||
1069 | sb->level != cpu_to_le32(6) && | ||
1070 | sb->level != cpu_to_le32(10)) { | ||
1071 | printk(KERN_WARNING | ||
1072 | "md: bitmaps not supported for this level.\n"); | ||
1073 | return -EINVAL; | ||
1074 | } | ||
1075 | } | ||
1076 | |||
1062 | rdev->preferred_minor = 0xffff; | 1077 | rdev->preferred_minor = 0xffff; |
1063 | rdev->data_offset = le64_to_cpu(sb->data_offset); | 1078 | rdev->data_offset = le64_to_cpu(sb->data_offset); |
1064 | atomic_set(&rdev->corrected_errors, le32_to_cpu(sb->cnt_corrected_read)); | 1079 | atomic_set(&rdev->corrected_errors, le32_to_cpu(sb->cnt_corrected_read)); |
@@ -1142,14 +1157,9 @@ static int super_1_validate(mddev_t *mddev, mdk_rdev_t *rdev) | |||
1142 | mddev->max_disks = (4096-256)/2; | 1157 | mddev->max_disks = (4096-256)/2; |
1143 | 1158 | ||
1144 | if ((le32_to_cpu(sb->feature_map) & MD_FEATURE_BITMAP_OFFSET) && | 1159 | if ((le32_to_cpu(sb->feature_map) & MD_FEATURE_BITMAP_OFFSET) && |
1145 | mddev->bitmap_file == NULL ) { | 1160 | mddev->bitmap_file == NULL ) |
1146 | if (mddev->level != 1 && mddev->level != 5 && mddev->level != 6 | ||
1147 | && mddev->level != 10) { | ||
1148 | printk(KERN_WARNING "md: bitmaps not supported for this level.\n"); | ||
1149 | return -EINVAL; | ||
1150 | } | ||
1151 | mddev->bitmap_offset = (__s32)le32_to_cpu(sb->bitmap_offset); | 1161 | mddev->bitmap_offset = (__s32)le32_to_cpu(sb->bitmap_offset); |
1152 | } | 1162 | |
1153 | if ((le32_to_cpu(sb->feature_map) & MD_FEATURE_RESHAPE_ACTIVE)) { | 1163 | if ((le32_to_cpu(sb->feature_map) & MD_FEATURE_RESHAPE_ACTIVE)) { |
1154 | mddev->reshape_position = le64_to_cpu(sb->reshape_position); | 1164 | mddev->reshape_position = le64_to_cpu(sb->reshape_position); |
1155 | mddev->delta_disks = le32_to_cpu(sb->delta_disks); | 1165 | mddev->delta_disks = le32_to_cpu(sb->delta_disks); |