ath9k_htc: Maintain individual counters for interfaces
This is required for allowing only one IBSS interface to be configured. Signed-off-by: Sujith Manoharan <Sujith.Manoharan@atheros.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
committed by
John W. Linville
parent
87df89579a
commit
0df8359a88
@@ -206,6 +206,32 @@ struct ath9k_htc_target_stats {
|
|||||||
|
|
||||||
#define ATH9K_HTC_MAX_VIF 2
|
#define ATH9K_HTC_MAX_VIF 2
|
||||||
|
|
||||||
|
#define INC_VIF(_priv, _type) do { \
|
||||||
|
switch (_type) { \
|
||||||
|
case NL80211_IFTYPE_STATION: \
|
||||||
|
_priv->num_sta_vif++; \
|
||||||
|
break; \
|
||||||
|
case NL80211_IFTYPE_ADHOC: \
|
||||||
|
_priv->num_ibss_vif++; \
|
||||||
|
break; \
|
||||||
|
default: \
|
||||||
|
break; \
|
||||||
|
} \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
#define DEC_VIF(_priv, _type) do { \
|
||||||
|
switch (_type) { \
|
||||||
|
case NL80211_IFTYPE_STATION: \
|
||||||
|
_priv->num_sta_vif--; \
|
||||||
|
break; \
|
||||||
|
case NL80211_IFTYPE_ADHOC: \
|
||||||
|
_priv->num_ibss_vif--; \
|
||||||
|
break; \
|
||||||
|
default: \
|
||||||
|
break; \
|
||||||
|
} \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
struct ath9k_htc_vif {
|
struct ath9k_htc_vif {
|
||||||
u8 index;
|
u8 index;
|
||||||
u16 seq_no;
|
u16 seq_no;
|
||||||
@@ -367,6 +393,8 @@ struct ath9k_htc_priv {
|
|||||||
u8 mon_vif_idx;
|
u8 mon_vif_idx;
|
||||||
u8 sta_slot;
|
u8 sta_slot;
|
||||||
u8 vif_sta_pos[ATH9K_HTC_MAX_VIF];
|
u8 vif_sta_pos[ATH9K_HTC_MAX_VIF];
|
||||||
|
u8 num_ibss_vif;
|
||||||
|
u8 num_sta_vif;
|
||||||
|
|
||||||
u16 op_flags;
|
u16 op_flags;
|
||||||
u16 curtxpow;
|
u16 curtxpow;
|
||||||
|
@@ -1193,9 +1193,15 @@ static int ath9k_htc_add_interface(struct ieee80211_hw *hw,
|
|||||||
mutex_lock(&priv->mutex);
|
mutex_lock(&priv->mutex);
|
||||||
|
|
||||||
if (priv->nvifs >= ATH9K_HTC_MAX_VIF) {
|
if (priv->nvifs >= ATH9K_HTC_MAX_VIF) {
|
||||||
ret = -ENOBUFS;
|
|
||||||
mutex_unlock(&priv->mutex);
|
mutex_unlock(&priv->mutex);
|
||||||
return ret;
|
return -ENOBUFS;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (priv->num_ibss_vif ||
|
||||||
|
(priv->nvifs && vif->type == NL80211_IFTYPE_ADHOC)) {
|
||||||
|
ath_err(common, "IBSS coexistence with other modes is not allowed\n");
|
||||||
|
mutex_unlock(&priv->mutex);
|
||||||
|
return -ENOBUFS;
|
||||||
}
|
}
|
||||||
|
|
||||||
ath9k_htc_ps_wakeup(priv);
|
ath9k_htc_ps_wakeup(priv);
|
||||||
@@ -1240,6 +1246,8 @@ static int ath9k_htc_add_interface(struct ieee80211_hw *hw,
|
|||||||
priv->nvifs++;
|
priv->nvifs++;
|
||||||
priv->vif = vif;
|
priv->vif = vif;
|
||||||
|
|
||||||
|
INC_VIF(priv, vif->type);
|
||||||
|
|
||||||
ath_dbg(common, ATH_DBG_CONFIG,
|
ath_dbg(common, ATH_DBG_CONFIG,
|
||||||
"Attach a VIF of type: %d at idx: %d\n", vif->type, avp->index);
|
"Attach a VIF of type: %d at idx: %d\n", vif->type, avp->index);
|
||||||
|
|
||||||
@@ -1273,6 +1281,8 @@ static void ath9k_htc_remove_interface(struct ieee80211_hw *hw,
|
|||||||
ath9k_htc_remove_station(priv, vif, NULL);
|
ath9k_htc_remove_station(priv, vif, NULL);
|
||||||
priv->vif = NULL;
|
priv->vif = NULL;
|
||||||
|
|
||||||
|
DEC_VIF(priv, vif->type);
|
||||||
|
|
||||||
ath_dbg(common, ATH_DBG_CONFIG, "Detach Interface at idx: %d\n", avp->index);
|
ath_dbg(common, ATH_DBG_CONFIG, "Detach Interface at idx: %d\n", avp->index);
|
||||||
|
|
||||||
ath9k_htc_ps_restore(priv);
|
ath9k_htc_ps_restore(priv);
|
||||||
|
Reference in New Issue
Block a user