aboutsummaryrefslogtreecommitdiffstats
path: root/net/batman-adv/originator.c
diff options
context:
space:
mode:
authorMarek Lindner <lindner_marek@yahoo.de>2011-01-25 16:52:11 -0500
committerMarek Lindner <lindner_marek@yahoo.de>2011-03-05 06:50:09 -0500
commitf3e0008f01b275bd08bd416cfcaa7021dd6bc277 (patch)
tree47c1787dce5d3bda821a4ccb015d54b6b9cadc82 /net/batman-adv/originator.c
parent0ede9f41b217d8982ab426e3c8c1b692a280a16f (diff)
batman-adv: make broadcast seqno operations atomic
Batman-adv could receive several payload broadcasts at the same time that would trigger access to the broadcast seqno sliding window to determine whether this is a new broadcast or not. If these incoming broadcasts are accessing the sliding window simultaneously it could be left in an inconsistent state. Therefore it is necessary to make sure this access is atomic. Reported-by: Linus Lüssing <linus.luessing@web.de> Signed-off-by: Marek Lindner <lindner_marek@yahoo.de>
Diffstat (limited to 'net/batman-adv/originator.c')
-rw-r--r--net/batman-adv/originator.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/net/batman-adv/originator.c b/net/batman-adv/originator.c
index 61299da82c6b..d9a8e316c249 100644
--- a/net/batman-adv/originator.c
+++ b/net/batman-adv/originator.c
@@ -215,6 +215,7 @@ struct orig_node *get_orig_node(struct bat_priv *bat_priv, uint8_t *addr)
215 INIT_HLIST_HEAD(&orig_node->neigh_list); 215 INIT_HLIST_HEAD(&orig_node->neigh_list);
216 INIT_LIST_HEAD(&orig_node->bond_list); 216 INIT_LIST_HEAD(&orig_node->bond_list);
217 spin_lock_init(&orig_node->ogm_cnt_lock); 217 spin_lock_init(&orig_node->ogm_cnt_lock);
218 spin_lock_init(&orig_node->bcast_seqno_lock);
218 spin_lock_init(&orig_node->neigh_list_lock); 219 spin_lock_init(&orig_node->neigh_list_lock);
219 kref_init(&orig_node->refcount); 220 kref_init(&orig_node->refcount);
220 221