diff options
author | Eric Dumazet <dada1@cosmosbay.com> | 2009-02-01 15:31:33 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2009-02-01 15:31:33 -0500 |
commit | 24dd1fa184595ff095a92de807fdf029b2632673 (patch) | |
tree | 6136ffd3f4d054acda875b07df18fd19d93647b9 | |
parent | 5add300975cf36b1bd30c461105bb938da260f14 (diff) |
net: move bsockets outside of read only beginning of struct inet_hashinfo
And switch bsockets to atomic_t since it might be changed in parallel.
Signed-off-by: Eric Dumazet <dada1@cosmosbay.com>
Acked-by: Evgeniy Polyakov <zbr@ioremap.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | include/net/inet_hashtables.h | 3 | ||||
-rw-r--r-- | net/ipv4/inet_connection_sock.c | 2 | ||||
-rw-r--r-- | net/ipv4/inet_hashtables.c | 5 |
3 files changed, 6 insertions, 4 deletions
diff --git a/include/net/inet_hashtables.h b/include/net/inet_hashtables.h index 8d98dc76bd76..a44e2248b2ef 100644 --- a/include/net/inet_hashtables.h +++ b/include/net/inet_hashtables.h | |||
@@ -134,7 +134,7 @@ struct inet_hashinfo { | |||
134 | struct inet_bind_hashbucket *bhash; | 134 | struct inet_bind_hashbucket *bhash; |
135 | 135 | ||
136 | unsigned int bhash_size; | 136 | unsigned int bhash_size; |
137 | int bsockets; | 137 | /* 4 bytes hole on 64 bit */ |
138 | 138 | ||
139 | struct kmem_cache *bind_bucket_cachep; | 139 | struct kmem_cache *bind_bucket_cachep; |
140 | 140 | ||
@@ -151,6 +151,7 @@ struct inet_hashinfo { | |||
151 | struct inet_listen_hashbucket listening_hash[INET_LHTABLE_SIZE] | 151 | struct inet_listen_hashbucket listening_hash[INET_LHTABLE_SIZE] |
152 | ____cacheline_aligned_in_smp; | 152 | ____cacheline_aligned_in_smp; |
153 | 153 | ||
154 | atomic_t bsockets; | ||
154 | }; | 155 | }; |
155 | 156 | ||
156 | static inline struct inet_ehash_bucket *inet_ehash_bucket( | 157 | static inline struct inet_ehash_bucket *inet_ehash_bucket( |
diff --git a/net/ipv4/inet_connection_sock.c b/net/ipv4/inet_connection_sock.c index 9bc6a187bdce..22cd19ee44e5 100644 --- a/net/ipv4/inet_connection_sock.c +++ b/net/ipv4/inet_connection_sock.c | |||
@@ -119,7 +119,7 @@ again: | |||
119 | (tb->num_owners < smallest_size || smallest_size == -1)) { | 119 | (tb->num_owners < smallest_size || smallest_size == -1)) { |
120 | smallest_size = tb->num_owners; | 120 | smallest_size = tb->num_owners; |
121 | smallest_rover = rover; | 121 | smallest_rover = rover; |
122 | if (hashinfo->bsockets > (high - low) + 1) { | 122 | if (atomic_read(&hashinfo->bsockets) > (high - low) + 1) { |
123 | spin_unlock(&head->lock); | 123 | spin_unlock(&head->lock); |
124 | snum = smallest_rover; | 124 | snum = smallest_rover; |
125 | goto have_snum; | 125 | goto have_snum; |
diff --git a/net/ipv4/inet_hashtables.c b/net/ipv4/inet_hashtables.c index d7b6178bf48b..625cc5f64c94 100644 --- a/net/ipv4/inet_hashtables.c +++ b/net/ipv4/inet_hashtables.c | |||
@@ -62,7 +62,7 @@ void inet_bind_hash(struct sock *sk, struct inet_bind_bucket *tb, | |||
62 | { | 62 | { |
63 | struct inet_hashinfo *hashinfo = sk->sk_prot->h.hashinfo; | 63 | struct inet_hashinfo *hashinfo = sk->sk_prot->h.hashinfo; |
64 | 64 | ||
65 | hashinfo->bsockets++; | 65 | atomic_inc(&hashinfo->bsockets); |
66 | 66 | ||
67 | inet_sk(sk)->num = snum; | 67 | inet_sk(sk)->num = snum; |
68 | sk_add_bind_node(sk, &tb->owners); | 68 | sk_add_bind_node(sk, &tb->owners); |
@@ -81,7 +81,7 @@ static void __inet_put_port(struct sock *sk) | |||
81 | struct inet_bind_hashbucket *head = &hashinfo->bhash[bhash]; | 81 | struct inet_bind_hashbucket *head = &hashinfo->bhash[bhash]; |
82 | struct inet_bind_bucket *tb; | 82 | struct inet_bind_bucket *tb; |
83 | 83 | ||
84 | hashinfo->bsockets--; | 84 | atomic_dec(&hashinfo->bsockets); |
85 | 85 | ||
86 | spin_lock(&head->lock); | 86 | spin_lock(&head->lock); |
87 | tb = inet_csk(sk)->icsk_bind_hash; | 87 | tb = inet_csk(sk)->icsk_bind_hash; |
@@ -532,6 +532,7 @@ void inet_hashinfo_init(struct inet_hashinfo *h) | |||
532 | { | 532 | { |
533 | int i; | 533 | int i; |
534 | 534 | ||
535 | atomic_set(&h->bsockets, 0); | ||
535 | for (i = 0; i < INET_LHTABLE_SIZE; i++) { | 536 | for (i = 0; i < INET_LHTABLE_SIZE; i++) { |
536 | spin_lock_init(&h->listening_hash[i].lock); | 537 | spin_lock_init(&h->listening_hash[i].lock); |
537 | INIT_HLIST_NULLS_HEAD(&h->listening_hash[i].head, | 538 | INIT_HLIST_NULLS_HEAD(&h->listening_hash[i].head, |