Commit 25703f83 authored by Philipp Reisner's avatar Philipp Reisner

drbd: Moved DISCARD_CONCURRENT to the per connection (tconn) flags

Signed-off-by: default avatarPhilipp Reisner <philipp.reisner@linbit.com>
Signed-off-by: default avatarLars Ellenberg <lars.ellenberg@linbit.com>
parent 01a311a5
...@@ -763,7 +763,6 @@ enum { ...@@ -763,7 +763,6 @@ enum {
UNPLUG_QUEUED, /* only relevant with kernel 2.4 */ UNPLUG_QUEUED, /* only relevant with kernel 2.4 */
UNPLUG_REMOTE, /* sending a "UnplugRemote" could help */ UNPLUG_REMOTE, /* sending a "UnplugRemote" could help */
MD_DIRTY, /* current uuids and flags not yet on disk */ 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. */ USE_DEGR_WFC_T, /* degr-wfc-timeout instead of wfc-timeout. */
CLUSTER_ST_CHANGE, /* Cluster wide state change going on... */ CLUSTER_ST_CHANGE, /* Cluster wide state change going on... */
CL_ST_CHG_SUCCESS, CL_ST_CHG_SUCCESS,
...@@ -911,6 +910,7 @@ struct fifo_buffer { ...@@ -911,6 +910,7 @@ struct fifo_buffer {
/* flag bits per tconn */ /* flag bits per tconn */
enum { enum {
NET_CONGESTED, /* The data socket is congested */ 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 */ struct drbd_tconn { /* is a resource from the config file */
......
...@@ -1637,7 +1637,7 @@ void resync_after_online_grow(struct drbd_conf *mdev) ...@@ -1637,7 +1637,7 @@ void resync_after_online_grow(struct drbd_conf *mdev)
if (mdev->state.role != mdev->state.peer) if (mdev->state.role != mdev->state.peer)
iass = (mdev->state.role == R_PRIMARY); iass = (mdev->state.role == R_PRIMARY);
else else
iass = test_bit(DISCARD_CONCURRENT, &mdev->flags); iass = test_bit(DISCARD_CONCURRENT, &mdev->tconn->flags);
if (iass) if (iass)
drbd_start_resync(mdev, C_SYNC_SOURCE); drbd_start_resync(mdev, C_SYNC_SOURCE);
......
...@@ -762,7 +762,7 @@ static int drbd_connect(struct drbd_conf *mdev) ...@@ -762,7 +762,7 @@ static int drbd_connect(struct drbd_conf *mdev)
if (drbd_request_state(mdev, NS(conn, C_WF_CONNECTION)) < SS_SUCCESS) if (drbd_request_state(mdev, NS(conn, C_WF_CONNECTION)) < SS_SUCCESS)
return -2; return -2;
clear_bit(DISCARD_CONCURRENT, &mdev->flags); clear_bit(DISCARD_CONCURRENT, &mdev->tconn->flags);
mdev->tconn->agreed_pro_version = 99; mdev->tconn->agreed_pro_version = 99;
/* agreed_pro_version must be smaller than 100 so we send the old /* agreed_pro_version must be smaller than 100 so we send the old
header (h80) in the first packet and in the handshake packet. */ header (h80) in the first packet and in the handshake packet. */
...@@ -823,7 +823,7 @@ static int drbd_connect(struct drbd_conf *mdev) ...@@ -823,7 +823,7 @@ static int drbd_connect(struct drbd_conf *mdev)
sock_release(msock); sock_release(msock);
} }
msock = s; msock = s;
set_bit(DISCARD_CONCURRENT, &mdev->flags); set_bit(DISCARD_CONCURRENT, &mdev->tconn->flags);
break; break;
default: default:
dev_warn(DEV, "Error receiving initial packet\n"); dev_warn(DEV, "Error receiving initial packet\n");
...@@ -1779,7 +1779,7 @@ static int receive_Data(struct drbd_conf *mdev, enum drbd_packet cmd, ...@@ -1779,7 +1779,7 @@ static int receive_Data(struct drbd_conf *mdev, enum drbd_packet cmd,
/* don't get the req_lock yet, /* don't get the req_lock yet,
* we may sleep in drbd_wait_peer_seq */ * we may sleep in drbd_wait_peer_seq */
const int size = peer_req->i.size; 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); DEFINE_WAIT(wait);
int first; int first;
...@@ -2239,7 +2239,7 @@ static int drbd_asb_recover_0p(struct drbd_conf *mdev) __must_hold(local) ...@@ -2239,7 +2239,7 @@ static int drbd_asb_recover_0p(struct drbd_conf *mdev) __must_hold(local)
"Using discard-least-changes instead\n"); "Using discard-least-changes instead\n");
case ASB_DISCARD_ZERO_CHG: case ASB_DISCARD_ZERO_CHG:
if (ch_peer == 0 && ch_self == 0) { if (ch_peer == 0 && ch_self == 0) {
rv = test_bit(DISCARD_CONCURRENT, &mdev->flags) rv = test_bit(DISCARD_CONCURRENT, &mdev->tconn->flags)
? -1 : 1; ? -1 : 1;
break; break;
} else { } else {
...@@ -2255,7 +2255,7 @@ static int drbd_asb_recover_0p(struct drbd_conf *mdev) __must_hold(local) ...@@ -2255,7 +2255,7 @@ static int drbd_asb_recover_0p(struct drbd_conf *mdev) __must_hold(local)
rv = 1; rv = 1;
else /* ( ch_self == ch_peer ) */ else /* ( ch_self == ch_peer ) */
/* Well, then use something else. */ /* Well, then use something else. */
rv = test_bit(DISCARD_CONCURRENT, &mdev->flags) rv = test_bit(DISCARD_CONCURRENT, &mdev->tconn->flags)
? -1 : 1; ? -1 : 1;
break; break;
case ASB_DISCARD_LOCAL: case ASB_DISCARD_LOCAL:
...@@ -2468,7 +2468,7 @@ static int drbd_uuid_compare(struct drbd_conf *mdev, int *rule_nr) __must_hold(l ...@@ -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 1: /* self_pri && !peer_pri */ return 1;
case 2: /* !self_pri && peer_pri */ return -1; case 2: /* !self_pri && peer_pri */ return -1;
case 3: /* self_pri && peer_pri */ 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; return dc ? -1 : 1;
} }
} }
...@@ -3209,7 +3209,7 @@ static int receive_req_state(struct drbd_conf *mdev, enum drbd_packet cmd, ...@@ -3209,7 +3209,7 @@ static int receive_req_state(struct drbd_conf *mdev, enum drbd_packet cmd,
mask.i = be32_to_cpu(p->mask); mask.i = be32_to_cpu(p->mask);
val.i = be32_to_cpu(p->val); 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)) { test_bit(CLUSTER_ST_CHANGE, &mdev->flags)) {
drbd_send_sr_reply(mdev, SS_CONCURRENT_ST_CHG); drbd_send_sr_reply(mdev, SS_CONCURRENT_ST_CHG);
return true; return true;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment