2017-01-01 00:00:00 +01:00
/* Copyright (C) 2010-2017 B.A.T.M.A.N. contributors:
2010-12-13 11:19:28 +00:00
*
* Marek Lindner
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of version 2 of the GNU General Public
* License as published by the Free Software Foundation .
*
* This program is distributed in the hope that it will be useful , but
* WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* General Public License for more details .
*
* You should have received a copy of the GNU General Public License
2013-11-03 20:40:48 +01:00
* along with this program ; if not , see < http : //www.gnu.org/licenses/>.
2010-12-13 11:19:28 +00:00
*/
2015-04-17 19:40:28 +02:00
# include "debugfs.h"
2010-12-13 11:19:28 +00:00
# include "main.h"
# include <linux/debugfs.h>
2017-01-28 10:23:30 +01:00
# include <linux/err.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>
# include <linux/sched.h> /* for linux/wait.h */
# 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
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
{
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 ;
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
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
/**
* batadv_originators_hardif_open - handles debugfs output for the
* originator table of an hard interface
* @ 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
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
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
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
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
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
/**
* batadv_dat_cache_open - Prepare file handler for reads from dat_chache
* @ 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
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
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
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
/**
* batadv_mcast_flags_open - prepare file handler for reads from mcast_flags
* @ 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 ;
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 ,
} ;
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
struct dentry * file ;
2012-06-03 22:19:08 +02:00
batadv_debugfs = debugfs_create_dir ( BATADV_DEBUGFS_SUBDIR , NULL ) ;
2012-05-12 18:33:50 +02:00
if ( batadv_debugfs = = ERR_PTR ( - ENODEV ) )
batadv_debugfs = NULL ;
2011-11-28 17:40:17 +08:00
2012-05-12 18:33:50 +02:00
if ( ! batadv_debugfs )
2012-10-16 10:04:39 +02:00
goto err ;
2011-11-28 17:40:17 +08:00
2012-10-16 10:04:39 +02:00
for ( bat_debug = batadv_general_debuginfos ; * bat_debug ; + + bat_debug ) {
file = debugfs_create_file ( ( ( * bat_debug ) - > attr ) . name ,
S_IFREG | ( ( * bat_debug ) - > attr ) . mode ,
batadv_debugfs , NULL ,
& ( * bat_debug ) - > fops ) ;
if ( ! file ) {
pr_err ( " Can't add general debugfs file: %s \n " ,
( ( * bat_debug ) - > attr ) . name ) ;
goto err ;
}
}
2011-11-28 17:40:17 +08:00
return ;
2012-10-16 10:04:39 +02:00
err :
debugfs_remove_recursive ( batadv_debugfs ) ;
2013-11-21 14:16:12 +01:00
batadv_debugfs = NULL ;
2010-12-13 11:19:28 +00:00
}
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
/**
* batadv_debugfs_add_hardif - creates the base directory for a hard interface
* in debugfs .
* @ hard_iface : hard interface which should be added .
2015-10-31 12:29:29 +01:00
*
* Return : 0 on success or negative error number in case of failure
2013-11-21 14:16:12 +01:00
*/
int batadv_debugfs_add_hardif ( struct batadv_hard_iface * hard_iface )
{
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 ;
struct dentry * file ;
if ( ! batadv_debugfs )
goto out ;
2016-07-03 13:31:34 +02:00
if ( net ! = & init_net )
return 0 ;
2013-11-21 14:16:12 +01:00
hard_iface - > debug_dir = debugfs_create_dir ( hard_iface - > net_dev - > name ,
batadv_debugfs ) ;
if ( ! hard_iface - > debug_dir )
goto out ;
for ( bat_debug = batadv_hardif_debuginfos ; * bat_debug ; + + bat_debug ) {
file = debugfs_create_file ( ( ( * bat_debug ) - > attr ) . name ,
S_IFREG | ( ( * bat_debug ) - > attr ) . mode ,
hard_iface - > debug_dir ,
hard_iface - > net_dev ,
& ( * bat_debug ) - > fops ) ;
if ( ! file )
goto rem_attr ;
}
return 0 ;
rem_attr :
debugfs_remove_recursive ( hard_iface - > debug_dir ) ;
hard_iface - > debug_dir = NULL ;
out :
return - ENOMEM ;
}
/**
* batadv_debugfs_del_hardif - delete the base directory for a hard interface
* 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 ;
}
}
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
struct dentry * file ;
2012-05-12 18:33:50 +02:00
if ( ! batadv_debugfs )
2010-12-13 11:19:28 +00:00
goto out ;
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
if ( ! bat_priv - > debug_dir )
goto out ;
2012-05-12 02:09:33 +02:00
if ( batadv_socket_setup ( bat_priv ) < 0 )
2012-05-05 13:27:28 +02:00
goto rem_attr ;
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
2012-05-12 18:33:50 +02:00
for ( bat_debug = batadv_mesh_debuginfos ; * bat_debug ; + + bat_debug ) {
2010-12-13 11:19:28 +00:00
file = debugfs_create_file ( ( ( * bat_debug ) - > attr ) . name ,
2012-06-19 20:26:30 +02:00
S_IFREG | ( ( * bat_debug ) - > attr ) . mode ,
bat_priv - > debug_dir ,
dev , & ( * bat_debug ) - > fops ) ;
2010-12-13 11:19:28 +00:00
if ( ! file ) {
2012-05-16 20:23:22 +02:00
batadv_err ( dev , " Can't add debugfs file: %s/%s \n " ,
dev - > name , ( ( * bat_debug ) - > attr ) . name ) ;
2010-12-13 11:19:28 +00:00
goto rem_attr ;
}
}
2013-01-25 11:12:39 +01:00
if ( batadv_nc_init_debugfs ( bat_priv ) < 0 )
goto rem_attr ;
2010-12-13 11:19:28 +00:00
return 0 ;
rem_attr :
debugfs_remove_recursive ( bat_priv - > debug_dir ) ;
bat_priv - > debug_dir = NULL ;
out :
return - ENOMEM ;
}
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 ;
}
}