[MAC80211]: refactor event sending
Create a new file event.c that will contain code to send mac/mlme events to userspace. For now put the Michael MIC failure condition into it and remove sending of that condition via the management interface, hostapd interestingly doesn't do anything when it gets such a packet besides printing a message, it reacts only on the private iwevent. Signed-off-by: Johannes Berg <johannes@sipsolutions.net> Acked-by: Michael Wu <flamingice@sourmilk.net> Signed-off-by: John W. Linville <linville@tuxdriver.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
808718c147
commit
eb063c1702
@@ -13,7 +13,6 @@
|
||||
#include <linux/skbuff.h>
|
||||
#include <linux/netdevice.h>
|
||||
#include <linux/etherdevice.h>
|
||||
#include <net/iw_handler.h>
|
||||
#include <net/mac80211.h>
|
||||
#include <net/ieee80211_radiotap.h>
|
||||
|
||||
@@ -1206,20 +1205,17 @@ static void ieee80211_rx_michael_mic_report(struct net_device *dev,
|
||||
}
|
||||
|
||||
if ((rx->local->hw.flags & IEEE80211_HW_WEP_INCLUDE_IV) &&
|
||||
rx->sdata->type == IEEE80211_IF_TYPE_AP) {
|
||||
keyidx = ieee80211_wep_get_keyidx(rx->skb);
|
||||
rx->sdata->type == IEEE80211_IF_TYPE_AP && keyidx) {
|
||||
/* AP with Pairwise keys support should never receive Michael
|
||||
* MIC errors for non-zero keyidx because these are reserved
|
||||
* for group keys and only the AP is sending real multicast
|
||||
* frames in BSS. */
|
||||
if (keyidx) {
|
||||
if (net_ratelimit())
|
||||
printk(KERN_DEBUG "%s: ignored Michael MIC "
|
||||
"error for a frame with non-zero keyidx"
|
||||
" (%d) (src " MAC_FMT ")\n", dev->name,
|
||||
keyidx, MAC_ARG(hdr->addr2));
|
||||
goto ignore;
|
||||
}
|
||||
if (net_ratelimit())
|
||||
printk(KERN_DEBUG "%s: ignored Michael MIC error for "
|
||||
"a frame with non-zero keyidx (%d)"
|
||||
" (src " MAC_FMT ")\n", dev->name, keyidx,
|
||||
MAC_ARG(hdr->addr2));
|
||||
goto ignore;
|
||||
}
|
||||
|
||||
if ((rx->fc & IEEE80211_FCTL_FTYPE) != IEEE80211_FTYPE_DATA &&
|
||||
@@ -1233,32 +1229,11 @@ static void ieee80211_rx_michael_mic_report(struct net_device *dev,
|
||||
goto ignore;
|
||||
}
|
||||
|
||||
do {
|
||||
union iwreq_data wrqu;
|
||||
char *buf = kmalloc(128, GFP_ATOMIC);
|
||||
if (!buf)
|
||||
break;
|
||||
|
||||
/* TODO: needed parameters: count, key type, TSC */
|
||||
sprintf(buf, "MLME-MICHAELMICFAILURE.indication("
|
||||
"keyid=%d %scast addr=" MAC_FMT ")",
|
||||
keyidx, hdr->addr1[0] & 0x01 ? "broad" : "uni",
|
||||
MAC_ARG(hdr->addr2));
|
||||
memset(&wrqu, 0, sizeof(wrqu));
|
||||
wrqu.data.length = strlen(buf);
|
||||
wireless_send_event(rx->dev, IWEVCUSTOM, &wrqu, buf);
|
||||
kfree(buf);
|
||||
} while (0);
|
||||
|
||||
/* TODO: consider verifying the MIC error report with software
|
||||
* implementation if we get too many spurious reports from the
|
||||
* hardware. */
|
||||
if (!rx->local->apdev)
|
||||
goto ignore;
|
||||
ieee80211_rx_mgmt(rx->local, rx->skb, rx->u.rx.status,
|
||||
ieee80211_msg_michael_mic_failure);
|
||||
return;
|
||||
|
||||
mac80211_ev_michael_mic_failure(rx->dev, keyidx, hdr);
|
||||
ignore:
|
||||
dev_kfree_skb(rx->skb);
|
||||
rx->skb = NULL;
|
||||
|
Reference in New Issue
Block a user