Skip to content

Commit 645b5ed

Browse files
committed
Merge branch 'md-fixes' of https://git.kernel.org/pub/scm/linux/kernel/git/song/md into block-6.0
Pull MD fixes from Song: "1. Fix for clustered raid, by Guoqing Jiang. 2. req_op fix, by Bart Van Assche. 3. Fix race condition in raid recreate, by David Sloan." * 'md-fixes' of https://git.kernel.org/pub/scm/linux/kernel/git/song/md: md: call __md_stop_writes in md_stop Revert "md-raid: destroy the bitmap after destroying the thread" md: Flush workqueue md_rdev_misc_wq in md_alloc() md/raid10: Fix the data type of an r10_sync_page_io() argument
2 parents c490a0b + 0dd84b3 commit 645b5ed

File tree

2 files changed

+9
-8
lines changed

2 files changed

+9
-8
lines changed

drivers/md/md.c

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5620,6 +5620,7 @@ struct mddev *md_alloc(dev_t dev, char *name)
56205620
* removed (mddev_delayed_delete).
56215621
*/
56225622
flush_workqueue(md_misc_wq);
5623+
flush_workqueue(md_rdev_misc_wq);
56235624

56245625
mutex_lock(&disks_mutex);
56255626
mddev = mddev_alloc(dev);
@@ -6238,11 +6239,11 @@ static void mddev_detach(struct mddev *mddev)
62386239
static void __md_stop(struct mddev *mddev)
62396240
{
62406241
struct md_personality *pers = mddev->pers;
6242+
md_bitmap_destroy(mddev);
62416243
mddev_detach(mddev);
62426244
/* Ensure ->event_work is done */
62436245
if (mddev->event_work.func)
62446246
flush_workqueue(md_misc_wq);
6245-
md_bitmap_destroy(mddev);
62466247
spin_lock(&mddev->lock);
62476248
mddev->pers = NULL;
62486249
spin_unlock(&mddev->lock);
@@ -6260,6 +6261,7 @@ void md_stop(struct mddev *mddev)
62606261
/* stop the array and free an attached data structures.
62616262
* This is called from dm-raid
62626263
*/
6264+
__md_stop_writes(mddev);
62636265
__md_stop(mddev);
62646266
bioset_exit(&mddev->bio_set);
62656267
bioset_exit(&mddev->sync_set);

drivers/md/raid10.c

Lines changed: 6 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -2639,18 +2639,18 @@ static void check_decay_read_errors(struct mddev *mddev, struct md_rdev *rdev)
26392639
}
26402640

26412641
static int r10_sync_page_io(struct md_rdev *rdev, sector_t sector,
2642-
int sectors, struct page *page, int rw)
2642+
int sectors, struct page *page, enum req_op op)
26432643
{
26442644
sector_t first_bad;
26452645
int bad_sectors;
26462646

26472647
if (is_badblock(rdev, sector, sectors, &first_bad, &bad_sectors)
2648-
&& (rw == READ || test_bit(WriteErrorSeen, &rdev->flags)))
2648+
&& (op == REQ_OP_READ || test_bit(WriteErrorSeen, &rdev->flags)))
26492649
return -1;
2650-
if (sync_page_io(rdev, sector, sectors << 9, page, rw, false))
2650+
if (sync_page_io(rdev, sector, sectors << 9, page, op, false))
26512651
/* success */
26522652
return 1;
2653-
if (rw == WRITE) {
2653+
if (op == REQ_OP_WRITE) {
26542654
set_bit(WriteErrorSeen, &rdev->flags);
26552655
if (!test_and_set_bit(WantReplacement, &rdev->flags))
26562656
set_bit(MD_RECOVERY_NEEDED,
@@ -2780,7 +2780,7 @@ static void fix_read_error(struct r10conf *conf, struct mddev *mddev, struct r10
27802780
if (r10_sync_page_io(rdev,
27812781
r10_bio->devs[sl].addr +
27822782
sect,
2783-
s, conf->tmppage, WRITE)
2783+
s, conf->tmppage, REQ_OP_WRITE)
27842784
== 0) {
27852785
/* Well, this device is dead */
27862786
pr_notice("md/raid10:%s: read correction write failed (%d sectors at %llu on %pg)\n",
@@ -2814,8 +2814,7 @@ static void fix_read_error(struct r10conf *conf, struct mddev *mddev, struct r10
28142814
switch (r10_sync_page_io(rdev,
28152815
r10_bio->devs[sl].addr +
28162816
sect,
2817-
s, conf->tmppage,
2818-
READ)) {
2817+
s, conf->tmppage, REQ_OP_READ)) {
28192818
case 0:
28202819
/* Well, this device is dead */
28212820
pr_notice("md/raid10:%s: unable to read back corrected sectors (%d sectors at %llu on %pg)\n",

0 commit comments

Comments
 (0)