aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHong Liu <hong.liu@intel.com>2005-09-14 22:04:15 -0400
committerJames Ketrenos <jketreno@linux.intel.com>2005-11-07 18:51:47 -0500
commite63247269de722c3e753991025fb7f15c6aba9aa (patch)
tree905710c6c5ad75b90dbb11da009dd064b705c03a
parentf4ff497d45c7071166277a39590cc59b50dc893c (diff)
Fixes WEP firmware error condition.
The problem is caused by the patch in bug455 -- Channel change flood generates fatal error. The patch set the DISASSOCIATING status bit after sending the command. The process was scheduled out when waiting for the command to be sent to the card. The disassociated notification clears the DISASSOCIATING bit in the tasklet before the process set the bit. Move the bit setting code before sending the command now. Signed-off-by: Hong Liu <hong.liu@intel.com> Signed-off-by: James Ketrenos <jketreno@linux.intel.com>
-rw-r--r--drivers/net/wireless/ipw2200.c31
1 files changed, 13 insertions, 18 deletions
diff --git a/drivers/net/wireless/ipw2200.c b/drivers/net/wireless/ipw2200.c
index 549f582551e5..a7630920ace8 100644
--- a/drivers/net/wireless/ipw2200.c
+++ b/drivers/net/wireless/ipw2200.c
@@ -1882,18 +1882,6 @@ static int ipw_send_cmd(struct ipw_priv *priv, struct host_cmd *cmd)
1882 return -EAGAIN; 1882 return -EAGAIN;
1883 } 1883 }
1884 1884
1885 if (priv->status & STATUS_ASSOCIATING) {
1886 IPW_DEBUG_HC("abandon a command while associating\n");
1887 spin_unlock_irqrestore(&priv->lock, flags);
1888 return -1;
1889 }
1890
1891 if (priv->status & STATUS_DISASSOCIATING) {
1892 IPW_DEBUG_HC("abandon a command while disassociating\n");
1893 spin_unlock_irqrestore(&priv->lock, flags);
1894 return -1;
1895 }
1896
1897 priv->status |= STATUS_HCMD_ACTIVE; 1885 priv->status |= STATUS_HCMD_ACTIVE;
1898 1886
1899 if (priv->cmdlog) { 1887 if (priv->cmdlog) {
@@ -3697,10 +3685,14 @@ static void ipw_send_disassociate(struct ipw_priv *priv, int quiet)
3697 MAC_ARG(priv->assoc_request.bssid), 3685 MAC_ARG(priv->assoc_request.bssid),
3698 priv->assoc_request.channel); 3686 priv->assoc_request.channel);
3699 3687
3688 priv->status &= ~(STATUS_ASSOCIATING | STATUS_ASSOCIATED);
3689 priv->status |= STATUS_DISASSOCIATING;
3690
3700 if (quiet) 3691 if (quiet)
3701 priv->assoc_request.assoc_type = HC_DISASSOC_QUIET; 3692 priv->assoc_request.assoc_type = HC_DISASSOC_QUIET;
3702 else 3693 else
3703 priv->assoc_request.assoc_type = HC_DISASSOCIATE; 3694 priv->assoc_request.assoc_type = HC_DISASSOCIATE;
3695
3704 err = ipw_send_associate(priv, &priv->assoc_request); 3696 err = ipw_send_associate(priv, &priv->assoc_request);
3705 if (err) { 3697 if (err) {
3706 IPW_DEBUG_HC("Attempt to send [dis]associate command " 3698 IPW_DEBUG_HC("Attempt to send [dis]associate command "
@@ -3708,9 +3700,6 @@ static void ipw_send_disassociate(struct ipw_priv *priv, int quiet)
3708 return; 3700 return;
3709 } 3701 }
3710 3702
3711 priv->status &= ~(STATUS_ASSOCIATING | STATUS_ASSOCIATED);
3712 priv->status |= STATUS_DISASSOCIATING;
3713
3714} 3703}
3715 3704
3716static int ipw_disassociate(void *data) 3705static int ipw_disassociate(void *data)
@@ -7672,6 +7661,8 @@ static int ipw_associate_network(struct ipw_priv *priv,
7672 */ 7661 */
7673 priv->channel = network->channel; 7662 priv->channel = network->channel;
7674 memcpy(priv->bssid, network->bssid, ETH_ALEN); 7663 memcpy(priv->bssid, network->bssid, ETH_ALEN);
7664 priv->status |= STATUS_ASSOCIATING;
7665 priv->status &= ~STATUS_SECURITY_UPDATED;
7675 7666
7676 priv->assoc_network = network; 7667 priv->assoc_network = network;
7677 7668
@@ -7685,9 +7676,6 @@ static int ipw_associate_network(struct ipw_priv *priv,
7685 return err; 7676 return err;
7686 } 7677 }
7687 7678
7688 priv->status |= STATUS_ASSOCIATING;
7689 priv->status &= ~STATUS_SECURITY_UPDATED;
7690
7691 IPW_DEBUG(IPW_DL_STATE, "associating: '%s' " MAC_FMT " \n", 7679 IPW_DEBUG(IPW_DL_STATE, "associating: '%s' " MAC_FMT " \n",
7692 escape_essid(priv->essid, priv->essid_len), 7680 escape_essid(priv->essid, priv->essid_len),
7693 MAC_ARG(priv->bssid)); 7681 MAC_ARG(priv->bssid));
@@ -7791,6 +7779,13 @@ static int ipw_associate(void *data)
7791 return 0; 7779 return 0;
7792 } 7780 }
7793 7781
7782 if (priv->status & STATUS_DISASSOCIATING) {
7783 IPW_DEBUG_ASSOC("Not attempting association (in "
7784 "disassociating)\n ");
7785 queue_work(priv->workqueue, &priv->associate);
7786 return 0;
7787 }
7788
7794 if (!ipw_is_init(priv) || (priv->status & STATUS_SCANNING)) { 7789 if (!ipw_is_init(priv) || (priv->status & STATUS_SCANNING)) {
7795 IPW_DEBUG_ASSOC("Not attempting association (scanning or not " 7790 IPW_DEBUG_ASSOC("Not attempting association (scanning or not "
7796 "initialized)\n"); 7791 "initialized)\n");