[PATCH] libertas: scan behaviour consistency improvements

Dan Williams dcbw at redhat.com
Thu Sep 22 13:05:12 EDT 2011


On Wed, 2011-09-21 at 18:43 +0100, Daniel Drake wrote:
> When scanning for the broadcast SSID, there is no need to add the
> SSID TLV (restoring the behaviour of the driver behaviour in the wext
> days, confirmed in Marvell specifications).

I reviewed the specs for v9 and v10 and this is correct.

> If bssid is unspecified, the current scan code will usually fire off an
> active scan probing for the specific requested SSID. However, if a scan
> is ongoing (or has just finished), those scan results will be used
> instead (even if that scan is totally different, e.g. a passive scan on
> channel 4 for a different SSID). Fix this inconsistency by always
> firing off a scan when associating without a bssid.

> Signed-off-by: Daniel Drake <dsd at laptop.org>

Acked-by: Dan Williams <dcbw at redhat.com>

> ---
>  drivers/net/wireless/libertas/cfg.c |   33 +++++++++++++++++----------------
>  drivers/net/wireless/libertas/dev.h |    1 -
>  2 files changed, 17 insertions(+), 17 deletions(-)
> 
> diff --git a/drivers/net/wireless/libertas/cfg.c b/drivers/net/wireless/libertas/cfg.c
> index b456a53..93e5dea 100644
> --- a/drivers/net/wireless/libertas/cfg.c
> +++ b/drivers/net/wireless/libertas/cfg.c
> @@ -691,7 +691,7 @@ static void lbs_scan_worker(struct work_struct *work)
>  	tlv = scan_cmd->tlvbuffer;
>  
>  	/* add SSID TLV */
> -	if (priv->scan_req->n_ssids)
> +	if (priv->scan_req->n_ssids && priv->scan_req->ssids[0].ssid_len > 0)
>  		tlv += lbs_add_ssid_tlv(tlv,
>  					priv->scan_req->ssids[0].ssid,
>  					priv->scan_req->ssids[0].ssid_len);
> @@ -732,7 +732,6 @@ static void lbs_scan_worker(struct work_struct *work)
>  			cfg80211_scan_done(priv->scan_req, false);
>  
>  		priv->scan_req = NULL;
> -		priv->last_scan = jiffies;
>  	}
>  
>  	/* Restart network */
> @@ -1295,24 +1294,26 @@ static int lbs_cfg_connect(struct wiphy *wiphy, struct net_device *dev,
>  	lbs_deb_enter(LBS_DEB_CFG80211);
>  
>  	if (!sme->bssid) {
> -		/* Run a scan if one isn't in-progress already and if the last
> -		 * scan was done more than 2 seconds ago.
> -		 */
> -		if (priv->scan_req == NULL &&
> -		    time_after(jiffies, priv->last_scan + (2 * HZ))) {
> -			struct cfg80211_scan_request *creq;
> +		struct cfg80211_scan_request *creq;
>  
> -			creq = _new_connect_scan_req(wiphy, sme);
> -			if (!creq) {
> -				ret = -EINVAL;
> -				goto done;
> -			}
> +		/*
> +		 * Scan for the requested network after waiting for existing
> +		 * scans to finish.
> +		 */
> +		lbs_deb_assoc("assoc: waiting for existing scans\n");
> +		wait_event_interruptible_timeout(priv->scan_q,
> +						 (priv->scan_req == NULL),
> +						 (15 * HZ));
>  
> -			lbs_deb_assoc("assoc: scanning for compatible AP\n");
> -			_internal_start_scan(priv, true, creq);
> +		creq = _new_connect_scan_req(wiphy, sme);
> +		if (!creq) {
> +			ret = -EINVAL;
> +			goto done;
>  		}
>  
> -		/* Wait for any in-progress scan to complete */
> +		lbs_deb_assoc("assoc: scanning for compatible AP\n");
> +		_internal_start_scan(priv, true, creq);
> +
>  		lbs_deb_assoc("assoc: waiting for scan to complete\n");
>  		wait_event_interruptible_timeout(priv->scan_q,
>  						 (priv->scan_req == NULL),
> diff --git a/drivers/net/wireless/libertas/dev.h b/drivers/net/wireless/libertas/dev.h
> index adb3490..5ac4d17 100644
> --- a/drivers/net/wireless/libertas/dev.h
> +++ b/drivers/net/wireless/libertas/dev.h
> @@ -167,7 +167,6 @@ struct lbs_private {
>  	wait_queue_head_t scan_q;
>  	/* Whether the scan was initiated internally and not by cfg80211 */
>  	bool internal_scan;
> -	unsigned long last_scan;
>  };
>  
>  extern struct cmd_confirm_sleep confirm_sleep;





More information about the libertas-dev mailing list