iwlagn: remove iw_mode check for beacon
Since we have the beacon context now, we no longer need to rely on iw_mode but can check the beacon context interface's type. However, that check must be in the work item instead due to locking constraints (mutex must be held when dereferencing beacon_ctx pointer). Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com>
This commit is contained in:
parent
ece9c4ee5e
commit
60744f6297
|
@ -613,6 +613,16 @@ static void iwl_bg_beacon_update(struct work_struct *work)
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (priv->beacon_ctx->vif->type != NL80211_IFTYPE_AP) {
|
||||||
|
/*
|
||||||
|
* The ucode will send beacon notifications even in
|
||||||
|
* IBSS mode, but we don't want to process them. But
|
||||||
|
* we need to defer the type check to here due to
|
||||||
|
* requiring locking around the beacon_ctx access.
|
||||||
|
*/
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
/* Pull updated AP beacon from mac80211. will fail if not in AP mode */
|
/* Pull updated AP beacon from mac80211. will fail if not in AP mode */
|
||||||
beacon = ieee80211_beacon_get(priv->hw, priv->beacon_ctx->vif);
|
beacon = ieee80211_beacon_get(priv->hw, priv->beacon_ctx->vif);
|
||||||
if (!beacon) {
|
if (!beacon) {
|
||||||
|
@ -846,8 +856,7 @@ static void iwl_rx_beacon_notif(struct iwl_priv *priv,
|
||||||
|
|
||||||
priv->ibss_manager = le32_to_cpu(beacon->ibss_mgr_status);
|
priv->ibss_manager = le32_to_cpu(beacon->ibss_mgr_status);
|
||||||
|
|
||||||
if ((priv->iw_mode == NL80211_IFTYPE_AP) &&
|
if (!test_bit(STATUS_EXIT_PENDING, &priv->status))
|
||||||
(!test_bit(STATUS_EXIT_PENDING, &priv->status)))
|
|
||||||
queue_work(priv->workqueue, &priv->beacon_update);
|
queue_work(priv->workqueue, &priv->beacon_update);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue