drbd: Moved DISCARD_CONCURRENT to the per connection (tconn) flags
authorPhilipp Reisner <philipp.reisner@linbit.com>
Mon, 7 Feb 2011 13:35:25 +0000 (14:35 +0100)
committerPhilipp Reisner <philipp.reisner@linbit.com>
Wed, 28 Sep 2011 08:26:55 +0000 (10:26 +0200)
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_receiver.c

index f46571acd4d0df3b54ae2ea012e1d63a9533cae2..2b8566362b78df67311eafab956b9e77eba75c61 100644 (file)
@@ -763,7 +763,6 @@ enum {
        UNPLUG_QUEUED,          /* only relevant with kernel 2.4 */
        UNPLUG_REMOTE,          /* sending a "UnplugRemote" could help */
        MD_DIRTY,               /* current uuids and flags not yet on disk */
-       DISCARD_CONCURRENT,     /* Set on one node, cleared on the peer! */
        USE_DEGR_WFC_T,         /* degr-wfc-timeout instead of wfc-timeout. */
        CLUSTER_ST_CHANGE,      /* Cluster wide state change going on... */
        CL_ST_CHG_SUCCESS,
@@ -911,6 +910,7 @@ struct fifo_buffer {
 /* flag bits per tconn */
 enum {
        NET_CONGESTED,          /* The data socket is congested */
+       DISCARD_CONCURRENT,     /* Set on one node, cleared on the peer! */
 };
 
 struct drbd_tconn {                    /* is a resource from the config file */
index e30d52ba3fcff62b50190ed0703945ca4c3846e7..fda399ace8dd5e6e880fbb2cee856836c2d39279 100644 (file)
@@ -1637,7 +1637,7 @@ void resync_after_online_grow(struct drbd_conf *mdev)
        if (mdev->state.role != mdev->state.peer)
                iass = (mdev->state.role == R_PRIMARY);
        else
-               iass = test_bit(DISCARD_CONCURRENT, &mdev->flags);
+               iass = test_bit(DISCARD_CONCURRENT, &mdev->tconn->flags);
 
        if (iass)
                drbd_start_resync(mdev, C_SYNC_SOURCE);
index 2e58d00742d9d58b579df8b9750a0ce2d48ae9d9..e2eed149bb9c01bee5a7625585e4d94b1466f71b 100644 (file)
@@ -762,7 +762,7 @@ static int drbd_connect(struct drbd_conf *mdev)
        if (drbd_request_state(mdev, NS(conn, C_WF_CONNECTION)) < SS_SUCCESS)
                return -2;
 
-       clear_bit(DISCARD_CONCURRENT, &mdev->flags);
+       clear_bit(DISCARD_CONCURRENT, &mdev->tconn->flags);
        mdev->tconn->agreed_pro_version = 99;
        /* agreed_pro_version must be smaller than 100 so we send the old
           header (h80) in the first packet and in the handshake packet. */
@@ -823,7 +823,7 @@ retry:
                                        sock_release(msock);
                                }
                                msock = s;
-                               set_bit(DISCARD_CONCURRENT, &mdev->flags);
+                               set_bit(DISCARD_CONCURRENT, &mdev->tconn->flags);
                                break;
                        default:
                                dev_warn(DEV, "Error receiving initial packet\n");
@@ -1779,7 +1779,7 @@ static int receive_Data(struct drbd_conf *mdev, enum drbd_packet cmd,
                /* don't get the req_lock yet,
                 * we may sleep in drbd_wait_peer_seq */
                const int size = peer_req->i.size;
-               const int discard = test_bit(DISCARD_CONCURRENT, &mdev->flags);
+               const int discard = test_bit(DISCARD_CONCURRENT, &mdev->tconn->flags);
                DEFINE_WAIT(wait);
                int first;
 
@@ -2239,7 +2239,7 @@ static int drbd_asb_recover_0p(struct drbd_conf *mdev) __must_hold(local)
                     "Using discard-least-changes instead\n");
        case ASB_DISCARD_ZERO_CHG:
                if (ch_peer == 0 && ch_self == 0) {
-                       rv = test_bit(DISCARD_CONCURRENT, &mdev->flags)
+                       rv = test_bit(DISCARD_CONCURRENT, &mdev->tconn->flags)
                                ? -1 : 1;
                        break;
                } else {
@@ -2255,7 +2255,7 @@ static int drbd_asb_recover_0p(struct drbd_conf *mdev) __must_hold(local)
                        rv =  1;
                else /* ( ch_self == ch_peer ) */
                     /* Well, then use something else. */
-                       rv = test_bit(DISCARD_CONCURRENT, &mdev->flags)
+                       rv = test_bit(DISCARD_CONCURRENT, &mdev->tconn->flags)
                                ? -1 : 1;
                break;
        case ASB_DISCARD_LOCAL:
@@ -2468,7 +2468,7 @@ static int drbd_uuid_compare(struct drbd_conf *mdev, int *rule_nr) __must_hold(l
                case 1: /*  self_pri && !peer_pri */ return 1;
                case 2: /* !self_pri &&  peer_pri */ return -1;
                case 3: /*  self_pri &&  peer_pri */
-                       dc = test_bit(DISCARD_CONCURRENT, &mdev->flags);
+                       dc = test_bit(DISCARD_CONCURRENT, &mdev->tconn->flags);
                        return dc ? -1 : 1;
                }
        }
@@ -3209,7 +3209,7 @@ static int receive_req_state(struct drbd_conf *mdev, enum drbd_packet cmd,
        mask.i = be32_to_cpu(p->mask);
        val.i = be32_to_cpu(p->val);
 
-       if (test_bit(DISCARD_CONCURRENT, &mdev->flags) &&
+       if (test_bit(DISCARD_CONCURRENT, &mdev->tconn->flags) &&
            test_bit(CLUSTER_ST_CHANGE, &mdev->flags)) {
                drbd_send_sr_reply(mdev, SS_CONCURRENT_ST_CHG);
                return true;