|
@@ -4566,7 +4566,6 @@ il_mac_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
|
|
|
struct il_priv *il = hw->priv;
|
|
|
struct il_vif_priv *vif_priv = (void *)vif->drv_priv;
|
|
|
int err;
|
|
|
- u32 modes;
|
|
|
|
|
|
D_MAC80211("enter: type %d, addr %pM\n", vif->type, vif->addr);
|
|
|
|
|
@@ -4578,15 +4577,7 @@ il_mac_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
|
|
|
goto out;
|
|
|
}
|
|
|
|
|
|
- /* check if busy context is exclusive */
|
|
|
- if (il->ctx.vif &&
|
|
|
- (il->ctx.exclusive_interface_modes & BIT(il->ctx.vif->type))) {
|
|
|
- err = -EINVAL;
|
|
|
- goto out;
|
|
|
- }
|
|
|
-
|
|
|
- modes = il->ctx.interface_modes | il->ctx.exclusive_interface_modes;
|
|
|
- if (!(modes & BIT(vif->type))) {
|
|
|
+ if (il->ctx.vif) {
|
|
|
err = -EOPNOTSUPP;
|
|
|
goto out;
|
|
|
}
|
|
@@ -4979,10 +4970,10 @@ il_mac_change_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
|
|
{
|
|
|
struct il_priv *il = hw->priv;
|
|
|
struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif);
|
|
|
- u32 modes;
|
|
|
int err;
|
|
|
|
|
|
- newtype = ieee80211_iftype_p2p(newtype, newp2p);
|
|
|
+ if (newp2p)
|
|
|
+ return -EOPNOTSUPP;
|
|
|
|
|
|
mutex_lock(&il->mutex);
|
|
|
|
|
@@ -4995,22 +4986,10 @@ il_mac_change_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
|
|
goto out;
|
|
|
}
|
|
|
|
|
|
- modes = ctx->interface_modes | ctx->exclusive_interface_modes;
|
|
|
- if (!(modes & BIT(newtype))) {
|
|
|
- err = -EOPNOTSUPP;
|
|
|
- goto out;
|
|
|
- }
|
|
|
-
|
|
|
- if ((il->ctx.exclusive_interface_modes & BIT(il->ctx.vif->type)) ||
|
|
|
- (il->ctx.exclusive_interface_modes & BIT(newtype))) {
|
|
|
- err = -EINVAL;
|
|
|
- goto out;
|
|
|
- }
|
|
|
-
|
|
|
/* success */
|
|
|
il_teardown_interface(il, vif, true);
|
|
|
vif->type = newtype;
|
|
|
- vif->p2p = newp2p;
|
|
|
+ vif->p2p = false;
|
|
|
err = il_setup_interface(il, ctx);
|
|
|
WARN_ON(err);
|
|
|
/*
|