summaryrefslogtreecommitdiff
path: root/crypto
diff options
context:
space:
mode:
authorPeter Oskolkov <posk@google.com>2018-12-13 00:15:36 +0300
committerDavid S. Miller <davem@davemloft.net>2018-12-15 02:55:20 +0300
commit0ee58dad5b065f5910c2c926d8c9f07cbe2db86c (patch)
treed3ddf14a070b7e5ad536fe0357b6cbcd783eb40f /crypto
parentd9fbc7f6431fc0e5c0ddedf72206d7c5175c5c9a (diff)
downloadlinux-0ee58dad5b065f5910c2c926d8c9f07cbe2db86c.tar.xz
net: tcp6: prefer listeners bound to an address
A relatively common use case is to have several IPs configured on a host, and have different listeners for each of them. We would like to add a "catch all" listener on addr_any, to match incoming connections not served by any of the listeners bound to a specific address. However, port-only lookups can match addr_any sockets when sockets listening on specific addresses are present if so_reuseport flag is set. This patch eliminates lookups into port-only hashtable, as lookups by (addr,port) tuple are easily available. In addition, compute_score() is tweaked to _not_ match addr_any sockets to specific addresses, as hash collisions could result in the unwanted behavior described above. Tested: the patch compiles; full test in the last patch in this patchset. Existing reuseport_* selftests also pass. Suggested-by: Eric Dumazet <edumazet@google.com> Signed-off-by: Peter Oskolkov <posk@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'crypto')
0 files changed, 0 insertions, 0 deletions