[SOCK]: Add some notes about per-bind-bucket sock lookup.
authorPavel Emelyanov <xemul@openvz.org>
Mon, 14 Apr 2008 09:42:27 +0000 (02:42 -0700)
committerDavid S. Miller <davem@davemloft.net>
Mon, 14 Apr 2008 09:42:27 +0000 (02:42 -0700)
I was asked about "why don't we perform a sk_net filtering in
bind_conflict calls, like we do in other sock lookup places"
for a couple of times.

Can we please add a comment about why we do not need one?

Signed-off-by: Pavel Emelyanov <xemul@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv4/inet_connection_sock.c
net/ipv6/inet6_connection_sock.c

index 8d70cfbacb78470105bbc02590fc8120f7daaece..828ea211ff211b204185b52b20d1a719912d5699 100644 (file)
@@ -55,6 +55,13 @@ int inet_csk_bind_conflict(const struct sock *sk,
        struct hlist_node *node;
        int reuse = sk->sk_reuse;
 
+       /*
+        * Unlike other sk lookup places we do not check
+        * for sk_net here, since _all_ the socks listed
+        * in tb->owners list belong to the same net - the
+        * one this bucket belongs to.
+        */
+
        sk_for_each_bound(sk2, node, &tb->owners) {
                if (sk != sk2 &&
                    !inet_v6_ipv6only(sk2) &&
index 78de42ada8444225799e9509ecb5424944e493f6..87801cc1b2f88405b363ebb11b25d58c1d16eea5 100644 (file)
@@ -33,6 +33,10 @@ int inet6_csk_bind_conflict(const struct sock *sk,
        const struct hlist_node *node;
 
        /* We must walk the whole port owner list in this case. -DaveM */
+       /*
+        * See comment in inet_csk_bind_conflict about sock lookup
+        * vs net namespaces issues.
+        */
        sk_for_each_bound(sk2, node, &tb->owners) {
                if (sk != sk2 &&
                    (!sk->sk_bound_dev_if ||