Commit c4121432 authored by Sven Eckelmann's avatar Sven Eckelmann Committed by Greg Kroah-Hartman

Staging: batman-adv: Move device for icmp injection to debugfs

batctl uses /dev/batman-adv to send special batman-adv icmp packets to
other nodes in the mesh. To get it working with multiple batX devices we
must ensure that every mesh device can have their own socket which is
used to inject those packets in exactly one mesh.

The current implementation still doesn't allow to use complete separated
meshes as we rely on structures which are not part of the private data
of a batman device.
Signed-off-by: default avatarSven Eckelmann <sven.eckelmann@gmx.de>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 1bd2c215
...@@ -19,4 +19,4 @@ ...@@ -19,4 +19,4 @@
# #
obj-m += batman-adv.o obj-m += batman-adv.o
batman-adv-objs := main.o send.o routing.o soft-interface.o device.o translation-table.o bitarray.o hash.o ring_buffer.o vis.o hard-interface.o aggregation.o originator.o bat_sysfs.o batman-adv-objs := main.o bat_debugfs.o bat_sysfs.o send.o routing.o soft-interface.o icmp_socket.o translation-table.o bitarray.o hash.o ring_buffer.o vis.o hard-interface.o aggregation.o originator.o
/*
* Copyright (C) 2010 B.A.T.M.A.N. contributors:
*
* 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
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301, USA
*
*/
#include <linux/debugfs.h>
#include "main.h"
#include "bat_debugfs.h"
#include "translation-table.h"
#include "originator.h"
#include "hard-interface.h"
#include "vis.h"
#include "icmp_socket.h"
static struct dentry *bat_debugfs;
void debugfs_init(void)
{
bat_debugfs = debugfs_create_dir(DEBUGFS_BAT_SUBDIR, NULL);
}
void debugfs_destroy(void)
{
if (bat_debugfs) {
debugfs_remove_recursive(bat_debugfs);
bat_debugfs = NULL;
}
}
int debugfs_add_meshif(struct net_device *dev)
{
struct bat_priv *bat_priv = netdev_priv(dev);
if (!bat_debugfs)
goto out;
bat_priv->debug_dir = debugfs_create_dir(dev->name, bat_debugfs);
if (!bat_priv->debug_dir)
goto out;
bat_socket_setup(bat_priv);
return 0;
out:
#ifdef CONFIG_DEBUG_FS
return -ENOMEM;
#else
return 0;
#endif /* CONFIG_DEBUG_FS */
}
void debugfs_del_meshif(struct net_device *dev)
{
struct bat_priv *bat_priv = netdev_priv(dev);
if (bat_debugfs) {
debugfs_remove_recursive(bat_priv->debug_dir);
bat_priv->debug_dir = NULL;
}
}
/*
* Copyright (C) 2010 B.A.T.M.A.N. contributors:
*
* 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
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301, USA
*
*/
#ifndef BAT_DEBUGFS_H
#define BAT_DEBUGFS_H
#define DEBUGFS_BAT_SUBDIR "batman_adv"
void debugfs_init(void);
void debugfs_destroy(void);
int debugfs_add_meshif(struct net_device *dev);
void debugfs_del_meshif(struct net_device *dev);
#endif
...@@ -21,16 +21,8 @@ ...@@ -21,16 +21,8 @@
#include "types.h" #include "types.h"
void bat_device_init(void); #define ICMP_SOCKET "socket"
int bat_device_setup(void);
void bat_device_destroy(void); void bat_socket_init(void);
int bat_device_open(struct inode *inode, struct file *file); int bat_socket_setup(struct bat_priv *bat_priv);
int bat_device_release(struct inode *inode, struct file *file); void bat_socket_receive_packet(struct icmp_packet *icmp_packet);
ssize_t bat_device_read(struct file *file, char __user *buf, size_t count,
loff_t *ppos);
ssize_t bat_device_write(struct file *file, const char __user *buff,
size_t len, loff_t *off);
unsigned int bat_device_poll(struct file *file, poll_table *wait);
void bat_device_add_packet(struct device_client *device_client,
struct icmp_packet *icmp_packet);
void bat_device_receive_packet(struct icmp_packet *icmp_packet);
...@@ -21,11 +21,12 @@ ...@@ -21,11 +21,12 @@
#include "main.h" #include "main.h"
#include "bat_sysfs.h" #include "bat_sysfs.h"
#include "bat_debugfs.h"
#include "routing.h" #include "routing.h"
#include "send.h" #include "send.h"
#include "originator.h" #include "originator.h"
#include "soft-interface.h" #include "soft-interface.h"
#include "device.h" #include "icmp_socket.h"
#include "translation-table.h" #include "translation-table.h"
#include "hard-interface.h" #include "hard-interface.h"
#include "types.h" #include "types.h"
...@@ -89,7 +90,8 @@ int init_module(void) ...@@ -89,7 +90,8 @@ int init_module(void)
if (!bat_event_workqueue) if (!bat_event_workqueue)
return -ENOMEM; return -ENOMEM;
bat_device_init(); bat_socket_init();
debugfs_init();
/* initialize layer 2 interface */ /* initialize layer 2 interface */
soft_device = alloc_netdev(sizeof(struct bat_priv) , "bat%d", soft_device = alloc_netdev(sizeof(struct bat_priv) , "bat%d",
...@@ -114,6 +116,11 @@ int init_module(void) ...@@ -114,6 +116,11 @@ int init_module(void)
if (retval < 0) if (retval < 0)
goto unreg_soft_device; goto unreg_soft_device;
retval = debugfs_add_meshif(soft_device);
if (retval < 0)
goto unreg_sysfs;
register_netdevice_notifier(&hard_if_notifier); register_netdevice_notifier(&hard_if_notifier);
dev_add_pack(&batman_adv_packet_type); dev_add_pack(&batman_adv_packet_type);
...@@ -123,6 +130,8 @@ int init_module(void) ...@@ -123,6 +130,8 @@ int init_module(void)
return 0; return 0;
unreg_sysfs:
sysfs_del_meshif(soft_device);
unreg_soft_device: unreg_soft_device:
unregister_netdev(soft_device); unregister_netdev(soft_device);
soft_device = NULL; soft_device = NULL;
...@@ -143,6 +152,7 @@ void cleanup_module(void) ...@@ -143,6 +152,7 @@ void cleanup_module(void)
hardif_remove_interfaces(); hardif_remove_interfaces();
if (soft_device) { if (soft_device) {
debugfs_del_meshif(soft_device);
sysfs_del_meshif(soft_device); sysfs_del_meshif(soft_device);
unregister_netdev(soft_device); unregister_netdev(soft_device);
soft_device = NULL; soft_device = NULL;
...@@ -154,7 +164,7 @@ void cleanup_module(void) ...@@ -154,7 +164,7 @@ void cleanup_module(void)
bat_event_workqueue = NULL; bat_event_workqueue = NULL;
} }
/* activates the module, creates bat device, starts timer ... */ /* activates the module, starts timer ... */
void activate_module(void) void activate_module(void)
{ {
if (originator_init() < 1) if (originator_init() < 1)
...@@ -168,9 +178,6 @@ void activate_module(void) ...@@ -168,9 +178,6 @@ void activate_module(void)
hna_local_add(soft_device->dev_addr); hna_local_add(soft_device->dev_addr);
if (bat_device_setup() < 1)
goto end;
if (vis_init() < 1) if (vis_init() < 1)
goto err; goto err;
...@@ -205,7 +212,7 @@ void deactivate_module(void) ...@@ -205,7 +212,7 @@ void deactivate_module(void)
hna_global_free(); hna_global_free();
synchronize_net(); synchronize_net();
bat_device_destroy(); debugfs_destroy();
synchronize_rcu(); synchronize_rcu();
atomic_set(&module_state, MODULE_INACTIVE); atomic_set(&module_state, MODULE_INACTIVE);
......
...@@ -25,7 +25,7 @@ ...@@ -25,7 +25,7 @@
#include "hash.h" #include "hash.h"
#include "soft-interface.h" #include "soft-interface.h"
#include "hard-interface.h" #include "hard-interface.h"
#include "device.h" #include "icmp_socket.h"
#include "translation-table.h" #include "translation-table.h"
#include "originator.h" #include "originator.h"
#include "types.h" #include "types.h"
...@@ -668,7 +668,7 @@ static int recv_my_icmp_packet(struct sk_buff *skb) ...@@ -668,7 +668,7 @@ static int recv_my_icmp_packet(struct sk_buff *skb)
/* add data to device queue */ /* add data to device queue */
if (icmp_packet->msg_type != ECHO_REQUEST) { if (icmp_packet->msg_type != ECHO_REQUEST) {
bat_device_receive_packet(icmp_packet); bat_socket_receive_packet(icmp_packet);
return NET_RX_DROP; return NET_RX_DROP;
} }
......
...@@ -106,9 +106,10 @@ struct bat_priv { ...@@ -106,9 +106,10 @@ struct bat_priv {
char num_ifaces; char num_ifaces;
struct batman_if *primary_if; struct batman_if *primary_if;
struct kobject *mesh_obj; struct kobject *mesh_obj;
struct dentry *debug_dir;
}; };
struct device_client { struct socket_client {
struct list_head queue_list; struct list_head queue_list;
unsigned int queue_len; unsigned int queue_len;
unsigned char index; unsigned char index;
...@@ -116,7 +117,7 @@ struct device_client { ...@@ -116,7 +117,7 @@ struct device_client {
wait_queue_head_t queue_wait; wait_queue_head_t queue_wait;
}; };
struct device_packet { struct socket_packet {
struct list_head list; struct list_head list;
struct icmp_packet icmp_packet; struct icmp_packet icmp_packet;
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment