diff options
author | Pavel Emelyanov <xemul@openvz.org> | 2007-12-20 18:32:54 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-01-28 17:59:28 -0500 |
commit | 7054fb9376e111d0edc06efcedbac6930a6caf76 (patch) | |
tree | a008ba9a3f844c5480dc650f4d0fa3fbd0690dab | |
parent | 77a5ba55dab7b4ece12f37c717022819e3f77b44 (diff) |
[INET]: Uninline the inet_twsk_put function.
This one is not that big, but is widely used: saves 1200 bytes
from net/ipv4/built-in.o
add/remove: 1/0 grow/shrink: 1/12 up/down: 97/-1300 (-1203)
function old new delta
inet_twsk_put - 87 +87
__inet_lookup_listener 274 284 +10
tcp_sacktag_write_queue 2255 2254 -1
tcp_time_wait 482 411 -71
__inet_check_established 796 722 -74
tcp_v4_err 973 898 -75
__inet_twsk_kill 230 154 -76
inet_twsk_deschedule 180 103 -77
tcp_v4_do_rcv 462 384 -78
inet_hash_connect 686 607 -79
inet_twdr_do_twkill_work 236 150 -86
inet_twdr_twcal_tick 395 307 -88
tcp_v4_rcv 1744 1480 -264
tcp_timewait_state_process 975 644 -331
Export it for ipv6 module.
Signed-off-by: Pavel Emelyanov <xemul@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | include/net/inet_timewait_sock.h | 14 | ||||
-rw-r--r-- | net/ipv4/inet_timewait_sock.c | 15 |
2 files changed, 16 insertions, 13 deletions
diff --git a/include/net/inet_timewait_sock.h b/include/net/inet_timewait_sock.h index abaff059727..67e925065aa 100644 --- a/include/net/inet_timewait_sock.h +++ b/include/net/inet_timewait_sock.h | |||
@@ -193,19 +193,7 @@ static inline __be32 inet_rcv_saddr(const struct sock *sk) | |||
193 | inet_sk(sk)->rcv_saddr : inet_twsk(sk)->tw_rcv_saddr; | 193 | inet_sk(sk)->rcv_saddr : inet_twsk(sk)->tw_rcv_saddr; |
194 | } | 194 | } |
195 | 195 | ||
196 | static inline void inet_twsk_put(struct inet_timewait_sock *tw) | 196 | extern void inet_twsk_put(struct inet_timewait_sock *tw); |
197 | { | ||
198 | if (atomic_dec_and_test(&tw->tw_refcnt)) { | ||
199 | struct module *owner = tw->tw_prot->owner; | ||
200 | twsk_destructor((struct sock *)tw); | ||
201 | #ifdef SOCK_REFCNT_DEBUG | ||
202 | printk(KERN_DEBUG "%s timewait_sock %p released\n", | ||
203 | tw->tw_prot->name, tw); | ||
204 | #endif | ||
205 | kmem_cache_free(tw->tw_prot->twsk_prot->twsk_slab, tw); | ||
206 | module_put(owner); | ||
207 | } | ||
208 | } | ||
209 | 197 | ||
210 | extern struct inet_timewait_sock *inet_twsk_alloc(const struct sock *sk, | 198 | extern struct inet_timewait_sock *inet_twsk_alloc(const struct sock *sk, |
211 | const int state); | 199 | const int state); |
diff --git a/net/ipv4/inet_timewait_sock.c b/net/ipv4/inet_timewait_sock.c index d43e787031a..1b7db420896 100644 --- a/net/ipv4/inet_timewait_sock.c +++ b/net/ipv4/inet_timewait_sock.c | |||
@@ -48,6 +48,21 @@ static void __inet_twsk_kill(struct inet_timewait_sock *tw, | |||
48 | inet_twsk_put(tw); | 48 | inet_twsk_put(tw); |
49 | } | 49 | } |
50 | 50 | ||
51 | void inet_twsk_put(struct inet_timewait_sock *tw) | ||
52 | { | ||
53 | if (atomic_dec_and_test(&tw->tw_refcnt)) { | ||
54 | struct module *owner = tw->tw_prot->owner; | ||
55 | twsk_destructor((struct sock *)tw); | ||
56 | #ifdef SOCK_REFCNT_DEBUG | ||
57 | printk(KERN_DEBUG "%s timewait_sock %p released\n", | ||
58 | tw->tw_prot->name, tw); | ||
59 | #endif | ||
60 | kmem_cache_free(tw->tw_prot->twsk_prot->twsk_slab, tw); | ||
61 | module_put(owner); | ||
62 | } | ||
63 | } | ||
64 | EXPORT_SYMBOL_GPL(inet_twsk_put); | ||
65 | |||
51 | /* | 66 | /* |
52 | * Enter the time wait state. This is called with locally disabled BH. | 67 | * Enter the time wait state. This is called with locally disabled BH. |
53 | * Essentially we whip up a timewait bucket, copy the relevant info into it | 68 | * Essentially we whip up a timewait bucket, copy the relevant info into it |