2019-04-05 13:31:35 -04:00
/*
2019-04-15 11:36:01 -04:00
* hsr_debugfs code
2019-04-15 11:36:02 -04:00
* Copyright ( C ) 2019 Texas Instruments Incorporated
2019-04-05 13:31:35 -04:00
*
* Author ( s ) :
2019-04-15 11:36:02 -04:00
* Murali Karicheri < m - karicheri2 @ ti . com >
2019-04-05 13:31:35 -04:00
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation version 2.
*
* This program is distributed " as is " WITHOUT ANY WARRANTY of any
* kind , whether express or implied ; without even the implied warranty
* of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*/
# include <linux/module.h>
# include <linux/errno.h>
# include <linux/debugfs.h>
# include "hsr_main.h"
# include "hsr_framereg.h"
2019-12-22 11:26:27 +00:00
static struct dentry * hsr_debugfs_root_dir ;
2019-04-05 13:31:35 -04:00
static void print_mac_address ( struct seq_file * sfp , unsigned char * mac )
{
seq_printf ( sfp , " %02x:%02x:%02x:%02x:%02x:%02x: " ,
mac [ 0 ] , mac [ 1 ] , mac [ 2 ] , mac [ 3 ] , mac [ 4 ] , mac [ 5 ] ) ;
}
2019-04-15 11:36:01 -04:00
/* hsr_node_table_show - Formats and prints node_table entries */
2019-04-05 13:31:35 -04:00
static int
2019-04-15 11:36:01 -04:00
hsr_node_table_show ( struct seq_file * sfp , void * data )
2019-04-05 13:31:35 -04:00
{
struct hsr_priv * priv = ( struct hsr_priv * ) sfp - > private ;
struct hsr_node * node ;
seq_puts ( sfp , " Node Table entries \n " ) ;
seq_puts ( sfp , " MAC-Address-A, MAC-Address-B, time_in[A], " ) ;
seq_puts ( sfp , " time_in[B], Address-B port \n " ) ;
rcu_read_lock ( ) ;
list_for_each_entry_rcu ( node , & priv - > node_db , mac_list ) {
/* skip self node */
if ( hsr_addr_is_self ( priv , node - > macaddress_A ) )
continue ;
print_mac_address ( sfp , & node - > macaddress_A [ 0 ] ) ;
seq_puts ( sfp , " " ) ;
print_mac_address ( sfp , & node - > macaddress_B [ 0 ] ) ;
seq_printf ( sfp , " 0x%lx, " , node - > time_in [ HSR_PT_SLAVE_A ] ) ;
seq_printf ( sfp , " 0x%lx " , node - > time_in [ HSR_PT_SLAVE_B ] ) ;
seq_printf ( sfp , " 0x%x \n " , node - > addr_B_port ) ;
}
rcu_read_unlock ( ) ;
return 0 ;
}
2019-04-15 11:36:01 -04:00
/* hsr_node_table_open - Open the node_table file
2019-04-05 13:31:35 -04:00
*
* Description :
* This routine opens a debugfs file node_table of specific hsr device
*/
static int
2019-04-15 11:36:01 -04:00
hsr_node_table_open ( struct inode * inode , struct file * filp )
2019-04-05 13:31:35 -04:00
{
2019-04-15 11:36:01 -04:00
return single_open ( filp , hsr_node_table_show , inode - > i_private ) ;
2019-04-05 13:31:35 -04:00
}
2019-04-15 11:36:01 -04:00
static const struct file_operations hsr_fops = {
. open = hsr_node_table_open ,
2019-04-05 13:31:35 -04:00
. read = seq_read ,
. llseek = seq_lseek ,
. release = single_release ,
} ;
2019-04-15 11:36:01 -04:00
/* hsr_debugfs_init - create hsr node_table file for dumping
2019-04-05 13:31:35 -04:00
* the node table
*
* Description :
* When debugfs is configured this routine sets up the node_table file per
2019-04-15 11:36:01 -04:00
* hsr device for dumping the node_table entries
2019-04-05 13:31:35 -04:00
*/
2019-12-22 11:26:15 +00:00
void hsr_debugfs_init ( struct hsr_priv * priv , struct net_device * hsr_dev )
2019-04-05 13:31:35 -04:00
{
struct dentry * de = NULL ;
2019-12-22 11:26:27 +00:00
de = debugfs_create_dir ( hsr_dev - > name , hsr_debugfs_root_dir ) ;
2019-12-22 11:26:15 +00:00
if ( IS_ERR ( de ) ) {
2019-12-22 11:26:27 +00:00
pr_err ( " Cannot create hsr debugfs directory \n " ) ;
2019-12-22 11:26:15 +00:00
return ;
2019-04-05 13:31:35 -04:00
}
priv - > node_tbl_root = de ;
de = debugfs_create_file ( " node_table " , S_IFREG | 0444 ,
priv - > node_tbl_root , priv ,
2019-04-15 11:36:01 -04:00
& hsr_fops ) ;
2019-12-22 11:26:15 +00:00
if ( IS_ERR ( de ) ) {
2019-12-22 11:26:27 +00:00
pr_err ( " Cannot create hsr node_table file \n " ) ;
2019-12-22 11:26:15 +00:00
debugfs_remove ( priv - > node_tbl_root ) ;
priv - > node_tbl_root = NULL ;
return ;
2019-04-05 13:31:35 -04:00
}
priv - > node_tbl_file = de ;
}
2019-04-15 11:36:01 -04:00
/* hsr_debugfs_term - Tear down debugfs intrastructure
2019-04-05 13:31:35 -04:00
*
* Description :
* When Debufs is configured this routine removes debugfs file system
2019-04-15 11:36:01 -04:00
* elements that are specific to hsr
2019-04-05 13:31:35 -04:00
*/
void
2019-04-15 11:36:01 -04:00
hsr_debugfs_term ( struct hsr_priv * priv )
2019-04-05 13:31:35 -04:00
{
debugfs_remove ( priv - > node_tbl_file ) ;
priv - > node_tbl_file = NULL ;
debugfs_remove ( priv - > node_tbl_root ) ;
priv - > node_tbl_root = NULL ;
}
2019-12-22 11:26:27 +00:00
void hsr_debugfs_create_root ( void )
{
hsr_debugfs_root_dir = debugfs_create_dir ( " hsr " , NULL ) ;
if ( IS_ERR ( hsr_debugfs_root_dir ) ) {
pr_err ( " Cannot create hsr debugfs root directory \n " ) ;
hsr_debugfs_root_dir = NULL ;
}
}
void hsr_debugfs_remove_root ( void )
{
/* debugfs_remove() internally checks NULL and ERROR */
debugfs_remove ( hsr_debugfs_root_dir ) ;
}