Eric Dumazet 035320d547 ipmr: dont corrupt lists
ipmr_rules_exit() and ip6mr_rules_exit() free a list of items, but
forget to properly remove these items from list. List head is not
changed and still points to freed memory.

This can trigger a fault later when icmpv6_sk_exit() is called.

Fix is to either reinit list, or use list_del() to properly remove items
from list before freeing them.

bugzilla report : https://bugzilla.kernel.org/show_bug.cgi?id=16120

Introduced by commit d1db275dd3f6e4 (ipv6: ip6mr: support multiple
tables) and commit f0ad0860d01e (ipv4: ipmr: support multiple tables)

Reported-by: Alex Zhavnerchik <alex.vizor@gmail.com>
Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com>
CC: Patrick McHardy <kaber@trash.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
2010-06-07 02:57:14 -07:00
..
2009-10-18 18:52:53 -07:00
2010-02-22 16:20:22 -08:00
2010-05-17 17:18:50 -07:00
2009-11-13 20:46:58 -08:00
2010-04-28 15:31:51 -07:00
2010-02-22 16:20:22 -08:00
2010-05-17 22:36:55 -07:00
2010-06-07 02:57:14 -07:00
2008-10-07 08:38:24 +11:00
2010-05-17 17:18:50 -07:00
2010-03-21 18:31:35 -07:00
2009-09-14 17:03:01 -07:00
2010-05-17 17:18:51 -07:00
2009-03-02 03:00:15 -08:00
2009-03-02 03:00:15 -08:00
2010-05-17 22:35:36 -07:00
2009-05-25 22:44:59 -07:00
2010-01-17 19:16:02 -08:00