diff options
-rw-r--r-- | drivers/md/raid5.c | 17 | ||||
-rw-r--r-- | drivers/md/raid5.h | 2 |
2 files changed, 9 insertions, 10 deletions
diff --git a/drivers/md/raid5.c b/drivers/md/raid5.c index 1f1b054ff0b6..3930b3e9aa04 100644 --- a/drivers/md/raid5.c +++ b/drivers/md/raid5.c | |||
@@ -2371,7 +2371,7 @@ static void handle_stripe_dirtying6(raid5_conf_t *conf, | |||
2371 | struct r6_state *r6s, int disks) | 2371 | struct r6_state *r6s, int disks) |
2372 | { | 2372 | { |
2373 | int rcw = 0, must_compute = 0, pd_idx = sh->pd_idx, i; | 2373 | int rcw = 0, must_compute = 0, pd_idx = sh->pd_idx, i; |
2374 | int qd_idx = r6s->qd_idx; | 2374 | int qd_idx = sh->qd_idx; |
2375 | for (i = disks; i--; ) { | 2375 | for (i = disks; i--; ) { |
2376 | struct r5dev *dev = &sh->dev[i]; | 2376 | struct r5dev *dev = &sh->dev[i]; |
2377 | /* Would I have to read this buffer for reconstruct_write */ | 2377 | /* Would I have to read this buffer for reconstruct_write */ |
@@ -2561,7 +2561,7 @@ static void handle_parity_checks6(raid5_conf_t *conf, struct stripe_head *sh, | |||
2561 | int update_p = 0, update_q = 0; | 2561 | int update_p = 0, update_q = 0; |
2562 | struct r5dev *dev; | 2562 | struct r5dev *dev; |
2563 | int pd_idx = sh->pd_idx; | 2563 | int pd_idx = sh->pd_idx; |
2564 | int qd_idx = r6s->qd_idx; | 2564 | int qd_idx = sh->qd_idx; |
2565 | 2565 | ||
2566 | set_bit(STRIPE_HANDLE, &sh->state); | 2566 | set_bit(STRIPE_HANDLE, &sh->state); |
2567 | 2567 | ||
@@ -2657,7 +2657,7 @@ static void handle_stripe_expansion(raid5_conf_t *conf, struct stripe_head *sh, | |||
2657 | struct dma_async_tx_descriptor *tx = NULL; | 2657 | struct dma_async_tx_descriptor *tx = NULL; |
2658 | clear_bit(STRIPE_EXPAND_SOURCE, &sh->state); | 2658 | clear_bit(STRIPE_EXPAND_SOURCE, &sh->state); |
2659 | for (i = 0; i < sh->disks; i++) | 2659 | for (i = 0; i < sh->disks; i++) |
2660 | if (i != sh->pd_idx && (!r6s || i != r6s->qd_idx)) { | 2660 | if (i != sh->pd_idx && i != sh->qd_idx) { |
2661 | int dd_idx, j; | 2661 | int dd_idx, j; |
2662 | struct stripe_head *sh2; | 2662 | struct stripe_head *sh2; |
2663 | 2663 | ||
@@ -2984,17 +2984,16 @@ static bool handle_stripe6(struct stripe_head *sh, struct page *tmp_page) | |||
2984 | raid5_conf_t *conf = sh->raid_conf; | 2984 | raid5_conf_t *conf = sh->raid_conf; |
2985 | int disks = sh->disks; | 2985 | int disks = sh->disks; |
2986 | struct bio *return_bi = NULL; | 2986 | struct bio *return_bi = NULL; |
2987 | int i, pd_idx = sh->pd_idx; | 2987 | int i, pd_idx = sh->pd_idx, qd_idx = sh->qd_idx; |
2988 | struct stripe_head_state s; | 2988 | struct stripe_head_state s; |
2989 | struct r6_state r6s; | 2989 | struct r6_state r6s; |
2990 | struct r5dev *dev, *pdev, *qdev; | 2990 | struct r5dev *dev, *pdev, *qdev; |
2991 | mdk_rdev_t *blocked_rdev = NULL; | 2991 | mdk_rdev_t *blocked_rdev = NULL; |
2992 | 2992 | ||
2993 | r6s.qd_idx = sh->qd_idx; | ||
2994 | pr_debug("handling stripe %llu, state=%#lx cnt=%d, " | 2993 | pr_debug("handling stripe %llu, state=%#lx cnt=%d, " |
2995 | "pd_idx=%d, qd_idx=%d\n", | 2994 | "pd_idx=%d, qd_idx=%d\n", |
2996 | (unsigned long long)sh->sector, sh->state, | 2995 | (unsigned long long)sh->sector, sh->state, |
2997 | atomic_read(&sh->count), pd_idx, r6s.qd_idx); | 2996 | atomic_read(&sh->count), pd_idx, qd_idx); |
2998 | memset(&s, 0, sizeof(s)); | 2997 | memset(&s, 0, sizeof(s)); |
2999 | 2998 | ||
3000 | spin_lock(&sh->lock); | 2999 | spin_lock(&sh->lock); |
@@ -3105,9 +3104,9 @@ static bool handle_stripe6(struct stripe_head *sh, struct page *tmp_page) | |||
3105 | pdev = &sh->dev[pd_idx]; | 3104 | pdev = &sh->dev[pd_idx]; |
3106 | r6s.p_failed = (s.failed >= 1 && r6s.failed_num[0] == pd_idx) | 3105 | r6s.p_failed = (s.failed >= 1 && r6s.failed_num[0] == pd_idx) |
3107 | || (s.failed >= 2 && r6s.failed_num[1] == pd_idx); | 3106 | || (s.failed >= 2 && r6s.failed_num[1] == pd_idx); |
3108 | qdev = &sh->dev[r6s.qd_idx]; | 3107 | qdev = &sh->dev[qd_idx]; |
3109 | r6s.q_failed = (s.failed >= 1 && r6s.failed_num[0] == r6s.qd_idx) | 3108 | r6s.q_failed = (s.failed >= 1 && r6s.failed_num[0] == qd_idx) |
3110 | || (s.failed >= 2 && r6s.failed_num[1] == r6s.qd_idx); | 3109 | || (s.failed >= 2 && r6s.failed_num[1] == qd_idx); |
3111 | 3110 | ||
3112 | if ( s.written && | 3111 | if ( s.written && |
3113 | ( r6s.p_failed || ((test_bit(R5_Insync, &pdev->flags) | 3112 | ( r6s.p_failed || ((test_bit(R5_Insync, &pdev->flags) |
diff --git a/drivers/md/raid5.h b/drivers/md/raid5.h index 2934ee0a39c6..c2f37f25ef44 100644 --- a/drivers/md/raid5.h +++ b/drivers/md/raid5.h | |||
@@ -239,7 +239,7 @@ struct stripe_head_state { | |||
239 | 239 | ||
240 | /* r6_state - extra state data only relevant to r6 */ | 240 | /* r6_state - extra state data only relevant to r6 */ |
241 | struct r6_state { | 241 | struct r6_state { |
242 | int p_failed, q_failed, qd_idx, failed_num[2]; | 242 | int p_failed, q_failed, failed_num[2]; |
243 | }; | 243 | }; |
244 | 244 | ||
245 | /* Flags */ | 245 | /* Flags */ |