]> git.baikalelectronics.ru Git - kernel.git/commit
tipc: improve link resiliency when rps is activated
authorJon Maloy <jon.maloy@ericsson.com>
Wed, 8 Nov 2017 08:59:26 +0000 (09:59 +0100)
committerDavid S. Miller <davem@davemloft.net>
Sat, 11 Nov 2017 06:36:05 +0000 (15:36 +0900)
commitbbd7cbb8dc4eeb8f7af928b8ea21afe72250ec6a
treef15780b41b74719daa4b849b1deb2e425a10ab61
parentb8bff43a226a6439d536a4d03bc4d17689bf3926
tipc: improve link resiliency when rps is activated

Currently, the TIPC RPS dissector is based only on the incoming packets'
source node address, hence steering all traffic from a node to the same
core. We have seen that this makes the links vulnerable to starvation
and unnecessary resets when we turn down the link tolerance to very low
values.

To reduce the risk of this happening, we exempt probe and probe replies
packets from the convergence to one core per source node. Instead, we do
the opposite, - we try to diverge those packets across as many cores as
possible, by randomizing the flow selector key.

To make such packets identifiable to the dissector, we add a new
'is_keepalive' bit to word 0 of the LINK_PROTOCOL header. This bit is
set both for PROBE and PROBE_REPLY messages, and only for those.

It should be noted that these packets are not part of any flow anyway,
and only constitute a minuscule fraction of all packets sent across a
link. Hence, there is no risk that this will affect overall performance.

Acked-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>
include/net/flow_dissector.h
include/net/tipc.h [new file with mode: 0644]
net/core/flow_dissector.c
net/tipc/link.c
net/tipc/msg.h