Skip to content

Commit c6d2770

Browse files
q2vendavem330
authored andcommitted
tcp: Factorise sk_family-independent comparison in inet_bind2_bucket_match(_addr_any).
This is a prep patch to make the following patches cleaner that touch inet_bind2_bucket_match() and inet_bind2_bucket_match_addr_any(). Both functions have duplicated comparison for netns, port, and l3mdev. Let's factorise them. Signed-off-by: Kuniyuki Iwashima <kuniyu@amazon.com> Reviewed-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
1 parent 8cdd9f1 commit c6d2770

File tree

1 file changed

+13
-15
lines changed

1 file changed

+13
-15
lines changed

net/ipv4/inet_hashtables.c

Lines changed: 13 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -815,41 +815,39 @@ static bool inet_bind2_bucket_match(const struct inet_bind2_bucket *tb,
815815
const struct net *net, unsigned short port,
816816
int l3mdev, const struct sock *sk)
817817
{
818+
if (!net_eq(ib2_net(tb), net) || tb->port != port ||
819+
tb->l3mdev != l3mdev)
820+
return false;
821+
818822
#if IS_ENABLED(CONFIG_IPV6)
819823
if (sk->sk_family != tb->family)
820824
return false;
821825

822826
if (sk->sk_family == AF_INET6)
823-
return net_eq(ib2_net(tb), net) && tb->port == port &&
824-
tb->l3mdev == l3mdev &&
825-
ipv6_addr_equal(&tb->v6_rcv_saddr, &sk->sk_v6_rcv_saddr);
826-
else
827+
return ipv6_addr_equal(&tb->v6_rcv_saddr, &sk->sk_v6_rcv_saddr);
827828
#endif
828-
return net_eq(ib2_net(tb), net) && tb->port == port &&
829-
tb->l3mdev == l3mdev && tb->rcv_saddr == sk->sk_rcv_saddr;
829+
return tb->rcv_saddr == sk->sk_rcv_saddr;
830830
}
831831

832832
bool inet_bind2_bucket_match_addr_any(const struct inet_bind2_bucket *tb, const struct net *net,
833833
unsigned short port, int l3mdev, const struct sock *sk)
834834
{
835+
if (!net_eq(ib2_net(tb), net) || tb->port != port ||
836+
tb->l3mdev != l3mdev)
837+
return false;
838+
835839
#if IS_ENABLED(CONFIG_IPV6)
836840
if (sk->sk_family != tb->family) {
837841
if (sk->sk_family == AF_INET)
838-
return net_eq(ib2_net(tb), net) && tb->port == port &&
839-
tb->l3mdev == l3mdev &&
840-
ipv6_addr_any(&tb->v6_rcv_saddr);
842+
return ipv6_addr_any(&tb->v6_rcv_saddr);
841843

842844
return false;
843845
}
844846

845847
if (sk->sk_family == AF_INET6)
846-
return net_eq(ib2_net(tb), net) && tb->port == port &&
847-
tb->l3mdev == l3mdev &&
848-
ipv6_addr_any(&tb->v6_rcv_saddr);
849-
else
848+
return ipv6_addr_any(&tb->v6_rcv_saddr);
850849
#endif
851-
return net_eq(ib2_net(tb), net) && tb->port == port &&
852-
tb->l3mdev == l3mdev && tb->rcv_saddr == 0;
850+
return tb->rcv_saddr == 0;
853851
}
854852

855853
/* The socket's bhash2 hashbucket spinlock must be held when this is called */

0 commit comments

Comments
 (0)