mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-09-26 12:26:11 +00:00
mwifiex: Use helper function for counting interface types
Use a small helper function to increment and decrement the counter of the interface types we currently manage. This makes the code that actually changes and sets up the interface type a bit less messy and also helps avoiding mistakes in case someone increments/decrements a counter wrongly. Signed-off-by: Jonas Dreßler <verdre@v0yd.nl> Signed-off-by: Kalle Valo <kvalo@codeaurora.org> Link: https://lore.kernel.org/r/20210914195909.36035-5-verdre@v0yd.nl
This commit is contained in:
parent
c2e9666cdf
commit
54350dac4e
1 changed files with 35 additions and 75 deletions
|
@ -1009,6 +1009,32 @@ is_vif_type_change_allowed(struct mwifiex_adapter *adapter,
|
|||
return false;
|
||||
}
|
||||
|
||||
static void
|
||||
update_vif_type_counter(struct mwifiex_adapter *adapter,
|
||||
enum nl80211_iftype iftype,
|
||||
int change)
|
||||
{
|
||||
switch (iftype) {
|
||||
case NL80211_IFTYPE_UNSPECIFIED:
|
||||
case NL80211_IFTYPE_ADHOC:
|
||||
case NL80211_IFTYPE_STATION:
|
||||
adapter->curr_iface_comb.sta_intf += change;
|
||||
break;
|
||||
case NL80211_IFTYPE_AP:
|
||||
adapter->curr_iface_comb.uap_intf += change;
|
||||
break;
|
||||
case NL80211_IFTYPE_P2P_CLIENT:
|
||||
case NL80211_IFTYPE_P2P_GO:
|
||||
adapter->curr_iface_comb.p2p_intf += change;
|
||||
break;
|
||||
default:
|
||||
mwifiex_dbg(adapter, ERROR,
|
||||
"%s: Unsupported iftype passed: %d\n",
|
||||
__func__, iftype);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static int
|
||||
mwifiex_change_vif_to_p2p(struct net_device *dev,
|
||||
enum nl80211_iftype curr_iftype,
|
||||
|
@ -1056,19 +1082,8 @@ mwifiex_change_vif_to_p2p(struct net_device *dev,
|
|||
if (mwifiex_sta_init_cmd(priv, false, false))
|
||||
return -1;
|
||||
|
||||
switch (curr_iftype) {
|
||||
case NL80211_IFTYPE_STATION:
|
||||
case NL80211_IFTYPE_ADHOC:
|
||||
adapter->curr_iface_comb.sta_intf--;
|
||||
break;
|
||||
case NL80211_IFTYPE_AP:
|
||||
adapter->curr_iface_comb.uap_intf--;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
adapter->curr_iface_comb.p2p_intf++;
|
||||
update_vif_type_counter(adapter, curr_iftype, -1);
|
||||
update_vif_type_counter(adapter, type, +1);
|
||||
dev->ieee80211_ptr->iftype = type;
|
||||
|
||||
return 0;
|
||||
|
@ -1107,20 +1122,10 @@ mwifiex_change_vif_to_sta_adhoc(struct net_device *dev,
|
|||
if (mwifiex_sta_init_cmd(priv, false, false))
|
||||
return -1;
|
||||
|
||||
switch (curr_iftype) {
|
||||
case NL80211_IFTYPE_P2P_CLIENT:
|
||||
case NL80211_IFTYPE_P2P_GO:
|
||||
adapter->curr_iface_comb.p2p_intf--;
|
||||
break;
|
||||
case NL80211_IFTYPE_AP:
|
||||
adapter->curr_iface_comb.uap_intf--;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
adapter->curr_iface_comb.sta_intf++;
|
||||
update_vif_type_counter(adapter, curr_iftype, -1);
|
||||
update_vif_type_counter(adapter, type, +1);
|
||||
dev->ieee80211_ptr->iftype = type;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -1153,20 +1158,8 @@ mwifiex_change_vif_to_ap(struct net_device *dev,
|
|||
if (mwifiex_sta_init_cmd(priv, false, false))
|
||||
return -1;
|
||||
|
||||
switch (curr_iftype) {
|
||||
case NL80211_IFTYPE_P2P_CLIENT:
|
||||
case NL80211_IFTYPE_P2P_GO:
|
||||
adapter->curr_iface_comb.p2p_intf--;
|
||||
break;
|
||||
case NL80211_IFTYPE_STATION:
|
||||
case NL80211_IFTYPE_ADHOC:
|
||||
adapter->curr_iface_comb.sta_intf--;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
adapter->curr_iface_comb.uap_intf++;
|
||||
update_vif_type_counter(adapter, curr_iftype, -1);
|
||||
update_vif_type_counter(adapter, type, +1);
|
||||
dev->ieee80211_ptr->iftype = type;
|
||||
return 0;
|
||||
}
|
||||
|
@ -3128,23 +3121,7 @@ struct wireless_dev *mwifiex_add_virtual_intf(struct wiphy *wiphy,
|
|||
mwifiex_dev_debugfs_init(priv);
|
||||
#endif
|
||||
|
||||
switch (type) {
|
||||
case NL80211_IFTYPE_UNSPECIFIED:
|
||||
case NL80211_IFTYPE_STATION:
|
||||
case NL80211_IFTYPE_ADHOC:
|
||||
adapter->curr_iface_comb.sta_intf++;
|
||||
break;
|
||||
case NL80211_IFTYPE_AP:
|
||||
adapter->curr_iface_comb.uap_intf++;
|
||||
break;
|
||||
case NL80211_IFTYPE_P2P_CLIENT:
|
||||
adapter->curr_iface_comb.p2p_intf++;
|
||||
break;
|
||||
default:
|
||||
/* This should be dead code; checked above */
|
||||
mwifiex_dbg(adapter, ERROR, "type not supported\n");
|
||||
return ERR_PTR(-EINVAL);
|
||||
}
|
||||
update_vif_type_counter(adapter, type, +1);
|
||||
|
||||
return &priv->wdev;
|
||||
|
||||
|
@ -3210,24 +3187,7 @@ int mwifiex_del_virtual_intf(struct wiphy *wiphy, struct wireless_dev *wdev)
|
|||
/* Clear the priv in adapter */
|
||||
priv->netdev = NULL;
|
||||
|
||||
switch (priv->bss_mode) {
|
||||
case NL80211_IFTYPE_UNSPECIFIED:
|
||||
case NL80211_IFTYPE_STATION:
|
||||
case NL80211_IFTYPE_ADHOC:
|
||||
adapter->curr_iface_comb.sta_intf--;
|
||||
break;
|
||||
case NL80211_IFTYPE_AP:
|
||||
adapter->curr_iface_comb.uap_intf--;
|
||||
break;
|
||||
case NL80211_IFTYPE_P2P_CLIENT:
|
||||
case NL80211_IFTYPE_P2P_GO:
|
||||
adapter->curr_iface_comb.p2p_intf--;
|
||||
break;
|
||||
default:
|
||||
mwifiex_dbg(adapter, ERROR,
|
||||
"del_virtual_intf: type not supported\n");
|
||||
break;
|
||||
}
|
||||
update_vif_type_counter(adapter, priv->bss_mode, -1);
|
||||
|
||||
priv->bss_mode = NL80211_IFTYPE_UNSPECIFIED;
|
||||
|
||||
|
|
Loading…
Reference in a new issue