diff options
author | Johannes Berg <johannes@sipsolutions.net> | 2008-02-19 05:31:14 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2008-02-29 15:37:13 -0500 |
commit | 4a9a66e9a87a8346129d557c7ec2303173318012 (patch) | |
tree | e89092e2188f9d9b479aa8f13a38fdcb2ea3e163 /net/mac80211/rx.c | |
parent | d007b7f42e2a3a2b95ef43e8cc1a3dfe66b19736 (diff) |
mac80211: convert sta_info.pspoll to a flag
This doesn't really need to be a full int variable since it's
just a flag to indicate a PS-poll is in progress.
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 | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c index 279ee493520d..c4b7cc07315d 100644 --- a/net/mac80211/rx.c +++ b/net/mac80211/rx.c | |||
@@ -579,7 +579,7 @@ static void ap_sta_ps_start(struct net_device *dev, struct sta_info *sta) | |||
579 | if (sdata->bss) | 579 | if (sdata->bss) |
580 | atomic_inc(&sdata->bss->num_sta_ps); | 580 | atomic_inc(&sdata->bss->num_sta_ps); |
581 | sta->flags |= WLAN_STA_PS; | 581 | sta->flags |= WLAN_STA_PS; |
582 | sta->pspoll = 0; | 582 | sta->flags &= ~WLAN_STA_PSPOLL; |
583 | #ifdef CONFIG_MAC80211_VERBOSE_PS_DEBUG | 583 | #ifdef CONFIG_MAC80211_VERBOSE_PS_DEBUG |
584 | printk(KERN_DEBUG "%s: STA %s aid %d enters power save mode\n", | 584 | printk(KERN_DEBUG "%s: STA %s aid %d enters power save mode\n", |
585 | dev->name, print_mac(mac, sta->addr), sta->aid); | 585 | dev->name, print_mac(mac, sta->addr), sta->aid); |
@@ -598,8 +598,7 @@ static int ap_sta_ps_end(struct net_device *dev, struct sta_info *sta) | |||
598 | sdata = IEEE80211_DEV_TO_SUB_IF(sta->dev); | 598 | sdata = IEEE80211_DEV_TO_SUB_IF(sta->dev); |
599 | if (sdata->bss) | 599 | if (sdata->bss) |
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); | 601 | sta->flags &= ~(WLAN_STA_PS | WLAN_STA_TIM | WLAN_STA_PSPOLL); |
602 | sta->pspoll = 0; | ||
603 | if (!skb_queue_empty(&sta->ps_tx_buf)) { | 602 | if (!skb_queue_empty(&sta->ps_tx_buf)) { |
604 | if (local->ops->set_tim) | 603 | if (local->ops->set_tim) |
605 | local->ops->set_tim(local_to_hw(local), sta->aid, 0); | 604 | local->ops->set_tim(local_to_hw(local), sta->aid, 0); |
@@ -925,9 +924,11 @@ ieee80211_rx_h_ps_poll(struct ieee80211_txrx_data *rx) | |||
925 | struct ieee80211_hdr *hdr = | 924 | struct ieee80211_hdr *hdr = |
926 | (struct ieee80211_hdr *) skb->data; | 925 | (struct ieee80211_hdr *) skb->data; |
927 | 926 | ||
928 | /* tell TX path to send one frame even though the STA may | 927 | /* |
929 | * still remain is PS mode after this frame exchange */ | 928 | * Tell TX path to send one frame even though the STA may |
930 | rx->sta->pspoll = 1; | 929 | * still remain is PS mode after this frame exchange. |
930 | */ | ||
931 | rx->sta->flags |= WLAN_STA_PSPOLL; | ||
931 | 932 | ||
932 | #ifdef CONFIG_MAC80211_VERBOSE_PS_DEBUG | 933 | #ifdef CONFIG_MAC80211_VERBOSE_PS_DEBUG |
933 | printk(KERN_DEBUG "STA %s aid %d: PS Poll (entries after %d)\n", | 934 | printk(KERN_DEBUG "STA %s aid %d: PS Poll (entries after %d)\n", |