42 lines
1.6 KiB
Diff
42 lines
1.6 KiB
Diff
From 3c92b633715b7eca80dc7a2347e0e4dbcce1f018 Mon Sep 17 00:00:00 2001
|
|
From: Simon Wunderlich <simon@open-mesh.com>
|
|
Date: Wed, 24 Jun 2015 14:50:19 +0200
|
|
Subject: [PATCH 12/17] batman-adv: initialize up/down values when adding a
|
|
gateway
|
|
|
|
Without this initialization, gateways which actually announce up/down
|
|
bandwidth of 0/0 could be added. If these nodes get purged via
|
|
_batadv_purge_orig() later, the gw_node structure does not get removed
|
|
since batadv_gw_node_delete() updates the gw_node with up/down
|
|
bandwidth of 0/0, and the updating function then discards the change
|
|
and does not free gw_node.
|
|
|
|
This results in leaking the gw_node structures, which references other
|
|
structures: gw_node -> orig_node -> orig_node_ifinfo -> hardif. When
|
|
removing the interface later, the open reference on the hardif may cause
|
|
hangs with the infamous "unregister_netdevice: waiting for mesh1 to
|
|
become free. Usage count = 1" message.
|
|
|
|
Signed-off-by: Simon Wunderlich <simon@open-mesh.com>
|
|
Acked-by: Antonio Quartulli <antonio@meshcoding.com>
|
|
Signed-off-by: Marek Lindner <mareklindner@neomailbox.ch>
|
|
---
|
|
gateway_client.c | 2 ++
|
|
1 file changed, 2 insertions(+)
|
|
|
|
diff --git a/gateway_client.c b/gateway_client.c
|
|
index 3f32357..d8e3ead 100644
|
|
--- a/gateway_client.c
|
|
+++ b/gateway_client.c
|
|
@@ -419,6 +419,8 @@ static void batadv_gw_node_add(struct batadv_priv *bat_priv,
|
|
|
|
INIT_HLIST_NODE(&gw_node->list);
|
|
gw_node->orig_node = orig_node;
|
|
+ gw_node->bandwidth_down = ntohl(gateway->bandwidth_down);
|
|
+ gw_node->bandwidth_up = ntohl(gateway->bandwidth_up);
|
|
atomic_set(&gw_node->refcount, 1);
|
|
|
|
spin_lock_bh(&bat_priv->gw.list_lock);
|
|
--
|
|
2.1.4
|
|
|