2017-11-19 15:05:11 +01:00
// SPDX-License-Identifier: GPL-2.0
2020-01-01 00:00:01 +01:00
/* Copyright (C) 2010-2020 B.A.T.M.A.N. contributors:
2010-12-13 11:19:28 +00:00
*
* Marek Lindner
*/
2015-04-17 19:40:28 +02:00
# include "debugfs.h"
2010-12-13 11:19:28 +00:00
# include "main.h"
2018-10-21 11:30:29 +02:00
# include <asm/current.h>
2018-06-01 19:24:23 +02:00
# include <linux/dcache.h>
2010-12-13 11:19:28 +00:00
# include <linux/debugfs.h>
2015-04-17 19:40:28 +02:00
# include <linux/errno.h>
# include <linux/export.h>
# include <linux/fs.h>
# include <linux/netdevice.h>
# include <linux/printk.h>
2018-10-21 11:30:29 +02:00
# include <linux/sched.h>
2015-04-17 19:40:28 +02:00
# include <linux/seq_file.h>
# include <linux/stat.h>
# include <linux/stddef.h>
# include <linux/stringify.h>
# include <linux/sysfs.h>
2016-07-03 13:31:34 +02:00
# include <net/net_namespace.h>
2010-12-13 11:19:28 +00:00
2016-05-15 11:07:44 +02:00
# include "bat_algo.h"
2012-01-22 20:00:21 +01:00
# include "bridge_loop_avoidance.h"
2012-06-30 20:01:19 +02:00
# include "distributed-arp-table.h"
2015-04-17 19:40:28 +02:00
# include "gateway_client.h"
# include "icmp_socket.h"
2016-05-15 23:48:31 +02:00
# include "log.h"
2016-05-10 18:41:27 +02:00
# include "multicast.h"
2013-01-25 11:12:39 +01:00
# include "network-coding.h"
2015-04-17 19:40:28 +02:00
# include "originator.h"
# include "translation-table.h"
2010-12-13 11:19:28 +00:00
2012-05-12 18:33:50 +02:00
static struct dentry * batadv_debugfs ;
2010-12-13 11:19:28 +00:00
2018-08-10 23:36:15 +02:00
/**
* batadv_debugfs_deprecated ( ) - Log use of deprecated batadv debugfs access
* @ file : file which was accessed
* @ alt : explanation what can be used as alternative
*/
void batadv_debugfs_deprecated ( struct file * file , const char * alt )
{
struct dentry * dentry = file_dentry ( file ) ;
const char * name = dentry - > d_name . name ;
pr_warn_ratelimited ( DEPRECATED " %s (pid %d) Use of debugfs file \" %s \" . \n %s " ,
current - > comm , task_pid_nr ( current ) , name , alt ) ;
}
2012-05-12 18:33:50 +02:00
static int batadv_algorithms_open ( struct inode * inode , struct file * file )
2011-11-28 17:40:17 +08:00
{
2018-08-10 23:36:15 +02:00
batadv_debugfs_deprecated ( file ,
" Use genl command BATADV_CMD_GET_ROUTING_ALGOS instead \n " ) ;
2012-05-12 02:09:42 +02:00
return single_open ( file , batadv_algo_seq_print_text , NULL ) ;
2011-11-28 17:40:17 +08:00
}
2015-08-04 21:09:57 +08:00
static int neighbors_open ( struct inode * inode , struct file * file )
{
struct net_device * net_dev = ( struct net_device * ) inode - > i_private ;
2018-08-10 23:36:15 +02:00
batadv_debugfs_deprecated ( file ,
" Use genl command BATADV_CMD_GET_NEIGHBORS instead \n " ) ;
2015-08-04 21:09:57 +08:00
return single_open ( file , batadv_hardif_neigh_seq_print_text , net_dev ) ;
}
2012-05-12 18:33:50 +02:00
static int batadv_originators_open ( struct inode * inode , struct file * file )
2010-12-13 11:19:28 +00:00
{
struct net_device * net_dev = ( struct net_device * ) inode - > i_private ;
2014-05-10 18:56:37 +02:00
2018-08-10 23:36:15 +02:00
batadv_debugfs_deprecated ( file ,
" Use genl command BATADV_CMD_GET_ORIGINATORS instead \n " ) ;
2012-05-12 02:09:34 +02:00
return single_open ( file , batadv_orig_seq_print_text , net_dev ) ;
2010-12-13 11:19:28 +00:00
}
2013-11-21 11:52:16 +01:00
/**
2017-12-02 19:51:47 +01:00
* batadv_originators_hardif_open ( ) - handles debugfs output for the originator
* table of an hard interface
2013-11-21 11:52:16 +01:00
* @ inode : inode pointer to debugfs file
* @ file : pointer to the seq_file
2015-10-31 12:29:29 +01:00
*
* Return : 0 on success or negative error number in case of failure
2013-11-21 11:52:16 +01:00
*/
static int batadv_originators_hardif_open ( struct inode * inode ,
struct file * file )
{
struct net_device * net_dev = ( struct net_device * ) inode - > i_private ;
2014-05-10 18:56:37 +02:00
2018-08-10 23:36:15 +02:00
batadv_debugfs_deprecated ( file ,
" Use genl command BATADV_CMD_GET_HARDIFS instead \n " ) ;
2013-11-21 11:52:16 +01:00
return single_open ( file , batadv_orig_hardif_seq_print_text , net_dev ) ;
}
2012-05-12 18:33:50 +02:00
static int batadv_gateways_open ( struct inode * inode , struct file * file )
2010-12-13 11:19:28 +00:00
{
struct net_device * net_dev = ( struct net_device * ) inode - > i_private ;
2014-05-10 18:56:37 +02:00
2018-08-10 23:36:15 +02:00
batadv_debugfs_deprecated ( file ,
" Use genl command BATADV_CMD_GET_GATEWAYS instead \n " ) ;
2012-05-12 02:09:29 +02:00
return single_open ( file , batadv_gw_client_seq_print_text , net_dev ) ;
2010-12-13 11:19:28 +00:00
}
2012-05-12 18:33:50 +02:00
static int batadv_transtable_global_open ( struct inode * inode , struct file * file )
2010-12-13 11:19:28 +00:00
{
struct net_device * net_dev = ( struct net_device * ) inode - > i_private ;
2014-05-10 18:56:37 +02:00
2018-08-10 23:36:15 +02:00
batadv_debugfs_deprecated ( file ,
" Use genl command BATADV_CMD_GET_TRANSTABLE_GLOBAL instead \n " ) ;
2012-05-12 02:09:39 +02:00
return single_open ( file , batadv_tt_global_seq_print_text , net_dev ) ;
2010-12-13 11:19:28 +00:00
}
2012-01-22 20:00:27 +01:00
# ifdef CONFIG_BATMAN_ADV_BLA
2012-05-12 18:33:50 +02:00
static int batadv_bla_claim_table_open ( struct inode * inode , struct file * file )
2012-01-22 20:00:21 +01:00
{
struct net_device * net_dev = ( struct net_device * ) inode - > i_private ;
2014-05-10 18:56:37 +02:00
2018-08-10 23:36:15 +02:00
batadv_debugfs_deprecated ( file ,
" Use genl command BATADV_CMD_GET_BLA_CLAIM instead \n " ) ;
2012-05-12 13:38:47 +02:00
return single_open ( file , batadv_bla_claim_table_seq_print_text ,
net_dev ) ;
2012-01-22 20:00:21 +01:00
}
2012-06-18 18:39:26 +02:00
static int batadv_bla_backbone_table_open ( struct inode * inode ,
struct file * file )
{
struct net_device * net_dev = ( struct net_device * ) inode - > i_private ;
2014-05-10 18:56:37 +02:00
2018-08-10 23:36:15 +02:00
batadv_debugfs_deprecated ( file ,
" Use genl command BATADV_CMD_GET_BLA_BACKBONE instead \n " ) ;
2012-06-18 18:39:26 +02:00
return single_open ( file , batadv_bla_backbone_table_seq_print_text ,
net_dev ) ;
}
2012-01-22 20:00:27 +01:00
# endif
2012-01-22 20:00:21 +01:00
2011-11-06 12:23:55 +01:00
# ifdef CONFIG_BATMAN_ADV_DAT
2012-06-30 20:01:19 +02:00
/**
2018-07-05 14:42:49 +02:00
* batadv_dat_cache_open ( ) - Prepare file handler for reads from dat_cache
2012-06-30 20:01:19 +02:00
* @ inode : inode which was opened
* @ file : file handle to be initialized
2015-10-31 12:29:29 +01:00
*
* Return : 0 on success or negative error number in case of failure
2012-06-30 20:01:19 +02:00
*/
static int batadv_dat_cache_open ( struct inode * inode , struct file * file )
{
struct net_device * net_dev = ( struct net_device * ) inode - > i_private ;
2014-05-10 18:56:37 +02:00
2018-08-10 23:36:15 +02:00
batadv_debugfs_deprecated ( file ,
" Use genl command BATADV_CMD_GET_DAT_CACHE instead \n " ) ;
2012-06-30 20:01:19 +02:00
return single_open ( file , batadv_dat_cache_seq_print_text , net_dev ) ;
}
2011-11-06 12:23:55 +01:00
# endif
2012-06-30 20:01:19 +02:00
2012-05-12 18:33:50 +02:00
static int batadv_transtable_local_open ( struct inode * inode , struct file * file )
2010-12-13 11:19:28 +00:00
{
struct net_device * net_dev = ( struct net_device * ) inode - > i_private ;
2014-05-10 18:56:37 +02:00
2018-08-10 23:36:15 +02:00
batadv_debugfs_deprecated ( file ,
" Use genl command BATADV_CMD_GET_TRANSTABLE_LOCAL instead \n " ) ;
2012-05-12 02:09:39 +02:00
return single_open ( file , batadv_tt_local_seq_print_text , net_dev ) ;
2010-12-13 11:19:28 +00:00
}
2012-06-05 22:31:27 +02:00
struct batadv_debuginfo {
2010-12-13 11:19:28 +00:00
struct attribute attr ;
const struct file_operations fops ;
} ;
2013-01-25 11:12:39 +01:00
# ifdef CONFIG_BATMAN_ADV_NC
static int batadv_nc_nodes_open ( struct inode * inode , struct file * file )
{
struct net_device * net_dev = ( struct net_device * ) inode - > i_private ;
2014-05-10 18:56:37 +02:00
2018-08-10 23:36:15 +02:00
batadv_debugfs_deprecated ( file , " " ) ;
2013-01-25 11:12:39 +01:00
return single_open ( file , batadv_nc_nodes_seq_print_text , net_dev ) ;
}
# endif
2016-05-10 18:41:27 +02:00
# ifdef CONFIG_BATMAN_ADV_MCAST
/**
2017-12-02 19:51:47 +01:00
* batadv_mcast_flags_open ( ) - prepare file handler for reads from mcast_flags
2016-05-10 18:41:27 +02:00
* @ inode : inode which was opened
* @ file : file handle to be initialized
*
* Return : 0 on success or negative error number in case of failure
*/
static int batadv_mcast_flags_open ( struct inode * inode , struct file * file )
{
struct net_device * net_dev = ( struct net_device * ) inode - > i_private ;
2018-08-10 23:36:15 +02:00
batadv_debugfs_deprecated ( file ,
" Use genl command BATADV_CMD_GET_MCAST_FLAGS instead \n " ) ;
2016-05-10 18:41:27 +02:00
return single_open ( file , batadv_mcast_flags_seq_print_text , net_dev ) ;
}
# endif
2012-06-03 22:19:07 +02:00
# define BATADV_DEBUGINFO(_name, _mode, _open) \
2012-06-05 22:31:27 +02:00
struct batadv_debuginfo batadv_debuginfo_ # # _name = { \
2016-03-11 14:01:11 +01:00
. attr = { \
. name = __stringify ( _name ) , \
. mode = _mode , \
} , \
. fops = { \
. owner = THIS_MODULE , \
. open = _open , \
. read = seq_read , \
. llseek = seq_lseek , \
. release = single_release , \
} , \
2014-05-15 11:24:26 +02:00
}
2010-12-13 11:19:28 +00:00
2012-10-16 10:04:39 +02:00
/* the following attributes are general and therefore they will be directly
* placed in the BATADV_DEBUGFS_SUBDIR subdirectory of debugfs
*/
2016-09-01 10:25:12 +02:00
static BATADV_DEBUGINFO ( routing_algos , 0444 , batadv_algorithms_open ) ;
2012-10-16 10:04:39 +02:00
static struct batadv_debuginfo * batadv_general_debuginfos [ ] = {
& batadv_debuginfo_routing_algos ,
NULL ,
} ;
/* The following attributes are per soft interface */
2016-09-01 10:25:12 +02:00
static BATADV_DEBUGINFO ( neighbors , 0444 , neighbors_open ) ;
static BATADV_DEBUGINFO ( originators , 0444 , batadv_originators_open ) ;
static BATADV_DEBUGINFO ( gateways , 0444 , batadv_gateways_open ) ;
static BATADV_DEBUGINFO ( transtable_global , 0444 , batadv_transtable_global_open ) ;
2012-01-22 20:00:27 +01:00
# ifdef CONFIG_BATMAN_ADV_BLA
2016-09-01 10:25:12 +02:00
static BATADV_DEBUGINFO ( bla_claim_table , 0444 , batadv_bla_claim_table_open ) ;
static BATADV_DEBUGINFO ( bla_backbone_table , 0444 ,
2012-06-18 18:39:26 +02:00
batadv_bla_backbone_table_open ) ;
2012-01-22 20:00:27 +01:00
# endif
2011-11-06 12:23:55 +01:00
# ifdef CONFIG_BATMAN_ADV_DAT
2016-09-01 10:25:12 +02:00
static BATADV_DEBUGINFO ( dat_cache , 0444 , batadv_dat_cache_open ) ;
2011-11-06 12:23:55 +01:00
# endif
2016-09-01 10:25:12 +02:00
static BATADV_DEBUGINFO ( transtable_local , 0444 , batadv_transtable_local_open ) ;
2013-01-25 11:12:39 +01:00
# ifdef CONFIG_BATMAN_ADV_NC
2016-09-01 10:25:12 +02:00
static BATADV_DEBUGINFO ( nc_nodes , 0444 , batadv_nc_nodes_open ) ;
2013-01-25 11:12:39 +01:00
# endif
2016-05-10 18:41:27 +02:00
# ifdef CONFIG_BATMAN_ADV_MCAST
2016-09-01 10:25:12 +02:00
static BATADV_DEBUGINFO ( mcast_flags , 0444 , batadv_mcast_flags_open ) ;
2016-05-10 18:41:27 +02:00
# endif
2010-12-13 11:19:28 +00:00
2012-06-05 22:31:27 +02:00
static struct batadv_debuginfo * batadv_mesh_debuginfos [ ] = {
2015-08-04 21:09:57 +08:00
& batadv_debuginfo_neighbors ,
2012-05-12 18:33:50 +02:00
& batadv_debuginfo_originators ,
& batadv_debuginfo_gateways ,
& batadv_debuginfo_transtable_global ,
2012-01-22 20:00:27 +01:00
# ifdef CONFIG_BATMAN_ADV_BLA
2012-05-12 18:33:50 +02:00
& batadv_debuginfo_bla_claim_table ,
2012-06-18 18:39:26 +02:00
& batadv_debuginfo_bla_backbone_table ,
2012-01-22 20:00:27 +01:00
# endif
2011-11-06 12:23:55 +01:00
# ifdef CONFIG_BATMAN_ADV_DAT
2012-06-30 20:01:19 +02:00
& batadv_debuginfo_dat_cache ,
2011-11-06 12:23:55 +01:00
# endif
2012-05-12 18:33:50 +02:00
& batadv_debuginfo_transtable_local ,
2013-01-25 11:12:39 +01:00
# ifdef CONFIG_BATMAN_ADV_NC
& batadv_debuginfo_nc_nodes ,
2016-05-10 18:41:27 +02:00
# endif
# ifdef CONFIG_BATMAN_ADV_MCAST
& batadv_debuginfo_mcast_flags ,
2013-01-25 11:12:39 +01:00
# endif
2010-12-13 11:19:28 +00:00
NULL ,
} ;
2013-11-21 14:16:12 +01:00
# define BATADV_HARDIF_DEBUGINFO(_name, _mode, _open) \
struct batadv_debuginfo batadv_hardif_debuginfo_ # # _name = { \
. attr = { \
. name = __stringify ( _name ) , \
. mode = _mode , \
} , \
. fops = { \
. owner = THIS_MODULE , \
. open = _open , \
. read = seq_read , \
. llseek = seq_lseek , \
. release = single_release , \
} , \
2014-05-15 11:24:26 +02:00
}
2014-09-01 14:37:27 +02:00
2016-09-01 10:25:12 +02:00
static BATADV_HARDIF_DEBUGINFO ( originators , 0444 ,
2013-11-21 11:52:16 +01:00
batadv_originators_hardif_open ) ;
2013-11-21 14:16:12 +01:00
static struct batadv_debuginfo * batadv_hardif_debuginfos [ ] = {
2013-11-21 11:52:16 +01:00
& batadv_hardif_debuginfo_originators ,
2013-11-21 14:16:12 +01:00
NULL ,
} ;
2017-12-02 19:51:53 +01:00
/**
* batadv_debugfs_init ( ) - Initialize soft interface independent debugfs entries
*/
2012-05-12 02:09:23 +02:00
void batadv_debugfs_init ( void )
2010-12-13 11:19:28 +00:00
{
2012-10-16 10:04:39 +02:00
struct batadv_debuginfo * * bat_debug ;
2011-11-28 17:40:17 +08:00
2012-06-03 22:19:08 +02:00
batadv_debugfs = debugfs_create_dir ( BATADV_DEBUGFS_SUBDIR , NULL ) ;
2011-11-28 17:40:17 +08:00
2019-06-14 09:11:23 +02:00
for ( bat_debug = batadv_general_debuginfos ; * bat_debug ; + + bat_debug )
debugfs_create_file ( ( ( * bat_debug ) - > attr ) . name ,
S_IFREG | ( ( * bat_debug ) - > attr ) . mode ,
batadv_debugfs , NULL , & ( * bat_debug ) - > fops ) ;
2010-12-13 11:19:28 +00:00
}
2017-12-02 19:51:53 +01:00
/**
* batadv_debugfs_destroy ( ) - Remove all debugfs entries
*/
2012-05-12 02:09:23 +02:00
void batadv_debugfs_destroy ( void )
2010-12-13 11:19:28 +00:00
{
2012-11-29 01:03:31 +01:00
debugfs_remove_recursive ( batadv_debugfs ) ;
batadv_debugfs = NULL ;
2010-12-13 11:19:28 +00:00
}
2013-11-21 14:16:12 +01:00
/**
2017-12-02 19:51:47 +01:00
* batadv_debugfs_add_hardif ( ) - creates the base directory for a hard interface
2013-11-21 14:16:12 +01:00
* in debugfs .
* @ hard_iface : hard interface which should be added .
*/
2019-06-14 09:11:23 +02:00
void batadv_debugfs_add_hardif ( struct batadv_hard_iface * hard_iface )
2013-11-21 14:16:12 +01:00
{
2016-07-03 13:31:34 +02:00
struct net * net = dev_net ( hard_iface - > net_dev ) ;
2013-11-21 14:16:12 +01:00
struct batadv_debuginfo * * bat_debug ;
2016-07-03 13:31:34 +02:00
if ( net ! = & init_net )
2019-06-14 09:11:23 +02:00
return ;
2016-07-03 13:31:34 +02:00
2013-11-21 14:16:12 +01:00
hard_iface - > debug_dir = debugfs_create_dir ( hard_iface - > net_dev - > name ,
batadv_debugfs ) ;
2019-06-14 09:11:23 +02:00
for ( bat_debug = batadv_hardif_debuginfos ; * bat_debug ; + + bat_debug )
debugfs_create_file ( ( ( * bat_debug ) - > attr ) . name ,
S_IFREG | ( ( * bat_debug ) - > attr ) . mode ,
hard_iface - > debug_dir , hard_iface - > net_dev ,
& ( * bat_debug ) - > fops ) ;
2013-11-21 14:16:12 +01:00
}
2018-06-01 19:24:23 +02:00
/**
* batadv_debugfs_rename_hardif ( ) - Fix debugfs path for renamed hardif
* @ hard_iface : hard interface which was renamed
*/
void batadv_debugfs_rename_hardif ( struct batadv_hard_iface * hard_iface )
{
const char * name = hard_iface - > net_dev - > name ;
struct dentry * dir ;
dir = hard_iface - > debug_dir ;
if ( ! dir )
return ;
2019-06-14 09:11:23 +02:00
debugfs_rename ( dir - > d_parent , dir , dir - > d_parent , name ) ;
2018-06-01 19:24:23 +02:00
}
2013-11-21 14:16:12 +01:00
/**
2017-12-02 19:51:47 +01:00
* batadv_debugfs_del_hardif ( ) - delete the base directory for a hard interface
2013-11-21 14:16:12 +01:00
* in debugfs .
* @ hard_iface : hard interface which is deleted .
*/
void batadv_debugfs_del_hardif ( struct batadv_hard_iface * hard_iface )
{
2016-07-03 13:31:34 +02:00
struct net * net = dev_net ( hard_iface - > net_dev ) ;
if ( net ! = & init_net )
return ;
2013-11-21 14:16:12 +01:00
if ( batadv_debugfs ) {
debugfs_remove_recursive ( hard_iface - > debug_dir ) ;
hard_iface - > debug_dir = NULL ;
}
}
2017-12-02 19:51:53 +01:00
/**
* batadv_debugfs_add_meshif ( ) - Initialize interface dependent debugfs entries
* @ dev : netdev struct of the soft interface
*
* Return : 0 on success or negative error number in case of failure
*/
2012-05-12 02:09:23 +02:00
int batadv_debugfs_add_meshif ( struct net_device * dev )
2010-12-13 11:19:28 +00:00
{
2012-06-05 22:31:31 +02:00
struct batadv_priv * bat_priv = netdev_priv ( dev ) ;
2012-06-05 22:31:27 +02:00
struct batadv_debuginfo * * bat_debug ;
2016-07-03 13:31:34 +02:00
struct net * net = dev_net ( dev ) ;
2010-12-13 11:19:28 +00:00
2016-07-03 13:31:34 +02:00
if ( net ! = & init_net )
return 0 ;
2012-05-12 18:33:50 +02:00
bat_priv - > debug_dir = debugfs_create_dir ( dev - > name , batadv_debugfs ) ;
2010-12-13 11:19:28 +00:00
2019-06-14 09:11:23 +02:00
batadv_socket_setup ( bat_priv ) ;
2012-05-05 13:27:28 +02:00
2012-05-12 18:33:50 +02:00
if ( batadv_debug_log_setup ( bat_priv ) < 0 )
2012-05-05 13:27:28 +02:00
goto rem_attr ;
2010-12-13 11:19:28 +00:00
2019-06-14 09:11:23 +02:00
for ( bat_debug = batadv_mesh_debuginfos ; * bat_debug ; + + bat_debug )
debugfs_create_file ( ( ( * bat_debug ) - > attr ) . name ,
S_IFREG | ( ( * bat_debug ) - > attr ) . mode ,
bat_priv - > debug_dir , dev ,
& ( * bat_debug ) - > fops ) ;
2010-12-13 11:19:28 +00:00
2019-06-14 09:11:23 +02:00
batadv_nc_init_debugfs ( bat_priv ) ;
2013-01-25 11:12:39 +01:00
2010-12-13 11:19:28 +00:00
return 0 ;
rem_attr :
debugfs_remove_recursive ( bat_priv - > debug_dir ) ;
bat_priv - > debug_dir = NULL ;
return - ENOMEM ;
}
2018-06-01 19:24:24 +02:00
/**
* batadv_debugfs_rename_meshif ( ) - Fix debugfs path for renamed softif
* @ dev : net_device which was renamed
*/
void batadv_debugfs_rename_meshif ( struct net_device * dev )
{
struct batadv_priv * bat_priv = netdev_priv ( dev ) ;
const char * name = dev - > name ;
struct dentry * dir ;
dir = bat_priv - > debug_dir ;
if ( ! dir )
return ;
2019-06-14 09:11:23 +02:00
debugfs_rename ( dir - > d_parent , dir , dir - > d_parent , name ) ;
2018-06-01 19:24:24 +02:00
}
2017-12-02 19:51:53 +01:00
/**
* batadv_debugfs_del_meshif ( ) - Remove interface dependent debugfs entries
* @ dev : netdev struct of the soft interface
*/
2012-05-12 02:09:23 +02:00
void batadv_debugfs_del_meshif ( struct net_device * dev )
2010-12-13 11:19:28 +00:00
{
2012-06-05 22:31:31 +02:00
struct batadv_priv * bat_priv = netdev_priv ( dev ) ;
2016-07-03 13:31:34 +02:00
struct net * net = dev_net ( dev ) ;
if ( net ! = & init_net )
return ;
2010-12-13 11:19:28 +00:00
2012-05-12 18:33:50 +02:00
batadv_debug_log_cleanup ( bat_priv ) ;
2010-12-13 11:19:28 +00:00
2012-05-12 18:33:50 +02:00
if ( batadv_debugfs ) {
2010-12-13 11:19:28 +00:00
debugfs_remove_recursive ( bat_priv - > debug_dir ) ;
bat_priv - > debug_dir = NULL ;
}
}