Skip to content

Commit 7267212

Browse files
committed
Merge tag 'md/4.15-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/shli/md
Pull md fixes from Shaohua Li: "Some MD fixes. The notable one is a raid5-cache deadlock bug with dm-raid, others are not significant" * tag 'md/4.15-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/shli/md: md/raid1/10: add missed blk plug md: limit mdstat resync progress to max_sectors md/r5cache: move mddev_lock() out of r5c_journal_mode_set() md/raid5: correct degraded calculation in raid5_error
2 parents 78d9b04 + 18022a1 commit 7267212

File tree

5 files changed

+21
-15
lines changed

5 files changed

+21
-15
lines changed

drivers/md/md.c

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -7605,7 +7605,9 @@ static int status_resync(struct seq_file *seq, struct mddev *mddev)
76057605
if (test_bit(MD_RECOVERY_DONE, &mddev->recovery))
76067606
/* Still cleaning up */
76077607
resync = max_sectors;
7608-
} else
7608+
} else if (resync > max_sectors)
7609+
resync = max_sectors;
7610+
else
76097611
resync -= atomic_read(&mddev->recovery_active);
76107612

76117613
if (resync == 0) {

drivers/md/raid1.c

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -809,11 +809,15 @@ static void flush_pending_writes(struct r1conf *conf)
809809
spin_lock_irq(&conf->device_lock);
810810

811811
if (conf->pending_bio_list.head) {
812+
struct blk_plug plug;
812813
struct bio *bio;
814+
813815
bio = bio_list_get(&conf->pending_bio_list);
814816
conf->pending_count = 0;
815817
spin_unlock_irq(&conf->device_lock);
818+
blk_start_plug(&plug);
816819
flush_bio_list(conf, bio);
820+
blk_finish_plug(&plug);
817821
} else
818822
spin_unlock_irq(&conf->device_lock);
819823
}

drivers/md/raid10.c

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -894,10 +894,13 @@ static void flush_pending_writes(struct r10conf *conf)
894894
spin_lock_irq(&conf->device_lock);
895895

896896
if (conf->pending_bio_list.head) {
897+
struct blk_plug plug;
897898
struct bio *bio;
899+
898900
bio = bio_list_get(&conf->pending_bio_list);
899901
conf->pending_count = 0;
900902
spin_unlock_irq(&conf->device_lock);
903+
blk_start_plug(&plug);
901904
/* flush any pending bitmap writes to disk
902905
* before proceeding w/ I/O */
903906
bitmap_unplug(conf->mddev->bitmap);
@@ -918,6 +921,7 @@ static void flush_pending_writes(struct r10conf *conf)
918921
generic_make_request(bio);
919922
bio = next;
920923
}
924+
blk_finish_plug(&plug);
921925
} else
922926
spin_unlock_irq(&conf->device_lock);
923927
}

drivers/md/raid5-cache.c

Lines changed: 9 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -2577,31 +2577,22 @@ static ssize_t r5c_journal_mode_show(struct mddev *mddev, char *page)
25772577
int r5c_journal_mode_set(struct mddev *mddev, int mode)
25782578
{
25792579
struct r5conf *conf;
2580-
int err;
25812580

25822581
if (mode < R5C_JOURNAL_MODE_WRITE_THROUGH ||
25832582
mode > R5C_JOURNAL_MODE_WRITE_BACK)
25842583
return -EINVAL;
25852584

2586-
err = mddev_lock(mddev);
2587-
if (err)
2588-
return err;
25892585
conf = mddev->private;
2590-
if (!conf || !conf->log) {
2591-
mddev_unlock(mddev);
2586+
if (!conf || !conf->log)
25922587
return -ENODEV;
2593-
}
25942588

25952589
if (raid5_calc_degraded(conf) > 0 &&
2596-
mode == R5C_JOURNAL_MODE_WRITE_BACK) {
2597-
mddev_unlock(mddev);
2590+
mode == R5C_JOURNAL_MODE_WRITE_BACK)
25982591
return -EINVAL;
2599-
}
26002592

26012593
mddev_suspend(mddev);
26022594
conf->log->r5c_journal_mode = mode;
26032595
mddev_resume(mddev);
2604-
mddev_unlock(mddev);
26052596

26062597
pr_debug("md/raid:%s: setting r5c cache mode to %d: %s\n",
26072598
mdname(mddev), mode, r5c_journal_mode_str[mode]);
@@ -2614,6 +2605,7 @@ static ssize_t r5c_journal_mode_store(struct mddev *mddev,
26142605
{
26152606
int mode = ARRAY_SIZE(r5c_journal_mode_str);
26162607
size_t len = length;
2608+
int ret;
26172609

26182610
if (len < 2)
26192611
return -EINVAL;
@@ -2625,8 +2617,12 @@ static ssize_t r5c_journal_mode_store(struct mddev *mddev,
26252617
if (strlen(r5c_journal_mode_str[mode]) == len &&
26262618
!strncmp(page, r5c_journal_mode_str[mode], len))
26272619
break;
2628-
2629-
return r5c_journal_mode_set(mddev, mode) ?: length;
2620+
ret = mddev_lock(mddev);
2621+
if (ret)
2622+
return ret;
2623+
ret = r5c_journal_mode_set(mddev, mode);
2624+
mddev_unlock(mddev);
2625+
return ret ?: length;
26302626
}
26312627

26322628
struct md_sysfs_entry

drivers/md/raid5.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2677,13 +2677,13 @@ static void raid5_error(struct mddev *mddev, struct md_rdev *rdev)
26772677
pr_debug("raid456: error called\n");
26782678

26792679
spin_lock_irqsave(&conf->device_lock, flags);
2680+
set_bit(Faulty, &rdev->flags);
26802681
clear_bit(In_sync, &rdev->flags);
26812682
mddev->degraded = raid5_calc_degraded(conf);
26822683
spin_unlock_irqrestore(&conf->device_lock, flags);
26832684
set_bit(MD_RECOVERY_INTR, &mddev->recovery);
26842685

26852686
set_bit(Blocked, &rdev->flags);
2686-
set_bit(Faulty, &rdev->flags);
26872687
set_mask_bits(&mddev->sb_flags, 0,
26882688
BIT(MD_SB_CHANGE_DEVS) | BIT(MD_SB_CHANGE_PENDING));
26892689
pr_crit("md/raid:%s: Disk failure on %s, disabling device.\n"

0 commit comments

Comments
 (0)