Re: [RFC bluetooth-next] cfg802154: pass name_assign_type to rdev_add_virtual_intf()

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 04/22/2015 02:07 PM, Varka Bhadram wrote:

> This code is based on commit 6bab2e19c5ffd
> ("cfg80211: pass name_assign_type to rdev_add_virtual_intf()")
>
> This will expose in sysfs whether the ifname of a IEEE-802.15.4
> device is set by userspace or generated by the kernel.
> We are using two types of name_assign_types
>  o NET_NAME_ENUM: Default interface name provided by kernel
>  o NET_NAME_USER: Interface name provided by user.
>
> Signed-off-by: Varka Bhadram <varkab@xxxxxxx>
> ---
>  include/net/cfg802154.h      |    2 ++
>  net/ieee802154/nl-phy.c      |    1 +
>  net/ieee802154/nl802154.c    |    1 +
>  net/ieee802154/rdev-ops.h    |   10 +++++++---
>  net/mac802154/cfg.c          |    9 ++++++---
>  net/mac802154/ieee802154_i.h |    1 +
>  net/mac802154/iface.c        |    5 +++--
>  net/mac802154/main.c         |    3 ++-
>  8 files changed, 23 insertions(+), 9 deletions(-)
>
> diff --git a/include/net/cfg802154.h b/include/net/cfg802154.h
> index eeda676..6ea16c8 100644
> --- a/include/net/cfg802154.h
> +++ b/include/net/cfg802154.h
> @@ -30,11 +30,13 @@ struct wpan_phy_cca;
>  struct cfg802154_ops {
>  	struct net_device * (*add_virtual_intf_deprecated)(struct wpan_phy *wpan_phy,
>  							   const char *name,
> +							   unsigned char name_assign_type,
>  							   int type);
>  	void	(*del_virtual_intf_deprecated)(struct wpan_phy *wpan_phy,
>  					       struct net_device *dev);
>  	int	(*add_virtual_intf)(struct wpan_phy *wpan_phy,
>  				    const char *name,
> +				    unsigned char name_assign_type,
>  				    enum nl802154_iftype type,
>  				    __le64 extended_addr);
>  	int	(*del_virtual_intf)(struct wpan_phy *wpan_phy,
> diff --git a/net/ieee802154/nl-phy.c b/net/ieee802154/nl-phy.c
> index 1b9d25f6..ac3462a 100644
> --- a/net/ieee802154/nl-phy.c
> +++ b/net/ieee802154/nl-phy.c
> @@ -221,6 +221,7 @@ int ieee802154_add_iface(struct sk_buff *skb, struct genl_info *info)
>  	}
>  
>  	dev = rdev_add_virtual_intf_deprecated(wpan_phy_to_rdev(phy), devname,
> +					       NET_NAME_ENUM,
>  					       type);
>  	if (IS_ERR(dev)) {
>  		rc = PTR_ERR(dev);
> diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c
> index a4daf91..a7eb16d 100644
> --- a/net/ieee802154/nl802154.c
> +++ b/net/ieee802154/nl802154.c
> @@ -589,6 +589,7 @@ static int nl802154_new_interface(struct sk_buff *skb, struct genl_info *info)
>  
>  	return rdev_add_virtual_intf(rdev,
>  				     nla_data(info->attrs[NL802154_ATTR_IFNAME]),
> +				     NET_NAME_USER,
>  				     type, extended_addr);
>  }
>  
> diff --git a/net/ieee802154/rdev-ops.h b/net/ieee802154/rdev-ops.h
> index 7c46732..ced5ac3 100644
> --- a/net/ieee802154/rdev-ops.h
> +++ b/net/ieee802154/rdev-ops.h
> @@ -7,10 +7,12 @@
>  
>  static inline struct net_device *
>  rdev_add_virtual_intf_deprecated(struct cfg802154_registered_device *rdev,
> -				 const char *name, int type)
> +				 const char *name,
> +				 unsigned char name_assign_type,
> +				 int type)
>  {
>  	return rdev->ops->add_virtual_intf_deprecated(&rdev->wpan_phy, name,
> -						      type);
> +						      name_assign_type, type);
>  }
>  
>  static inline void
> @@ -22,9 +24,11 @@ rdev_del_virtual_intf_deprecated(struct cfg802154_registered_device *rdev,
>  
>  static inline int
>  rdev_add_virtual_intf(struct cfg802154_registered_device *rdev, char *name,
> +		      unsigned char name_assign_type,
>  		      enum nl802154_iftype type, __le64 extended_addr)
>  {
> -	return rdev->ops->add_virtual_intf(&rdev->wpan_phy, name, type,
> +	return rdev->ops->add_virtual_intf(&rdev->wpan_phy, name,
> +					   name_assign_type, type,
>  					   extended_addr);
>  }
>  
> diff --git a/net/mac802154/cfg.c b/net/mac802154/cfg.c
> index 5d9f68c..41a167b 100644
> --- a/net/mac802154/cfg.c
> +++ b/net/mac802154/cfg.c
> @@ -22,13 +22,14 @@
>  
>  static struct net_device *
>  ieee802154_add_iface_deprecated(struct wpan_phy *wpan_phy,
> -				const char *name, int type)
> +				const char *name,
> +				unsigned char name_assign_type, int type)
>  {
>  	struct ieee802154_local *local = wpan_phy_priv(wpan_phy);
>  	struct net_device *dev;
>  
>  	rtnl_lock();
> -	dev = ieee802154_if_add(local, name, type,
> +	dev = ieee802154_if_add(local, name, name_assign_type, type,
>  				cpu_to_le64(0x0000000000000000ULL));
>  	rtnl_unlock();
>  
> @@ -45,12 +46,14 @@ static void ieee802154_del_iface_deprecated(struct wpan_phy *wpan_phy,
>  
>  static int
>  ieee802154_add_iface(struct wpan_phy *phy, const char *name,
> +		     unsigned char name_assign_type,
>  		     enum nl802154_iftype type, __le64 extended_addr)
>  {
>  	struct ieee802154_local *local = wpan_phy_priv(phy);
>  	struct net_device *err;
>  
> -	err = ieee802154_if_add(local, name, type, extended_addr);
> +	err = ieee802154_if_add(local, name, name_assign_type,
> +				type, extended_addr);
>  	return PTR_ERR_OR_ZERO(err);
>  }
>  
> diff --git a/net/mac802154/ieee802154_i.h b/net/mac802154/ieee802154_i.h
> index bebd70f..35a5920 100644
> --- a/net/mac802154/ieee802154_i.h
> +++ b/net/mac802154/ieee802154_i.h
> @@ -182,6 +182,7 @@ void ieee802154_iface_exit(void);
>  void ieee802154_if_remove(struct ieee802154_sub_if_data *sdata);
>  struct net_device *
>  ieee802154_if_add(struct ieee802154_local *local, const char *name,
> +		  unsigned char name_assign_type,
>  		  enum nl802154_iftype type, __le64 extended_addr);
>  void ieee802154_remove_interfaces(struct ieee802154_local *local);
>  
> diff --git a/net/mac802154/iface.c b/net/mac802154/iface.c
> index 38b56f9..91b75ab 100644
> --- a/net/mac802154/iface.c
> +++ b/net/mac802154/iface.c
> @@ -522,7 +522,8 @@ ieee802154_setup_sdata(struct ieee802154_sub_if_data *sdata,
>  
>  struct net_device *
>  ieee802154_if_add(struct ieee802154_local *local, const char *name,
> -		  enum nl802154_iftype type, __le64 extended_addr)
> +		  unsigned char name_assign_type, enum nl802154_iftype type,
> +		  __le64 extended_addr)
>  {
>  	struct net_device *ndev = NULL;
>  	struct ieee802154_sub_if_data *sdata = NULL;
> @@ -531,7 +532,7 @@ ieee802154_if_add(struct ieee802154_local *local, const char *name,
>  	ASSERT_RTNL();
>  
>  	ndev = alloc_netdev(sizeof(*sdata) + local->hw.vif_data_size, name,
> -			    NET_NAME_UNKNOWN, ieee802154_if_setup);
> +			    name_assign_type, ieee802154_if_setup);
>  	if (!ndev)
>  		return ERR_PTR(-ENOMEM);
>  
> diff --git a/net/mac802154/main.c b/net/mac802154/main.c
> index 8500378..68b9667 100644
> --- a/net/mac802154/main.c
> +++ b/net/mac802154/main.c
> @@ -161,7 +161,8 @@ int ieee802154_register_hw(struct ieee802154_hw *hw)
>  
>  	rtnl_lock();
>  
> -	dev = ieee802154_if_add(local, "wpan%d", NL802154_IFTYPE_NODE,
> +	dev = ieee802154_if_add(local, "wpan%d", NET_NAME_ENUM,
> +				NL802154_IFTYPE_NODE,
>  				cpu_to_le64(0x0000000000000000ULL));
>  	if (IS_ERR(dev)) {
>  		rtnl_unlock();

Ping ..?

-- 
Varka Bhadram

--
To unsubscribe from this list: send the line "unsubscribe linux-wpan" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Linux Audio Users]     [Photo]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux