2019-09-23 08:02:25 +02:00
|
|
|
diff -Naur drbd-9.0.11+git.1e2bccdc.orig/drbd/drbd_state.c drbd-9.0.11+git.1e2bccdc/drbd/drbd_state.c
|
|
|
|
--- drbd-9.0.11+git.1e2bccdc.orig/drbd/drbd_state.c 2019-08-27 13:34:08.462567903 +0800
|
|
|
|
+++ drbd-9.0.11+git.1e2bccdc/drbd/drbd_state.c 2019-08-30 12:56:37.664186710 +0800
|
|
|
|
@@ -1398,8 +1398,13 @@
|
2019-03-13 03:17:02 +01:00
|
|
|
nc = rcu_dereference(connection->transport.net_conf);
|
|
|
|
two_primaries = nc ? nc->two_primaries : false;
|
|
|
|
if (peer_role[NEW] == R_PRIMARY && peer_role[OLD] != R_PRIMARY && !two_primaries) {
|
|
|
|
- if (role[NOW] == R_PRIMARY)
|
2019-09-23 08:02:25 +02:00
|
|
|
- return SS_TWO_PRIMARIES;
|
|
|
|
+ if (role[NOW] == R_PRIMARY) {
|
|
|
|
+ if (role[OLD] == R_PRIMARY && connection->cstate[OLD] < C_CONNECTED) {
|
|
|
|
+ drbd_info(connection, "Two primaries but not allowed. Rely on split brain handler or to disconnect.\n");
|
|
|
|
+ } else {
|
|
|
|
+ return SS_TWO_PRIMARIES;
|
|
|
|
+ }
|
|
|
|
+ }
|
2019-03-13 03:17:02 +01:00
|
|
|
idr_for_each_entry(&resource->devices, device, vnr) {
|
2019-09-23 08:02:25 +02:00
|
|
|
if (device->open_ro_cnt)
|
2019-03-13 03:17:02 +01:00
|
|
|
return SS_PRIMARY_READER;
|
2019-09-23 08:02:25 +02:00
|
|
|
@@ -3665,7 +3670,11 @@
|
2019-03-13 03:17:02 +01:00
|
|
|
mask = NODE_MASK(connection->peer_node_id);
|
|
|
|
if ((resource->twopc_reply.primary_nodes & mask) &&
|
|
|
|
!(connection->transport.net_conf->two_primaries)) {
|
|
|
|
- rv = SS_TWO_PRIMARIES;
|
2019-09-23 08:02:25 +02:00
|
|
|
+ if (connection->cstate[OLD] < C_CONNECTED && connection->cstate[NEW] == C_CONNECTED) {
|
|
|
|
+ drbd_info(connection, "Two primaries but not allowed after reconnected. Rely on split brain handler or to disconnect.\n");
|
|
|
|
+ } else {
|
2019-03-13 03:17:02 +01:00
|
|
|
+ rv = SS_TWO_PRIMARIES;
|
|
|
|
+ }
|
2019-09-23 08:02:25 +02:00
|
|
|
break;
|
2019-03-13 03:17:02 +01:00
|
|
|
}
|
|
|
|
}
|
2019-09-23 08:02:25 +02:00
|
|
|
@@ -3739,7 +3748,11 @@
|
2019-03-13 03:17:02 +01:00
|
|
|
nc = rcu_dereference(connection->transport.net_conf);
|
|
|
|
if (!nc->two_primaries &&
|
|
|
|
NODE_MASK(connection->peer_node_id) & reply->primary_nodes) {
|
|
|
|
- rv = SS_PRIMARY_READER;
|
2019-09-23 08:02:25 +02:00
|
|
|
+ if (connection->cstate[OLD] < C_CONNECTED && connection->cstate[NEW] == C_CONNECTED) {
|
|
|
|
+ drbd_info(connection, "Two primaries and device is opened as read only. Rely on split brain handler or to disconnect.\n");
|
|
|
|
+ } else {
|
2019-03-13 03:17:02 +01:00
|
|
|
+ rv = SS_PRIMARY_READER;
|
|
|
|
+ }
|
2019-09-23 08:02:25 +02:00
|
|
|
break;
|
2019-03-13 03:17:02 +01:00
|
|
|
}
|
|
|
|
}
|