txhash: fix sk->sk_txrehash default
authorKevin Yang <yyd@google.com>
Tue, 7 Feb 2023 02:08:20 +0000 (02:08 +0000)
committerDavid S. Miller <davem@davemloft.net>
Wed, 8 Feb 2023 09:07:11 +0000 (09:07 +0000)
commitc11204c78d6966c5bda6dd05c3ac5cbb193f93e3
tree54f64528a4dd356ee84f12c30f5174c41577b4d7
parentc966153d120222cd4e85e1e1601584d7d4d91dcb
txhash: fix sk->sk_txrehash default

This code fix a bug that sk->sk_txrehash gets its default enable
value from sysctl_txrehash only when the socket is a TCP listener.

We should have sysctl_txrehash to set the default sk->sk_txrehash,
no matter TCP, nor listerner/connector.

Tested by following packetdrill:
  0 socket(..., SOCK_STREAM, IPPROTO_TCP) = 3
  +0 socket(..., SOCK_DGRAM, IPPROTO_UDP) = 4
  // SO_TXREHASH == 74, default to sysctl_txrehash == 1
  +0 getsockopt(3, SOL_SOCKET, 74, [1], [4]) = 0
  +0 getsockopt(4, SOL_SOCKET, 74, [1], [4]) = 0

Fixes: 26859240e4ee ("txhash: Add socket option to control TX hash rethink behavior")
Signed-off-by: Kevin Yang <yyd@google.com>
Signed-off-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/core/sock.c
net/ipv4/af_inet.c
net/ipv4/inet_connection_sock.c
net/ipv6/af_inet6.c