diff options
author | Eric Dumazet <dada1@cosmosbay.com> | 2008-11-23 18:42:23 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-11-23 18:42:23 -0500 |
commit | 04f258ce7f085dd69422fa01d41c8f0194a0e270 (patch) | |
tree | 948bf0a108717265df6228bcac2126ec423cb988 | |
parent | c46920dadba65856eb1a1f1ffa1b350875db1228 (diff) |
net: some optimizations in af_inet
1) Use eq_net() in inet_netns_ok() to speedup socket creation if
!CONFIG_NET_NS
2) Reorder the tests about inet_ehash_secret generation (once only)
Use the unlikely() macro when testing if inet_ehash_secret already
generated.
Signed-off-by: Eric Dumazet <dada1@cosmosbay.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/ipv4/af_inet.c | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/net/ipv4/af_inet.c b/net/ipv4/af_inet.c index b1462e8c64cf..fe03048c130d 100644 --- a/net/ipv4/af_inet.c +++ b/net/ipv4/af_inet.c | |||
@@ -245,7 +245,7 @@ static inline int inet_netns_ok(struct net *net, int protocol) | |||
245 | int hash; | 245 | int hash; |
246 | struct net_protocol *ipprot; | 246 | struct net_protocol *ipprot; |
247 | 247 | ||
248 | if (net == &init_net) | 248 | if (net_eq(net, &init_net)) |
249 | return 1; | 249 | return 1; |
250 | 250 | ||
251 | hash = protocol & (MAX_INET_PROTOS - 1); | 251 | hash = protocol & (MAX_INET_PROTOS - 1); |
@@ -272,10 +272,9 @@ static int inet_create(struct net *net, struct socket *sock, int protocol) | |||
272 | int try_loading_module = 0; | 272 | int try_loading_module = 0; |
273 | int err; | 273 | int err; |
274 | 274 | ||
275 | if (sock->type != SOCK_RAW && | 275 | if (unlikely(!inet_ehash_secret)) |
276 | sock->type != SOCK_DGRAM && | 276 | if (sock->type != SOCK_RAW && sock->type != SOCK_DGRAM) |
277 | !inet_ehash_secret) | 277 | build_ehash_secret(); |
278 | build_ehash_secret(); | ||
279 | 278 | ||
280 | sock->state = SS_UNCONNECTED; | 279 | sock->state = SS_UNCONNECTED; |
281 | 280 | ||