diff options
author | Sven Eckelmann <sven@narfation.org> | 2012-05-11 20:09:31 -0400 |
---|---|---|
committer | Antonio Quartulli <ordex@autistici.org> | 2012-06-20 16:15:20 -0400 |
commit | 9563877ea52ea18bb4f1ed724c5e3a39bbbcf60b (patch) | |
tree | 56bd2312e4aa7d04b448edd1d8ed87309c941f80 | |
parent | 84d5e5e003752bc56b413f8d2c3fcfeeec066145 (diff) |
batman-adv: Prefix hard-interface non-static functions with batadv_
batman-adv can be compiled as part of the kernel instead of an module. In that
case the linker will see all non-static symbols of batman-adv and all other
non-static symbols of the kernel. This could lead to symbol collisions. A
prefix for the batman-adv symbols that defines their private namespace avoids
such a problem.
Reported-by: David Miller <davem@davemloft.net>
Signed-off-by: Sven Eckelmann <sven@narfation.org>
-rw-r--r-- | net/batman-adv/bat_sysfs.c | 20 | ||||
-rw-r--r-- | net/batman-adv/hard-interface.c | 32 | ||||
-rw-r--r-- | net/batman-adv/hard-interface.h | 22 | ||||
-rw-r--r-- | net/batman-adv/main.c | 6 | ||||
-rw-r--r-- | net/batman-adv/soft-interface.c | 2 | ||||
-rw-r--r-- | net/batman-adv/translation-table.c | 2 |
6 files changed, 43 insertions, 41 deletions
diff --git a/net/batman-adv/bat_sysfs.c b/net/batman-adv/bat_sysfs.c index a8fb66095d83..5a7b042873e1 100644 --- a/net/batman-adv/bat_sysfs.c +++ b/net/batman-adv/bat_sysfs.c | |||
@@ -122,9 +122,10 @@ ssize_t store_##_name(struct kobject *kobj, struct attribute *attr, \ | |||
122 | char *buff, size_t count) \ | 122 | char *buff, size_t count) \ |
123 | { \ | 123 | { \ |
124 | struct net_device *net_dev = kobj_to_netdev(kobj); \ | 124 | struct net_device *net_dev = kobj_to_netdev(kobj); \ |
125 | struct hard_iface *hard_iface = hardif_get_by_netdev(net_dev); \ | 125 | struct hard_iface *hard_iface; \ |
126 | ssize_t length; \ | 126 | ssize_t length; \ |
127 | \ | 127 | \ |
128 | hard_iface = batadv_hardif_get_by_netdev(net_dev); \ | ||
128 | if (!hard_iface) \ | 129 | if (!hard_iface) \ |
129 | return 0; \ | 130 | return 0; \ |
130 | \ | 131 | \ |
@@ -140,9 +141,10 @@ ssize_t show_##_name(struct kobject *kobj, \ | |||
140 | struct attribute *attr, char *buff) \ | 141 | struct attribute *attr, char *buff) \ |
141 | { \ | 142 | { \ |
142 | struct net_device *net_dev = kobj_to_netdev(kobj); \ | 143 | struct net_device *net_dev = kobj_to_netdev(kobj); \ |
143 | struct hard_iface *hard_iface = hardif_get_by_netdev(net_dev); \ | 144 | struct hard_iface *hard_iface; \ |
144 | ssize_t length; \ | 145 | ssize_t length; \ |
145 | \ | 146 | \ |
147 | hard_iface = batadv_hardif_get_by_netdev(net_dev); \ | ||
146 | if (!hard_iface) \ | 148 | if (!hard_iface) \ |
147 | return 0; \ | 149 | return 0; \ |
148 | \ | 150 | \ |
@@ -433,7 +435,7 @@ BAT_ATTR_SIF_BOOL(bonding, S_IRUGO | S_IWUSR, NULL); | |||
433 | #ifdef CONFIG_BATMAN_ADV_BLA | 435 | #ifdef CONFIG_BATMAN_ADV_BLA |
434 | BAT_ATTR_SIF_BOOL(bridge_loop_avoidance, S_IRUGO | S_IWUSR, NULL); | 436 | BAT_ATTR_SIF_BOOL(bridge_loop_avoidance, S_IRUGO | S_IWUSR, NULL); |
435 | #endif | 437 | #endif |
436 | BAT_ATTR_SIF_BOOL(fragmentation, S_IRUGO | S_IWUSR, update_min_mtu); | 438 | BAT_ATTR_SIF_BOOL(fragmentation, S_IRUGO | S_IWUSR, batadv_update_min_mtu); |
437 | BAT_ATTR_SIF_BOOL(ap_isolation, S_IRUGO | S_IWUSR, NULL); | 439 | BAT_ATTR_SIF_BOOL(ap_isolation, S_IRUGO | S_IWUSR, NULL); |
438 | static BAT_ATTR(vis_mode, S_IRUGO | S_IWUSR, show_vis_mode, store_vis_mode); | 440 | static BAT_ATTR(vis_mode, S_IRUGO | S_IWUSR, show_vis_mode, store_vis_mode); |
439 | static BAT_ATTR(routing_algo, S_IRUGO, show_bat_algo, NULL); | 441 | static BAT_ATTR(routing_algo, S_IRUGO, show_bat_algo, NULL); |
@@ -523,7 +525,7 @@ static ssize_t show_mesh_iface(struct kobject *kobj, struct attribute *attr, | |||
523 | char *buff) | 525 | char *buff) |
524 | { | 526 | { |
525 | struct net_device *net_dev = kobj_to_netdev(kobj); | 527 | struct net_device *net_dev = kobj_to_netdev(kobj); |
526 | struct hard_iface *hard_iface = hardif_get_by_netdev(net_dev); | 528 | struct hard_iface *hard_iface = batadv_hardif_get_by_netdev(net_dev); |
527 | ssize_t length; | 529 | ssize_t length; |
528 | 530 | ||
529 | if (!hard_iface) | 531 | if (!hard_iface) |
@@ -541,7 +543,7 @@ static ssize_t store_mesh_iface(struct kobject *kobj, struct attribute *attr, | |||
541 | char *buff, size_t count) | 543 | char *buff, size_t count) |
542 | { | 544 | { |
543 | struct net_device *net_dev = kobj_to_netdev(kobj); | 545 | struct net_device *net_dev = kobj_to_netdev(kobj); |
544 | struct hard_iface *hard_iface = hardif_get_by_netdev(net_dev); | 546 | struct hard_iface *hard_iface = batadv_hardif_get_by_netdev(net_dev); |
545 | int status_tmp = -1; | 547 | int status_tmp = -1; |
546 | int ret = count; | 548 | int ret = count; |
547 | 549 | ||
@@ -576,15 +578,15 @@ static ssize_t store_mesh_iface(struct kobject *kobj, struct attribute *attr, | |||
576 | } | 578 | } |
577 | 579 | ||
578 | if (status_tmp == IF_NOT_IN_USE) { | 580 | if (status_tmp == IF_NOT_IN_USE) { |
579 | hardif_disable_interface(hard_iface); | 581 | batadv_hardif_disable_interface(hard_iface); |
580 | goto unlock; | 582 | goto unlock; |
581 | } | 583 | } |
582 | 584 | ||
583 | /* if the interface already is in use */ | 585 | /* if the interface already is in use */ |
584 | if (hard_iface->if_status != IF_NOT_IN_USE) | 586 | if (hard_iface->if_status != IF_NOT_IN_USE) |
585 | hardif_disable_interface(hard_iface); | 587 | batadv_hardif_disable_interface(hard_iface); |
586 | 588 | ||
587 | ret = hardif_enable_interface(hard_iface, buff); | 589 | ret = batadv_hardif_enable_interface(hard_iface, buff); |
588 | 590 | ||
589 | unlock: | 591 | unlock: |
590 | rtnl_unlock(); | 592 | rtnl_unlock(); |
@@ -597,7 +599,7 @@ static ssize_t show_iface_status(struct kobject *kobj, struct attribute *attr, | |||
597 | char *buff) | 599 | char *buff) |
598 | { | 600 | { |
599 | struct net_device *net_dev = kobj_to_netdev(kobj); | 601 | struct net_device *net_dev = kobj_to_netdev(kobj); |
600 | struct hard_iface *hard_iface = hardif_get_by_netdev(net_dev); | 602 | struct hard_iface *hard_iface = batadv_hardif_get_by_netdev(net_dev); |
601 | ssize_t length; | 603 | ssize_t length; |
602 | 604 | ||
603 | if (!hard_iface) | 605 | if (!hard_iface) |
diff --git a/net/batman-adv/hard-interface.c b/net/batman-adv/hard-interface.c index 1643e7fca6c6..4f44f049186f 100644 --- a/net/batman-adv/hard-interface.c +++ b/net/batman-adv/hard-interface.c | |||
@@ -32,7 +32,7 @@ | |||
32 | 32 | ||
33 | #include <linux/if_arp.h> | 33 | #include <linux/if_arp.h> |
34 | 34 | ||
35 | void hardif_free_rcu(struct rcu_head *rcu) | 35 | void batadv_hardif_free_rcu(struct rcu_head *rcu) |
36 | { | 36 | { |
37 | struct hard_iface *hard_iface; | 37 | struct hard_iface *hard_iface; |
38 | 38 | ||
@@ -41,7 +41,7 @@ void hardif_free_rcu(struct rcu_head *rcu) | |||
41 | kfree(hard_iface); | 41 | kfree(hard_iface); |
42 | } | 42 | } |
43 | 43 | ||
44 | struct hard_iface *hardif_get_by_netdev(const struct net_device *net_dev) | 44 | struct hard_iface *batadv_hardif_get_by_netdev(const struct net_device *net_dev) |
45 | { | 45 | { |
46 | struct hard_iface *hard_iface; | 46 | struct hard_iface *hard_iface; |
47 | 47 | ||
@@ -180,7 +180,7 @@ static void check_known_mac_addr(const struct net_device *net_dev) | |||
180 | rcu_read_unlock(); | 180 | rcu_read_unlock(); |
181 | } | 181 | } |
182 | 182 | ||
183 | int hardif_min_mtu(struct net_device *soft_iface) | 183 | int batadv_hardif_min_mtu(struct net_device *soft_iface) |
184 | { | 184 | { |
185 | const struct bat_priv *bat_priv = netdev_priv(soft_iface); | 185 | const struct bat_priv *bat_priv = netdev_priv(soft_iface); |
186 | const struct hard_iface *hard_iface; | 186 | const struct hard_iface *hard_iface; |
@@ -209,11 +209,11 @@ out: | |||
209 | } | 209 | } |
210 | 210 | ||
211 | /* adjusts the MTU if a new interface with a smaller MTU appeared. */ | 211 | /* adjusts the MTU if a new interface with a smaller MTU appeared. */ |
212 | void update_min_mtu(struct net_device *soft_iface) | 212 | void batadv_update_min_mtu(struct net_device *soft_iface) |
213 | { | 213 | { |
214 | int min_mtu; | 214 | int min_mtu; |
215 | 215 | ||
216 | min_mtu = hardif_min_mtu(soft_iface); | 216 | min_mtu = batadv_hardif_min_mtu(soft_iface); |
217 | if (soft_iface->mtu != min_mtu) | 217 | if (soft_iface->mtu != min_mtu) |
218 | soft_iface->mtu = min_mtu; | 218 | soft_iface->mtu = min_mtu; |
219 | } | 219 | } |
@@ -242,7 +242,7 @@ static void hardif_activate_interface(struct hard_iface *hard_iface) | |||
242 | bat_info(hard_iface->soft_iface, "Interface activated: %s\n", | 242 | bat_info(hard_iface->soft_iface, "Interface activated: %s\n", |
243 | hard_iface->net_dev->name); | 243 | hard_iface->net_dev->name); |
244 | 244 | ||
245 | update_min_mtu(hard_iface->soft_iface); | 245 | batadv_update_min_mtu(hard_iface->soft_iface); |
246 | 246 | ||
247 | out: | 247 | out: |
248 | if (primary_if) | 248 | if (primary_if) |
@@ -260,11 +260,11 @@ static void hardif_deactivate_interface(struct hard_iface *hard_iface) | |||
260 | bat_info(hard_iface->soft_iface, "Interface deactivated: %s\n", | 260 | bat_info(hard_iface->soft_iface, "Interface deactivated: %s\n", |
261 | hard_iface->net_dev->name); | 261 | hard_iface->net_dev->name); |
262 | 262 | ||
263 | update_min_mtu(hard_iface->soft_iface); | 263 | batadv_update_min_mtu(hard_iface->soft_iface); |
264 | } | 264 | } |
265 | 265 | ||
266 | int hardif_enable_interface(struct hard_iface *hard_iface, | 266 | int batadv_hardif_enable_interface(struct hard_iface *hard_iface, |
267 | const char *iface_name) | 267 | const char *iface_name) |
268 | { | 268 | { |
269 | struct bat_priv *bat_priv; | 269 | struct bat_priv *bat_priv; |
270 | struct net_device *soft_iface; | 270 | struct net_device *soft_iface; |
@@ -357,7 +357,7 @@ err: | |||
357 | return ret; | 357 | return ret; |
358 | } | 358 | } |
359 | 359 | ||
360 | void hardif_disable_interface(struct hard_iface *hard_iface) | 360 | void batadv_hardif_disable_interface(struct hard_iface *hard_iface) |
361 | { | 361 | { |
362 | struct bat_priv *bat_priv = netdev_priv(hard_iface->soft_iface); | 362 | struct bat_priv *bat_priv = netdev_priv(hard_iface->soft_iface); |
363 | struct hard_iface *primary_if = NULL; | 363 | struct hard_iface *primary_if = NULL; |
@@ -461,7 +461,7 @@ static void hardif_remove_interface(struct hard_iface *hard_iface) | |||
461 | 461 | ||
462 | /* first deactivate interface */ | 462 | /* first deactivate interface */ |
463 | if (hard_iface->if_status != IF_NOT_IN_USE) | 463 | if (hard_iface->if_status != IF_NOT_IN_USE) |
464 | hardif_disable_interface(hard_iface); | 464 | batadv_hardif_disable_interface(hard_iface); |
465 | 465 | ||
466 | if (hard_iface->if_status != IF_NOT_IN_USE) | 466 | if (hard_iface->if_status != IF_NOT_IN_USE) |
467 | return; | 467 | return; |
@@ -471,7 +471,7 @@ static void hardif_remove_interface(struct hard_iface *hard_iface) | |||
471 | hardif_free_ref(hard_iface); | 471 | hardif_free_ref(hard_iface); |
472 | } | 472 | } |
473 | 473 | ||
474 | void hardif_remove_interfaces(void) | 474 | void batadv_hardif_remove_interfaces(void) |
475 | { | 475 | { |
476 | struct hard_iface *hard_iface, *hard_iface_tmp; | 476 | struct hard_iface *hard_iface, *hard_iface_tmp; |
477 | 477 | ||
@@ -488,7 +488,7 @@ static int hard_if_event(struct notifier_block *this, | |||
488 | unsigned long event, void *ptr) | 488 | unsigned long event, void *ptr) |
489 | { | 489 | { |
490 | struct net_device *net_dev = ptr; | 490 | struct net_device *net_dev = ptr; |
491 | struct hard_iface *hard_iface = hardif_get_by_netdev(net_dev); | 491 | struct hard_iface *hard_iface = batadv_hardif_get_by_netdev(net_dev); |
492 | struct hard_iface *primary_if = NULL; | 492 | struct hard_iface *primary_if = NULL; |
493 | struct bat_priv *bat_priv; | 493 | struct bat_priv *bat_priv; |
494 | 494 | ||
@@ -513,7 +513,7 @@ static int hard_if_event(struct notifier_block *this, | |||
513 | break; | 513 | break; |
514 | case NETDEV_CHANGEMTU: | 514 | case NETDEV_CHANGEMTU: |
515 | if (hard_iface->soft_iface) | 515 | if (hard_iface->soft_iface) |
516 | update_min_mtu(hard_iface->soft_iface); | 516 | batadv_update_min_mtu(hard_iface->soft_iface); |
517 | break; | 517 | break; |
518 | case NETDEV_CHANGEADDR: | 518 | case NETDEV_CHANGEADDR: |
519 | if (hard_iface->if_status == IF_NOT_IN_USE) | 519 | if (hard_iface->if_status == IF_NOT_IN_USE) |
@@ -545,7 +545,7 @@ out: | |||
545 | 545 | ||
546 | /* This function returns true if the interface represented by ifindex is a | 546 | /* This function returns true if the interface represented by ifindex is a |
547 | * 802.11 wireless device */ | 547 | * 802.11 wireless device */ |
548 | bool is_wifi_iface(int ifindex) | 548 | bool batadv_is_wifi_iface(int ifindex) |
549 | { | 549 | { |
550 | struct net_device *net_device = NULL; | 550 | struct net_device *net_device = NULL; |
551 | bool ret = false; | 551 | bool ret = false; |
@@ -573,6 +573,6 @@ out: | |||
573 | return ret; | 573 | return ret; |
574 | } | 574 | } |
575 | 575 | ||
576 | struct notifier_block hard_if_notifier = { | 576 | struct notifier_block batadv_hard_if_notifier = { |
577 | .notifier_call = hard_if_event, | 577 | .notifier_call = hard_if_event, |
578 | }; | 578 | }; |
diff --git a/net/batman-adv/hard-interface.h b/net/batman-adv/hard-interface.h index e68c5655e616..20e09db29d15 100644 --- a/net/batman-adv/hard-interface.h +++ b/net/batman-adv/hard-interface.h | |||
@@ -31,23 +31,23 @@ enum hard_if_state { | |||
31 | IF_I_WANT_YOU | 31 | IF_I_WANT_YOU |
32 | }; | 32 | }; |
33 | 33 | ||
34 | extern struct notifier_block hard_if_notifier; | 34 | extern struct notifier_block batadv_hard_if_notifier; |
35 | 35 | ||
36 | struct hard_iface* | 36 | struct hard_iface* |
37 | hardif_get_by_netdev(const struct net_device *net_dev); | 37 | batadv_hardif_get_by_netdev(const struct net_device *net_dev); |
38 | int hardif_enable_interface(struct hard_iface *hard_iface, | 38 | int batadv_hardif_enable_interface(struct hard_iface *hard_iface, |
39 | const char *iface_name); | 39 | const char *iface_name); |
40 | void hardif_disable_interface(struct hard_iface *hard_iface); | 40 | void batadv_hardif_disable_interface(struct hard_iface *hard_iface); |
41 | void hardif_remove_interfaces(void); | 41 | void batadv_hardif_remove_interfaces(void); |
42 | int hardif_min_mtu(struct net_device *soft_iface); | 42 | int batadv_hardif_min_mtu(struct net_device *soft_iface); |
43 | void update_min_mtu(struct net_device *soft_iface); | 43 | void batadv_update_min_mtu(struct net_device *soft_iface); |
44 | void hardif_free_rcu(struct rcu_head *rcu); | 44 | void batadv_hardif_free_rcu(struct rcu_head *rcu); |
45 | bool is_wifi_iface(int ifindex); | 45 | bool batadv_is_wifi_iface(int ifindex); |
46 | 46 | ||
47 | static inline void hardif_free_ref(struct hard_iface *hard_iface) | 47 | static inline void hardif_free_ref(struct hard_iface *hard_iface) |
48 | { | 48 | { |
49 | if (atomic_dec_and_test(&hard_iface->refcount)) | 49 | if (atomic_dec_and_test(&hard_iface->refcount)) |
50 | call_rcu(&hard_iface->rcu, hardif_free_rcu); | 50 | call_rcu(&hard_iface->rcu, batadv_hardif_free_rcu); |
51 | } | 51 | } |
52 | 52 | ||
53 | static inline struct hard_iface *primary_if_get_selected( | 53 | static inline struct hard_iface *primary_if_get_selected( |
diff --git a/net/batman-adv/main.c b/net/batman-adv/main.c index 8fe70b487b49..8e4083612523 100644 --- a/net/batman-adv/main.c +++ b/net/batman-adv/main.c | |||
@@ -68,7 +68,7 @@ static int __init batman_init(void) | |||
68 | bat_socket_init(); | 68 | bat_socket_init(); |
69 | batadv_debugfs_init(); | 69 | batadv_debugfs_init(); |
70 | 70 | ||
71 | register_netdevice_notifier(&hard_if_notifier); | 71 | register_netdevice_notifier(&batadv_hard_if_notifier); |
72 | 72 | ||
73 | pr_info("B.A.T.M.A.N. advanced %s (compatibility version %i) loaded\n", | 73 | pr_info("B.A.T.M.A.N. advanced %s (compatibility version %i) loaded\n", |
74 | SOURCE_VERSION, COMPAT_VERSION); | 74 | SOURCE_VERSION, COMPAT_VERSION); |
@@ -79,8 +79,8 @@ static int __init batman_init(void) | |||
79 | static void __exit batman_exit(void) | 79 | static void __exit batman_exit(void) |
80 | { | 80 | { |
81 | batadv_debugfs_destroy(); | 81 | batadv_debugfs_destroy(); |
82 | unregister_netdevice_notifier(&hard_if_notifier); | 82 | unregister_netdevice_notifier(&batadv_hard_if_notifier); |
83 | hardif_remove_interfaces(); | 83 | batadv_hardif_remove_interfaces(); |
84 | 84 | ||
85 | flush_workqueue(bat_event_workqueue); | 85 | flush_workqueue(bat_event_workqueue); |
86 | destroy_workqueue(bat_event_workqueue); | 86 | destroy_workqueue(bat_event_workqueue); |
diff --git a/net/batman-adv/soft-interface.c b/net/batman-adv/soft-interface.c index bfc4fe03cafa..5bf9a73ae799 100644 --- a/net/batman-adv/soft-interface.c +++ b/net/batman-adv/soft-interface.c | |||
@@ -122,7 +122,7 @@ static int interface_set_mac_addr(struct net_device *dev, void *p) | |||
122 | static int interface_change_mtu(struct net_device *dev, int new_mtu) | 122 | static int interface_change_mtu(struct net_device *dev, int new_mtu) |
123 | { | 123 | { |
124 | /* check ranges */ | 124 | /* check ranges */ |
125 | if ((new_mtu < 68) || (new_mtu > hardif_min_mtu(dev))) | 125 | if ((new_mtu < 68) || (new_mtu > batadv_hardif_min_mtu(dev))) |
126 | return -EINVAL; | 126 | return -EINVAL; |
127 | 127 | ||
128 | dev->mtu = new_mtu; | 128 | dev->mtu = new_mtu; |
diff --git a/net/batman-adv/translation-table.c b/net/batman-adv/translation-table.c index bb8557ea30f1..7324b89bf731 100644 --- a/net/batman-adv/translation-table.c +++ b/net/batman-adv/translation-table.c | |||
@@ -221,7 +221,7 @@ void tt_local_add(struct net_device *soft_iface, const uint8_t *addr, | |||
221 | 221 | ||
222 | memcpy(tt_local_entry->common.addr, addr, ETH_ALEN); | 222 | memcpy(tt_local_entry->common.addr, addr, ETH_ALEN); |
223 | tt_local_entry->common.flags = NO_FLAGS; | 223 | tt_local_entry->common.flags = NO_FLAGS; |
224 | if (is_wifi_iface(ifindex)) | 224 | if (batadv_is_wifi_iface(ifindex)) |
225 | tt_local_entry->common.flags |= TT_CLIENT_WIFI; | 225 | tt_local_entry->common.flags |= TT_CLIENT_WIFI; |
226 | atomic_set(&tt_local_entry->common.refcount, 2); | 226 | atomic_set(&tt_local_entry->common.refcount, 2); |
227 | tt_local_entry->last_seen = jiffies; | 227 | tt_local_entry->last_seen = jiffies; |