diff options
author | Eric W. Biederman <ebiederm@xmission.com> | 2012-08-06 04:40:21 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-08-15 01:44:12 -0400 |
commit | 4cdadcbcb64bdf3ae8bdf3ef5bb2b91c85444cfa (patch) | |
tree | fc6fd317dd6e128f176101c5843f58ed8ab86c9c /include | |
parent | f1f4376307ca45558eb22487022aefceed7385e8 (diff) |
sctp: Make the endpoint hashtable handle multiple network namespaces
- Use struct net in the hash calculation
- Use sock_net(endpoint.base.sk) in the endpoint lookups.
- On receive calculate the network namespace from skb->dev.
Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com>
Acked-by: Vlad Yasevich <vyasevich@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include')
-rw-r--r-- | include/net/sctp/sctp.h | 4 | ||||
-rw-r--r-- | include/net/sctp/structs.h | 2 |
2 files changed, 3 insertions, 3 deletions
diff --git a/include/net/sctp/sctp.h b/include/net/sctp/sctp.h index 7c0504034583..87b119f74c4a 100644 --- a/include/net/sctp/sctp.h +++ b/include/net/sctp/sctp.h | |||
@@ -638,9 +638,9 @@ static inline int sctp_phashfn(struct net *net, __u16 lport) | |||
638 | } | 638 | } |
639 | 639 | ||
640 | /* This is the hash function for the endpoint hash table. */ | 640 | /* This is the hash function for the endpoint hash table. */ |
641 | static inline int sctp_ep_hashfn(__u16 lport) | 641 | static inline int sctp_ep_hashfn(struct net *net, __u16 lport) |
642 | { | 642 | { |
643 | return lport & (sctp_ep_hashsize - 1); | 643 | return (net_hash_mix(net) + lport) & (sctp_ep_hashsize - 1); |
644 | } | 644 | } |
645 | 645 | ||
646 | /* This is the hash function for the association hash table. */ | 646 | /* This is the hash function for the association hash table. */ |
diff --git a/include/net/sctp/structs.h b/include/net/sctp/structs.h index c089bb12af77..9f9de558541f 100644 --- a/include/net/sctp/structs.h +++ b/include/net/sctp/structs.h | |||
@@ -1426,7 +1426,7 @@ struct sctp_association *sctp_endpoint_lookup_assoc( | |||
1426 | int sctp_endpoint_is_peeled_off(struct sctp_endpoint *, | 1426 | int sctp_endpoint_is_peeled_off(struct sctp_endpoint *, |
1427 | const union sctp_addr *); | 1427 | const union sctp_addr *); |
1428 | struct sctp_endpoint *sctp_endpoint_is_match(struct sctp_endpoint *, | 1428 | struct sctp_endpoint *sctp_endpoint_is_match(struct sctp_endpoint *, |
1429 | const union sctp_addr *); | 1429 | struct net *, const union sctp_addr *); |
1430 | int sctp_has_association(const union sctp_addr *laddr, | 1430 | int sctp_has_association(const union sctp_addr *laddr, |
1431 | const union sctp_addr *paddr); | 1431 | const union sctp_addr *paddr); |
1432 | 1432 | ||