diff options
author | Johannes Berg <johannes@sipsolutions.net> | 2008-02-19 19:36:16 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2008-02-29 15:37:26 -0500 |
commit | d2259243a19894eee06c16e278adfea81dc42bd9 (patch) | |
tree | 0e9b2c27151c6d67f789f71b7bef0bfceafb2a95 /net/mac80211/rx.c | |
parent | 013b73faff107e56cbe75fe4b881f5d80a8cf022 (diff) |
mac80211: invoke set_tim() callback after setting own TIM info
Drivers should be allowed to simply get a complete new beacon when
set_tim() is invoked (and set_tim() is required for drivers that
just want a beacon template!), so we need to update our own TIM
bitmap before calling set_tim() so that getting the beacon will
now get an already updated beacon.
Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211/rx.c')
-rw-r--r-- | net/mac80211/rx.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c index c4b7cc07315d..af606f715016 100644 --- a/net/mac80211/rx.c +++ b/net/mac80211/rx.c | |||
@@ -600,10 +600,10 @@ static int ap_sta_ps_end(struct net_device *dev, struct sta_info *sta) | |||
600 | atomic_dec(&sdata->bss->num_sta_ps); | 600 | atomic_dec(&sdata->bss->num_sta_ps); |
601 | sta->flags &= ~(WLAN_STA_PS | WLAN_STA_TIM | WLAN_STA_PSPOLL); | 601 | sta->flags &= ~(WLAN_STA_PS | WLAN_STA_TIM | WLAN_STA_PSPOLL); |
602 | if (!skb_queue_empty(&sta->ps_tx_buf)) { | 602 | if (!skb_queue_empty(&sta->ps_tx_buf)) { |
603 | if (local->ops->set_tim) | ||
604 | local->ops->set_tim(local_to_hw(local), sta->aid, 0); | ||
605 | if (sdata->bss) | 603 | if (sdata->bss) |
606 | bss_tim_clear(local, sdata->bss, sta->aid); | 604 | bss_tim_clear(local, sdata->bss, sta->aid); |
605 | if (local->ops->set_tim) | ||
606 | local->ops->set_tim(local_to_hw(local), sta->aid, 0); | ||
607 | } | 607 | } |
608 | #ifdef CONFIG_MAC80211_VERBOSE_PS_DEBUG | 608 | #ifdef CONFIG_MAC80211_VERBOSE_PS_DEBUG |
609 | printk(KERN_DEBUG "%s: STA %s aid %d exits power save mode\n", | 609 | printk(KERN_DEBUG "%s: STA %s aid %d exits power save mode\n", |
@@ -947,11 +947,11 @@ ieee80211_rx_h_ps_poll(struct ieee80211_txrx_data *rx) | |||
947 | dev_queue_xmit(skb); | 947 | dev_queue_xmit(skb); |
948 | 948 | ||
949 | if (no_pending_pkts) { | 949 | if (no_pending_pkts) { |
950 | if (rx->sdata->bss) | ||
951 | bss_tim_clear(rx->local, rx->sdata->bss, rx->sta->aid); | ||
950 | if (rx->local->ops->set_tim) | 952 | if (rx->local->ops->set_tim) |
951 | rx->local->ops->set_tim(local_to_hw(rx->local), | 953 | rx->local->ops->set_tim(local_to_hw(rx->local), |
952 | rx->sta->aid, 0); | 954 | rx->sta->aid, 0); |
953 | if (rx->sdata->bss) | ||
954 | bss_tim_clear(rx->local, rx->sdata->bss, rx->sta->aid); | ||
955 | } | 955 | } |
956 | #ifdef CONFIG_MAC80211_VERBOSE_PS_DEBUG | 956 | #ifdef CONFIG_MAC80211_VERBOSE_PS_DEBUG |
957 | } else if (!rx->u.rx.sent_ps_buffered) { | 957 | } else if (!rx->u.rx.sent_ps_buffered) { |