* [PATCH] tipc: Increase frequency of load distribution over broadcast link
@ 2010-03-15 18:02 Neil Horman
2010-03-17 4:27 ` David Miller
0 siblings, 1 reply; 2+ messages in thread
From: Neil Horman @ 2010-03-15 18:02 UTC (permalink / raw)
To: netdev; +Cc: davem, nhorman, allan.stephens
Forward port commit 29eb572941501c40ac6e62dbc5043bf9ee76ee56
from git://tipc.cslab.ericsson.net/pub/git/people/allan/tipc.git
Origional commit message:
Increase frequency of load distribution over broadcast link
This patch enhances the behavior of TIPC's broadcast link so that it
alternates between redundant bearers (if available) after every
message sent, rather than after every 10 messages. This change helps
to speed up delivery of retransmitted messages by ensuring that
they are not sent repeatedly over a bearer that is no longer working,
but not yet recognized as failed.
Tested by myself in the latest net-2.6 tree using the tipc sanity test suite
Origionally-signed-off-by: Allan Stephens <allan.stephens@windriver.com>
Signed-off-by: Neil Horman <nhorman@tuxdriver.com>
bcast.c | 35 ++++++++++++++---------------------
1 file changed, 14 insertions(+), 21 deletions(-)
diff --git a/net/tipc/bcast.c b/net/tipc/bcast.c
index a3bfd40..90a0519 100644
--- a/net/tipc/bcast.c
+++ b/net/tipc/bcast.c
@@ -558,10 +558,7 @@ static int tipc_bcbearer_send(struct sk_buff *buf,
struct tipc_bearer *unused1,
struct tipc_media_addr *unused2)
{
- static int send_count = 0;
-
int bp_index;
- int swap_time;
/* Prepare buffer for broadcasting (if first time trying to send it) */
@@ -575,11 +572,6 @@ static int tipc_bcbearer_send(struct sk_buff *buf,
msg_set_mc_netid(msg, tipc_net_id);
}
- /* Determine if bearer pairs should be swapped following this attempt */
-
- if ((swap_time = (++send_count >= 10)))
- send_count = 0;
-
/* Send buffer over bearers until all targets reached */
bcbearer->remains = tipc_cltr_bcast_nodes;
@@ -595,21 +587,22 @@ static int tipc_bcbearer_send(struct sk_buff *buf,
if (bcbearer->remains_new.count == bcbearer->remains.count)
continue; /* bearer pair doesn't add anything */
- if (!p->publ.blocked &&
- !p->media->send_msg(buf, &p->publ, &p->media->bcast_addr)) {
- if (swap_time && s && !s->publ.blocked)
- goto swap;
- else
- goto update;
+ if (p->publ.blocked ||
+ p->media->send_msg(buf, &p->publ, &p->media->bcast_addr)) {
+ /* unable to send on primary bearer */
+ if (!s || s->publ.blocked ||
+ s->media->send_msg(buf, &s->publ,
+ &s->media->bcast_addr)) {
+ /* unable to send on either bearer */
+ continue;
+ }
+ }
+
+ if (s) {
+ bcbearer->bpairs[bp_index].primary = s;
+ bcbearer->bpairs[bp_index].secondary = p;
}
- if (!s || s->publ.blocked ||
- s->media->send_msg(buf, &s->publ, &s->media->bcast_addr))
- continue; /* unable to send using bearer pair */
-swap:
- bcbearer->bpairs[bp_index].primary = s;
- bcbearer->bpairs[bp_index].secondary = p;
-update:
if (bcbearer->remains_new.count == 0)
return 0;
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH] tipc: Increase frequency of load distribution over broadcast link
2010-03-15 18:02 [PATCH] tipc: Increase frequency of load distribution over broadcast link Neil Horman
@ 2010-03-17 4:27 ` David Miller
0 siblings, 0 replies; 2+ messages in thread
From: David Miller @ 2010-03-17 4:27 UTC (permalink / raw)
To: nhorman; +Cc: netdev, allan.stephens
From: Neil Horman <nhorman@tuxdriver.com>
Date: Mon, 15 Mar 2010 14:02:24 -0400
> Forward port commit 29eb572941501c40ac6e62dbc5043bf9ee76ee56
> from git://tipc.cslab.ericsson.net/pub/git/people/allan/tipc.git
>
> Origional commit message:
> Increase frequency of load distribution over broadcast link
>
> This patch enhances the behavior of TIPC's broadcast link so that it
> alternates between redundant bearers (if available) after every
> message sent, rather than after every 10 messages. This change helps
> to speed up delivery of retransmitted messages by ensuring that
> they are not sent repeatedly over a bearer that is no longer working,
> but not yet recognized as failed.
>
> Tested by myself in the latest net-2.6 tree using the tipc sanity test suite
>
> Origionally-signed-off-by: Allan Stephens <allan.stephens@windriver.com>
> Signed-off-by: Neil Horman <nhorman@tuxdriver.com>
Applied.
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2010-03-17 4:26 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-03-15 18:02 [PATCH] tipc: Increase frequency of load distribution over broadcast link Neil Horman
2010-03-17 4:27 ` David Miller
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).