From: Jakub Kicinski Date: Thu, 12 May 2022 23:52:21 +0000 (-0700) Subject: Merge branch 'net-inet-retire-port-only-listening_hash' X-Git-Tag: dma-mapping-5.19-2022-06-26~242^2~125 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=b67fd3d9d94223b424674f45eeadeff58b4b03ef;p=users%2Fhch%2Fdma-mapping.git Merge branch 'net-inet-retire-port-only-listening_hash' Martin KaFai Lau says: ==================== net: inet: Retire port only listening_hash This series is to retire the port only listening_hash. The listen sk is currently stored in two hash tables, listening_hash (hashed by port) and lhash2 (hashed by port and address). After commit 0ee58dad5b06 ("net: tcp6: prefer listeners bound to an address") and commit d9fbc7f6431f ("net: tcp: prefer listeners bound to an address"), the TCP-SYN lookup fast path does not use listening_hash. The commit 05c0b35709c5 ("tcp: seq_file: Replace listening_hash with lhash2") also moved the seq_file (/proc/net/tcp) iteration usage from listening_hash to lhash2. There are still a few listening_hash usages left. One of them is inet_reuseport_add_sock() which uses the listening_hash to search a listen sk during the listen() system call. This turns out to be very slow on use cases that listen on many different VIPs at a popular port (e.g. 443). [ On top of the slowness in adding to the tail in the IPv6 case ]. A latter patch has a selftest to demonstrate this case. This series takes this chance to move all remaining listening_hash usages to lhash2 and then retire listening_hash. ==================== Link: https://lore.kernel.org/r/20220512000546.188616-1-kafai@fb.com Signed-off-by: Jakub Kicinski --- b67fd3d9d94223b424674f45eeadeff58b4b03ef