summaryrefslogtreecommitdiffstats
path: root/epan/dissectors/packet-netperfmeter.c
diff options
context:
space:
mode:
Diffstat (limited to 'epan/dissectors/packet-netperfmeter.c')
-rw-r--r--epan/dissectors/packet-netperfmeter.c245
1 files changed, 124 insertions, 121 deletions
diff --git a/epan/dissectors/packet-netperfmeter.c b/epan/dissectors/packet-netperfmeter.c
index 9e5349ab..543703b3 100644
--- a/epan/dissectors/packet-netperfmeter.c
+++ b/epan/dissectors/packet-netperfmeter.c
@@ -19,24 +19,27 @@
#include <epan/packet.h>
#include <epan/sctpppids.h>
#include <epan/stat_tap_ui.h>
+#include <epan/tfs.h>
+
+#include <wsutil/array.h>
void proto_register_npm(void);
void proto_reg_handoff_npm(void);
static dissector_handle_t npm_handle;
-static int proto_npm = -1;
+static int proto_npm;
static int tap_npm = -1;
-static int ett_npm = -1;
-static int ett_addflow_flags = -1;
-static int ett_identifyflow_flags = -1;
-static int ett_start_flags = -1;
-static int ett_data_flags = -1;
-static int ett_results_flags = -1;
-static int ett_onoffarray = -1;
+static int ett_npm;
+static int ett_addflow_flags;
+static int ett_identifyflow_flags;
+static int ett_start_flags;
+static int ett_data_flags;
+static int ett_results_flags;
+static int ett_onoffarray;
-static guint64 npm_total_msgs = 0;
-static guint64 npm_total_bytes = 0;
+static uint64_t npm_total_msgs;
+static uint64_t npm_total_bytes;
#define PPID_NETPERFMETER_CONTROL_LEGACY 0x29097605
@@ -66,83 +69,83 @@ static const value_string message_type_values[] = {
{ 0, NULL }
};
-static int hf_message_type = -1;
-static int hf_message_flags = -1;
-static int hf_message_length = -1;
-
-static int hf_acknowledge_flowid = -1;
-static int hf_acknowledge_measurementid = -1;
-static int hf_acknowledge_streamid = -1;
-// static int hf_acknowledge_padding = -1;
-static int hf_acknowledge_status = -1;
-
-static int hf_addflow_flag_debug = -1;
-static int hf_addflow_flag_nodelay = -1;
-static int hf_addflow_flag_repeatonoff = -1;
-static int hf_addflow_flowid = -1;
-static int hf_addflow_measurementid = -1;
-static int hf_addflow_streamid = -1;
-static int hf_addflow_protocol = -1;
-static int hf_addflow_flags = -1;
-static int hf_addflow_description = -1;
-static int hf_addflow_ordered = -1;
-static int hf_addflow_reliable = -1;
-static int hf_addflow_retranstrials = -1;
-static int hf_addflow_framerate1 = -1;
-static int hf_addflow_framerate2 = -1;
-static int hf_addflow_framerate3 = -1;
-static int hf_addflow_framerate4 = -1;
-static int hf_addflow_framesize1 = -1;
-static int hf_addflow_framesize2 = -1;
-static int hf_addflow_framesize3 = -1;
-static int hf_addflow_framesize4 = -1;
-static int hf_addflow_frameraterng = -1;
-static int hf_addflow_framesizerng = -1;
-static int hf_addflow_rcvbuffersize = -1;
-static int hf_addflow_sndbuffersize = -1;
-static int hf_addflow_maxmsgsize = -1;
-static int hf_addflow_cmt = -1;
-static int hf_addflow_ccid = -1;
-static int hf_addflow_onoffevents = -1;
-static int hf_addflow_onoffeventarray = -1;
-
-static int hf_removeflow_flowid = -1;
-static int hf_removeflow_measurementid = -1;
-static int hf_removeflow_streamid = -1;
-
-static int hf_identifyflow_flag_compress_vectors = -1;
-static int hf_identifyflow_flag_no_vectors = -1;
-static int hf_identifyflow_flowid = -1;
-static int hf_identifyflow_magicnumber = -1;
-static int hf_identifyflow_measurementid = -1;
-static int hf_identifyflow_streamid = -1;
+static int hf_message_type;
+static int hf_message_flags;
+static int hf_message_length;
+
+static int hf_acknowledge_flowid;
+static int hf_acknowledge_measurementid;
+static int hf_acknowledge_streamid;
+// static int hf_acknowledge_padding;
+static int hf_acknowledge_status;
+
+static int hf_addflow_flag_debug;
+static int hf_addflow_flag_nodelay;
+static int hf_addflow_flag_repeatonoff;
+static int hf_addflow_flowid;
+static int hf_addflow_measurementid;
+static int hf_addflow_streamid;
+static int hf_addflow_protocol;
+static int hf_addflow_flags;
+static int hf_addflow_description;
+static int hf_addflow_ordered;
+static int hf_addflow_reliable;
+static int hf_addflow_retranstrials;
+static int hf_addflow_framerate1;
+static int hf_addflow_framerate2;
+static int hf_addflow_framerate3;
+static int hf_addflow_framerate4;
+static int hf_addflow_framesize1;
+static int hf_addflow_framesize2;
+static int hf_addflow_framesize3;
+static int hf_addflow_framesize4;
+static int hf_addflow_frameraterng;
+static int hf_addflow_framesizerng;
+static int hf_addflow_rcvbuffersize;
+static int hf_addflow_sndbuffersize;
+static int hf_addflow_maxmsgsize;
+static int hf_addflow_cmt;
+static int hf_addflow_ccid;
+static int hf_addflow_onoffevents;
+static int hf_addflow_onoffeventarray;
+
+static int hf_removeflow_flowid;
+static int hf_removeflow_measurementid;
+static int hf_removeflow_streamid;
+
+static int hf_identifyflow_flag_compress_vectors;
+static int hf_identifyflow_flag_no_vectors;
+static int hf_identifyflow_flowid;
+static int hf_identifyflow_magicnumber;
+static int hf_identifyflow_measurementid;
+static int hf_identifyflow_streamid;
#define NETPERFMETER_IDENTIFY_FLOW_MAGIC_NUMBER 0x4bcdf3aa303c6774ULL
-static int hf_data_flag_frame_begin = -1;
-static int hf_data_flag_frame_end = -1;
-static int hf_data_flowid = -1;
-static int hf_data_measurementid = -1;
-static int hf_data_streamid = -1;
-static int hf_data_padding = -1;
-static int hf_data_frameid = -1;
-static int hf_data_packetseqnumber = -1;
-static int hf_data_byteseqnumber = -1;
-static int hf_data_timestamp = -1;
-static int hf_data_payload = -1;
+static int hf_data_flag_frame_begin;
+static int hf_data_flag_frame_end;
+static int hf_data_flowid;
+static int hf_data_measurementid;
+static int hf_data_streamid;
+static int hf_data_padding;
+static int hf_data_frameid;
+static int hf_data_packetseqnumber;
+static int hf_data_byteseqnumber;
+static int hf_data_timestamp;
+static int hf_data_payload;
-static int hf_start_flag_compress_vectors = -1;
-static int hf_start_flag_compress_scalars = -1;
-static int hf_start_flag_no_vectors = -1;
-static int hf_start_flag_no_scalars = -1;
-// static int hf_start_padding = -1;
-static int hf_start_measurementid = -1;
+static int hf_start_flag_compress_vectors;
+static int hf_start_flag_compress_scalars;
+static int hf_start_flag_no_vectors;
+static int hf_start_flag_no_scalars;
+// static int hf_start_padding;
+static int hf_start_measurementid;
-// static int hf_stop_padding = -1;
-static int hf_stop_measurementid = -1;
+// static int hf_stop_padding;
+static int hf_stop_measurementid;
-static int hf_results_flag_eof = -1;
-static int hf_results_data = -1;
+static int hf_results_flag_eof;
+static int hf_results_data;
/* Setup list of Transport Layer protocol types */
@@ -279,8 +282,8 @@ static hf_register_info hf[] = {
typedef struct _tap_npm_rec_t {
- guint8 type;
- guint16 size;
+ uint8_t type;
+ uint16_t size;
const char* type_string;
} tap_npm_rec_t;
@@ -299,12 +302,12 @@ dissect_npm_acknowledge_message(tvbuff_t *message_tvb, proto_tree *message_tree)
static void
dissect_npm_add_flow_message(tvbuff_t *message_tvb, proto_tree *message_tree, proto_item *flags_item)
{
- guint32 retranstrials;
+ uint32_t retranstrials;
proto_item* onoffitem;
proto_tree* onofftree;
proto_tree* flags_tree;
- guint16 onoffevents;
- guint32 onoffvalue;
+ uint16_t onoffevents;
+ uint32_t onoffvalue;
unsigned int i;
flags_tree = proto_item_add_subtree(flags_item, ett_addflow_flags);
@@ -353,9 +356,9 @@ dissect_npm_add_flow_message(tvbuff_t *message_tvb, proto_tree *message_tree, pr
if (onoffevents > 0) {
onofftree = proto_item_add_subtree(onoffitem, ett_onoffarray);
for(i = 0;i < onoffevents;i++) {
- onoffvalue = tvb_get_ntohl(message_tvb, 144 + (int)(sizeof(guint32) * i));
+ onoffvalue = tvb_get_ntohl(message_tvb, 144 + (int)(sizeof(uint32_t) * i));
proto_tree_add_uint_format(onofftree, hf_addflow_onoffeventarray, message_tvb,
- 144 + (int)(sizeof(guint32) * i), (int)sizeof(guint32),
+ 144 + (int)(sizeof(uint32_t) * i), (int)sizeof(uint32_t),
onoffvalue, "%1.3f s: set to %s", onoffvalue / 1000.0, (i & 1) ? "OFF" : "ON");
}
}
@@ -391,8 +394,8 @@ static void
dissect_npm_data_message(tvbuff_t *message_tvb, proto_tree *message_tree, proto_item *flags_item)
{
proto_tree* flags_tree;
- const guint16 message_length = tvb_get_ntohs(message_tvb, 2);
- guint64 timestamp;
+ const uint16_t message_length = tvb_get_ntohs(message_tvb, 2);
+ uint64_t timestamp;
nstime_t t;
flags_tree = proto_item_add_subtree(flags_item, ett_data_flags);
@@ -449,7 +452,7 @@ dissect_npm_results_message(tvbuff_t *message_tvb, proto_tree *message_tree, pro
flags_tree = proto_item_add_subtree(flags_item, ett_data_flags);
proto_tree_add_item(flags_tree, hf_results_flag_eof, message_tvb, 1, 1, ENC_BIG_ENDIAN);
- const guint16 message_length = tvb_get_ntohs(message_tvb, 2);
+ const uint16_t message_length = tvb_get_ntohs(message_tvb, 2);
if (message_length > 4) {
proto_tree_add_item(message_tree, hf_results_data, message_tvb, 4, message_length - 4, ENC_NA);
}
@@ -462,7 +465,7 @@ dissect_npm_message(tvbuff_t *message_tvb, packet_info *pinfo, proto_tree *npm_t
proto_tree* flags_tree;
tap_npm_rec_t* tap_rec = wmem_new0(pinfo->pool, tap_npm_rec_t);
- tap_rec->type = tvb_get_guint8(message_tvb, 0);
+ tap_rec->type = tvb_get_uint8(message_tvb, 0);
tap_rec->size = tvb_get_ntohs(message_tvb, 2);
tap_rec->type_string = val_to_str_const(tap_rec->type, message_type_values, "Unknown NetPerfMeter message type");
tap_queue_packet(tap_npm, pinfo, tap_rec);
@@ -520,46 +523,46 @@ dissect_npm(tvbuff_t *message_tvb, packet_info *pinfo, proto_tree *tree, void *d
};
/* dissect the message */
dissect_npm_message(message_tvb, pinfo, npm_tree);
- return TRUE;
+ return true;
}
-static int
-heur_dissect_npm(tvbuff_t *message_tvb, packet_info *pinfo, proto_tree *tree, void *data _U_)
+static bool
+dissect_npm_heur(tvbuff_t *message_tvb, packet_info *pinfo, proto_tree *tree, void *data _U_)
{
- const guint length = tvb_captured_length(message_tvb);
+ const unsigned length = tvb_captured_length(message_tvb);
if (length < 4)
- return FALSE;
+ return false;
/* For TCP, UDP or DCCP:
Type must either be NETPERFMETER_DATA or NETPERFMETER_IDENTIFY_FLOW */
- const guint8 type = tvb_get_guint8(message_tvb, 0);
+ const uint8_t type = tvb_get_uint8(message_tvb, 0);
switch(type) {
case NETPERFMETER_DATA:
if (length < 48 + 8)
- return FALSE;
+ return false;
/* Identify NetPerfMeter flow by payload pattern */
for(int i = 0; i < 8; i++) {
- guint8 d = tvb_get_guint8(message_tvb, 48 + i);
+ uint8_t d = tvb_get_uint8(message_tvb, 48 + i);
if( (d != 30 + i) && (d != 127 - i) )
- return FALSE;
+ return false;
}
break;
case NETPERFMETER_IDENTIFY_FLOW:
if (length < 24 + 2)
- return FALSE;
+ return false;
if (tvb_get_ntoh64(message_tvb, 8) != NETPERFMETER_IDENTIFY_FLOW_MAGIC_NUMBER) {
/* Identify NetPerfMeter flow by NETPERFMETER_IDENTIFY_FLOW_MAGIC_NUMBER */
- return FALSE;
+ return false;
}
break;
default:
/* Not a NetPerfMeter packet */
- return FALSE;
+ return false;
break;
}
-
- return dissect_npm(message_tvb, pinfo, tree, data);
+ dissect_npm(message_tvb, pinfo, tree, data);
+ return true;
}
@@ -594,10 +597,10 @@ static stat_tap_table_item npm_stat_fields[] = {
static void npm_stat_init(stat_tap_table_ui* new_stat)
{
const char *table_name = "NetPerfMeter Statistics";
- int num_fields = sizeof(npm_stat_fields)/sizeof(stat_tap_table_item);
+ int num_fields = array_length(npm_stat_fields);
stat_tap_table *table;
int i = 0;
- stat_tap_table_item_type items[sizeof(npm_stat_fields)/sizeof(stat_tap_table_item)];
+ stat_tap_table_item_type items[array_length(npm_stat_fields)];
table = stat_tap_find_table(new_stat, table_name);
if (table) {
@@ -645,9 +648,9 @@ npm_stat_packet(void* tapdata, packet_info* pinfo _U_, epan_dissect_t* edt _U_,
const tap_npm_rec_t* tap_rec = (const tap_npm_rec_t*)data;
stat_tap_table* table;
stat_tap_table_item_type* msg_data;
- gint idx;
- guint64 messages;
- guint64 bytes;
+ int idx;
+ uint64_t messages;
+ uint64_t bytes;
int i = 0;
double firstSeen = -1.0;
double lastSeen = -1.0;
@@ -675,9 +678,9 @@ npm_stat_packet(void* tapdata, packet_info* pinfo _U_, epan_dissect_t* edt _U_,
/* Update messages and bytes share */
while (message_type_values[i].strptr) {
msg_data = stat_tap_get_field_data(table, i, MESSAGES_COLUMN);
- const guint m = msg_data->value.uint_value;
+ const unsigned m = msg_data->value.uint_value;
msg_data = stat_tap_get_field_data(table, i, BYTES_COLUMN);
- const guint b = msg_data->value.uint_value;
+ const unsigned b = msg_data->value.uint_value;
msg_data = stat_tap_get_field_data(table, i, MESSAGES_SHARE_COLUMN);
msg_data->type = TABLE_ITEM_FLOAT;
@@ -735,7 +738,7 @@ npm_stat_packet(void* tapdata, packet_info* pinfo _U_, epan_dissect_t* edt _U_,
static void
npm_stat_reset(stat_tap_table* table)
{
- guint element;
+ unsigned element;
stat_tap_table_item_type* item_data;
for (element = 0; element < table->num_elements; element++) {
@@ -792,7 +795,7 @@ void
proto_register_npm(void)
{
/* Setup protocol subtree array */
- static gint *ett[] = {
+ static int *ett[] = {
&ett_npm,
&ett_addflow_flags,
&ett_identifyflow_flags,
@@ -803,7 +806,7 @@ proto_register_npm(void)
};
static tap_param npm_stat_params[] = {
- { PARAM_FILTER, "filter", "Filter", NULL, TRUE }
+ { PARAM_FILTER, "filter", "Filter", NULL, true }
};
static stat_tap_table_ui npm_stat_table = {
@@ -816,8 +819,8 @@ proto_register_npm(void)
npm_stat_reset,
NULL,
NULL,
- sizeof(npm_stat_fields)/sizeof(stat_tap_table_item), npm_stat_fields,
- sizeof(npm_stat_params)/sizeof(tap_param), npm_stat_params,
+ array_length(npm_stat_fields), npm_stat_fields,
+ array_length(npm_stat_params), npm_stat_params,
NULL,
0
};
@@ -847,9 +850,9 @@ proto_reg_handoff_npm(void)
dissector_add_uint("sctp.ppi", NPMP_DATA_PAYLOAD_PROTOCOL_ID, npm_handle);
/* Heuristic dissector for TCP, UDP and DCCP */
- heur_dissector_add("tcp", heur_dissect_npm, "NetPerfMeter over TCP", "netperfmeter_tcp", proto_npm, HEURISTIC_ENABLE);
- heur_dissector_add("udp", heur_dissect_npm, "NetPerfMeter over UDP", "netperfmeter_udp", proto_npm, HEURISTIC_ENABLE);
- heur_dissector_add("dccp", heur_dissect_npm, "NetPerfMeter over DCCP", "netperfmeter_dccp", proto_npm, HEURISTIC_ENABLE);
+ heur_dissector_add("tcp", dissect_npm_heur, "NetPerfMeter over TCP", "netperfmeter_tcp", proto_npm, HEURISTIC_ENABLE);
+ heur_dissector_add("udp", dissect_npm_heur, "NetPerfMeter over UDP", "netperfmeter_udp", proto_npm, HEURISTIC_ENABLE);
+ heur_dissector_add("dccp", dissect_npm_heur, "NetPerfMeter over DCCP", "netperfmeter_dccp", proto_npm, HEURISTIC_ENABLE);
}
/*