summaryrefslogtreecommitdiffstats
path: root/net/ipv6/addrconf.c
diff options
context:
space:
mode:
authorNikolay Borisov <kernel@kyup.com>2015-10-16 09:40:28 +0300
committerPablo Neira Ayuso <pablo@netfilter.org>2015-10-17 13:01:24 +0200
commit00db674bedd68ff8b5afae9030ff5e04d45d1b4a (patch)
treec012653980bb096c790f7cd090ce5d14c60cb01d /net/ipv6/addrconf.c
parent514ed62ed3f6846325d9bfb15cb5c3540547f13b (diff)
downloadblackbird-obmc-linux-00db674bedd68ff8b5afae9030ff5e04d45d1b4a.tar.gz
blackbird-obmc-linux-00db674bedd68ff8b5afae9030ff5e04d45d1b4a.zip
netfilter: ipset: Fix sleeping memory allocation in atomic context
Commit 00590fdd5be0 introduced RCU locking in list type and in doing so introduced a memory allocation in list_set_add, which is done in an atomic context, due to the fact that ipset rcu list modifications are serialised with a spin lock. The reason why we can't use a mutex is that in addition to modifying the list with ipset commands, it's also being modified when a particular ipset rule timeout expires aka garbage collection. This gc is triggered from set_cleanup_entries, which in turn is invoked from a timer thus requiring the lock to be bh-safe. Concretely the following call chain can lead to "sleeping function called in atomic context" splat: call_ad -> list_set_uadt -> list_set_uadd -> kzalloc(, GFP_KERNEL). And since GFP_KERNEL allows initiating direct reclaim thus potentially sleeping in the allocation path. To fix the issue change the allocation type to GFP_ATOMIC, to correctly reflect that it is occuring in an atomic context. Fixes: 00590fdd5be0 ("netfilter: ipset: Introduce RCU locking in list type") Signed-off-by: Nikolay Borisov <kernel@kyup.com> Acked-by: Jozsef Kadlecsik <kadlec@blackhole.kfki.hu> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'net/ipv6/addrconf.c')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud