• Guillaume Nault's avatar
    tcp: Dump bound-only sockets in inet_diag. · 91051f00
    Guillaume Nault authored
    Walk the hashinfo->bhash2 table so that inet_diag can dump TCP sockets
    that are bound but haven't yet called connect() or listen().
    
    The code is inspired by the ->lhash2 loop. However there's no manual
    test of the source port, since this kind of filtering is already
    handled by inet_diag_bc_sk(). Also, a maximum of 16 sockets are dumped
    at a time, to avoid running with bh disabled for too long.
    
    There's no TCP state for bound but otherwise inactive sockets. Such
    sockets normally map to TCP_CLOSE. However, "ss -l", which is supposed
    to only dump listening sockets, actually requests the kernel to dump
    sockets in either the TCP_LISTEN or TCP_CLOSE states. To avoid dumping
    bound-only sockets with "ss -l", we therefore need to define a new
    pseudo-state (TCP_BOUND_INACTIVE) that user space will be able to set
    explicitly.
    
    With an IPv4, an IPv6 and an IPv6-only socket, bound respectively to
    40000, 64000, 60000, an updated version of iproute2 could work as
    follow:
    
      $ ss -t state bound-inactive
      Recv-Q   Send-Q     Local Address:Port       Peer Address:Port   Process
      0        0                0.0.0.0:40000           0.0.0.0:*
      0        0                   [::]:60000              [::]:*
      0        0                      *:64000                 *:*
    Reviewed-by: default avatarEric Dumazet <edumazet@google.com>
    Signed-off-by: default avatarGuillaume Nault <gnault@redhat.com>
    Reviewed-by: default avatarKuniyuki Iwashima <kuniyu@amazon.com>
    Link: https://lore.kernel.org/r/b3a84ae61e19c06806eea9c602b3b66e8f0cfc81.1701362867.git.gnault@redhat.comSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
    91051f00
inet_diag.c 37.4 KB