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;
>
>
prev parent 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).