Move some frame control field #defines to a header and use them elsewhere.

Move a bunch of #defines that involve the frame control field to
packet-ieee80211.h and have the WLAN statistics tap use them rather than
hardcoded numbers.

Change-Id: I893cc50e546af67c910755357cefd86c39a1c783
Reviewed-on: https://code.wireshark.org/review/9476
Reviewed-by: Guy Harris <guy@alum.mit.edu>
This commit is contained in:
Guy Harris 2015-07-02 19:51:22 -07:00
parent df5a315048
commit 363511cb67
3 changed files with 193 additions and 193 deletions

View File

@ -312,98 +312,6 @@ static gboolean is_80211ad(proto_node * pnode, gpointer data) {
return FALSE;
}
/*
* Extract the protocol version from the frame control field
*/
#define FCF_PROT_VERSION(x) ((x) & 0x3)
/*
* Extract the frame type from the frame control field.
*/
#define FCF_FRAME_TYPE(x) (((x) & 0xC) >> 2)
/*
* Extract the frame subtype from the frame control field.
*/
#define FCF_FRAME_SUBTYPE(x) (((x) & 0xF0) >> 4)
/*
* Extract the control frame extension from the frame control field.
*/
#define FCF_FRAME_EXTENSION(x) (((x) & 0xF00) >> 8)
/*
* Checks if the frame is control frame extension.
*/
#define IS_FRAME_EXTENSION(x) ((FCF_FRAME_TYPE(x) == 0x1 && FCF_FRAME_SUBTYPE(x) == 0x6) ? 1 : 0)
/*
* Convert the frame type and subtype from the frame control field into
* one of the MGT_, CTRL_, or DATA_ values.
* Now includes extension subtype in case present.
*/
#define COMPOSE_FRAME_TYPE(x) ((FCF_FRAME_TYPE(x) == 0x1 && FCF_FRAME_SUBTYPE(x) == 0x6) ? (((x & 0x0C)<< 6) + ((x) & 0xF0) + FCF_FRAME_EXTENSION(x)) : (((x & 0x0C)<< 2)+FCF_FRAME_SUBTYPE(x))) /* Create key to (sub)type */
/*
* The subtype field of a data frame is, in effect, composed of 4 flag
* bits - CF-Ack, CF-Poll, Null (means the frame doesn't actually have
* any data), and QoS.
*/
#define DATA_FRAME_IS_CF_ACK(x) ((x) & 0x01)
#define DATA_FRAME_IS_CF_POLL(x) ((x) & 0x02)
#define DATA_FRAME_IS_NULL(x) ((x) & 0x04)
#define DATA_FRAME_IS_QOS(x) ((x) & 0x08)
/*
* Extract the flags from the frame control field.
* Now includes subset of flags when the subtype is control frame extension.
*/
#define FCF_FLAGS(x) ((FCF_FRAME_TYPE(x) == 0x1 && FCF_FRAME_SUBTYPE(x) == 0x6) ? (((x) & 0xF000) >> 12) : (((x) & 0xFF00) >> 8))
/*
* Bits from the flags field.
*/
#define FLAG_TO_DS 0x01
#define FLAG_FROM_DS 0x02
#define FLAG_MORE_FRAGMENTS 0x04
#define FLAG_RETRY 0x08
#define FLAG_POWER_MGT 0x10
#define FLAG_MORE_DATA 0x20
#define FLAG_PROTECTED 0x40
#define FLAG_ORDER 0x80
/*
* Test bits in the flags field.
*/
/*
* XXX - Only HAVE_FRAGMENTS, IS_PROTECTED, and IS_STRICTLY_ORDERED
* are in use. Should the rest be removed?
*/
#define IS_TO_DS(x) ((x) & FLAG_TO_DS)
#define IS_FROM_DS(x) ((x) & FLAG_FROM_DS)
#define HAVE_FRAGMENTS(x) ((x) & FLAG_MORE_FRAGMENTS)
#define IS_RETRY(x) ((x) & FLAG_RETRY)
#define POWER_MGT_STATUS(x) ((x) & FLAG_POWER_MGT)
#define HAS_MORE_DATA(x) ((x) & FLAG_MORE_DATA)
#define IS_PROTECTED(x) ((x) & FLAG_PROTECTED)
#define IS_STRICTLY_ORDERED(x) ((x) & FLAG_ORDER)
/*
* Extract subfields from the flags field.
*/
#define FLAGS_DS_STATUS(x) ((x) & (FLAG_FROM_DS|FLAG_TO_DS))
/*
* Extract an indication of the types of addresses in a data frame from
* the frame control field.
*/
#define FCF_ADDR_SELECTOR(x) ((x) & ((FLAG_TO_DS|FLAG_FROM_DS) << 8))
#define DATA_ADDR_T1 0
#define DATA_ADDR_T2 (FLAG_FROM_DS << 8)
#define DATA_ADDR_T3 (FLAG_TO_DS << 8)
#define DATA_ADDR_T4 ((FLAG_TO_DS|FLAG_FROM_DS) << 8)
/*
* Extract the fragment number and sequence number from the sequence
* control field.
@ -488,74 +396,6 @@ static gboolean is_80211ad(proto_node * pnode, gpointer data) {
#define DATA_LONG_HDR_LEN 30
#define MGT_FRAME_HDR_LEN 24 /* Length of Management frame-headers */
/*
* COMPOSE_FRAME_TYPE() values for management frames.
*/
#define MGT_ASSOC_REQ 0x00 /* association request */
#define MGT_ASSOC_RESP 0x01 /* association response */
#define MGT_REASSOC_REQ 0x02 /* reassociation request */
#define MGT_REASSOC_RESP 0x03 /* reassociation response */
#define MGT_PROBE_REQ 0x04 /* Probe request */
#define MGT_PROBE_RESP 0x05 /* Probe response */
#define MGT_MEASUREMENT_PILOT 0x06 /* Measurement Pilot */
#define MGT_BEACON 0x08 /* Beacon frame */
#define MGT_ATIM 0x09 /* ATIM */
#define MGT_DISASS 0x0A /* Disassociation */
#define MGT_AUTHENTICATION 0x0B /* Authentication */
#define MGT_DEAUTHENTICATION 0x0C /* Deauthentication */
#define MGT_ACTION 0x0D /* Action */
#define MGT_ACTION_NO_ACK 0x0E /* Action No Ack */
#define MGT_ARUBA_WLAN 0x0F /* Aruba WLAN Specific */
/*
* COMPOSE_FRAME_TYPE() values for control frames.
* 0x160 - 0x16A are for control frame extension where type = 1 and subtype =6.
*/
#define CTRL_VHT_NDP_ANNC 0x15 /* VHT NDP Announcement */
#define CTRL_POLL 0x162 /* Poll */
#define CTRL_SPR 0x163 /* Service Period Request */
#define CTRL_GRANT 0x164 /* Grant */
#define CTRL_DMG_CTS 0x165 /* DMG Clear to Send */
#define CTRL_DMG_DTS 0x166 /* DMG Denial to Send */
#define CTRL_GRANT_ACK 0x167 /* Grant Acknowledgment */
#define CTRL_SSW 0x168 /* Sector Sweep */
#define CTRL_SSW_FEEDBACK 0x169 /* Sector Sweep Feedback */
#define CTRL_SSW_ACK 0x16A /* Sector Sweep Acknowledgment */
#define CTRL_CONTROL_WRAPPER 0x17 /* Control Wrapper */
#define CTRL_BLOCK_ACK_REQ 0x18 /* Block ack Request */
#define CTRL_BLOCK_ACK 0x19 /* Block ack */
#define CTRL_PS_POLL 0x1A /* power-save poll */
#define CTRL_RTS 0x1B /* request to send */
#define CTRL_CTS 0x1C /* clear to send */
#define CTRL_ACKNOWLEDGEMENT 0x1D /* acknowledgement */
#define CTRL_CFP_END 0x1E /* contention-free period end */
#define CTRL_CFP_ENDACK 0x1F /* contention-free period end/ack */
/*
* COMPOSE_FRAME_TYPE() values for data frames.
*/
#define DATA 0x20 /* Data */
#define DATA_CF_ACK 0x21 /* Data + CF-Ack */
#define DATA_CF_POLL 0x22 /* Data + CF-Poll */
#define DATA_CF_ACK_POLL 0x23 /* Data + CF-Ack + CF-Poll */
#define DATA_NULL_FUNCTION 0x24 /* Null function (no data) */
#define DATA_CF_ACK_NOD 0x25 /* CF-Ack (no data) */
#define DATA_CF_POLL_NOD 0x26 /* CF-Poll (No data) */
#define DATA_CF_ACK_POLL_NOD 0x27 /* CF-Ack + CF-Poll (no data) */
#define DATA_QOS_DATA 0x28 /* QoS Data */
#define DATA_QOS_DATA_CF_ACK 0x29 /* QoS Data + CF-Ack */
#define DATA_QOS_DATA_CF_POLL 0x2A /* QoS Data + CF-Poll */
#define DATA_QOS_DATA_CF_ACK_POLL 0x2B /* QoS Data + CF-Ack + CF-Poll */
#define DATA_QOS_NULL 0x2C /* QoS Null */
#define DATA_QOS_CF_POLL_NOD 0x2E /* QoS CF-Poll (No Data) */
#define DATA_QOS_CF_ACK_POLL_NOD 0x2F /* QoS CF-Ack + CF-Poll (No Data) */
/*
* COMPOSE_FRAME_TYPE() values for extension frames.
*/
#define EXTENSION_DMG_BEACON 0x30 /* Extension DMG beacon */
/* ************************************************************************* */
/* Logical field codes (dissector's encoding of fixed fields) */

View File

@ -65,6 +65,166 @@ WS_DLL_PUBLIC const float ieee80211_float_htrates[MAX_MCS_INDEX+1][2][2];
WS_DLL_PUBLIC value_string_ext ieee80211_supported_rates_vals_ext;
/*
* Extract the protocol version from the frame control field
*/
#define FCF_PROT_VERSION(x) ((x) & 0x3)
/*
* Extract the frame type from the frame control field.
*/
#define FCF_FRAME_TYPE(x) (((x) & 0xC) >> 2)
/*
* Extract the frame subtype from the frame control field.
*/
#define FCF_FRAME_SUBTYPE(x) (((x) & 0xF0) >> 4)
/*
* Extract the control frame extension from the frame control field.
*/
#define FCF_FRAME_EXTENSION(x) (((x) & 0xF00) >> 8)
/*
* Checks if the frame is control frame extension.
*/
#define IS_FRAME_EXTENSION(x) ((FCF_FRAME_TYPE(x) == 0x1 && FCF_FRAME_SUBTYPE(x) == 0x6) ? 1 : 0)
/*
* Convert the frame type and subtype from the frame control field into
* one of the MGT_, CTRL_, or DATA_ values.
* Now includes extension subtype in case present.
*/
#define COMPOSE_FRAME_TYPE(x) ((FCF_FRAME_TYPE(x) == 0x1 && FCF_FRAME_SUBTYPE(x) == 0x6) ? (((x & 0x0C)<< 6) + ((x) & 0xF0) + FCF_FRAME_EXTENSION(x)) : (((x & 0x0C)<< 2)+FCF_FRAME_SUBTYPE(x))) /* Create key to (sub)type */
/*
* The subtype field of a data frame is, in effect, composed of 4 flag
* bits - CF-Ack, CF-Poll, Null (means the frame doesn't actually have
* any data), and QoS.
*/
#define DATA_FRAME_IS_CF_ACK(x) ((x) & 0x01)
#define DATA_FRAME_IS_CF_POLL(x) ((x) & 0x02)
#define DATA_FRAME_IS_NULL(x) ((x) & 0x04)
#define DATA_FRAME_IS_QOS(x) ((x) & 0x08)
/*
* Extract the flags from the frame control field.
* Now includes subset of flags when the subtype is control frame extension.
*/
#define FCF_FLAGS(x) ((FCF_FRAME_TYPE(x) == 0x1 && FCF_FRAME_SUBTYPE(x) == 0x6) ? (((x) & 0xF000) >> 12) : (((x) & 0xFF00) >> 8))
/*
* Bits from the flags field.
*/
#define FLAG_TO_DS 0x01
#define FLAG_FROM_DS 0x02
#define FLAG_MORE_FRAGMENTS 0x04
#define FLAG_RETRY 0x08
#define FLAG_POWER_MGT 0x10
#define FLAG_MORE_DATA 0x20
#define FLAG_PROTECTED 0x40
#define FLAG_ORDER 0x80
/*
* Test bits in the flags field.
*/
/*
* XXX - Only HAVE_FRAGMENTS, IS_PROTECTED, and IS_STRICTLY_ORDERED
* are in use. Should the rest be removed?
*/
#define IS_TO_DS(x) ((x) & FLAG_TO_DS)
#define IS_FROM_DS(x) ((x) & FLAG_FROM_DS)
#define HAVE_FRAGMENTS(x) ((x) & FLAG_MORE_FRAGMENTS)
#define IS_RETRY(x) ((x) & FLAG_RETRY)
#define POWER_MGT_STATUS(x) ((x) & FLAG_POWER_MGT)
#define HAS_MORE_DATA(x) ((x) & FLAG_MORE_DATA)
#define IS_PROTECTED(x) ((x) & FLAG_PROTECTED)
#define IS_STRICTLY_ORDERED(x) ((x) & FLAG_ORDER)
/*
* Extract subfields from the flags field.
*/
#define FLAGS_DS_STATUS(x) ((x) & (FLAG_FROM_DS|FLAG_TO_DS))
/*
* Extract an indication of the types of addresses in a data frame from
* the frame control field.
*/
#define FCF_ADDR_SELECTOR(x) ((x) & ((FLAG_TO_DS|FLAG_FROM_DS) << 8))
#define DATA_ADDR_T1 0
#define DATA_ADDR_T2 (FLAG_FROM_DS << 8)
#define DATA_ADDR_T3 (FLAG_TO_DS << 8)
#define DATA_ADDR_T4 ((FLAG_TO_DS|FLAG_FROM_DS) << 8)
/*
* COMPOSE_FRAME_TYPE() values for management frames.
*/
#define MGT_ASSOC_REQ 0x00 /* association request */
#define MGT_ASSOC_RESP 0x01 /* association response */
#define MGT_REASSOC_REQ 0x02 /* reassociation request */
#define MGT_REASSOC_RESP 0x03 /* reassociation response */
#define MGT_PROBE_REQ 0x04 /* Probe request */
#define MGT_PROBE_RESP 0x05 /* Probe response */
#define MGT_MEASUREMENT_PILOT 0x06 /* Measurement Pilot */
#define MGT_BEACON 0x08 /* Beacon frame */
#define MGT_ATIM 0x09 /* ATIM */
#define MGT_DISASS 0x0A /* Disassociation */
#define MGT_AUTHENTICATION 0x0B /* Authentication */
#define MGT_DEAUTHENTICATION 0x0C /* Deauthentication */
#define MGT_ACTION 0x0D /* Action */
#define MGT_ACTION_NO_ACK 0x0E /* Action No Ack */
#define MGT_ARUBA_WLAN 0x0F /* Aruba WLAN Specific */
/*
* COMPOSE_FRAME_TYPE() values for control frames.
* 0x160 - 0x16A are for control frame extension where type = 1 and subtype =6.
*/
#define CTRL_VHT_NDP_ANNC 0x15 /* VHT NDP Announcement */
#define CTRL_POLL 0x162 /* Poll */
#define CTRL_SPR 0x163 /* Service Period Request */
#define CTRL_GRANT 0x164 /* Grant */
#define CTRL_DMG_CTS 0x165 /* DMG Clear to Send */
#define CTRL_DMG_DTS 0x166 /* DMG Denial to Send */
#define CTRL_GRANT_ACK 0x167 /* Grant Acknowledgment */
#define CTRL_SSW 0x168 /* Sector Sweep */
#define CTRL_SSW_FEEDBACK 0x169 /* Sector Sweep Feedback */
#define CTRL_SSW_ACK 0x16A /* Sector Sweep Acknowledgment */
#define CTRL_CONTROL_WRAPPER 0x17 /* Control Wrapper */
#define CTRL_BLOCK_ACK_REQ 0x18 /* Block ack Request */
#define CTRL_BLOCK_ACK 0x19 /* Block ack */
#define CTRL_PS_POLL 0x1A /* power-save poll */
#define CTRL_RTS 0x1B /* request to send */
#define CTRL_CTS 0x1C /* clear to send */
#define CTRL_ACKNOWLEDGEMENT 0x1D /* acknowledgement */
#define CTRL_CFP_END 0x1E /* contention-free period end */
#define CTRL_CFP_ENDACK 0x1F /* contention-free period end/ack */
/*
* COMPOSE_FRAME_TYPE() values for data frames.
*/
#define DATA 0x20 /* Data */
#define DATA_CF_ACK 0x21 /* Data + CF-Ack */
#define DATA_CF_POLL 0x22 /* Data + CF-Poll */
#define DATA_CF_ACK_POLL 0x23 /* Data + CF-Ack + CF-Poll */
#define DATA_NULL_FUNCTION 0x24 /* Null function (no data) */
#define DATA_CF_ACK_NOD 0x25 /* CF-Ack (no data) */
#define DATA_CF_POLL_NOD 0x26 /* CF-Poll (No data) */
#define DATA_CF_ACK_POLL_NOD 0x27 /* CF-Ack + CF-Poll (no data) */
#define DATA_QOS_DATA 0x28 /* QoS Data */
#define DATA_QOS_DATA_CF_ACK 0x29 /* QoS Data + CF-Ack */
#define DATA_QOS_DATA_CF_POLL 0x2A /* QoS Data + CF-Poll */
#define DATA_QOS_DATA_CF_ACK_POLL 0x2B /* QoS Data + CF-Ack + CF-Poll */
#define DATA_QOS_NULL 0x2C /* QoS Null */
#define DATA_QOS_CF_POLL_NOD 0x2E /* QoS CF-Poll (No Data) */
#define DATA_QOS_CF_ACK_POLL_NOD 0x2F /* QoS CF-Ack + CF-Poll (No Data) */
/*
* COMPOSE_FRAME_TYPE() values for extension frames.
*/
#define EXTENSION_DMG_BEACON 0x30 /* Extension DMG beacon */
struct _wlan_stats {
guint8 channel;
guint8 ssid_len;

View File

@ -318,29 +318,29 @@ wlanstat_packet_details (wlan_ep_t *te, guint32 type, const address *addr, gbool
wlan_details_ep_t *d_te = get_details_ep (te, addr);
switch (type) {
case 0x04:
case MGT_PROBE_REQ:
d_te->probe_req++;
break;
case 0x05:
case MGT_PROBE_RESP:
d_te->probe_rsp++;
break;
case 0x08:
case MGT_BEACON:
/* No counting for beacons */
break;
case 0x0B:
case MGT_AUTHENTICATION:
d_te->auth++;
break;
case 0x0C:
case MGT_DEAUTHENTICATION:
d_te->deauth++;
break;
case 0x20:
case 0x21:
case 0x22:
case 0x23:
case 0x28:
case 0x29:
case 0x2A:
case 0x2B:
case DATA:
case DATA_CF_ACK:
case DATA_CF_POLL:
case DATA_CF_ACK_POLL:
case DATA_QOS_DATA:
case DATA_QOS_DATA_CF_ACK:
case DATA_QOS_DATA_CF_POLL:
case DATA_QOS_DATA_CF_ACK_POLL:
if (src) {
d_te->data_sent++;
} else {
@ -352,7 +352,7 @@ wlanstat_packet_details (wlan_ep_t *te, guint32 type, const address *addr, gbool
break;
}
if (type != 0x08) {
if (type != MGT_BEACON) {
/* Do not count beacons in details */
d_te->number_of_packets++;
}
@ -397,12 +397,12 @@ wlanstat_packet (void *phs, packet_info *pinfo, epan_dissect_t *edt _U_, const v
te->is_broadcast = is_broadcast(&si->bssid);
} else {
for (tmp = hs->ep_list; tmp; tmp = tmp->next) {
if ((((si->type == 0x04) && (
if ((((si->type == MGT_PROBE_REQ) && (
((tmp->stats.ssid_len == 0) && (si->stats.ssid_len == 0) && tmp->is_broadcast)
|| ((si->stats.ssid_len != 0) && (ssid_equal(&tmp->stats, &si->stats)))
)))
||
((si->type != 0x04) && !CMP_ADDRESS(&tmp->bssid, &si->bssid))) {
((si->type != MGT_PROBE_REQ) && !CMP_ADDRESS(&tmp->bssid, &si->bssid))) {
te = tmp;
break;
}
@ -415,7 +415,7 @@ wlanstat_packet (void *phs, packet_info *pinfo, epan_dissect_t *edt _U_, const v
hs->ep_list = te;
}
if (!te->probe_req_searched && (si->type != 0x04) && (te->type[0x04] == 0) &&
if (!te->probe_req_searched && (si->type != MGT_PROBE_REQ) && (te->type[MGT_PROBE_REQ] == 0) &&
(si->stats.ssid_len > 1 || si->stats.ssid[0] != 0)) {
/*
* We have found a matching entry without Probe Requests.
@ -434,18 +434,18 @@ wlanstat_packet (void *phs, packet_info *pinfo, epan_dissect_t *edt _U_, const v
* Found a matching entry. Merge with the previous
* found entry and remove from list.
*/
te->type[0x04] += tmp->type[0x04];
te->type[MGT_PROBE_REQ] += tmp->type[MGT_PROBE_REQ];
te->number_of_packets += tmp->number_of_packets;
if (tmp->details && tmp->details->next) {
/* Adjust received probe requests */
wlan_details_ep_t *d_te;
d_te = get_details_ep (te, &tmp->details->addr);
d_te->probe_req += tmp->type[0x04];
d_te->number_of_packets += tmp->type[0x04];
d_te->probe_req += tmp->type[MGT_PROBE_REQ];
d_te->number_of_packets += tmp->type[MGT_PROBE_REQ];
d_te = get_details_ep (te, &tmp->details->next->addr);
d_te->probe_req += tmp->type[0x04];
d_te->number_of_packets += tmp->type[0x04];
d_te->probe_req += tmp->type[MGT_PROBE_REQ];
d_te->number_of_packets += tmp->type[MGT_PROBE_REQ];
}
if (prev) {
prev->next = tmp->next;
@ -504,8 +504,8 @@ wlanstat_draw_details(wlanstat_t *hs, wlan_ep_t *wlan_ep, gboolean clear)
broadcast_flag = is_broadcast(&tmp->addr);
basestation_flag = !broadcast_flag && !CMP_ADDRESS(&tmp->addr, &wlan_ep->bssid);
if ((wlan_ep->number_of_packets - wlan_ep->type[0x08]) > 0) {
f = (float)(((float)tmp->number_of_packets * 100.0) / (wlan_ep->number_of_packets - wlan_ep->type[0x08]));
if ((wlan_ep->number_of_packets - wlan_ep->type[MGT_BEACON]) > 0) {
f = (float)(((float)tmp->number_of_packets * 100.0) / (wlan_ep->number_of_packets - wlan_ep->type[MGT_BEACON]));
} else {
f = 0.0f;
}
@ -569,10 +569,10 @@ wlanstat_draw(void *phs)
continue;
}
data = tmp->type[0x20] + tmp->type[0x21] + tmp->type[0x22] + tmp->type[0x23] +
tmp->type[0x28] + tmp->type[0x29] + tmp->type[0x2A] + tmp->type[0x2B];
other = tmp->number_of_packets - data - tmp->type[0x08] - tmp->type[0x04] -
tmp->type[0x05] - tmp->type[0x0B] - tmp->type[0x0C];
data = tmp->type[DATA] + tmp->type[DATA_CF_ACK] + tmp->type[DATA_CF_POLL] + tmp->type[DATA_CF_ACK_POLL] +
tmp->type[DATA_QOS_DATA] + tmp->type[DATA_QOS_DATA_CF_ACK] + tmp->type[DATA_QOS_DATA_CF_POLL] + tmp->type[DATA_QOS_DATA_CF_ACK_POLL];
other = tmp->number_of_packets - data - tmp->type[MGT_BEACON] - tmp->type[MGT_PROBE_REQ] -
tmp->type[MGT_PROBE_RESP] - tmp->type[MGT_AUTHENTICATION] - tmp->type[MGT_DEAUTHENTICATION];
f = (float)(((float)tmp->number_of_packets * 100.0) / hs->number_of_packets);
bssid = (char*)get_conversation_address(NULL, &tmp->bssid, hs->resolve_names);
@ -599,12 +599,12 @@ wlanstat_draw(void *phs)
CHANNEL_COLUMN, channel,
SSID_COLUMN, ssid,
PERCENT_COLUMN, percent,
BEACONS_COLUMN, tmp->type[0x08],
BEACONS_COLUMN, tmp->type[MGT_BEACON],
DATA_COLUMN, data,
PROBE_REQ_COLUMN, tmp->type[0x04],
PROBE_RESP_COLUMN, tmp->type[0x05],
AUTH_COLUMN, tmp->type[0x0B],
DEAUTH_COLUMN, tmp->type[0x0C],
PROBE_REQ_COLUMN, tmp->type[MGT_PROBE_REQ],
PROBE_RESP_COLUMN, tmp->type[MGT_PROBE_RESP],
AUTH_COLUMN, tmp->type[MGT_AUTHENTICATION],
DEAUTH_COLUMN, tmp->type[MGT_DEAUTHENTICATION],
OTHER_COLUMN, other,
PROTECTION_COLUMN, tmp->stats.protection,
PERCENT_VALUE_COLUMN, f,