Sign Up
Log In
Log In
or
Sign Up
Places
All Projects
Status Monitor
Collapse sidebar
SUSE:SLE-12-SP2:Update
drbd.9948
rely-on-sb-handlers.patch
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File rely-on-sb-handlers.patch of Package drbd.9948
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-01-10 13:05:08.320625940 +0800 +++ drbd-9.0.11+git.1e2bccdc/drbd/drbd_state.c 2019-01-10 13:07:10.708544653 +0800 @@ -225,6 +225,27 @@ return rv; } +static bool is_sb_handlers_configured(struct drbd_connection *connection) +{ + bool configured = false; + + enum drbd_after_sb_p after_sb_0p = -1; + enum drbd_after_sb_p after_sb_1p = -1; + enum drbd_after_sb_p after_sb_2p = -1; + + after_sb_0p = rcu_dereference(connection->transport.net_conf)->after_sb_0p; + after_sb_1p = rcu_dereference(connection->transport.net_conf)->after_sb_1p; + after_sb_2p = rcu_dereference(connection->transport.net_conf)->after_sb_2p; + + if (after_sb_2p != 0 || after_sb_0p != 0 || after_sb_1p != 0) { + drbd_info(connection, "Split-brain handler configured, rely on it.\n"); + configured = true; + } + + return configured; +} + + bool resource_is_suspended(struct drbd_resource *resource, enum which_state which) { bool rv = resource->susp[which] || resource->susp_nod[which]; @@ -1363,7 +1384,8 @@ if (!nc || nc->two_primaries) continue; if (connection->peer_role[NEW] == R_PRIMARY) - return SS_TWO_PRIMARIES; + if (!is_sb_handlers_configured(connection)) + return SS_TWO_PRIMARIES; } } @@ -1398,10 +1420,10 @@ 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) + if (role[NOW] == R_PRIMARY && !is_sb_handlers_configured(connection)) return SS_TWO_PRIMARIES; idr_for_each_entry(&resource->devices, device, vnr) { - if (device->open_ro_cnt) + if (device->open_ro_cnt && !is_sb_handlers_configured(connection)) return SS_PRIMARY_READER; } } @@ -3665,8 +3687,10 @@ mask = NODE_MASK(connection->peer_node_id); if ((resource->twopc_reply.primary_nodes & mask) && !(connection->transport.net_conf->two_primaries)) { - rv = SS_TWO_PRIMARIES; - break; + if (!is_sb_handlers_configured(connection)){ + rv = SS_TWO_PRIMARIES; + break; + } } } rcu_read_unlock(); @@ -3709,10 +3733,13 @@ rcu_read_lock(); nc = rcu_dereference(connection->transport.net_conf); two_primaries = nc ? nc->two_primaries : false; - rcu_read_unlock(); - if (!two_primaries) + if (!two_primaries && !is_sb_handlers_configured(connection)) { + rcu_read_unlock(); return SS_TWO_PRIMARIES; + } + + rcu_read_unlock(); } return SS_SUCCESS; @@ -3739,8 +3766,10 @@ nc = rcu_dereference(connection->transport.net_conf); if (!nc->two_primaries && NODE_MASK(connection->peer_node_id) & reply->primary_nodes) { - rv = SS_PRIMARY_READER; - break; + if (!is_sb_handlers_configured(connection)){ + rv = SS_PRIMARY_READER; + break; + } } } rcu_read_unlock();
Locations
Projects
Search
Status Monitor
Help
OpenBuildService.org
Documentation
API Documentation
Code of Conduct
Contact
Support
@OBShq
Terms
openSUSE Build Service is sponsored by
The Open Build Service is an
openSUSE project
.
Sign Up
Log In
Places
Places
All Projects
Status Monitor