aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/wireless/iwmc3200wifi/cfg80211.c2
-rw-r--r--drivers/net/wireless/iwmc3200wifi/commands.c1
-rw-r--r--drivers/net/wireless/iwmc3200wifi/iwm.h2
-rw-r--r--drivers/net/wireless/iwmc3200wifi/rx.c26
4 files changed, 23 insertions, 8 deletions
diff --git a/drivers/net/wireless/iwmc3200wifi/cfg80211.c b/drivers/net/wireless/iwmc3200wifi/cfg80211.c
index 2784b089f491..a56a2b0ac99a 100644
--- a/drivers/net/wireless/iwmc3200wifi/cfg80211.c
+++ b/drivers/net/wireless/iwmc3200wifi/cfg80211.c
@@ -673,7 +673,7 @@ static int iwm_cfg80211_disconnect(struct wiphy *wiphy, struct net_device *dev,
673 IWM_DBG_WEXT(iwm, DBG, "Active: %d\n", iwm->umac_profile_active); 673 IWM_DBG_WEXT(iwm, DBG, "Active: %d\n", iwm->umac_profile_active);
674 674
675 if (iwm->umac_profile_active) 675 if (iwm->umac_profile_active)
676 return iwm_invalidate_mlme_profile(iwm); 676 iwm_invalidate_mlme_profile(iwm);
677 677
678 return 0; 678 return 0;
679} 679}
diff --git a/drivers/net/wireless/iwmc3200wifi/commands.c b/drivers/net/wireless/iwmc3200wifi/commands.c
index a68a2aff3c1e..23b52fa2605f 100644
--- a/drivers/net/wireless/iwmc3200wifi/commands.c
+++ b/drivers/net/wireless/iwmc3200wifi/commands.c
@@ -756,6 +756,7 @@ int iwm_send_mlme_profile(struct iwm_priv *iwm)
756 return ret; 756 return ret;
757 } 757 }
758 758
759 set_bit(IWM_STATUS_SME_CONNECTING, &iwm->status);
759 return 0; 760 return 0;
760} 761}
761 762
diff --git a/drivers/net/wireless/iwmc3200wifi/iwm.h b/drivers/net/wireless/iwmc3200wifi/iwm.h
index 7a51bc340fda..f054cc828d8d 100644
--- a/drivers/net/wireless/iwmc3200wifi/iwm.h
+++ b/drivers/net/wireless/iwmc3200wifi/iwm.h
@@ -175,7 +175,7 @@ struct iwm_key {
175#define IWM_STATUS_READY 0 175#define IWM_STATUS_READY 0
176#define IWM_STATUS_SCANNING 1 176#define IWM_STATUS_SCANNING 1
177#define IWM_STATUS_SCAN_ABORTING 2 177#define IWM_STATUS_SCAN_ABORTING 2
178#define IWM_STATUS_ASSOCIATING 3 178#define IWM_STATUS_SME_CONNECTING 3
179#define IWM_STATUS_ASSOCIATED 4 179#define IWM_STATUS_ASSOCIATED 4
180 180
181struct iwm_tx_queue { 181struct iwm_tx_queue {
diff --git a/drivers/net/wireless/iwmc3200wifi/rx.c b/drivers/net/wireless/iwmc3200wifi/rx.c
index 86079a187eef..9e6f2cd38d60 100644
--- a/drivers/net/wireless/iwmc3200wifi/rx.c
+++ b/drivers/net/wireless/iwmc3200wifi/rx.c
@@ -487,8 +487,6 @@ static int iwm_mlme_assoc_start(struct iwm_priv *iwm, u8 *buf,
487 487
488 start = (struct iwm_umac_notif_assoc_start *)buf; 488 start = (struct iwm_umac_notif_assoc_start *)buf;
489 489
490 set_bit(IWM_STATUS_ASSOCIATING, &iwm->status);
491
492 IWM_DBG_MLME(iwm, INFO, "Association with %pM Started, reason: %d\n", 490 IWM_DBG_MLME(iwm, INFO, "Association with %pM Started, reason: %d\n",
493 start->bssid, le32_to_cpu(start->roam_reason)); 491 start->bssid, le32_to_cpu(start->roam_reason));
494 492
@@ -507,14 +505,23 @@ static int iwm_mlme_assoc_complete(struct iwm_priv *iwm, u8 *buf,
507 IWM_DBG_MLME(iwm, INFO, "Association with %pM completed, status: %d\n", 505 IWM_DBG_MLME(iwm, INFO, "Association with %pM completed, status: %d\n",
508 complete->bssid, complete->status); 506 complete->bssid, complete->status);
509 507
510 clear_bit(IWM_STATUS_ASSOCIATING, &iwm->status);
511
512 switch (le32_to_cpu(complete->status)) { 508 switch (le32_to_cpu(complete->status)) {
513 case UMAC_ASSOC_COMPLETE_SUCCESS: 509 case UMAC_ASSOC_COMPLETE_SUCCESS:
514 set_bit(IWM_STATUS_ASSOCIATED, &iwm->status); 510 set_bit(IWM_STATUS_ASSOCIATED, &iwm->status);
515 memcpy(iwm->bssid, complete->bssid, ETH_ALEN); 511 memcpy(iwm->bssid, complete->bssid, ETH_ALEN);
516 iwm->channel = complete->channel; 512 iwm->channel = complete->channel;
517 513
514 /* Internal roaming state, avoid notifying SME. */
515 if (!test_and_clear_bit(IWM_STATUS_SME_CONNECTING, &iwm->status)
516 && iwm->conf.mode == UMAC_MODE_BSS) {
517 cfg80211_roamed(iwm_to_ndev(iwm),
518 complete->bssid,
519 iwm->req_ie, iwm->req_ie_len,
520 iwm->resp_ie, iwm->resp_ie_len,
521 GFP_KERNEL);
522 break;
523 }
524
518 iwm_link_on(iwm); 525 iwm_link_on(iwm);
519 526
520 if (iwm->conf.mode == UMAC_MODE_IBSS) 527 if (iwm->conf.mode == UMAC_MODE_IBSS)
@@ -531,6 +538,11 @@ static int iwm_mlme_assoc_complete(struct iwm_priv *iwm, u8 *buf,
531 memset(iwm->bssid, 0, ETH_ALEN); 538 memset(iwm->bssid, 0, ETH_ALEN);
532 iwm->channel = 0; 539 iwm->channel = 0;
533 540
541 /* Internal roaming state, avoid notifying SME. */
542 if (!test_and_clear_bit(IWM_STATUS_SME_CONNECTING, &iwm->status)
543 && iwm->conf.mode == UMAC_MODE_BSS)
544 break;
545
534 iwm_link_off(iwm); 546 iwm_link_off(iwm);
535 547
536 if (iwm->conf.mode == UMAC_MODE_IBSS) 548 if (iwm->conf.mode == UMAC_MODE_IBSS)
@@ -540,6 +552,7 @@ static int iwm_mlme_assoc_complete(struct iwm_priv *iwm, u8 *buf,
540 NULL, 0, NULL, 0, 552 NULL, 0, NULL, 0,
541 WLAN_STATUS_UNSPECIFIED_FAILURE, 553 WLAN_STATUS_UNSPECIFIED_FAILURE,
542 GFP_KERNEL); 554 GFP_KERNEL);
555 break;
543 default: 556 default:
544 break; 557 break;
545 } 558 }
@@ -562,7 +575,7 @@ static int iwm_mlme_profile_invalidate(struct iwm_priv *iwm, u8 *buf,
562 IWM_DBG_MLME(iwm, INFO, "Profile Invalidated. Reason: %d\n", 575 IWM_DBG_MLME(iwm, INFO, "Profile Invalidated. Reason: %d\n",
563 le32_to_cpu(invalid->reason)); 576 le32_to_cpu(invalid->reason));
564 577
565 clear_bit(IWM_STATUS_ASSOCIATING, &iwm->status); 578 clear_bit(IWM_STATUS_SME_CONNECTING, &iwm->status);
566 clear_bit(IWM_STATUS_ASSOCIATED, &iwm->status); 579 clear_bit(IWM_STATUS_ASSOCIATED, &iwm->status);
567 580
568 iwm->umac_profile_active = 0; 581 iwm->umac_profile_active = 0;
@@ -813,7 +826,8 @@ static int iwm_mlme_mgt_frame(struct iwm_priv *iwm, u8 *buf,
813 iwm->resp_ie = kmemdup(mgt->u.reassoc_resp.variable, 826 iwm->resp_ie = kmemdup(mgt->u.reassoc_resp.variable,
814 iwm->resp_ie_len, GFP_KERNEL); 827 iwm->resp_ie_len, GFP_KERNEL);
815 } else { 828 } else {
816 IWM_ERR(iwm, "Unsupported management frame"); 829 IWM_ERR(iwm, "Unsupported management frame: 0x%x",
830 cpu_to_le16(mgt->frame_control));
817 return 0; 831 return 0;
818 } 832 }
819 833