aboutsummaryrefslogtreecommitdiffstats
path: root/net/batman-adv/hard-interface.c
diff options
context:
space:
mode:
authorYing Xue <ying.xue@windriver.com>2014-01-14 21:23:42 -0500
committerDavid S. Miller <davem@davemloft.net>2014-01-14 21:50:47 -0500
commit16b77695ed8fa158be864ee448a9ef4c78457c14 (patch)
tree190bea238dc941acb25f8178838dba9cf6402b55 /net/batman-adv/hard-interface.c
parent737639493032afec87fc9e8809f80878f74bd465 (diff)
batman-adv: use __dev_get_by_index instead of dev_get_by_index to find interface
The following call chains indicate that batadv_is_on_batman_iface() is always under rtnl_lock protection as call_netdevice_notifier() is protected by rtnl_lock. So if __dev_get_by_index() rather than dev_get_by_index() is used to find interface handler in it, this would help us avoid to change interface reference counter. call_netdevice_notifier() batadv_hard_if_event() batadv_hardif_add_interface() batadv_is_valid_iface() batadv_is_on_batman_iface() Cc: Antonio Quartulli <antonio@meshcoding.com> Signed-off-by: Ying Xue <ying.xue@windriver.com> Acked-by: Antonio Quartulli <antonio@meshcoding.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/batman-adv/hard-interface.c')
-rw-r--r--net/batman-adv/hard-interface.c4
1 files changed, 1 insertions, 3 deletions
diff --git a/net/batman-adv/hard-interface.c b/net/batman-adv/hard-interface.c
index 1b12573bcf83..3d417d3641c6 100644
--- a/net/batman-adv/hard-interface.c
+++ b/net/batman-adv/hard-interface.c
@@ -87,15 +87,13 @@ static bool batadv_is_on_batman_iface(const struct net_device *net_dev)
87 return false; 87 return false;
88 88
89 /* recurse over the parent device */ 89 /* recurse over the parent device */
90 parent_dev = dev_get_by_index(&init_net, net_dev->iflink); 90 parent_dev = __dev_get_by_index(&init_net, net_dev->iflink);
91 /* if we got a NULL parent_dev there is something broken.. */ 91 /* if we got a NULL parent_dev there is something broken.. */
92 if (WARN(!parent_dev, "Cannot find parent device")) 92 if (WARN(!parent_dev, "Cannot find parent device"))
93 return false; 93 return false;
94 94
95 ret = batadv_is_on_batman_iface(parent_dev); 95 ret = batadv_is_on_batman_iface(parent_dev);
96 96
97 if (parent_dev)
98 dev_put(parent_dev);
99 return ret; 97 return ret;
100} 98}
101 99