File bsc#1189680-cancel_hold_on_retransmit-option.patch of Package corosync.20964

diff -Naur a/exec/totemconfig.c b/exec/totemconfig.c
--- a/exec/totemconfig.c	2019-07-30 15:26:39.000000000 +0300
+++ b/exec/totemconfig.c	2021-08-24 18:53:30.186343450 +0300
@@ -78,6 +78,7 @@
 #define RRP_PROBLEM_COUNT_THRESHOLD_MIN		2
 #define RRP_AUTORECOVERY_CHECK_TIMEOUT		1000
 #define BLOCK_UNLISTED_IPS			1
+#define CANCEL_TOKEN_HOLD_ON_RETRANSMIT 	0
 
 #define DEFAULT_PORT				5405
 
@@ -133,6 +134,8 @@
 		return &totem_config->miss_count_const;
 	if (strcmp(param_name, "totem.block_unlisted_ips") == 0)
 		return &totem_config->block_unlisted_ips;
+	if (strcmp(param_name, "totem.cancel_token_hold_on_retransmit") == 0)
+		return &totem_config->cancel_token_hold_on_retransmit;
 
 	return NULL;
 }
@@ -293,6 +296,9 @@
 
 	totem_volatile_config_set_boolean_value(totem_config, "totem.block_unlisted_ips", deleted_key,
 	    BLOCK_UNLISTED_IPS);
+
+	totem_volatile_config_set_boolean_value(totem_config, "totem.cancel_token_hold_on_retransmit",
+	    deleted_key, CANCEL_TOKEN_HOLD_ON_RETRANSMIT);
 }
 
 static int totem_volatile_config_validate (
diff -Naur a/exec/totemsrp.c b/exec/totemsrp.c
--- a/exec/totemsrp.c	2019-07-30 15:26:39.000000000 +0300
+++ b/exec/totemsrp.c	2021-08-24 18:49:00.069047413 +0300
@@ -4097,7 +4097,8 @@
 		transmits_allowed = fcc_calculate (instance, token);
 		mcasted_retransmit = orf_token_rtr (instance, token, &transmits_allowed);
 
-		if (instance->my_token_held == 1 &&
+		if (instance->totem_config->cancel_token_hold_on_retransmit &&
+			instance->my_token_held == 1 &&
 			(token->rtr_list_entries > 0 || mcasted_retransmit > 0)) {
 			instance->my_token_held = 0;
 			forward_token = 1;
diff -Naur a/include/corosync/totem/totem.h b/include/corosync/totem/totem.h
--- a/include/corosync/totem/totem.h	2019-07-30 15:26:39.000000000 +0300
+++ b/include/corosync/totem/totem.h	2021-08-24 18:49:00.069047413 +0300
@@ -193,6 +193,8 @@
 
 	unsigned int block_unlisted_ips;
 
+	unsigned int cancel_token_hold_on_retransmit;
+
 	void (*totem_memb_ring_id_create_or_load) (
 	    struct memb_ring_id *memb_ring_id,
 	    const struct totem_ip_address *addr);
diff -Naur a/man/corosync.conf.5 b/man/corosync.conf.5
--- a/man/corosync.conf.5	2019-07-30 15:26:39.000000000 +0300
+++ b/man/corosync.conf.5	2021-08-24 18:49:00.073047431 +0300
@@ -529,6 +529,19 @@
 
 The default value is yes.
 
+.TP
+cancel_token_hold_on_retransmit
+Allows Corosync to hold token by representative when there is too much
+retransmit messages. This allows network to process increased load without
+overloading it. Used mechanism is same as described for
+.B hold
+directive.
+
+Some deployments may prefer to never hold token when there is
+retransmit messages. If so, option should be set to yes.
+
+The default value is no.
+
 .PP
 Within the
 .B logging
openSUSE Build Service is sponsored by