summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGuy Harris <guy@alum.mit.edu>2015-07-02 19:51:22 -0700
committerGuy Harris <guy@alum.mit.edu>2015-07-03 02:51:51 +0000
commit363511cb670a42e449bb4e208775715748b81879 (patch)
treef41db4124f1c2a75c613468e792996546d610f86
parentdf5a315048e9b318f7862901c1bd40fa2c08dad5 (diff)
downloadwireshark-363511cb670a42e449bb4e208775715748b81879.tar.gz
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>
-rw-r--r--epan/dissectors/packet-ieee80211.c160
-rw-r--r--epan/dissectors/packet-ieee80211.h160
-rw-r--r--ui/gtk/wlan_stat_dlg.c66
3 files changed, 193 insertions, 193 deletions
diff --git a/epan/dissectors/packet-ieee80211.c b/epan/dissectors/packet-ieee80211.c
index ae7c4112dc..52ffcb6acc 100644
--- a/epan/dissectors/packet-ieee80211.c
+++ b/epan/dissectors/packet-ieee80211.c
@@ -313,98 +313,6 @@ static gboolean is_80211ad(proto_node * pnode, gpointer data) {
}
/*
- * 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) */
diff --git a/epan/dissectors/packet-ieee80211.h b/epan/dissectors/packet-ieee80211.h
index 4086903e62..df63bf2e77 100644
--- a/epan/dissectors/packet-ieee80211.h
+++ b/epan/dissectors/packet-ieee80211.h
@@ -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;
diff --git a/ui/gtk/wlan_stat_dlg.c b/ui/gtk/wlan_stat_dlg.c
index 278b58823e..8b92c3e8fe 100644
--- a/ui/gtk/wlan_stat_dlg.c
+++ b/ui/gtk/wlan_stat_dlg.c
@@ -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,