diff options
Diffstat (limited to 'net/mac80211')
-rw-r--r-- | net/mac80211/rx.c | 13 | ||||
-rw-r--r-- | net/mac80211/sta_info.h | 3 | ||||
-rw-r--r-- | net/mac80211/tx.c | 5 |
3 files changed, 12 insertions, 9 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", |
diff --git a/net/mac80211/sta_info.h b/net/mac80211/sta_info.h index 19f3fb412940..ca51d29b7008 100644 --- a/net/mac80211/sta_info.h +++ b/net/mac80211/sta_info.h | |||
@@ -32,6 +32,7 @@ | |||
32 | * @WLAN_STA_ASSOC_AP: We're associated to that station, it is an AP. | 32 | * @WLAN_STA_ASSOC_AP: We're associated to that station, it is an AP. |
33 | * @WLAN_STA_WME: Station is a QoS-STA. | 33 | * @WLAN_STA_WME: Station is a QoS-STA. |
34 | * @WLAN_STA_WDS: Station is one of our WDS peers. | 34 | * @WLAN_STA_WDS: Station is one of our WDS peers. |
35 | * @WLAN_STA_PSPOLL: Station has just PS-polled us. | ||
35 | */ | 36 | */ |
36 | enum ieee80211_sta_info_flags { | 37 | enum ieee80211_sta_info_flags { |
37 | WLAN_STA_AUTH = 1<<0, | 38 | WLAN_STA_AUTH = 1<<0, |
@@ -43,6 +44,7 @@ enum ieee80211_sta_info_flags { | |||
43 | WLAN_STA_ASSOC_AP = 1<<6, | 44 | WLAN_STA_ASSOC_AP = 1<<6, |
44 | WLAN_STA_WME = 1<<7, | 45 | WLAN_STA_WME = 1<<7, |
45 | WLAN_STA_WDS = 1<<8, | 46 | WLAN_STA_WDS = 1<<8, |
47 | WLAN_STA_PSPOLL = 1<<9, | ||
46 | }; | 48 | }; |
47 | 49 | ||
48 | #define STA_TID_NUM 16 | 50 | #define STA_TID_NUM 16 |
@@ -133,7 +135,6 @@ struct sta_info { | |||
133 | 135 | ||
134 | struct sk_buff_head ps_tx_buf; /* buffer of TX frames for station in | 136 | struct sk_buff_head ps_tx_buf; /* buffer of TX frames for station in |
135 | * power saving state */ | 137 | * power saving state */ |
136 | int pspoll; /* whether STA has send a PS Poll frame */ | ||
137 | struct sk_buff_head tx_filtered; /* buffer of TX frames that were | 138 | struct sk_buff_head tx_filtered; /* buffer of TX frames that were |
138 | * already given to low-level driver, | 139 | * already given to low-level driver, |
139 | * but were filtered */ | 140 | * but were filtered */ |
diff --git a/net/mac80211/tx.c b/net/mac80211/tx.c index 181d97015f61..4f951e78df15 100644 --- a/net/mac80211/tx.c +++ b/net/mac80211/tx.c | |||
@@ -395,7 +395,8 @@ ieee80211_tx_h_unicast_ps_buf(struct ieee80211_txrx_data *tx) | |||
395 | (tx->fc & IEEE80211_FCTL_STYPE) == IEEE80211_STYPE_PROBE_RESP))) | 395 | (tx->fc & IEEE80211_FCTL_STYPE) == IEEE80211_STYPE_PROBE_RESP))) |
396 | return TX_CONTINUE; | 396 | return TX_CONTINUE; |
397 | 397 | ||
398 | if (unlikely((sta->flags & WLAN_STA_PS) && !sta->pspoll)) { | 398 | if (unlikely((sta->flags & WLAN_STA_PS) && |
399 | !(sta->flags & WLAN_STA_PSPOLL))) { | ||
399 | struct ieee80211_tx_packet_data *pkt_data; | 400 | struct ieee80211_tx_packet_data *pkt_data; |
400 | #ifdef CONFIG_MAC80211_VERBOSE_PS_DEBUG | 401 | #ifdef CONFIG_MAC80211_VERBOSE_PS_DEBUG |
401 | printk(KERN_DEBUG "STA %s aid %d: PS buffer (entries " | 402 | printk(KERN_DEBUG "STA %s aid %d: PS buffer (entries " |
@@ -436,7 +437,7 @@ ieee80211_tx_h_unicast_ps_buf(struct ieee80211_txrx_data *tx) | |||
436 | print_mac(mac, sta->addr)); | 437 | print_mac(mac, sta->addr)); |
437 | } | 438 | } |
438 | #endif /* CONFIG_MAC80211_VERBOSE_PS_DEBUG */ | 439 | #endif /* CONFIG_MAC80211_VERBOSE_PS_DEBUG */ |
439 | sta->pspoll = 0; | 440 | sta->flags &= ~WLAN_STA_PSPOLL; |
440 | 441 | ||
441 | return TX_CONTINUE; | 442 | return TX_CONTINUE; |
442 | } | 443 | } |