ieee802154: rework interface registration
This patch meld mac802154_netdev_register into ieee802154_if_add function. Also we have now only one alloc_netdev call with one interface setup routine "ieee802154_if_setup" instead two different one for each interface type. This patch checks via runtime the interface type and do different handling now. Additional we add the wpan_dev struct in ieee802154_sub_if_data and set the new ieee802154_ptr while netdev registration. This behaviour is very similar the mac80211 netdev registration functionality. Signed-off-by: Alexander Aring <alex.aring@gmail.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
This commit is contained in:

committed by
Marcel Holtmann

parent
12cb56c237
commit
d5ae67bacd
@@ -13,6 +13,7 @@
|
||||
* Based on: net/mac80211/cfg.c
|
||||
*/
|
||||
|
||||
#include <net/rtnetlink.h>
|
||||
#include <net/cfg802154.h>
|
||||
|
||||
#include "ieee802154_i.h"
|
||||
@@ -23,8 +24,13 @@ ieee802154_add_iface_deprecated(struct wpan_phy *wpan_phy,
|
||||
const char *name, int type)
|
||||
{
|
||||
struct ieee802154_local *local = wpan_phy_priv(wpan_phy);
|
||||
struct net_device *dev;
|
||||
|
||||
return ieee802154_if_add(local, name, NULL, type);
|
||||
rtnl_lock();
|
||||
dev = ieee802154_if_add(local, name, NULL, type);
|
||||
rtnl_unlock();
|
||||
|
||||
return dev;
|
||||
}
|
||||
|
||||
static void ieee802154_del_iface_deprecated(struct wpan_phy *wpan_phy,
|
||||
|
Reference in New Issue
Block a user