diff options
Diffstat (limited to 'net/ipv6')
-rw-r--r-- | net/ipv6/af_inet6.c | 31 | ||||
-rw-r--r-- | net/ipv6/ipv6_sockglue.c | 15 | ||||
-rw-r--r-- | net/ipv6/tcp_ipv6.c | 18 |
3 files changed, 32 insertions, 32 deletions
diff --git a/net/ipv6/af_inet6.c b/net/ipv6/af_inet6.c index 574047353628..7df2ccb380d9 100644 --- a/net/ipv6/af_inet6.c +++ b/net/ipv6/af_inet6.c | |||
@@ -86,26 +86,12 @@ extern void if6_proc_exit(void); | |||
86 | 86 | ||
87 | int sysctl_ipv6_bindv6only; | 87 | int sysctl_ipv6_bindv6only; |
88 | 88 | ||
89 | #ifdef INET_REFCNT_DEBUG | ||
90 | atomic_t inet6_sock_nr; | ||
91 | EXPORT_SYMBOL(inet6_sock_nr); | ||
92 | #endif | ||
93 | |||
94 | /* The inetsw table contains everything that inet_create needs to | 89 | /* The inetsw table contains everything that inet_create needs to |
95 | * build a new socket. | 90 | * build a new socket. |
96 | */ | 91 | */ |
97 | static struct list_head inetsw6[SOCK_MAX]; | 92 | static struct list_head inetsw6[SOCK_MAX]; |
98 | static DEFINE_SPINLOCK(inetsw6_lock); | 93 | static DEFINE_SPINLOCK(inetsw6_lock); |
99 | 94 | ||
100 | static void inet6_sock_destruct(struct sock *sk) | ||
101 | { | ||
102 | inet_sock_destruct(sk); | ||
103 | |||
104 | #ifdef INET_REFCNT_DEBUG | ||
105 | atomic_dec(&inet6_sock_nr); | ||
106 | #endif | ||
107 | } | ||
108 | |||
109 | static __inline__ struct ipv6_pinfo *inet6_sk_generic(struct sock *sk) | 95 | static __inline__ struct ipv6_pinfo *inet6_sk_generic(struct sock *sk) |
110 | { | 96 | { |
111 | const int offset = sk->sk_prot->obj_size - sizeof(struct ipv6_pinfo); | 97 | const int offset = sk->sk_prot->obj_size - sizeof(struct ipv6_pinfo); |
@@ -186,7 +172,7 @@ static int inet6_create(struct socket *sock, int protocol) | |||
186 | inet->hdrincl = 1; | 172 | inet->hdrincl = 1; |
187 | } | 173 | } |
188 | 174 | ||
189 | sk->sk_destruct = inet6_sock_destruct; | 175 | sk->sk_destruct = inet_sock_destruct; |
190 | sk->sk_family = PF_INET6; | 176 | sk->sk_family = PF_INET6; |
191 | sk->sk_protocol = protocol; | 177 | sk->sk_protocol = protocol; |
192 | 178 | ||
@@ -213,12 +199,17 @@ static int inet6_create(struct socket *sock, int protocol) | |||
213 | inet->pmtudisc = IP_PMTUDISC_DONT; | 199 | inet->pmtudisc = IP_PMTUDISC_DONT; |
214 | else | 200 | else |
215 | inet->pmtudisc = IP_PMTUDISC_WANT; | 201 | inet->pmtudisc = IP_PMTUDISC_WANT; |
202 | /* | ||
203 | * Increment only the relevant sk_prot->socks debug field, this changes | ||
204 | * the previous behaviour of incrementing both the equivalent to | ||
205 | * answer->prot->socks (inet6_sock_nr) and inet_sock_nr. | ||
206 | * | ||
207 | * This allows better debug granularity as we'll know exactly how many | ||
208 | * UDPv6, TCPv6, etc socks were allocated, not the sum of all IPv6 | ||
209 | * transport protocol socks. -acme | ||
210 | */ | ||
211 | sk_refcnt_debug_inc(sk); | ||
216 | 212 | ||
217 | |||
218 | #ifdef INET_REFCNT_DEBUG | ||
219 | atomic_inc(&inet6_sock_nr); | ||
220 | atomic_inc(&inet_sock_nr); | ||
221 | #endif | ||
222 | if (inet->num) { | 213 | if (inet->num) { |
223 | /* It assumes that any protocol which allows | 214 | /* It assumes that any protocol which allows |
224 | * the user to assign a number at socket | 215 | * the user to assign a number at socket |
diff --git a/net/ipv6/ipv6_sockglue.c b/net/ipv6/ipv6_sockglue.c index 3bc144a79fa5..76fe23925d77 100644 --- a/net/ipv6/ipv6_sockglue.c +++ b/net/ipv6/ipv6_sockglue.c | |||
@@ -163,6 +163,13 @@ int ipv6_setsockopt(struct sock *sk, int level, int optname, | |||
163 | fl6_free_socklist(sk); | 163 | fl6_free_socklist(sk); |
164 | ipv6_sock_mc_close(sk); | 164 | ipv6_sock_mc_close(sk); |
165 | 165 | ||
166 | /* | ||
167 | * Sock is moving from IPv6 to IPv4 (sk_prot), so | ||
168 | * remove it from the refcnt debug socks count in the | ||
169 | * original family... | ||
170 | */ | ||
171 | sk_refcnt_debug_dec(sk); | ||
172 | |||
166 | if (sk->sk_protocol == IPPROTO_TCP) { | 173 | if (sk->sk_protocol == IPPROTO_TCP) { |
167 | struct tcp_sock *tp = tcp_sk(sk); | 174 | struct tcp_sock *tp = tcp_sk(sk); |
168 | 175 | ||
@@ -192,9 +199,11 @@ int ipv6_setsockopt(struct sock *sk, int level, int optname, | |||
192 | kfree_skb(pktopt); | 199 | kfree_skb(pktopt); |
193 | 200 | ||
194 | sk->sk_destruct = inet_sock_destruct; | 201 | sk->sk_destruct = inet_sock_destruct; |
195 | #ifdef INET_REFCNT_DEBUG | 202 | /* |
196 | atomic_dec(&inet6_sock_nr); | 203 | * ... and add it to the refcnt debug socks count |
197 | #endif | 204 | * in the new family. -acme |
205 | */ | ||
206 | sk_refcnt_debug_inc(sk); | ||
198 | module_put(THIS_MODULE); | 207 | module_put(THIS_MODULE); |
199 | retv = 0; | 208 | retv = 0; |
200 | break; | 209 | break; |
diff --git a/net/ipv6/tcp_ipv6.c b/net/ipv6/tcp_ipv6.c index ef29cfd936d3..885e05bd99f6 100644 --- a/net/ipv6/tcp_ipv6.c +++ b/net/ipv6/tcp_ipv6.c | |||
@@ -1407,12 +1407,11 @@ static struct sock * tcp_v6_syn_recv_sock(struct sock *sk, struct sk_buff *skb, | |||
1407 | newnp->mcast_oif = tcp_v6_iif(skb); | 1407 | newnp->mcast_oif = tcp_v6_iif(skb); |
1408 | newnp->mcast_hops = skb->nh.ipv6h->hop_limit; | 1408 | newnp->mcast_hops = skb->nh.ipv6h->hop_limit; |
1409 | 1409 | ||
1410 | /* Charge newly allocated IPv6 socket. Though it is mapped, | 1410 | /* |
1411 | * it is IPv6 yet. | 1411 | * No need to charge this sock to the relevant IPv6 refcnt debug socks count |
1412 | * here, tcp_create_openreq_child now does this for us, see the comment in | ||
1413 | * that function for the gory details. -acme | ||
1412 | */ | 1414 | */ |
1413 | #ifdef INET_REFCNT_DEBUG | ||
1414 | atomic_inc(&inet6_sock_nr); | ||
1415 | #endif | ||
1416 | 1415 | ||
1417 | /* It is tricky place. Until this moment IPv4 tcp | 1416 | /* It is tricky place. Until this moment IPv4 tcp |
1418 | worked with IPv6 af_tcp.af_specific. | 1417 | worked with IPv6 af_tcp.af_specific. |
@@ -1467,10 +1466,11 @@ static struct sock * tcp_v6_syn_recv_sock(struct sock *sk, struct sk_buff *skb, | |||
1467 | if (newsk == NULL) | 1466 | if (newsk == NULL) |
1468 | goto out; | 1467 | goto out; |
1469 | 1468 | ||
1470 | /* Charge newly allocated IPv6 socket */ | 1469 | /* |
1471 | #ifdef INET_REFCNT_DEBUG | 1470 | * No need to charge this sock to the relevant IPv6 refcnt debug socks |
1472 | atomic_inc(&inet6_sock_nr); | 1471 | * count here, tcp_create_openreq_child now does this for us, see the |
1473 | #endif | 1472 | * comment in that function for the gory details. -acme |
1473 | */ | ||
1474 | 1474 | ||
1475 | ip6_dst_store(newsk, dst, NULL); | 1475 | ip6_dst_store(newsk, dst, NULL); |
1476 | newsk->sk_route_caps = dst->dev->features & | 1476 | newsk->sk_route_caps = dst->dev->features & |