md/bitmap: use mddev_suspend/resume instead of ->quiesce()
authorJack Wang <jinpu.wang@profitbricks.com>
Mon, 8 Oct 2018 15:24:03 +0000 (17:24 +0200)
committerShaohua Li <shli@fb.com>
Wed, 10 Oct 2018 18:03:34 +0000 (11:03 -0700)
After 9e1cc0a54556 ("md: use mddev_suspend/resume instead of ->quiesce()")
We still have similar left in bitmap functions.

Replace quiesce() with mddev_suspend/resume.

Also move md_bitmap_create out of mddev_suspend. and move mddev_resume
after md_bitmap_destroy. as we did in set_bitmap_file.

Signed-off-by: Jack Wang <jinpu.wang@profitbricks.com>
Reviewed-by: Gioh Kim <gi-oh.kim@profitbricks.com>
Signed-off-by: Shaohua Li <shli@fb.com>
drivers/md/md-bitmap.c

index 2fc8c113977fbec7877220e034dd34561399741b..1cd4f991792cf138448584b1e5328d3a1a73ff1e 100644 (file)
@@ -2288,9 +2288,9 @@ location_store(struct mddev *mddev, const char *buf, size_t len)
                        goto out;
                }
                if (mddev->pers) {
-                       mddev->pers->quiesce(mddev, 1);
+                       mddev_suspend(mddev);
                        md_bitmap_destroy(mddev);
-                       mddev->pers->quiesce(mddev, 0);
+                       mddev_resume(mddev);
                }
                mddev->bitmap_info.offset = 0;
                if (mddev->bitmap_info.file) {
@@ -2327,8 +2327,8 @@ location_store(struct mddev *mddev, const char *buf, size_t len)
                        mddev->bitmap_info.offset = offset;
                        if (mddev->pers) {
                                struct bitmap *bitmap;
-                               mddev->pers->quiesce(mddev, 1);
                                bitmap = md_bitmap_create(mddev, -1);
+                               mddev_suspend(mddev);
                                if (IS_ERR(bitmap))
                                        rv = PTR_ERR(bitmap);
                                else {
@@ -2337,11 +2337,12 @@ location_store(struct mddev *mddev, const char *buf, size_t len)
                                        if (rv)
                                                mddev->bitmap_info.offset = 0;
                                }
-                               mddev->pers->quiesce(mddev, 0);
                                if (rv) {
                                        md_bitmap_destroy(mddev);
+                                       mddev_resume(mddev);
                                        goto out;
                                }
+                               mddev_resume(mddev);
                        }
                }
        }