aboutsummaryrefslogtreecommitdiffstats
path: root/net/tipc
diff options
context:
space:
mode:
authorJon Paul Maloy <jon.maloy@ericsson.com>2015-03-13 16:08:09 -0400
committerDavid S. Miller <davem@davemloft.net>2015-03-14 14:38:32 -0400
commit2cdf3918e47e98c8f34f7a64455ea9fd433756e7 (patch)
treef70b865533e5a66cd59ed5e8224863bacafa05ed /net/tipc
parentc1336ee472f83a90ede01fdae095ed5d0a2934c9 (diff)
tipc: eliminate unnecessary call to broadcast ack function
The unicast packet header contains a broadcast acknowledge sequence number, that may need to be conveyed to the broadcast link for proper treatment. Currently, the function tipc_rcv(), which is on the most critical data path, calls the function tipc_bclink_acknowledge() to have this done. This call is made for each received packet, and results in the unconditional grabbing of the broadcast link spinlock. This is unnecessary, since we can see directly from tipc_rcv() if the acknowledged number differs from what has been previously acked from the node in question. In the vast majority of cases the numbers won't differ, and there is nothing to update. We now make the call to tipc_bclink_acknowledge() conditional to that the two ack values differ. Reviewed-by: Erik Hugne <erik.hugne@ericsson.com> Reviewed-by: Ying Xue <ying.xue@windriver.com> Signed-off-by: Jon Maloy <jon.maloy@ericsson.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/tipc')
-rw-r--r--net/tipc/bcast.c4
-rw-r--r--net/tipc/link.c2
2 files changed, 5 insertions, 1 deletions
diff --git a/net/tipc/bcast.c b/net/tipc/bcast.c
index 3e41704832de..5ee5076a8b27 100644
--- a/net/tipc/bcast.c
+++ b/net/tipc/bcast.c
@@ -215,7 +215,11 @@ void tipc_bclink_acknowledge(struct tipc_node *n_ptr, u32 acked)
215 struct net *net = n_ptr->net; 215 struct net *net = n_ptr->net;
216 struct tipc_net *tn = net_generic(net, tipc_net_id); 216 struct tipc_net *tn = net_generic(net, tipc_net_id);
217 217
218 if (unlikely(!n_ptr->bclink.recv_permitted))
219 return;
220
218 tipc_bclink_lock(net); 221 tipc_bclink_lock(net);
222
219 /* Bail out if tx queue is empty (no clean up is required) */ 223 /* Bail out if tx queue is empty (no clean up is required) */
220 skb = skb_peek(&tn->bcl->outqueue); 224 skb = skb_peek(&tn->bcl->outqueue);
221 if (!skb) 225 if (!skb)
diff --git a/net/tipc/link.c b/net/tipc/link.c
index 56c39b1a53a9..2652c3286e2f 100644
--- a/net/tipc/link.c
+++ b/net/tipc/link.c
@@ -1117,7 +1117,7 @@ void tipc_rcv(struct net *net, struct sk_buff *skb, struct tipc_bearer *b_ptr)
1117 ackd = msg_ack(msg); 1117 ackd = msg_ack(msg);
1118 1118
1119 /* Release acked messages */ 1119 /* Release acked messages */
1120 if (likely(n_ptr->bclink.recv_permitted)) 1120 if (unlikely(n_ptr->bclink.acked != msg_bcast_ack(msg)))
1121 tipc_bclink_acknowledge(n_ptr, msg_bcast_ack(msg)); 1121 tipc_bclink_acknowledge(n_ptr, msg_bcast_ack(msg));
1122 1122
1123 released = 0; 1123 released = 0;