Commit e666619e authored by James Ketrenos's avatar James Ketrenos

Modified ipw_config and STATUS_INIT setting to correct race condition

with request_scan being called before initialized if invoked from
insmod, resulting in no association occurring during boot until iwlist
scan is run.
Signed-off-by: default avatarJames Ketrenos <jketreno@linux.intel.com>
parent 6de9f7f2
...@@ -10465,9 +10465,17 @@ static int ipw_config(struct ipw_priv *priv) ...@@ -10465,9 +10465,17 @@ static int ipw_config(struct ipw_priv *priv)
if (ipw_send_host_complete(priv)) if (ipw_send_host_complete(priv))
goto error; goto error;
/* If configured to try and auto-associate, kick off a scan */ priv->status |= STATUS_INIT;
if (priv->config & CFG_ASSOCIATE)
queue_work(priv->workqueue, &priv->request_scan); ipw_led_init(priv);
ipw_led_radio_on(priv);
priv->notif_missed_beacons = 0;
/* Set hardware WEP key if it is configured. */
if ((priv->capability & CAP_PRIVACY_ON) &&
(priv->ieee->sec.level == SEC_LEVEL_1) &&
!(priv->ieee->host_encrypt || priv->ieee->host_decrypt))
ipw_set_hwcrypto_keys(priv);
return 0; return 0;
...@@ -10773,17 +10781,10 @@ static int ipw_up(struct ipw_priv *priv) ...@@ -10773,17 +10781,10 @@ static int ipw_up(struct ipw_priv *priv)
rc = ipw_config(priv); rc = ipw_config(priv);
if (!rc) { if (!rc) {
IPW_DEBUG_INFO("Configured device on count %i\n", i); IPW_DEBUG_INFO("Configured device on count %i\n", i);
ipw_led_init(priv);
ipw_led_radio_on(priv);
priv->notif_missed_beacons = 0;
priv->status |= STATUS_INIT;
/* Set hardware WEP key if it is configured. */ /* If configure to try and auto-associate, kick
if ((priv->capability & CAP_PRIVACY_ON) && * off a scan. */
(priv->ieee->sec.level == SEC_LEVEL_1) && queue_work(priv->workqueue, &priv->request_scan);
!(priv->ieee->host_encrypt ||
priv->ieee->host_decrypt))
ipw_set_hwcrypto_keys(priv);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment