diff options
Diffstat (limited to 'drivers/md/raid5.c')
-rw-r--r-- | drivers/md/raid5.c | 149 |
1 files changed, 69 insertions, 80 deletions
diff --git a/drivers/md/raid5.c b/drivers/md/raid5.c index 81563b7c0357..cee9f93b35c4 100644 --- a/drivers/md/raid5.c +++ b/drivers/md/raid5.c | |||
@@ -1509,7 +1509,7 @@ static void raid5_end_read_request(struct bio * bi, int error) | |||
1509 | set_bit(R5_UPTODATE, &sh->dev[i].flags); | 1509 | set_bit(R5_UPTODATE, &sh->dev[i].flags); |
1510 | if (test_bit(R5_ReadError, &sh->dev[i].flags)) { | 1510 | if (test_bit(R5_ReadError, &sh->dev[i].flags)) { |
1511 | rdev = conf->disks[i].rdev; | 1511 | rdev = conf->disks[i].rdev; |
1512 | printk_rl(KERN_INFO "raid5:%s: read error corrected" | 1512 | printk_rl(KERN_INFO "md/raid:%s: read error corrected" |
1513 | " (%lu sectors at %llu on %s)\n", | 1513 | " (%lu sectors at %llu on %s)\n", |
1514 | mdname(conf->mddev), STRIPE_SECTORS, | 1514 | mdname(conf->mddev), STRIPE_SECTORS, |
1515 | (unsigned long long)(sh->sector | 1515 | (unsigned long long)(sh->sector |
@@ -1529,7 +1529,7 @@ static void raid5_end_read_request(struct bio * bi, int error) | |||
1529 | atomic_inc(&rdev->read_errors); | 1529 | atomic_inc(&rdev->read_errors); |
1530 | if (conf->mddev->degraded) | 1530 | if (conf->mddev->degraded) |
1531 | printk_rl(KERN_WARNING | 1531 | printk_rl(KERN_WARNING |
1532 | "raid5:%s: read error not correctable " | 1532 | "md/raid:%s: read error not correctable " |
1533 | "(sector %llu on %s).\n", | 1533 | "(sector %llu on %s).\n", |
1534 | mdname(conf->mddev), | 1534 | mdname(conf->mddev), |
1535 | (unsigned long long)(sh->sector | 1535 | (unsigned long long)(sh->sector |
@@ -1538,7 +1538,7 @@ static void raid5_end_read_request(struct bio * bi, int error) | |||
1538 | else if (test_bit(R5_ReWrite, &sh->dev[i].flags)) | 1538 | else if (test_bit(R5_ReWrite, &sh->dev[i].flags)) |
1539 | /* Oh, no!!! */ | 1539 | /* Oh, no!!! */ |
1540 | printk_rl(KERN_WARNING | 1540 | printk_rl(KERN_WARNING |
1541 | "raid5:%s: read error NOT corrected!! " | 1541 | "md/raid:%s: read error NOT corrected!! " |
1542 | "(sector %llu on %s).\n", | 1542 | "(sector %llu on %s).\n", |
1543 | mdname(conf->mddev), | 1543 | mdname(conf->mddev), |
1544 | (unsigned long long)(sh->sector | 1544 | (unsigned long long)(sh->sector |
@@ -1547,7 +1547,7 @@ static void raid5_end_read_request(struct bio * bi, int error) | |||
1547 | else if (atomic_read(&rdev->read_errors) | 1547 | else if (atomic_read(&rdev->read_errors) |
1548 | > conf->max_nr_stripes) | 1548 | > conf->max_nr_stripes) |
1549 | printk(KERN_WARNING | 1549 | printk(KERN_WARNING |
1550 | "raid5:%s: Too many read errors, failing device %s.\n", | 1550 | "md/raid:%s: Too many read errors, failing device %s.\n", |
1551 | mdname(conf->mddev), bdn); | 1551 | mdname(conf->mddev), bdn); |
1552 | else | 1552 | else |
1553 | retry = 1; | 1553 | retry = 1; |
@@ -1620,7 +1620,7 @@ static void error(mddev_t *mddev, mdk_rdev_t *rdev) | |||
1620 | { | 1620 | { |
1621 | char b[BDEVNAME_SIZE]; | 1621 | char b[BDEVNAME_SIZE]; |
1622 | raid5_conf_t *conf = mddev->private; | 1622 | raid5_conf_t *conf = mddev->private; |
1623 | pr_debug("raid5: error called\n"); | 1623 | pr_debug("raid456: error called\n"); |
1624 | 1624 | ||
1625 | if (!test_bit(Faulty, &rdev->flags)) { | 1625 | if (!test_bit(Faulty, &rdev->flags)) { |
1626 | set_bit(MD_CHANGE_DEVS, &mddev->flags); | 1626 | set_bit(MD_CHANGE_DEVS, &mddev->flags); |
@@ -1636,9 +1636,13 @@ static void error(mddev_t *mddev, mdk_rdev_t *rdev) | |||
1636 | } | 1636 | } |
1637 | set_bit(Faulty, &rdev->flags); | 1637 | set_bit(Faulty, &rdev->flags); |
1638 | printk(KERN_ALERT | 1638 | printk(KERN_ALERT |
1639 | "raid5: Disk failure on %s, disabling device.\n" | 1639 | "md/raid:%s: Disk failure on %s, disabling device.\n" |
1640 | "raid5: Operation continuing on %d devices.\n", | 1640 | KERN_ALERT |
1641 | bdevname(rdev->bdev,b), conf->raid_disks - mddev->degraded); | 1641 | "md/raid:%s: Operation continuing on %d devices.\n", |
1642 | mdname(mddev), | ||
1643 | bdevname(rdev->bdev, b), | ||
1644 | mdname(mddev), | ||
1645 | conf->raid_disks - mddev->degraded); | ||
1642 | } | 1646 | } |
1643 | } | 1647 | } |
1644 | 1648 | ||
@@ -1719,8 +1723,6 @@ static sector_t raid5_compute_sector(raid5_conf_t *conf, sector_t r_sector, | |||
1719 | pd_idx = data_disks; | 1723 | pd_idx = data_disks; |
1720 | break; | 1724 | break; |
1721 | default: | 1725 | default: |
1722 | printk(KERN_ERR "raid5: unsupported algorithm %d\n", | ||
1723 | algorithm); | ||
1724 | BUG(); | 1726 | BUG(); |
1725 | } | 1727 | } |
1726 | break; | 1728 | break; |
@@ -1836,10 +1838,7 @@ static sector_t raid5_compute_sector(raid5_conf_t *conf, sector_t r_sector, | |||
1836 | qd_idx = raid_disks - 1; | 1838 | qd_idx = raid_disks - 1; |
1837 | break; | 1839 | break; |
1838 | 1840 | ||
1839 | |||
1840 | default: | 1841 | default: |
1841 | printk(KERN_CRIT "raid6: unsupported algorithm %d\n", | ||
1842 | algorithm); | ||
1843 | BUG(); | 1842 | BUG(); |
1844 | } | 1843 | } |
1845 | break; | 1844 | break; |
@@ -1902,8 +1901,6 @@ static sector_t compute_blocknr(struct stripe_head *sh, int i, int previous) | |||
1902 | case ALGORITHM_PARITY_N: | 1901 | case ALGORITHM_PARITY_N: |
1903 | break; | 1902 | break; |
1904 | default: | 1903 | default: |
1905 | printk(KERN_ERR "raid5: unsupported algorithm %d\n", | ||
1906 | algorithm); | ||
1907 | BUG(); | 1904 | BUG(); |
1908 | } | 1905 | } |
1909 | break; | 1906 | break; |
@@ -1962,8 +1959,6 @@ static sector_t compute_blocknr(struct stripe_head *sh, int i, int previous) | |||
1962 | i -= 1; | 1959 | i -= 1; |
1963 | break; | 1960 | break; |
1964 | default: | 1961 | default: |
1965 | printk(KERN_CRIT "raid6: unsupported algorithm %d\n", | ||
1966 | algorithm); | ||
1967 | BUG(); | 1962 | BUG(); |
1968 | } | 1963 | } |
1969 | break; | 1964 | break; |
@@ -1976,7 +1971,8 @@ static sector_t compute_blocknr(struct stripe_head *sh, int i, int previous) | |||
1976 | previous, &dummy1, &sh2); | 1971 | previous, &dummy1, &sh2); |
1977 | if (check != sh->sector || dummy1 != dd_idx || sh2.pd_idx != sh->pd_idx | 1972 | if (check != sh->sector || dummy1 != dd_idx || sh2.pd_idx != sh->pd_idx |
1978 | || sh2.qd_idx != sh->qd_idx) { | 1973 | || sh2.qd_idx != sh->qd_idx) { |
1979 | printk(KERN_ERR "compute_blocknr: map not correct\n"); | 1974 | printk(KERN_ERR "md/raid:%s: compute_blocknr: map not correct\n", |
1975 | mdname(conf->mddev)); | ||
1980 | return 0; | 1976 | return 0; |
1981 | } | 1977 | } |
1982 | return r_sector; | 1978 | return r_sector; |
@@ -3942,7 +3938,7 @@ static int make_request(mddev_t *mddev, struct bio * bi) | |||
3942 | new_sector = raid5_compute_sector(conf, logical_sector, | 3938 | new_sector = raid5_compute_sector(conf, logical_sector, |
3943 | previous, | 3939 | previous, |
3944 | &dd_idx, NULL); | 3940 | &dd_idx, NULL); |
3945 | pr_debug("raid5: make_request, sector %llu logical %llu\n", | 3941 | pr_debug("raid456: make_request, sector %llu logical %llu\n", |
3946 | (unsigned long long)new_sector, | 3942 | (unsigned long long)new_sector, |
3947 | (unsigned long long)logical_sector); | 3943 | (unsigned long long)logical_sector); |
3948 | 3944 | ||
@@ -4721,7 +4717,7 @@ static raid5_conf_t *setup_conf(mddev_t *mddev) | |||
4721 | if (mddev->new_level != 5 | 4717 | if (mddev->new_level != 5 |
4722 | && mddev->new_level != 4 | 4718 | && mddev->new_level != 4 |
4723 | && mddev->new_level != 6) { | 4719 | && mddev->new_level != 6) { |
4724 | printk(KERN_ERR "raid5: %s: raid level not set to 4/5/6 (%d)\n", | 4720 | printk(KERN_ERR "md/raid:%s: raid level not set to 4/5/6 (%d)\n", |
4725 | mdname(mddev), mddev->new_level); | 4721 | mdname(mddev), mddev->new_level); |
4726 | return ERR_PTR(-EIO); | 4722 | return ERR_PTR(-EIO); |
4727 | } | 4723 | } |
@@ -4729,12 +4725,12 @@ static raid5_conf_t *setup_conf(mddev_t *mddev) | |||
4729 | && !algorithm_valid_raid5(mddev->new_layout)) || | 4725 | && !algorithm_valid_raid5(mddev->new_layout)) || |
4730 | (mddev->new_level == 6 | 4726 | (mddev->new_level == 6 |
4731 | && !algorithm_valid_raid6(mddev->new_layout))) { | 4727 | && !algorithm_valid_raid6(mddev->new_layout))) { |
4732 | printk(KERN_ERR "raid5: %s: layout %d not supported\n", | 4728 | printk(KERN_ERR "md/raid:%s: layout %d not supported\n", |
4733 | mdname(mddev), mddev->new_layout); | 4729 | mdname(mddev), mddev->new_layout); |
4734 | return ERR_PTR(-EIO); | 4730 | return ERR_PTR(-EIO); |
4735 | } | 4731 | } |
4736 | if (mddev->new_level == 6 && mddev->raid_disks < 4) { | 4732 | if (mddev->new_level == 6 && mddev->raid_disks < 4) { |
4737 | printk(KERN_ERR "raid6: not enough configured devices for %s (%d, minimum 4)\n", | 4733 | printk(KERN_ERR "md/raid:%s: not enough configured devices (%d, minimum 4)\n", |
4738 | mdname(mddev), mddev->raid_disks); | 4734 | mdname(mddev), mddev->raid_disks); |
4739 | return ERR_PTR(-EINVAL); | 4735 | return ERR_PTR(-EINVAL); |
4740 | } | 4736 | } |
@@ -4742,8 +4738,8 @@ static raid5_conf_t *setup_conf(mddev_t *mddev) | |||
4742 | if (!mddev->new_chunk_sectors || | 4738 | if (!mddev->new_chunk_sectors || |
4743 | (mddev->new_chunk_sectors << 9) % PAGE_SIZE || | 4739 | (mddev->new_chunk_sectors << 9) % PAGE_SIZE || |
4744 | !is_power_of_2(mddev->new_chunk_sectors)) { | 4740 | !is_power_of_2(mddev->new_chunk_sectors)) { |
4745 | printk(KERN_ERR "raid5: invalid chunk size %d for %s\n", | 4741 | printk(KERN_ERR "md/raid:%s: invalid chunk size %d\n", |
4746 | mddev->new_chunk_sectors << 9, mdname(mddev)); | 4742 | mdname(mddev), mddev->new_chunk_sectors << 9); |
4747 | return ERR_PTR(-EINVAL); | 4743 | return ERR_PTR(-EINVAL); |
4748 | } | 4744 | } |
4749 | 4745 | ||
@@ -4785,7 +4781,7 @@ static raid5_conf_t *setup_conf(mddev_t *mddev) | |||
4785 | if (raid5_alloc_percpu(conf) != 0) | 4781 | if (raid5_alloc_percpu(conf) != 0) |
4786 | goto abort; | 4782 | goto abort; |
4787 | 4783 | ||
4788 | pr_debug("raid5: run(%s) called.\n", mdname(mddev)); | 4784 | pr_debug("raid456: run(%s) called.\n", mdname(mddev)); |
4789 | 4785 | ||
4790 | list_for_each_entry(rdev, &mddev->disks, same_set) { | 4786 | list_for_each_entry(rdev, &mddev->disks, same_set) { |
4791 | raid_disk = rdev->raid_disk; | 4787 | raid_disk = rdev->raid_disk; |
@@ -4798,9 +4794,9 @@ static raid5_conf_t *setup_conf(mddev_t *mddev) | |||
4798 | 4794 | ||
4799 | if (test_bit(In_sync, &rdev->flags)) { | 4795 | if (test_bit(In_sync, &rdev->flags)) { |
4800 | char b[BDEVNAME_SIZE]; | 4796 | char b[BDEVNAME_SIZE]; |
4801 | printk(KERN_INFO "raid5: device %s operational as raid" | 4797 | printk(KERN_INFO "md/raid:%s: device %s operational as raid" |
4802 | " disk %d\n", bdevname(rdev->bdev,b), | 4798 | " disk %d\n", |
4803 | raid_disk); | 4799 | mdname(mddev), bdevname(rdev->bdev, b), raid_disk); |
4804 | } else | 4800 | } else |
4805 | /* Cannot rely on bitmap to complete recovery */ | 4801 | /* Cannot rely on bitmap to complete recovery */ |
4806 | conf->fullsync = 1; | 4802 | conf->fullsync = 1; |
@@ -4824,16 +4820,17 @@ static raid5_conf_t *setup_conf(mddev_t *mddev) | |||
4824 | max_disks * ((sizeof(struct bio) + PAGE_SIZE))) / 1024; | 4820 | max_disks * ((sizeof(struct bio) + PAGE_SIZE))) / 1024; |
4825 | if (grow_stripes(conf, conf->max_nr_stripes)) { | 4821 | if (grow_stripes(conf, conf->max_nr_stripes)) { |
4826 | printk(KERN_ERR | 4822 | printk(KERN_ERR |
4827 | "raid5: couldn't allocate %dkB for buffers\n", memory); | 4823 | "md/raid:%s: couldn't allocate %dkB for buffers\n", |
4824 | mdname(mddev), memory); | ||
4828 | goto abort; | 4825 | goto abort; |
4829 | } else | 4826 | } else |
4830 | printk(KERN_INFO "raid5: allocated %dkB for %s\n", | 4827 | printk(KERN_INFO "md/raid:%s: allocated %dkB\n", |
4831 | memory, mdname(mddev)); | 4828 | mdname(mddev), memory); |
4832 | 4829 | ||
4833 | conf->thread = md_register_thread(raid5d, mddev, NULL); | 4830 | conf->thread = md_register_thread(raid5d, mddev, NULL); |
4834 | if (!conf->thread) { | 4831 | if (!conf->thread) { |
4835 | printk(KERN_ERR | 4832 | printk(KERN_ERR |
4836 | "raid5: couldn't allocate thread for %s\n", | 4833 | "md/raid:%s: couldn't allocate thread.\n", |
4837 | mdname(mddev)); | 4834 | mdname(mddev)); |
4838 | goto abort; | 4835 | goto abort; |
4839 | } | 4836 | } |
@@ -4884,7 +4881,7 @@ static int run(mddev_t *mddev) | |||
4884 | sector_t reshape_offset = 0; | 4881 | sector_t reshape_offset = 0; |
4885 | 4882 | ||
4886 | if (mddev->recovery_cp != MaxSector) | 4883 | if (mddev->recovery_cp != MaxSector) |
4887 | printk(KERN_NOTICE "raid5: %s is not clean" | 4884 | printk(KERN_NOTICE "md/raid:%s: not clean" |
4888 | " -- starting background reconstruction\n", | 4885 | " -- starting background reconstruction\n", |
4889 | mdname(mddev)); | 4886 | mdname(mddev)); |
4890 | if (mddev->reshape_position != MaxSector) { | 4887 | if (mddev->reshape_position != MaxSector) { |
@@ -4898,7 +4895,7 @@ static int run(mddev_t *mddev) | |||
4898 | int max_degraded = (mddev->level == 6 ? 2 : 1); | 4895 | int max_degraded = (mddev->level == 6 ? 2 : 1); |
4899 | 4896 | ||
4900 | if (mddev->new_level != mddev->level) { | 4897 | if (mddev->new_level != mddev->level) { |
4901 | printk(KERN_ERR "raid5: %s: unsupported reshape " | 4898 | printk(KERN_ERR "md/raid:%s: unsupported reshape " |
4902 | "required - aborting.\n", | 4899 | "required - aborting.\n", |
4903 | mdname(mddev)); | 4900 | mdname(mddev)); |
4904 | return -EINVAL; | 4901 | return -EINVAL; |
@@ -4911,8 +4908,8 @@ static int run(mddev_t *mddev) | |||
4911 | here_new = mddev->reshape_position; | 4908 | here_new = mddev->reshape_position; |
4912 | if (sector_div(here_new, mddev->new_chunk_sectors * | 4909 | if (sector_div(here_new, mddev->new_chunk_sectors * |
4913 | (mddev->raid_disks - max_degraded))) { | 4910 | (mddev->raid_disks - max_degraded))) { |
4914 | printk(KERN_ERR "raid5: reshape_position not " | 4911 | printk(KERN_ERR "md/raid:%s: reshape_position not " |
4915 | "on a stripe boundary\n"); | 4912 | "on a stripe boundary\n", mdname(mddev)); |
4916 | return -EINVAL; | 4913 | return -EINVAL; |
4917 | } | 4914 | } |
4918 | reshape_offset = here_new * mddev->new_chunk_sectors; | 4915 | reshape_offset = here_new * mddev->new_chunk_sectors; |
@@ -4933,8 +4930,9 @@ static int run(mddev_t *mddev) | |||
4933 | if ((here_new * mddev->new_chunk_sectors != | 4930 | if ((here_new * mddev->new_chunk_sectors != |
4934 | here_old * mddev->chunk_sectors) || | 4931 | here_old * mddev->chunk_sectors) || |
4935 | mddev->ro == 0) { | 4932 | mddev->ro == 0) { |
4936 | printk(KERN_ERR "raid5: in-place reshape must be started" | 4933 | printk(KERN_ERR "md/raid:%s: in-place reshape must be started" |
4937 | " in read-only mode - aborting\n"); | 4934 | " in read-only mode - aborting\n", |
4935 | mdname(mddev)); | ||
4938 | return -EINVAL; | 4936 | return -EINVAL; |
4939 | } | 4937 | } |
4940 | } else if (mddev->delta_disks < 0 | 4938 | } else if (mddev->delta_disks < 0 |
@@ -4943,11 +4941,13 @@ static int run(mddev_t *mddev) | |||
4943 | : (here_new * mddev->new_chunk_sectors >= | 4941 | : (here_new * mddev->new_chunk_sectors >= |
4944 | here_old * mddev->chunk_sectors)) { | 4942 | here_old * mddev->chunk_sectors)) { |
4945 | /* Reading from the same stripe as writing to - bad */ | 4943 | /* Reading from the same stripe as writing to - bad */ |
4946 | printk(KERN_ERR "raid5: reshape_position too early for " | 4944 | printk(KERN_ERR "md/raid:%s: reshape_position too early for " |
4947 | "auto-recovery - aborting.\n"); | 4945 | "auto-recovery - aborting.\n", |
4946 | mdname(mddev)); | ||
4948 | return -EINVAL; | 4947 | return -EINVAL; |
4949 | } | 4948 | } |
4950 | printk(KERN_INFO "raid5: reshape will continue\n"); | 4949 | printk(KERN_INFO "md/raid:%s: reshape will continue\n", |
4950 | mdname(mddev)); | ||
4951 | /* OK, we should be able to continue; */ | 4951 | /* OK, we should be able to continue; */ |
4952 | } else { | 4952 | } else { |
4953 | BUG_ON(mddev->level != mddev->new_level); | 4953 | BUG_ON(mddev->level != mddev->new_level); |
@@ -4989,18 +4989,6 @@ static int run(mddev_t *mddev) | |||
4989 | mddev->minor_version > 90) | 4989 | mddev->minor_version > 90) |
4990 | rdev->recovery_offset = reshape_offset; | 4990 | rdev->recovery_offset = reshape_offset; |
4991 | 4991 | ||
4992 | printk("%d: w=%d pa=%d pr=%d m=%d a=%d r=%d op1=%d op2=%d\n", | ||
4993 | rdev->raid_disk, working_disks, conf->prev_algo, | ||
4994 | conf->previous_raid_disks, conf->max_degraded, | ||
4995 | conf->algorithm, conf->raid_disks, | ||
4996 | only_parity(rdev->raid_disk, | ||
4997 | conf->prev_algo, | ||
4998 | conf->previous_raid_disks, | ||
4999 | conf->max_degraded), | ||
5000 | only_parity(rdev->raid_disk, | ||
5001 | conf->algorithm, | ||
5002 | conf->raid_disks, | ||
5003 | conf->max_degraded)); | ||
5004 | if (rdev->recovery_offset < reshape_offset) { | 4992 | if (rdev->recovery_offset < reshape_offset) { |
5005 | /* We need to check old and new layout */ | 4993 | /* We need to check old and new layout */ |
5006 | if (!only_parity(rdev->raid_disk, | 4994 | if (!only_parity(rdev->raid_disk, |
@@ -5021,7 +5009,7 @@ static int run(mddev_t *mddev) | |||
5021 | - working_disks); | 5009 | - working_disks); |
5022 | 5010 | ||
5023 | if (mddev->degraded > conf->max_degraded) { | 5011 | if (mddev->degraded > conf->max_degraded) { |
5024 | printk(KERN_ERR "raid5: not enough operational devices for %s" | 5012 | printk(KERN_ERR "md/raid:%s: not enough operational devices" |
5025 | " (%d/%d failed)\n", | 5013 | " (%d/%d failed)\n", |
5026 | mdname(mddev), mddev->degraded, conf->raid_disks); | 5014 | mdname(mddev), mddev->degraded, conf->raid_disks); |
5027 | goto abort; | 5015 | goto abort; |
@@ -5035,32 +5023,32 @@ static int run(mddev_t *mddev) | |||
5035 | mddev->recovery_cp != MaxSector) { | 5023 | mddev->recovery_cp != MaxSector) { |
5036 | if (mddev->ok_start_degraded) | 5024 | if (mddev->ok_start_degraded) |
5037 | printk(KERN_WARNING | 5025 | printk(KERN_WARNING |
5038 | "raid5: starting dirty degraded array: %s" | 5026 | "md/raid:%s: starting dirty degraded array" |
5039 | "- data corruption possible.\n", | 5027 | " - data corruption possible.\n", |
5040 | mdname(mddev)); | 5028 | mdname(mddev)); |
5041 | else { | 5029 | else { |
5042 | printk(KERN_ERR | 5030 | printk(KERN_ERR |
5043 | "raid5: cannot start dirty degraded array for %s\n", | 5031 | "md/raid:%s: cannot start dirty degraded array.\n", |
5044 | mdname(mddev)); | 5032 | mdname(mddev)); |
5045 | goto abort; | 5033 | goto abort; |
5046 | } | 5034 | } |
5047 | } | 5035 | } |
5048 | 5036 | ||
5049 | if (mddev->degraded == 0) | 5037 | if (mddev->degraded == 0) |
5050 | printk("raid5: raid level %d set %s active with %d out of %d" | 5038 | printk(KERN_INFO "md/raid:%s: raid level %d active with %d out of %d" |
5051 | " devices, algorithm %d\n", conf->level, mdname(mddev), | 5039 | " devices, algorithm %d\n", mdname(mddev), conf->level, |
5052 | mddev->raid_disks-mddev->degraded, mddev->raid_disks, | 5040 | mddev->raid_disks-mddev->degraded, mddev->raid_disks, |
5053 | mddev->new_layout); | 5041 | mddev->new_layout); |
5054 | else | 5042 | else |
5055 | printk(KERN_ALERT "raid5: raid level %d set %s active with %d" | 5043 | printk(KERN_ALERT "md/raid:%s: raid level %d active with %d" |
5056 | " out of %d devices, algorithm %d\n", conf->level, | 5044 | " out of %d devices, algorithm %d\n", |
5057 | mdname(mddev), mddev->raid_disks - mddev->degraded, | 5045 | mdname(mddev), conf->level, |
5058 | mddev->raid_disks, mddev->new_layout); | 5046 | mddev->raid_disks - mddev->degraded, |
5047 | mddev->raid_disks, mddev->new_layout); | ||
5059 | 5048 | ||
5060 | print_raid5_conf(conf); | 5049 | print_raid5_conf(conf); |
5061 | 5050 | ||
5062 | if (conf->reshape_progress != MaxSector) { | 5051 | if (conf->reshape_progress != MaxSector) { |
5063 | printk("...ok start reshape thread\n"); | ||
5064 | conf->reshape_safe = conf->reshape_progress; | 5052 | conf->reshape_safe = conf->reshape_progress; |
5065 | atomic_set(&conf->reshape_stripes, 0); | 5053 | atomic_set(&conf->reshape_stripes, 0); |
5066 | clear_bit(MD_RECOVERY_SYNC, &mddev->recovery); | 5054 | clear_bit(MD_RECOVERY_SYNC, &mddev->recovery); |
@@ -5087,7 +5075,7 @@ static int run(mddev_t *mddev) | |||
5087 | mddev->to_remove = NULL; | 5075 | mddev->to_remove = NULL; |
5088 | else if (sysfs_create_group(&mddev->kobj, &raid5_attrs_group)) | 5076 | else if (sysfs_create_group(&mddev->kobj, &raid5_attrs_group)) |
5089 | printk(KERN_WARNING | 5077 | printk(KERN_WARNING |
5090 | "raid5: failed to create sysfs attributes for %s\n", | 5078 | "md/raid:%s: failed to create sysfs attributes.\n", |
5091 | mdname(mddev)); | 5079 | mdname(mddev)); |
5092 | 5080 | ||
5093 | mddev->queue->queue_lock = &conf->device_lock; | 5081 | mddev->queue->queue_lock = &conf->device_lock; |
@@ -5117,12 +5105,10 @@ abort: | |||
5117 | free_conf(conf); | 5105 | free_conf(conf); |
5118 | } | 5106 | } |
5119 | mddev->private = NULL; | 5107 | mddev->private = NULL; |
5120 | printk(KERN_ALERT "raid5: failed to run raid set %s\n", mdname(mddev)); | 5108 | printk(KERN_ALERT "md/raid:%s: failed to run raid set.\n", mdname(mddev)); |
5121 | return -EIO; | 5109 | return -EIO; |
5122 | } | 5110 | } |
5123 | 5111 | ||
5124 | |||
5125 | |||
5126 | static int stop(mddev_t *mddev) | 5112 | static int stop(mddev_t *mddev) |
5127 | { | 5113 | { |
5128 | raid5_conf_t *conf = mddev->private; | 5114 | raid5_conf_t *conf = mddev->private; |
@@ -5196,21 +5182,22 @@ static void print_raid5_conf (raid5_conf_t *conf) | |||
5196 | int i; | 5182 | int i; |
5197 | struct disk_info *tmp; | 5183 | struct disk_info *tmp; |
5198 | 5184 | ||
5199 | printk("RAID5 conf printout:\n"); | 5185 | printk(KERN_DEBUG "RAID conf printout:\n"); |
5200 | if (!conf) { | 5186 | if (!conf) { |
5201 | printk("(conf==NULL)\n"); | 5187 | printk("(conf==NULL)\n"); |
5202 | return; | 5188 | return; |
5203 | } | 5189 | } |
5204 | printk(" --- rd:%d wd:%d\n", conf->raid_disks, | 5190 | printk(KERN_DEBUG " --- level:%d rd:%d wd:%d\n", conf->level, |
5205 | conf->raid_disks - conf->mddev->degraded); | 5191 | conf->raid_disks, |
5192 | conf->raid_disks - conf->mddev->degraded); | ||
5206 | 5193 | ||
5207 | for (i = 0; i < conf->raid_disks; i++) { | 5194 | for (i = 0; i < conf->raid_disks; i++) { |
5208 | char b[BDEVNAME_SIZE]; | 5195 | char b[BDEVNAME_SIZE]; |
5209 | tmp = conf->disks + i; | 5196 | tmp = conf->disks + i; |
5210 | if (tmp->rdev) | 5197 | if (tmp->rdev) |
5211 | printk(" disk %d, o:%d, dev:%s\n", | 5198 | printk(KERN_DEBUG " disk %d, o:%d, dev:%s\n", |
5212 | i, !test_bit(Faulty, &tmp->rdev->flags), | 5199 | i, !test_bit(Faulty, &tmp->rdev->flags), |
5213 | bdevname(tmp->rdev->bdev,b)); | 5200 | bdevname(tmp->rdev->bdev, b)); |
5214 | } | 5201 | } |
5215 | } | 5202 | } |
5216 | 5203 | ||
@@ -5358,7 +5345,8 @@ static int check_stripe_cache(mddev_t *mddev) | |||
5358 | > conf->max_nr_stripes || | 5345 | > conf->max_nr_stripes || |
5359 | ((mddev->new_chunk_sectors << 9) / STRIPE_SIZE) * 4 | 5346 | ((mddev->new_chunk_sectors << 9) / STRIPE_SIZE) * 4 |
5360 | > conf->max_nr_stripes) { | 5347 | > conf->max_nr_stripes) { |
5361 | printk(KERN_WARNING "raid5: reshape: not enough stripes. Needed %lu\n", | 5348 | printk(KERN_WARNING "md/raid:%s: reshape: not enough stripes. Needed %lu\n", |
5349 | mdname(mddev), | ||
5362 | ((max(mddev->chunk_sectors, mddev->new_chunk_sectors) << 9) | 5350 | ((max(mddev->chunk_sectors, mddev->new_chunk_sectors) << 9) |
5363 | / STRIPE_SIZE)*4); | 5351 | / STRIPE_SIZE)*4); |
5364 | return 0; | 5352 | return 0; |
@@ -5429,7 +5417,7 @@ static int raid5_start_reshape(mddev_t *mddev) | |||
5429 | */ | 5417 | */ |
5430 | if (raid5_size(mddev, 0, conf->raid_disks + mddev->delta_disks) | 5418 | if (raid5_size(mddev, 0, conf->raid_disks + mddev->delta_disks) |
5431 | < mddev->array_sectors) { | 5419 | < mddev->array_sectors) { |
5432 | printk(KERN_ERR "md: %s: array size must be reduced " | 5420 | printk(KERN_ERR "md/raid:%s: array size must be reduced " |
5433 | "before number of disks\n", mdname(mddev)); | 5421 | "before number of disks\n", mdname(mddev)); |
5434 | return -EINVAL; | 5422 | return -EINVAL; |
5435 | } | 5423 | } |
@@ -5467,9 +5455,9 @@ static int raid5_start_reshape(mddev_t *mddev) | |||
5467 | if (sysfs_create_link(&mddev->kobj, | 5455 | if (sysfs_create_link(&mddev->kobj, |
5468 | &rdev->kobj, nm)) | 5456 | &rdev->kobj, nm)) |
5469 | printk(KERN_WARNING | 5457 | printk(KERN_WARNING |
5470 | "raid5: failed to create " | 5458 | "md/raid:%s: failed to create " |
5471 | " link %s for %s\n", | 5459 | " link %s\n", |
5472 | nm, mdname(mddev)); | 5460 | mdname(mddev), nm); |
5473 | } else | 5461 | } else |
5474 | break; | 5462 | break; |
5475 | } | 5463 | } |
@@ -5616,7 +5604,8 @@ static void *raid45_takeover_raid0(mddev_t *mddev, int level) | |||
5616 | 5604 | ||
5617 | /* for raid0 takeover only one zone is supported */ | 5605 | /* for raid0 takeover only one zone is supported */ |
5618 | if (raid0_priv->nr_strip_zones > 1) { | 5606 | if (raid0_priv->nr_strip_zones > 1) { |
5619 | printk(KERN_ERR "md: cannot takeover raid0 with more than one zone.\n"); | 5607 | printk(KERN_ERR "md/raid:%s: cannot takeover raid0 with more than one zone.\n", |
5608 | mdname(mddev)); | ||
5620 | return ERR_PTR(-EINVAL); | 5609 | return ERR_PTR(-EINVAL); |
5621 | } | 5610 | } |
5622 | 5611 | ||