diff options
author | Miroslav Urbanek <mu@miroslavurbanek.com> | 2015-02-05 10:36:50 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-02-05 17:38:53 -0500 |
commit | 233c96fc077d310772375d47522fb444ff546905 (patch) | |
tree | 4fa6a03001136123b52f522ed22778f6f36ad28e /net/core/flow.c | |
parent | 9d82f5eb3376cbae96ad36a063a9390de1694546 (diff) |
flowcache: Fix kernel panic in flow_cache_flush_task
flow_cache_flush_task references a structure member flow_cache_gc_work
where it should reference flow_cache_flush_task instead.
Kernel panic occurs on kernels using IPsec during XFRM garbage
collection. The garbage collection interval can be shortened using the
following sysctl settings:
net.ipv4.xfrm4_gc_thresh=4
net.ipv6.xfrm6_gc_thresh=4
With the default settings, our productions servers crash approximately
once a week. With the settings above, they crash immediately.
Fixes: ca925cf1534e ("flowcache: Make flow cache name space aware")
Reported-by: Tomáš Charvát <tc@excello.cz>
Tested-by: Jan Hejl <jh@excello.cz>
Signed-off-by: Miroslav Urbanek <mu@miroslavurbanek.com>
Acked-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core/flow.c')
-rw-r--r-- | net/core/flow.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/core/flow.c b/net/core/flow.c index a0348fde1fdf..1033725be40b 100644 --- a/net/core/flow.c +++ b/net/core/flow.c | |||
@@ -379,7 +379,7 @@ done: | |||
379 | static void flow_cache_flush_task(struct work_struct *work) | 379 | static void flow_cache_flush_task(struct work_struct *work) |
380 | { | 380 | { |
381 | struct netns_xfrm *xfrm = container_of(work, struct netns_xfrm, | 381 | struct netns_xfrm *xfrm = container_of(work, struct netns_xfrm, |
382 | flow_cache_gc_work); | 382 | flow_cache_flush_work); |
383 | struct net *net = container_of(xfrm, struct net, xfrm); | 383 | struct net *net = container_of(xfrm, struct net, xfrm); |
384 | 384 | ||
385 | flow_cache_flush(net); | 385 | flow_cache_flush(net); |