batman-adv: Prefix bat_debugfs 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>
This commit is contained in:
Sven Eckelmann 2012-05-12 02:09:23 +02:00 committed by Antonio Quartulli
parent 81c524f76a
commit 40a072d777
5 changed files with 17 additions and 16 deletions

View File

@ -76,7 +76,7 @@ static int fdebug_log(struct debug_log *debug_log, const char *fmt, ...)
return 0; return 0;
} }
int debug_log(struct bat_priv *bat_priv, const char *fmt, ...) int batadv_debug_log(struct bat_priv *bat_priv, const char *fmt, ...)
{ {
va_list args; va_list args;
char tmp_log_buf[256]; char tmp_log_buf[256];
@ -304,7 +304,7 @@ static struct bat_debuginfo *mesh_debuginfos[] = {
NULL, NULL,
}; };
void debugfs_init(void) void batadv_debugfs_init(void)
{ {
struct bat_debuginfo *bat_debug; struct bat_debuginfo *bat_debug;
struct dentry *file; struct dentry *file;
@ -327,7 +327,7 @@ void debugfs_init(void)
return; return;
} }
void debugfs_destroy(void) void batadv_debugfs_destroy(void)
{ {
if (bat_debugfs) { if (bat_debugfs) {
debugfs_remove_recursive(bat_debugfs); debugfs_remove_recursive(bat_debugfs);
@ -335,7 +335,7 @@ void debugfs_destroy(void)
} }
} }
int debugfs_add_meshif(struct net_device *dev) int batadv_debugfs_add_meshif(struct net_device *dev)
{ {
struct bat_priv *bat_priv = netdev_priv(dev); struct bat_priv *bat_priv = netdev_priv(dev);
struct bat_debuginfo **bat_debug; struct bat_debuginfo **bat_debug;
@ -378,7 +378,7 @@ int debugfs_add_meshif(struct net_device *dev)
#endif /* CONFIG_DEBUG_FS */ #endif /* CONFIG_DEBUG_FS */
} }
void debugfs_del_meshif(struct net_device *dev) void batadv_debugfs_del_meshif(struct net_device *dev)
{ {
struct bat_priv *bat_priv = netdev_priv(dev); struct bat_priv *bat_priv = netdev_priv(dev);

View File

@ -25,9 +25,9 @@
#define DEBUGFS_BAT_SUBDIR "batman_adv" #define DEBUGFS_BAT_SUBDIR "batman_adv"
void debugfs_init(void); void batadv_debugfs_init(void);
void debugfs_destroy(void); void batadv_debugfs_destroy(void);
int debugfs_add_meshif(struct net_device *dev); int batadv_debugfs_add_meshif(struct net_device *dev);
void debugfs_del_meshif(struct net_device *dev); void batadv_debugfs_del_meshif(struct net_device *dev);
#endif /* _NET_BATMAN_ADV_DEBUGFS_H_ */ #endif /* _NET_BATMAN_ADV_DEBUGFS_H_ */

View File

@ -66,7 +66,7 @@ static int __init batman_init(void)
return -ENOMEM; return -ENOMEM;
bat_socket_init(); bat_socket_init();
debugfs_init(); batadv_debugfs_init();
register_netdevice_notifier(&hard_if_notifier); register_netdevice_notifier(&hard_if_notifier);
@ -78,7 +78,7 @@ static int __init batman_init(void)
static void __exit batman_exit(void) static void __exit batman_exit(void)
{ {
debugfs_destroy(); batadv_debugfs_destroy();
unregister_netdevice_notifier(&hard_if_notifier); unregister_netdevice_notifier(&hard_if_notifier);
hardif_remove_interfaces(); hardif_remove_interfaces();

View File

@ -167,12 +167,13 @@ int bat_algo_select(struct bat_priv *bat_priv, char *name);
int bat_algo_seq_print_text(struct seq_file *seq, void *offset); int bat_algo_seq_print_text(struct seq_file *seq, void *offset);
#ifdef CONFIG_BATMAN_ADV_DEBUG #ifdef CONFIG_BATMAN_ADV_DEBUG
int debug_log(struct bat_priv *bat_priv, const char *fmt, ...) __printf(2, 3); int batadv_debug_log(struct bat_priv *bat_priv, const char *fmt, ...)
__printf(2, 3);
#define bat_dbg(type, bat_priv, fmt, arg...) \ #define bat_dbg(type, bat_priv, fmt, arg...) \
do { \ do { \
if (atomic_read(&bat_priv->log_level) & type) \ if (atomic_read(&bat_priv->log_level) & type) \
debug_log(bat_priv, fmt, ## arg); \ batadv_debug_log(bat_priv, fmt, ## arg);\
} \ } \
while (0) while (0)
#else /* !CONFIG_BATMAN_ADV_DEBUG */ #else /* !CONFIG_BATMAN_ADV_DEBUG */

View File

@ -419,7 +419,7 @@ struct net_device *softif_create(const char *name)
if (ret < 0) if (ret < 0)
goto free_bat_counters; goto free_bat_counters;
ret = debugfs_add_meshif(soft_iface); ret = batadv_debugfs_add_meshif(soft_iface);
if (ret < 0) if (ret < 0)
goto unreg_sysfs; goto unreg_sysfs;
@ -430,7 +430,7 @@ struct net_device *softif_create(const char *name)
return soft_iface; return soft_iface;
unreg_debugfs: unreg_debugfs:
debugfs_del_meshif(soft_iface); batadv_debugfs_del_meshif(soft_iface);
unreg_sysfs: unreg_sysfs:
sysfs_del_meshif(soft_iface); sysfs_del_meshif(soft_iface);
free_bat_counters: free_bat_counters:
@ -447,7 +447,7 @@ struct net_device *softif_create(const char *name)
void softif_destroy(struct net_device *soft_iface) void softif_destroy(struct net_device *soft_iface)
{ {
debugfs_del_meshif(soft_iface); batadv_debugfs_del_meshif(soft_iface);
sysfs_del_meshif(soft_iface); sysfs_del_meshif(soft_iface);
mesh_free(soft_iface); mesh_free(soft_iface);
unregister_netdevice(soft_iface); unregister_netdevice(soft_iface);