diff options
| -rw-r--r-- | net/mac80211/rx.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c index 6e2a7bcd8cb8..5e0b65406c44 100644 --- a/net/mac80211/rx.c +++ b/net/mac80211/rx.c | |||
| @@ -1818,17 +1818,26 @@ ieee80211_rx_h_ctrl(struct ieee80211_rx_data *rx, struct sk_buff_head *frames) | |||
| 1818 | return RX_CONTINUE; | 1818 | return RX_CONTINUE; |
| 1819 | 1819 | ||
| 1820 | if (ieee80211_is_back_req(bar->frame_control)) { | 1820 | if (ieee80211_is_back_req(bar->frame_control)) { |
| 1821 | struct { | ||
| 1822 | __le16 control, start_seq_num; | ||
| 1823 | } __packed bar_data; | ||
| 1824 | |||
| 1821 | if (!rx->sta) | 1825 | if (!rx->sta) |
| 1822 | return RX_DROP_MONITOR; | 1826 | return RX_DROP_MONITOR; |
| 1827 | |||
| 1828 | if (skb_copy_bits(skb, offsetof(struct ieee80211_bar, control), | ||
| 1829 | &bar_data, sizeof(bar_data))) | ||
| 1830 | return RX_DROP_MONITOR; | ||
| 1831 | |||
| 1823 | spin_lock(&rx->sta->lock); | 1832 | spin_lock(&rx->sta->lock); |
| 1824 | tid = le16_to_cpu(bar->control) >> 12; | 1833 | tid = le16_to_cpu(bar_data.control) >> 12; |
| 1825 | if (!rx->sta->ampdu_mlme.tid_active_rx[tid]) { | 1834 | if (!rx->sta->ampdu_mlme.tid_active_rx[tid]) { |
| 1826 | spin_unlock(&rx->sta->lock); | 1835 | spin_unlock(&rx->sta->lock); |
| 1827 | return RX_DROP_MONITOR; | 1836 | return RX_DROP_MONITOR; |
| 1828 | } | 1837 | } |
| 1829 | tid_agg_rx = rx->sta->ampdu_mlme.tid_rx[tid]; | 1838 | tid_agg_rx = rx->sta->ampdu_mlme.tid_rx[tid]; |
| 1830 | 1839 | ||
| 1831 | start_seq_num = le16_to_cpu(bar->start_seq_num) >> 4; | 1840 | start_seq_num = le16_to_cpu(bar_data.start_seq_num) >> 4; |
| 1832 | 1841 | ||
| 1833 | /* reset session timer */ | 1842 | /* reset session timer */ |
| 1834 | if (tid_agg_rx->timeout) | 1843 | if (tid_agg_rx->timeout) |
