6lowpan: add debugfs support
authorAlexander Aring <alex.aring@gmail.com>
Wed, 9 Dec 2015 21:46:30 +0000 (22:46 +0100)
committerMarcel Holtmann <marcel@holtmann.org>
Thu, 10 Dec 2015 00:25:25 +0000 (01:25 +0100)
This patch will introduce a 6lowpan entry into the debugfs if enabled.
Inside this 6lowpan directory we create a subdirectories of all 6lowpan
interfaces to offer a per interface debugfs support.

Reviewed-by: Stefan Schmidt <stefan@osg.samsung.com>
Signed-off-by: Alexander Aring <alex.aring@gmail.com>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
include/net/6lowpan.h
net/6lowpan/6lowpan_i.h [new file with mode: 0644]
net/6lowpan/Kconfig
net/6lowpan/Makefile
net/6lowpan/core.c
net/6lowpan/debugfs.c [new file with mode: 0644]

index 730211fd8ed7f812338013185cd773737bf70244..2f6a3f2233edf8e2052c7c5bd5856894bbe7d5eb 100644 (file)
@@ -53,6 +53,8 @@
 #ifndef __6LOWPAN_H__
 #define __6LOWPAN_H__
 
+#include <linux/debugfs.h>
+
 #include <net/ipv6.h>
 #include <net/net_namespace.h>
 
@@ -98,6 +100,7 @@ enum lowpan_lltypes {
 
 struct lowpan_priv {
        enum lowpan_lltypes lltype;
+       struct dentry *iface_debugfs;
 
        /* must be last */
        u8 priv[0] __aligned(sizeof(void *));
diff --git a/net/6lowpan/6lowpan_i.h b/net/6lowpan/6lowpan_i.h
new file mode 100644 (file)
index 0000000..d16bb4b
--- /dev/null
@@ -0,0 +1,28 @@
+#ifndef __6LOWPAN_I_H
+#define __6LOWPAN_I_H
+
+#include <linux/netdevice.h>
+
+#ifdef CONFIG_6LOWPAN_DEBUGFS
+int lowpan_dev_debugfs_init(struct net_device *dev);
+void lowpan_dev_debugfs_exit(struct net_device *dev);
+
+int __init lowpan_debugfs_init(void);
+void lowpan_debugfs_exit(void);
+#else
+static inline int lowpan_dev_debugfs_init(struct net_device *dev)
+{
+       return 0;
+}
+
+static inline void lowpan_dev_debugfs_exit(struct net_device *dev) { }
+
+static inline int __init lowpan_debugfs_init(void)
+{
+       return 0;
+}
+
+static inline void lowpan_debugfs_exit(void) { }
+#endif /* CONFIG_6LOWPAN_DEBUGFS */
+
+#endif /* __6LOWPAN_I_H */
index bcb9d8a21fc0297bd5766e4d3ad90527ed87d11e..9c051512d14f5b70307e8c907704d4c9875cd56d 100644 (file)
@@ -5,6 +5,14 @@ menuconfig 6LOWPAN
          This enables IPv6 over Low power Wireless Personal Area Network -
          "6LoWPAN" which is supported by IEEE 802.15.4 or Bluetooth stacks.
 
+config 6LOWPAN_DEBUGFS
+       bool "6LoWPAN debugfs support"
+       depends on 6LOWPAN
+       depends on DEBUG_FS
+       ---help---
+         This enables 6LoWPAN debugfs support. For example to manipulate
+         IPHC context information at runtime.
+
 menuconfig 6LOWPAN_NHC
        tristate "Next Header and Generic Header Compression Support"
        depends on 6LOWPAN
index 9e35a5d7b92d54addb2550710819a1496ce47e7f..e44f3bf2dd42e23e22cc7acb008e52cb2210f75c 100644 (file)
@@ -1,6 +1,7 @@
 obj-$(CONFIG_6LOWPAN) += 6lowpan.o
 
 6lowpan-y := core.o iphc.o nhc.o
+6lowpan-$(CONFIG_6LOWPAN_DEBUGFS) += debugfs.o
 
 #rfc6282 nhcs
 obj-$(CONFIG_6LOWPAN_NHC_DEST) += nhc_dest.o
index 80fc50987cf380b49d67f8a77bcf7d77f6df8db2..c7f06f5c01213d280f57106c37d066be956a3942 100644 (file)
 
 #include <net/6lowpan.h>
 
+#include "6lowpan_i.h"
+
 int lowpan_register_netdevice(struct net_device *dev,
                              enum lowpan_lltypes lltype)
 {
+       int ret;
+
        dev->addr_len = EUI64_ADDR_LEN;
        dev->type = ARPHRD_6LOWPAN;
        dev->mtu = IPV6_MIN_MTU;
@@ -25,7 +29,15 @@ int lowpan_register_netdevice(struct net_device *dev,
 
        lowpan_priv(dev)->lltype = lltype;
 
-       return register_netdevice(dev);
+       ret = lowpan_dev_debugfs_init(dev);
+       if (ret < 0)
+               return ret;
+
+       ret = register_netdevice(dev);
+       if (ret < 0)
+               lowpan_dev_debugfs_exit(dev);
+
+       return ret;
 }
 EXPORT_SYMBOL(lowpan_register_netdevice);
 
@@ -44,6 +56,7 @@ EXPORT_SYMBOL(lowpan_register_netdev);
 void lowpan_unregister_netdevice(struct net_device *dev)
 {
        unregister_netdevice(dev);
+       lowpan_dev_debugfs_exit(dev);
 }
 EXPORT_SYMBOL(lowpan_unregister_netdevice);
 
@@ -57,6 +70,12 @@ EXPORT_SYMBOL(lowpan_unregister_netdev);
 
 static int __init lowpan_module_init(void)
 {
+       int ret;
+
+       ret = lowpan_debugfs_init();
+       if (ret < 0)
+               return ret;
+
        request_module_nowait("ipv6");
 
        request_module_nowait("nhc_dest");
@@ -69,6 +88,13 @@ static int __init lowpan_module_init(void)
 
        return 0;
 }
+
+static void __exit lowpan_module_exit(void)
+{
+       lowpan_debugfs_exit();
+}
+
 module_init(lowpan_module_init);
+module_exit(lowpan_module_exit);
 
 MODULE_LICENSE("GPL");
diff --git a/net/6lowpan/debugfs.c b/net/6lowpan/debugfs.c
new file mode 100644 (file)
index 0000000..88eef84
--- /dev/null
@@ -0,0 +1,53 @@
+/* This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2
+ * 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.
+ *
+ * Authors:
+ * (C) 2015 Pengutronix, Alexander Aring <aar@pengutronix.de>
+ * Copyright (c)  2015 Nordic Semiconductor. All Rights Reserved.
+ */
+
+#include <net/6lowpan.h>
+
+#include "6lowpan_i.h"
+
+static struct dentry *lowpan_debugfs;
+
+int lowpan_dev_debugfs_init(struct net_device *dev)
+{
+       struct lowpan_priv *lpriv = lowpan_priv(dev);
+
+       /* creating the root */
+       lpriv->iface_debugfs = debugfs_create_dir(dev->name, lowpan_debugfs);
+       if (!lpriv->iface_debugfs)
+               goto fail;
+
+       return 0;
+
+fail:
+       return -EINVAL;
+}
+
+void lowpan_dev_debugfs_exit(struct net_device *dev)
+{
+       debugfs_remove_recursive(lowpan_priv(dev)->iface_debugfs);
+}
+
+int __init lowpan_debugfs_init(void)
+{
+       lowpan_debugfs = debugfs_create_dir("6lowpan", NULL);
+       if (!lowpan_debugfs)
+               return -EINVAL;
+
+       return 0;
+}
+
+void lowpan_debugfs_exit(void)
+{
+       debugfs_remove_recursive(lowpan_debugfs);
+}