md: remove special meaning of ->quiesce(.., 2)
authorNeilBrown <neilb@suse.com>
Thu, 19 Oct 2017 01:49:15 +0000 (12:49 +1100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 8 Jul 2018 13:30:50 +0000 (15:30 +0200)
commit b03e0ccb5ab9df3efbe51c87843a1ffbecbafa1f upstream.

The '2' argument means "wake up anything that is waiting".
This is an inelegant part of the design and was added
to help support management of suspend_lo/suspend_hi setting.
Now that suspend_lo/hi is managed in mddev_suspend/resume,
that need is gone.
These is still a couple of places where we call 'quiesce'
with an argument of '2', but they can safely be changed to
call ->quiesce(.., 1); ->quiesce(.., 0) which
achieve the same result at the small cost of pausing IO
briefly.

This removes a small "optimization" from suspend_{hi,lo}_store,
but it isn't clear that optimization served a useful purpose.
The code now is a lot clearer.

Suggested-by: Shaohua Li <shli@kernel.org>
Signed-off-by: NeilBrown <neilb@suse.com>
Signed-off-by: Shaohua Li <shli@fb.com>
Signed-off-by: Jack Wang <jinpu.wang@profitbricks.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/md/md-cluster.c
drivers/md/md.c
drivers/md/md.h
drivers/md/raid0.c
drivers/md/raid1.c
drivers/md/raid10.c
drivers/md/raid5-cache.c
drivers/md/raid5-log.h
drivers/md/raid5.c

index 03082e17c65cc87af2a44a8020bda6cbdb8b0262..72ce0bccc86553a5ecbf6ffb59d3883f01e3dc0e 100644 (file)
@@ -442,10 +442,11 @@ static void __remove_suspend_info(struct md_cluster_info *cinfo, int slot)
 static void remove_suspend_info(struct mddev *mddev, int slot)
 {
        struct md_cluster_info *cinfo = mddev->cluster_info;
+       mddev->pers->quiesce(mddev, 1);
        spin_lock_irq(&cinfo->suspend_lock);
        __remove_suspend_info(cinfo, slot);
        spin_unlock_irq(&cinfo->suspend_lock);
-       mddev->pers->quiesce(mddev, 2);
+       mddev->pers->quiesce(mddev, 0);
 }
 
 
@@ -492,13 +493,12 @@ static void process_suspend_info(struct mddev *mddev,
        s->lo = lo;
        s->hi = hi;
        mddev->pers->quiesce(mddev, 1);
-       mddev->pers->quiesce(mddev, 0);
        spin_lock_irq(&cinfo->suspend_lock);
        /* Remove existing entry (if exists) before adding */
        __remove_suspend_info(cinfo, slot);
        list_add(&s->list, &cinfo->suspend_list);
        spin_unlock_irq(&cinfo->suspend_lock);
-       mddev->pers->quiesce(mddev, 2);
+       mddev->pers->quiesce(mddev, 0);
 }
 
 static void process_add_new_disk(struct mddev *mddev, struct cluster_msg *cmsg)
index b74cca273e38e5b12677292fdddfe35b3cdf0c52..11a67eac55b1e7b3082d32c38379e4c289ce4a66 100644 (file)
@@ -4850,7 +4850,7 @@ suspend_lo_show(struct mddev *mddev, char *page)
 static ssize_t
 suspend_lo_store(struct mddev *mddev, const char *buf, size_t len)
 {
-       unsigned long long old, new;
+       unsigned long long new;
        int err;
 
        err = kstrtoull(buf, 10, &new);
@@ -4866,17 +4866,10 @@ suspend_lo_store(struct mddev *mddev, const char *buf, size_t len)
        if (mddev->pers == NULL ||
            mddev->pers->quiesce == NULL)
                goto unlock;
-       old = mddev->suspend_lo;
+       mddev_suspend(mddev);
        mddev->suspend_lo = new;
-       if (new >= old) {
-               /* Shrinking suspended region */
-               wake_up(&mddev->sb_wait);
-               mddev->pers->quiesce(mddev, 2);
-       } else {
-               /* Expanding suspended region - need to wait */
-               mddev_suspend(mddev);
-               mddev_resume(mddev);
-       }
+       mddev_resume(mddev);
+
        err = 0;
 unlock:
        mddev_unlock(mddev);
@@ -4894,7 +4887,7 @@ suspend_hi_show(struct mddev *mddev, char *page)
 static ssize_t
 suspend_hi_store(struct mddev *mddev, const char *buf, size_t len)
 {
-       unsigned long long old, new;
+       unsigned long long new;
        int err;
 
        err = kstrtoull(buf, 10, &new);
@@ -4907,20 +4900,13 @@ suspend_hi_store(struct mddev *mddev, const char *buf, size_t len)
        if (err)
                return err;
        err = -EINVAL;
-       if (mddev->pers == NULL ||
-           mddev->pers->quiesce == NULL)
+       if (mddev->pers == NULL)
                goto unlock;
-       old = mddev->suspend_hi;
+
+       mddev_suspend(mddev);
        mddev->suspend_hi = new;
-       if (new <= old) {
-               /* Shrinking suspended region */
-               wake_up(&mddev->sb_wait);
-               mddev->pers->quiesce(mddev, 2);
-       } else {
-               /* Expanding suspended region - need to wait */
-               mddev_suspend(mddev);
-               mddev_resume(mddev);
-       }
+       mddev_resume(mddev);
+
        err = 0;
 unlock:
        mddev_unlock(mddev);
index 37c19b7b5df940125dfa747b2297eab503e02080..11696aba94e30cf5b4b30d935f168cb394ba42c3 100644 (file)
@@ -546,12 +546,11 @@ struct md_personality
        int (*check_reshape) (struct mddev *mddev);
        int (*start_reshape) (struct mddev *mddev);
        void (*finish_reshape) (struct mddev *mddev);
-       /* quiesce moves between quiescence states
-        * 0 - fully active
-        * 1 - no new requests allowed
-        * others - reserved
+       /* quiesce suspends or resumes internal processing.
+        * 1 - stop new actions and wait for action io to complete
+        * 0 - return to normal behaviour
         */
-       void (*quiesce) (struct mddev *mddev, int state);
+       void (*quiesce) (struct mddev *mddev, int quiesce);
        /* takeover is used to transition an array from one
         * personality to another.  The new personality must be able
         * to handle the data in the current layout.
index 5a00fc1184706a6f332df5ce29516dc9bf164e22..5ecba9eef441fb3ddf0d6929a91a894553e2363a 100644 (file)
@@ -768,7 +768,7 @@ static void *raid0_takeover(struct mddev *mddev)
        return ERR_PTR(-EINVAL);
 }
 
-static void raid0_quiesce(struct mddev *mddev, int state)
+static void raid0_quiesce(struct mddev *mddev, int quiesce)
 {
 }
 
index bd5976aefb55c4eca9af2c69611692079660f052..029ecba607272cdabc315e83ddf21780b356b26a 100644 (file)
@@ -3276,21 +3276,14 @@ static int raid1_reshape(struct mddev *mddev)
        return 0;
 }
 
-static void raid1_quiesce(struct mddev *mddev, int state)
+static void raid1_quiesce(struct mddev *mddev, int quiesce)
 {
        struct r1conf *conf = mddev->private;
 
-       switch(state) {
-       case 2: /* wake for suspend */
-               wake_up(&conf->wait_barrier);
-               break;
-       case 1:
+       if (quiesce)
                freeze_array(conf, 0);
-               break;
-       case 0:
+       else
                unfreeze_array(conf);
-               break;
-       }
 }
 
 static void *raid1_takeover(struct mddev *mddev)
index 5fb31ef529454c6296057d683854b10e10400247..b20c23f970f494f18d6a4b5b29de8275aef77bc8 100644 (file)
@@ -3838,18 +3838,14 @@ static void raid10_free(struct mddev *mddev, void *priv)
        kfree(conf);
 }
 
-static void raid10_quiesce(struct mddev *mddev, int state)
+static void raid10_quiesce(struct mddev *mddev, int quiesce)
 {
        struct r10conf *conf = mddev->private;
 
-       switch(state) {
-       case 1:
+       if (quiesce)
                raise_barrier(conf, 0);
-               break;
-       case 0:
+       else
                lower_barrier(conf);
-               break;
-       }
 }
 
 static int raid10_resize(struct mddev *mddev, sector_t sectors)
index 79d812717406ebe0beced0f4e10d2187622cfdb1..0d535b40cb3bbc292f5d4a607db14e837d1221f3 100644 (file)
@@ -1589,21 +1589,21 @@ void r5l_wake_reclaim(struct r5l_log *log, sector_t space)
        md_wakeup_thread(log->reclaim_thread);
 }
 
-void r5l_quiesce(struct r5l_log *log, int state)
+void r5l_quiesce(struct r5l_log *log, int quiesce)
 {
        struct mddev *mddev;
-       if (!log || state == 2)
+       if (!log)
                return;
-       if (state == 0)
-               kthread_unpark(log->reclaim_thread->tsk);
-       else if (state == 1) {
+
+       if (quiesce) {
                /* make sure r5l_write_super_and_discard_space exits */
                mddev = log->rdev->mddev;
                wake_up(&mddev->sb_wait);
                kthread_park(log->reclaim_thread->tsk);
                r5l_wake_reclaim(log, MaxSector);
                r5l_do_reclaim(log);
-       }
+       } else
+               kthread_unpark(log->reclaim_thread->tsk);
 }
 
 bool r5l_log_disk_error(struct r5conf *conf)
index 7f9ad5f7cda025e3c421995cb48a7365aac949f0..284578b0a349c7acf5d6398b19fa4196854cdff0 100644 (file)
@@ -9,7 +9,7 @@ extern void r5l_write_stripe_run(struct r5l_log *log);
 extern void r5l_flush_stripe_to_raid(struct r5l_log *log);
 extern void r5l_stripe_write_finished(struct stripe_head *sh);
 extern int r5l_handle_flush_request(struct r5l_log *log, struct bio *bio);
-extern void r5l_quiesce(struct r5l_log *log, int state);
+extern void r5l_quiesce(struct r5l_log *log, int quiesce);
 extern bool r5l_log_disk_error(struct r5conf *conf);
 extern bool r5c_is_writeback(struct r5l_log *log);
 extern int
index 30c1dc17d5afc0e6eca9dd6d0bf135686193e399..07ca2fd10189f2e68cfbf840e95305e49b98c274 100644 (file)
@@ -8003,16 +8003,12 @@ static void raid5_finish_reshape(struct mddev *mddev)
        }
 }
 
-static void raid5_quiesce(struct mddev *mddev, int state)
+static void raid5_quiesce(struct mddev *mddev, int quiesce)
 {
        struct r5conf *conf = mddev->private;
 
-       switch(state) {
-       case 2: /* resume for a suspend */
-               wake_up(&conf->wait_for_overlap);
-               break;
-
-       case 1: /* stop all writes */
+       if (quiesce) {
+               /* stop all writes */
                lock_all_device_hash_locks_irq(conf);
                /* '2' tells resync/reshape to pause so that all
                 * active stripes can drain
@@ -8028,17 +8024,15 @@ static void raid5_quiesce(struct mddev *mddev, int state)
                unlock_all_device_hash_locks_irq(conf);
                /* allow reshape to continue */
                wake_up(&conf->wait_for_overlap);
-               break;
-
-       case 0: /* re-enable writes */
+       } else {
+               /* re-enable writes */
                lock_all_device_hash_locks_irq(conf);
                conf->quiesce = 0;
                wake_up(&conf->wait_for_quiescent);
                wake_up(&conf->wait_for_overlap);
                unlock_all_device_hash_locks_irq(conf);
-               break;
        }
-       r5l_quiesce(conf->log, state);
+       r5l_quiesce(conf->log, quiesce);
 }
 
 static void *raid45_takeover_raid0(struct mddev *mddev, int level)