blob: faf65baed617d5c5b39d9cadd5ef0264ea546d59 [file] [log] [blame]
Alexander Aringb72f6f52015-08-11 21:44:08 +02001/* This program is free software; you can redistribute it and/or modify
2 * it under the terms of the GNU General Public License version 2
3 * as published by the Free Software Foundation.
4 *
5 * This program is distributed in the hope that it will be useful,
6 * but WITHOUT ANY WARRANTY; without even the implied warranty of
7 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
8 * GNU General Public License for more details.
9 *
10 * Authors:
11 * (C) 2015 Pengutronix, Alexander Aring <aar@pengutronix.de>
12 */
13
Alexander Aring4ae935c2015-08-11 21:44:09 +020014#include <linux/module.h>
15
Alexander Aringb72f6f52015-08-11 21:44:08 +020016#include <net/6lowpan.h>
17
Alexander Aringb1815fd2015-12-09 22:46:30 +010018#include "6lowpan_i.h"
19
Alexander Aring00f59312015-12-09 22:46:29 +010020int lowpan_register_netdevice(struct net_device *dev,
21 enum lowpan_lltypes lltype)
Alexander Aringb72f6f52015-08-11 21:44:08 +020022{
Alexander Aringb1815fd2015-12-09 22:46:30 +010023 int ret;
24
Alexander Aring4d6a6ae2015-10-02 20:28:04 +020025 dev->addr_len = EUI64_ADDR_LEN;
26 dev->type = ARPHRD_6LOWPAN;
27 dev->mtu = IPV6_MIN_MTU;
28 dev->priv_flags |= IFF_NO_QUEUE;
29
Alexander Aringb72f6f52015-08-11 21:44:08 +020030 lowpan_priv(dev)->lltype = lltype;
Alexander Aring00f59312015-12-09 22:46:29 +010031
Alexander Aring92e17ee2015-12-15 12:25:35 +010032 ret = register_netdevice(dev);
Alexander Aringb1815fd2015-12-09 22:46:30 +010033 if (ret < 0)
34 return ret;
35
Alexander Aring92e17ee2015-12-15 12:25:35 +010036 ret = lowpan_dev_debugfs_init(dev);
Alexander Aringb1815fd2015-12-09 22:46:30 +010037 if (ret < 0)
Alexander Aring92e17ee2015-12-15 12:25:35 +010038 unregister_netdevice(dev);
Alexander Aringb1815fd2015-12-09 22:46:30 +010039
40 return ret;
Alexander Aringb72f6f52015-08-11 21:44:08 +020041}
Alexander Aring00f59312015-12-09 22:46:29 +010042EXPORT_SYMBOL(lowpan_register_netdevice);
43
44int lowpan_register_netdev(struct net_device *dev,
45 enum lowpan_lltypes lltype)
46{
47 int ret;
48
49 rtnl_lock();
50 ret = lowpan_register_netdevice(dev, lltype);
51 rtnl_unlock();
52 return ret;
53}
54EXPORT_SYMBOL(lowpan_register_netdev);
55
56void lowpan_unregister_netdevice(struct net_device *dev)
57{
58 unregister_netdevice(dev);
Alexander Aringb1815fd2015-12-09 22:46:30 +010059 lowpan_dev_debugfs_exit(dev);
Alexander Aring00f59312015-12-09 22:46:29 +010060}
61EXPORT_SYMBOL(lowpan_unregister_netdevice);
62
63void lowpan_unregister_netdev(struct net_device *dev)
64{
65 rtnl_lock();
66 lowpan_unregister_netdevice(dev);
67 rtnl_unlock();
68}
69EXPORT_SYMBOL(lowpan_unregister_netdev);
Alexander Aring4ae935c2015-08-11 21:44:09 +020070
71static int __init lowpan_module_init(void)
72{
Alexander Aringb1815fd2015-12-09 22:46:30 +010073 int ret;
74
75 ret = lowpan_debugfs_init();
76 if (ret < 0)
77 return ret;
78
Alexander Aring4ae935c2015-08-11 21:44:09 +020079 request_module_nowait("ipv6");
80
81 request_module_nowait("nhc_dest");
82 request_module_nowait("nhc_fragment");
83 request_module_nowait("nhc_hop");
84 request_module_nowait("nhc_ipv6");
85 request_module_nowait("nhc_mobility");
86 request_module_nowait("nhc_routing");
87 request_module_nowait("nhc_udp");
88
89 return 0;
90}
Alexander Aringb1815fd2015-12-09 22:46:30 +010091
92static void __exit lowpan_module_exit(void)
93{
94 lowpan_debugfs_exit();
95}
96
Alexander Aring4ae935c2015-08-11 21:44:09 +020097module_init(lowpan_module_init);
Alexander Aringb1815fd2015-12-09 22:46:30 +010098module_exit(lowpan_module_exit);
Alexander Aring4ae935c2015-08-11 21:44:09 +020099
100MODULE_LICENSE("GPL");