diff options
| -rw-r--r-- | net/mac80211/mesh.c | 3 | ||||
| -rw-r--r-- | net/mac80211/rx.c | 5 |
2 files changed, 5 insertions, 3 deletions
diff --git a/net/mac80211/mesh.c b/net/mac80211/mesh.c index 61080c5fad50..7a6bebce7f2f 100644 --- a/net/mac80211/mesh.c +++ b/net/mac80211/mesh.c | |||
| @@ -749,9 +749,6 @@ ieee80211_mesh_rx_mgmt(struct ieee80211_sub_if_data *sdata, struct sk_buff *skb) | |||
| 749 | 749 | ||
| 750 | switch (fc & IEEE80211_FCTL_STYPE) { | 750 | switch (fc & IEEE80211_FCTL_STYPE) { |
| 751 | case IEEE80211_STYPE_ACTION: | 751 | case IEEE80211_STYPE_ACTION: |
| 752 | if (skb->len < IEEE80211_MIN_ACTION_SIZE) | ||
| 753 | return RX_DROP_MONITOR; | ||
| 754 | /* fall through */ | ||
| 755 | case IEEE80211_STYPE_PROBE_RESP: | 752 | case IEEE80211_STYPE_PROBE_RESP: |
| 756 | case IEEE80211_STYPE_BEACON: | 753 | case IEEE80211_STYPE_BEACON: |
| 757 | skb_queue_tail(&ifmsh->skb_queue, skb); | 754 | skb_queue_tail(&ifmsh->skb_queue, skb); |
diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c index b5c48de81d8b..13fcd2d17c6b 100644 --- a/net/mac80211/rx.c +++ b/net/mac80211/rx.c | |||
| @@ -1973,6 +1973,11 @@ ieee80211_rx_h_action(struct ieee80211_rx_data *rx) | |||
| 1973 | goto handled; | 1973 | goto handled; |
| 1974 | } | 1974 | } |
| 1975 | break; | 1975 | break; |
| 1976 | case MESH_PLINK_CATEGORY: | ||
| 1977 | case MESH_PATH_SEL_CATEGORY: | ||
| 1978 | if (ieee80211_vif_is_mesh(&sdata->vif)) | ||
| 1979 | return ieee80211_mesh_rx_mgmt(sdata, rx->skb); | ||
| 1980 | break; | ||
| 1976 | } | 1981 | } |
| 1977 | 1982 | ||
| 1978 | /* | 1983 | /* |
