linux-wireless.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Dan Williams <dcbw@redhat.com>
To: Michael Buesch <mb@bu3sch.de>
Cc: John W Linville <linville@tuxdriver.com>,
	linux-wireless@vger.kernel.org,
	Johannes Berg <johannes@sipsolutions.net>
Subject: Re: [PATCH] mac80211: Add software scan notifiers
Date: Fri, 20 Feb 2009 09:59:20 -0500	[thread overview]
Message-ID: <1235141960.10326.16.camel@localhost> (raw)
In-Reply-To: <200902201537.03643.mb@bu3sch.de>

On Fri, 2009-02-20 at 15:37 +0100, Michael Buesch wrote:
> This adds optional notifier functions for software scan.

Yay!  Another user of this :)  I had proposed something like this for
Marvell parts a while ago (which need commands sent to the MAC before
and after scan) but we ended up implementing it using flags from the
interface config handler.  So +1 from me.

Dan

> Signed-off-by: Michael Buesch <mb@bu3sch.de>
> 
> ---
> 
> John, please queue for the next feature release.
> 
> 
> Index: wireless-testing/include/net/mac80211.h
> ===================================================================
> --- wireless-testing.orig/include/net/mac80211.h	2009-02-19 22:20:25.000000000 +0100
> +++ wireless-testing/include/net/mac80211.h	2009-02-20 15:20:35.000000000 +0100
> @@ -1321,12 +1321,18 @@ enum ieee80211_ampdu_mlme_action {
>   *	configuration done by the regulatory agent in the wiphy's registered
>   *	bands. When the scan finishes, ieee80211_scan_completed() must be
>   *	called; note that it also must be called when the scan cannot finish
>   *	because the hardware is turned off! Anything else is a bug!
>   *	Returns a negative error code which will be seen in userspace.
>   *
> + * @sw_scan_start: Notifier function that is called just before a software scan
> + *	is started. Can be NULL, if the driver doesn't need this notification.
> + *
> + * @sw_scan_complete: Notifier function that is called just after a software scan
> + *	finished. Can be NULL, if the driver doesn't need this notification.
> + *
>   * @get_stats: Return low-level statistics.
>   * 	Returns zero if statistics are available.
>   *
>   * @get_tkip_seq: If your device implements TKIP encryption in hardware this
>   *	callback should be provided to read the TKIP transmit IVs (both IV32
>   *	and IV16) for the given key from hardware.
> @@ -1400,12 +1406,14 @@ struct ieee80211_ops {
>  		       struct ieee80211_key_conf *key);
>  	void (*update_tkip_key)(struct ieee80211_hw *hw,
>  			struct ieee80211_key_conf *conf, const u8 *address,
>  			u32 iv32, u16 *phase1key);
>  	int (*hw_scan)(struct ieee80211_hw *hw,
>  		       struct cfg80211_scan_request *req);
> +	void (*sw_scan_start)(struct ieee80211_hw *hw);
> +	void (*sw_scan_complete)(struct ieee80211_hw *hw);
>  	int (*get_stats)(struct ieee80211_hw *hw,
>  			 struct ieee80211_low_level_stats *stats);
>  	void (*get_tkip_seq)(struct ieee80211_hw *hw, u8 hw_key_idx,
>  			     u32 *iv32, u16 *iv16);
>  	int (*set_rts_threshold)(struct ieee80211_hw *hw, u32 value);
>  	void (*sta_notify)(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
> Index: wireless-testing/net/mac80211/scan.c
> ===================================================================
> --- wireless-testing.orig/net/mac80211/scan.c	2009-02-19 22:20:25.000000000 +0100
> +++ wireless-testing/net/mac80211/scan.c	2009-02-20 15:19:21.000000000 +0100
> @@ -242,12 +242,15 @@ void ieee80211_scan_completed(struct iee
>  				     local->mdev->mc_count,
>  				     local->mdev->mc_list);
>  
>  	netif_addr_unlock(local->mdev);
>  	netif_tx_unlock_bh(local->mdev);
>  
> +	if (local->ops->sw_scan_complete)
> +		local->ops->sw_scan_complete(local_to_hw(local));
> +
>  	mutex_lock(&local->iflist_mtx);
>  	list_for_each_entry(sdata, &local->interfaces, list) {
>  		if (!netif_running(sdata->dev))
>  			continue;
>  
>  		/* Tell AP we're back */
> @@ -392,12 +395,14 @@ int ieee80211_start_scan(struct ieee8021
>  		}
>  		local->scan_sdata = scan_sdata;
>  		return 0;
>  	}
>  
>  	local->sw_scanning = true;
> +	if (local->ops->sw_scan_start)
> +		local->ops->sw_scan_start(local_to_hw(local));
>  
>  	mutex_lock(&local->iflist_mtx);
>  	list_for_each_entry(sdata, &local->interfaces, list) {
>  		if (!netif_running(sdata->dev))
>  			continue;
>  
> 


      reply	other threads:[~2009-02-20 15:01 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-02-20 14:37 [PATCH] mac80211: Add software scan notifiers Michael Buesch
2009-02-20 14:59 ` Dan Williams [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1235141960.10326.16.camel@localhost \
    --to=dcbw@redhat.com \
    --cc=johannes@sipsolutions.net \
    --cc=linux-wireless@vger.kernel.org \
    --cc=linville@tuxdriver.com \
    --cc=mb@bu3sch.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).