X-Git-Url: http://git.ipfire.org/?a=blobdiff_plain;f=event.c;h=100f644d00d1a0ba41a30ea0c6376139ebf4a640;hb=HEAD;hp=e0908dd5b5242a4d9a2fd244952d4a0d42cc44fb;hpb=e848afea3f180edf9fcee138f9f3a535c8276c56;p=thirdparty%2Fiw.git diff --git a/event.c b/event.c index e0908dd..dec50f0 100644 --- a/event.c +++ b/event.c @@ -295,6 +295,8 @@ static void parse_wowlan_wake_event(struct nlattr **attrs) printf("\t* TCP connection lost\n"); if (tb[NL80211_WOWLAN_TRIG_WAKEUP_TCP_NOMORETOKENS]) printf("\t* TCP connection ran out of tokens\n"); + if (tb[NL80211_WOWLAN_TRIG_UNPROTECTED_DEAUTH_DISASSOC]) + printf("\t* unprotected deauth/disassoc\n"); } extern struct vendor_event *__start_vendor_event[]; @@ -893,6 +895,21 @@ static void parse_ch_switch_notify(struct nlattr **attrs, int command) printf("\n"); } +static void parse_assoc_comeback(struct nlattr **attrs, int command) +{ + __u32 timeout = 0; + char macbuf[6 * 3] = ""; + + if (attrs[NL80211_ATTR_MAC]) + mac_addr_n2a(macbuf, nla_data(attrs[NL80211_ATTR_MAC])); + + if (attrs[NL80211_ATTR_TIMEOUT]) + timeout = nla_get_u32(attrs[NL80211_ATTR_TIMEOUT]); + + printf("assoc comeback bssid %s timeout %d\n", + macbuf, timeout); +} + static int print_event(struct nl_msg *msg, void *arg) { struct genlmsghdr *gnlh = nlmsg_data(nlmsg_hdr(msg)); @@ -927,7 +944,7 @@ static int print_event(struct nl_msg *msg, void *arg) memset(buf, 0, 255); strftime(buf, sizeof(buf), "%Y-%m-%d %H:%M:%S", tm); - printf("[%s.%06lu]: ", buf, args->ts.tv_usec); + printf("[%s.%06lu]: ", buf, (unsigned long )args->ts.tv_usec); } else { printf("%llu.%06llu: ", usecs/1000000, usecs % 1000000); } @@ -1233,6 +1250,12 @@ static int print_event(struct nl_msg *msg, void *arg) case NL80211_RADAR_NOP_FINISHED: printf("%d MHz: NOP finished\n", freq); break; + case NL80211_RADAR_PRE_CAC_EXPIRED: + printf("%d MHz: PRE-CAC expired\n", freq); + break; + case NL80211_RADAR_CAC_STARTED: + printf("%d MHz: CAC started\n", freq); + break; default: printf("%d MHz: unknown radar event\n", freq); } @@ -1271,6 +1294,9 @@ static int print_event(struct nl_msg *msg, void *arg) case NL80211_CMD_CH_SWITCH_NOTIFY: parse_ch_switch_notify(tb, gnlh->cmd); break; + case NL80211_CMD_ASSOC_COMEBACK: /* 147 */ + parse_assoc_comeback(tb, gnlh->cmd); + break; default: printf("unknown event %d (%s)\n", gnlh->cmd, command_name(gnlh->cmd));