diff options
Diffstat (limited to 'net/mac80211/rx.c')
| -rw-r--r-- | net/mac80211/rx.c | 27 | 
1 files changed, 10 insertions, 17 deletions
| diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c index 6a9b8e63a6b..de5bba7f910 100644 --- a/net/mac80211/rx.c +++ b/net/mac80211/rx.c @@ -797,8 +797,7 @@ static int ap_sta_ps_end(struct sta_info *sta)  {  	struct ieee80211_sub_if_data *sdata = sta->sdata;  	struct ieee80211_local *local = sdata->local; -	struct sk_buff *skb; -	int sent = 0; +	int sent, buffered;  	atomic_dec(&sdata->bss->num_sta_ps); @@ -814,22 +813,16 @@ static int ap_sta_ps_end(struct sta_info *sta)  #endif /* CONFIG_MAC80211_VERBOSE_PS_DEBUG */  	/* Send all buffered frames to the station */ -	while ((skb = skb_dequeue(&sta->tx_filtered)) != NULL) { -		sent++; -		skb->requeue = 1; -		dev_queue_xmit(skb); -	} -	while ((skb = skb_dequeue(&sta->ps_tx_buf)) != NULL) { -		local->total_ps_buffered--; -		sent++; +	sent = ieee80211_add_pending_skbs(local, &sta->tx_filtered); +	buffered = ieee80211_add_pending_skbs(local, &sta->ps_tx_buf); +	sent += buffered; +	local->total_ps_buffered -= buffered; +  #ifdef CONFIG_MAC80211_VERBOSE_PS_DEBUG -		printk(KERN_DEBUG "%s: STA %pM aid %d send PS frame " -		       "since STA not sleeping anymore\n", sdata->dev->name, -		       sta->sta.addr, sta->sta.aid); +	printk(KERN_DEBUG "%s: STA %pM aid %d sending %d filtered/%d PS frames " +	       "since STA not sleeping anymore\n", sdata->dev->name, +	       sta->sta.addr, sta->sta.aid, sent - buffered, buffered);  #endif /* CONFIG_MAC80211_VERBOSE_PS_DEBUG */ -		skb->requeue = 1; -		dev_queue_xmit(skb); -	}  	return sent;  } @@ -1335,7 +1328,7 @@ ieee80211_deliver_skb(struct ieee80211_rx_data *rx)  		 * mac80211. That also explains the __skb_push()  		 * below.  		 */ -		align = (unsigned long)skb->data & 3; +		align = ((unsigned long)(skb->data + sizeof(struct ethhdr))) & 3;  		if (align) {  			if (WARN_ON(skb_headroom(skb) < 3)) {  				dev_kfree_skb(skb); | 
