diff options
author | David S. Miller <davem@davemloft.net> | 2008-09-10 01:13:28 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-09-10 01:13:28 -0400 |
commit | 08569908fffec3625e29eec7cf7577eaa512e719 (patch) | |
tree | 5d28f7766863b7146e76a92909e8a1c5099ef886 | |
parent | abb81c4f3cb9b8d421f1e5474811ef1d461d341c (diff) |
ipsec: Add missing list_del() in xfrm_state_gc_task().
Otherwise entries stay on the GC todo list forever, even after we free
them.
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/xfrm/xfrm_state.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/net/xfrm/xfrm_state.c b/net/xfrm/xfrm_state.c index aaafcee02fc5..abbe2702c400 100644 --- a/net/xfrm/xfrm_state.c +++ b/net/xfrm/xfrm_state.c | |||
@@ -423,6 +423,7 @@ static void xfrm_state_gc_task(struct work_struct *data) | |||
423 | list_for_each_entry_safe(x, tmp, &xfrm_state_gc_leftovers, gclist) { | 423 | list_for_each_entry_safe(x, tmp, &xfrm_state_gc_leftovers, gclist) { |
424 | if ((long)(x->lastused - completed) > 0) | 424 | if ((long)(x->lastused - completed) > 0) |
425 | break; | 425 | break; |
426 | list_del(&x->gclist); | ||
426 | xfrm_state_gc_destroy(x); | 427 | xfrm_state_gc_destroy(x); |
427 | } | 428 | } |
428 | 429 | ||