]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
drbd: Removed the OBJECT_DYING and the CONFIG_PENDING bits
authorPhilipp Reisner <philipp.reisner@linbit.com>
Sun, 24 Apr 2011 09:09:55 +0000 (11:09 +0200)
committerPhilipp Reisner <philipp.reisner@linbit.com>
Thu, 8 Nov 2012 15:49:07 +0000 (16:49 +0100)
superseded by refcounting

Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com>
Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com>
drivers/block/drbd/drbd_int.h
drivers/block/drbd/drbd_nl.c
drivers/block/drbd/drbd_state.c
drivers/block/drbd/drbd_worker.c

index 7797879d32644cf0c3a09523a2a0a2b1ccddb1d6..28e7ecc91888ca53e10340541d8aaf8d77d4ee9e 100644 (file)
@@ -816,12 +816,6 @@ enum {
        GOT_PING_ACK,           /* set when we receive a ping_ack packet, ping_wait gets woken */
        CONN_WD_ST_CHG_OKAY,
        CONN_WD_ST_CHG_FAIL,
-       CONFIG_PENDING,         /* serialization of (re)configuration requests.
-                                * if set, also prevents the device from dying */
-       OBJECT_DYING,           /* device became unconfigured,
-                                * but worker thread is still handling the cleanup.
-                                * reconfiguring (nl_disk_conf, nl_net_conf) is dissalowed,
-                                * while this is set. */
        CONN_DRY_RUN,           /* Expect disconnect after resync handshake. */
 };
 
index 272c4a08ee4237d10a661ee4ad2ee93f9d023636..caaef71ec614b9e474dc9a100a9746e3ad4a094e 100644 (file)
@@ -1040,34 +1040,20 @@ void drbd_reconsider_max_bio_size(struct drbd_conf *mdev)
        drbd_setup_queue_param(mdev, new);
 }
 
-/* serialize deconfig (worker exiting, doing cleanup)
- * and reconfig (drbdsetup disk, drbdsetup net)
- *
- * Wait for a potentially exiting worker, then restart it,
- * or start a new one.  Flush any pending work, there may still be an
- * after_state_change queued.
- */
+/* Starts the worker thread */
 static void conn_reconfig_start(struct drbd_tconn *tconn)
 {
-       wait_event(tconn->ping_wait, !test_and_set_bit(CONFIG_PENDING, &tconn->flags));
-       wait_event(tconn->ping_wait, !test_bit(OBJECT_DYING, &tconn->flags));
        drbd_thread_start(&tconn->worker);
        conn_flush_workqueue(tconn);
 }
 
-/* if still unconfigured, stops worker again.
- * if configured now, clears CONFIG_PENDING.
- * wakes potential waiters */
+/* if still unconfigured, stops worker again. */
 static void conn_reconfig_done(struct drbd_tconn *tconn)
 {
        spin_lock_irq(&tconn->req_lock);
-       if (conn_all_vols_unconf(tconn)) {
-               set_bit(OBJECT_DYING, &tconn->flags);
+       if (conn_all_vols_unconf(tconn))
                drbd_thread_stop_nowait(&tconn->worker);
-       } else
-               clear_bit(CONFIG_PENDING, &tconn->flags);
        spin_unlock_irq(&tconn->req_lock);
-       wake_up(&tconn->ping_wait);
 }
 
 /* Make sure IO is suspended before calling this function(). */
index d7a330e0135f73d7cdcbc1bb8f363ac0cee06886..05628b45cf03aaf699da5dfec565f580271c12f2 100644 (file)
@@ -926,18 +926,6 @@ __drbd_set_state(struct drbd_conf *mdev, union drbd_state ns,
        mdev->tconn->susp_nod = ns.susp_nod;
        mdev->tconn->susp_fen = ns.susp_fen;
 
-       /* solve the race between becoming unconfigured,
-        * worker doing the cleanup, and
-        * admin reconfiguring us:
-        * on (re)configure, first set CONFIG_PENDING,
-        * then wait for a potentially exiting worker,
-        * start the worker, and schedule one no_op.
-        * then proceed with configuration.
-        */
-       if(conn_all_vols_unconf(mdev->tconn) &&
-          !test_and_set_bit(CONFIG_PENDING, &mdev->tconn->flags))
-               set_bit(OBJECT_DYING, &mdev->tconn->flags);
-
        if (os.disk == D_ATTACHING && ns.disk >= D_NEGOTIATING)
                drbd_print_uuids(mdev, "attached to UUIDs");
 
@@ -1401,10 +1389,8 @@ struct after_conn_state_chg_work {
 
 static void after_all_state_ch(struct drbd_tconn *tconn)
 {
-       if (conn_all_vols_unconf(tconn) &&
-           test_bit(OBJECT_DYING, &tconn->flags)) {
+       if (conn_all_vols_unconf(tconn))
                drbd_thread_stop_nowait(&tconn->worker);
-       }
 }
 
 static int w_after_conn_state_ch(struct drbd_work *w, int unused)
index 9d1ba8ea68186304bfaf1bf7c5197970867fd72a..7a73bd4287c411bed3abe7e2a81bd9a9391d57c4 100644 (file)
@@ -1754,9 +1754,6 @@ int drbd_worker(struct drbd_thread *thi)
                drbd_mdev_cleanup(mdev);
        }
        up_read(&drbd_cfg_rwsem);
-       clear_bit(OBJECT_DYING, &tconn->flags);
-       clear_bit(CONFIG_PENDING, &tconn->flags);
-       wake_up(&tconn->ping_wait);
 
        return 0;
 }