]> git.baikalelectronics.ru Git - kernel.git/commit
batman-adv: Reduce refcnt of removed router when updating route
authorSven Eckelmann <sven@narfation.org>
Sun, 20 Mar 2016 11:27:53 +0000 (12:27 +0100)
committerAntonio Quartulli <a@unstable.cc>
Sun, 24 Apr 2016 07:41:25 +0000 (15:41 +0800)
commit9106ac86c2fa0a3c9e07ad48b301598f26b2bcdb
treea5d658274874bb05bca55c123e3193a61db187ee
parent6904c5ccc9c6724fd48264c4fb968a4423b129b2
batman-adv: Reduce refcnt of removed router when updating route

_batadv_update_route rcu_derefences orig_ifinfo->router outside of a
spinlock protected region to print some information messages to the debug
log. But this pointer is not checked again when the new pointer is assigned
in the spinlock protected region. Thus is can happen that the value of
orig_ifinfo->router changed in the meantime and thus the reference counter
of the wrong router gets reduced after the spinlock protected region.

Just rcu_dereferencing the value of orig_ifinfo->router inside the spinlock
protected region (which also set the new pointer) is enough to get the
correct old router object.

Fixes: 79afe08a9a5b ("batman-adv: Make orig_node->router an rcu protected pointer")
Signed-off-by: Sven Eckelmann <sven@narfation.org>
Signed-off-by: Marek Lindner <mareklindner@neomailbox.ch>
Signed-off-by: Antonio Quartulli <a@unstable.cc>
net/batman-adv/routing.c