aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric Dumazet <dada1@cosmosbay.com>2008-02-07 04:40:19 -0500
committerYOSHIFUJI Hideaki <yoshfuji@linux-ipv6.org>2008-03-04 01:18:21 -0500
commit11baab7ac34723ad481e0f97fca733272ef364d4 (patch)
tree611ed2f14f6e3c9d36d748094e4c9c736caa699b
parent988b705077d8f922408913f4f521ae073256d4a1 (diff)
[TCP]: lower stack usage in cookie_hash() function
400 bytes allocated on stack might be a litle bit too much. Using a per_cpu var is more friendly. Signed-off-by: Eric Dumazet <dada1@cosmosbay.com> Signed-off-by: YOSHIFUJI Hideaki <yoshfuji@linux-ipv6.org>
-rw-r--r--net/ipv4/syncookies.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/net/ipv4/syncookies.c b/net/ipv4/syncookies.c
index f470fe4511db..177da14f6b14 100644
--- a/net/ipv4/syncookies.c
+++ b/net/ipv4/syncookies.c
@@ -35,10 +35,12 @@ module_init(init_syncookies);
35#define COOKIEBITS 24 /* Upper bits store count */ 35#define COOKIEBITS 24 /* Upper bits store count */
36#define COOKIEMASK (((__u32)1 << COOKIEBITS) - 1) 36#define COOKIEMASK (((__u32)1 << COOKIEBITS) - 1)
37 37
38static DEFINE_PER_CPU(__u32, cookie_scratch)[16 + 5 + SHA_WORKSPACE_WORDS];
39
38static u32 cookie_hash(__be32 saddr, __be32 daddr, __be16 sport, __be16 dport, 40static u32 cookie_hash(__be32 saddr, __be32 daddr, __be16 sport, __be16 dport,
39 u32 count, int c) 41 u32 count, int c)
40{ 42{
41 __u32 tmp[16 + 5 + SHA_WORKSPACE_WORDS]; 43 __u32 *tmp = __get_cpu_var(cookie_scratch);
42 44
43 memcpy(tmp + 3, syncookie_secret[c], sizeof(syncookie_secret[c])); 45 memcpy(tmp + 3, syncookie_secret[c], sizeof(syncookie_secret[c]));
44 tmp[0] = (__force u32)saddr; 46 tmp[0] = (__force u32)saddr;