summaryrefslogtreecommitdiffstats
path: root/epan/dissectors/packet-tipc.c
diff options
context:
space:
mode:
Diffstat (limited to 'epan/dissectors/packet-tipc.c')
-rw-r--r--epan/dissectors/packet-tipc.c499
1 files changed, 254 insertions, 245 deletions
diff --git a/epan/dissectors/packet-tipc.c b/epan/dissectors/packet-tipc.c
index a556ed6a..9a9dd9d3 100644
--- a/epan/dissectors/packet-tipc.c
+++ b/epan/dissectors/packet-tipc.c
@@ -12,7 +12,8 @@
*
* SPDX-License-Identifier: GPL-2.0-or-later
* Protocol ref:
- * http://tipc.sourceforge.net/
+ * https://tipc.sourceforge.net/
+ * https://tipc.sourceforge.net/protocol.html
*/
@@ -30,171 +31,171 @@
void proto_register_tipc(void);
-static int proto_tipc = -1;
-
-static int hf_tipc_msg_fragments = -1;
-static int hf_tipc_msg_fragment = -1;
-static int hf_tipc_msg_fragment_overlap = -1;
-static int hf_tipc_msg_fragment_overlap_conflicts = -1;
-static int hf_tipc_msg_fragment_multiple_tails = -1;
-static int hf_tipc_msg_fragment_too_long_fragment = -1;
-static int hf_tipc_msg_fragment_error = -1;
-static int hf_tipc_msg_fragment_count = -1;
-static int hf_tipc_msg_reassembled_in = -1;
-static int hf_tipc_msg_reassembled_length = -1;
-
-static int hf_tipc_ver = -1;
-static int hf_tipc_usr = -1;
-static int hf_tipcv2_usr = -1;
-static int hf_tipc_hdr_size = -1;
-static int hf_tipc_nonsequenced = -1;
-static int hf_tipc_destdrop = -1;
-static int hf_tipc_unused = -1;
-static int hf_tipc_msg_size = -1;
-static int hf_tipc_ack_link_lev_seq = -1;
-static int hf_tipc_link_lev_seq = -1;
-static int hf_tipc_prev_proc = -1;
-static int hf_tipc_org_port = -1;
-static int hf_tipc_dst_port = -1;
-static int hf_tipc_data_msg_type = -1;
-static int hf_tipc_err_code = -1;
-static int hf_tipc_reroute_cnt = -1;
-static int hf_tipc_act_id = -1;
-static int hf_tipc_org_proc = -1;
-static int hf_tipc_dst_proc = -1;
-static int hf_tipc_unused2 = -1;
-static int hf_tipc_importance = -1;
-static int hf_tipc_link_selector = -1;
-static int hf_tipc_msg_cnt = -1;
-static int hf_tipc_probe = -1;
-static int hf_tipc_bearer_id = -1;
-static int hf_tipc_link_selector2 = -1;
-static int hf_tipc_remote_addr = -1;
-static int hf_tipc_rm_msg_type = -1;
-static int hf_tipc_nd_msg_type = -1;
-static int hf_tipc_cm_msg_type = -1;
-static int hf_tipc_lp_msg_type = -1;
-static int hf_tipc_cng_prot_msg_type = -1;
-static int hf_tipc_sm_msg_type = -1;
-static int hf_tipc_unknown_msg_type = -1;
-static int hf_tipc_seq_gap = -1;
-static int hf_tipc_nxt_snt_pkg = -1;
-static int hf_tipc_unused_word = -1;
-static int hf_tipc_bearer_name = -1;
-static int hf_tipc_data = -1;
-static int hf_tipc_msg_no_bundle = -1;
-static int hf_tipc_changeover_protocol = -1;
-static int hf_tipc_named_msg_hdr = -1;
-static int hf_tipc_port_name_type = -1;
-static int hf_tipc_port_name_instance = -1;
-static int hf_tipc_data_fragment = -1;
-static int hf_tipc_message_bundle = -1;
-
-
-static int hf_tipc_name_dist_type = -1;
-static int hf_tipc_name_dist_lower = -1;
-static int hf_tipc_name_dist_upper = -1;
-static int hf_tipc_name_dist_port = -1;
-static int hf_tipc_name_dist_key = -1;
-
-static int hf_tipcv2_srcdrop = -1;
-static int hf_tipcv2_data_msg_type = -1;
-static int hf_tipcv2_bcast_mtype = -1;
-static int hf_tipcv2_bundler_mtype = -1;
-static int hf_tipcv2_link_mtype = -1;
-static int hf_tipcv2_connmgr_mtype = -1;
-static int hf_tipcv2_route_mtype_1_6 = -1;
-static int hf_tipcv2_route_mtype_1_7 = -1;
-static int hf_tipcv2_changeover_mtype = -1;
-static int hf_tipcv2_naming_mtype = -1;
-static int hf_tipcv2_fragmenter_mtype = -1;
-static int hf_tipcv2_neighbour_mtype = -1;
-static int hf_tipcv2_errorcode = -1;
-static int hf_tipcv2_rer_cnt = -1;
-static int hf_tipcv2_lookup_scope = -1;
-static int hf_tipcv2_opt_p = -1;
-static int hf_tipcv2_broadcast_ack_no = -1;
-static int hf_tipcv2_link_level_ack_no = -1;
-static int hf_tipcv2_link_level_seq_no = -1;
-/* static int hf_tipcv2_bcast_seq_no = -1; */
-static int hf_tipcv2_prev_node = -1;
-static int hf_tipcv2_orig_node = -1;
-static int hf_tipcv2_dest_node = -1;
-static int hf_tipcv2_port_name_type = -1;
-static int hf_tipcv2_port_name_instance = -1;
-static int hf_tipcv2_multicast_lower = -1;
-static int hf_tipcv2_multicast_upper = -1;
-
-static int hf_tipcv2_sequence_gap = -1;
-static int hf_tipcv2_next_sent_broadcast = -1;
-static int hf_tipcv2_fragment_number = -1;
-static int hf_tipcv2_fragment_msg_number = -1;
-static int hf_tipcv2_next_sent_packet = -1;
-static int hf_tipcv2_session_no = -1;
-static int hf_tipcv2_link_prio = -1;
-static int hf_tipcv2_network_plane = -1;
-static int hf_tipcv2_probe = -1;
-static int hf_tipcv2_link_tolerance = -1;
-static int hf_tipcv2_bearer_instance = -1;
-static int hf_tipcv2_padding = -1;
-static int hf_tipcv2_bearer_level_orig_addr = -1;
-static int hf_tipcv2_cluster_address = -1;
-static int hf_tipcv2_bitmap = -1;
-static int hf_tipcv2_node_address = -1;
-static int hf_tipcv2_destination_domain = -1;
-static int hf_tipcv2_network_id = -1;
-
-static int hf_tipcv2_bcast_tag = -1;
-static int hf_tipcv2_msg_count = -1;
-static int hf_tipcv2_max_packet = -1;
-static int hf_tipcv2_transport_seq_no = -1;
-static int hf_tipcv2_redundant_link = -1;
-static int hf_tipcv2_bearer_id = -1;
-static int hf_tipcv2_conn_mgr_msg_ack = -1;
-static int hf_tipcv2_minor_pv = -1;
-static int hf_tipcv2_node_sig = -1;
-static int hf_tipcv2_filler_mtu_discovery = -1;
-static int hf_tipcv2_vendor_specific_data = -1;
-static int hf_tipcv2_options = -1;
+static int proto_tipc;
+
+static int hf_tipc_msg_fragments;
+static int hf_tipc_msg_fragment;
+static int hf_tipc_msg_fragment_overlap;
+static int hf_tipc_msg_fragment_overlap_conflicts;
+static int hf_tipc_msg_fragment_multiple_tails;
+static int hf_tipc_msg_fragment_too_long_fragment;
+static int hf_tipc_msg_fragment_error;
+static int hf_tipc_msg_fragment_count;
+static int hf_tipc_msg_reassembled_in;
+static int hf_tipc_msg_reassembled_length;
+
+static int hf_tipc_ver;
+static int hf_tipc_usr;
+static int hf_tipcv2_usr;
+static int hf_tipc_hdr_size;
+static int hf_tipc_nonsequenced;
+static int hf_tipc_destdrop;
+static int hf_tipc_unused;
+static int hf_tipc_msg_size;
+static int hf_tipc_ack_link_lev_seq;
+static int hf_tipc_link_lev_seq;
+static int hf_tipc_prev_proc;
+static int hf_tipc_org_port;
+static int hf_tipc_dst_port;
+static int hf_tipc_data_msg_type;
+static int hf_tipc_err_code;
+static int hf_tipc_reroute_cnt;
+static int hf_tipc_act_id;
+static int hf_tipc_org_proc;
+static int hf_tipc_dst_proc;
+static int hf_tipc_unused2;
+static int hf_tipc_importance;
+static int hf_tipc_link_selector;
+static int hf_tipc_msg_cnt;
+static int hf_tipc_probe;
+static int hf_tipc_bearer_id;
+static int hf_tipc_link_selector2;
+static int hf_tipc_remote_addr;
+static int hf_tipc_rm_msg_type;
+static int hf_tipc_nd_msg_type;
+static int hf_tipc_cm_msg_type;
+static int hf_tipc_lp_msg_type;
+static int hf_tipc_cng_prot_msg_type;
+static int hf_tipc_sm_msg_type;
+static int hf_tipc_unknown_msg_type;
+static int hf_tipc_seq_gap;
+static int hf_tipc_nxt_snt_pkg;
+static int hf_tipc_unused_word;
+static int hf_tipc_bearer_name;
+static int hf_tipc_data;
+static int hf_tipc_msg_no_bundle;
+static int hf_tipc_changeover_protocol;
+static int hf_tipc_named_msg_hdr;
+static int hf_tipc_port_name_type;
+static int hf_tipc_port_name_instance;
+static int hf_tipc_data_fragment;
+static int hf_tipc_message_bundle;
+
+
+static int hf_tipc_name_dist_type;
+static int hf_tipc_name_dist_lower;
+static int hf_tipc_name_dist_upper;
+static int hf_tipc_name_dist_port;
+static int hf_tipc_name_dist_key;
+
+static int hf_tipcv2_srcdrop;
+static int hf_tipcv2_data_msg_type;
+static int hf_tipcv2_bcast_mtype;
+static int hf_tipcv2_bundler_mtype;
+static int hf_tipcv2_link_mtype;
+static int hf_tipcv2_connmgr_mtype;
+static int hf_tipcv2_route_mtype_1_6;
+static int hf_tipcv2_route_mtype_1_7;
+static int hf_tipcv2_changeover_mtype;
+static int hf_tipcv2_naming_mtype;
+static int hf_tipcv2_fragmenter_mtype;
+static int hf_tipcv2_neighbour_mtype;
+static int hf_tipcv2_errorcode;
+static int hf_tipcv2_rer_cnt;
+static int hf_tipcv2_lookup_scope;
+static int hf_tipcv2_opt_p;
+static int hf_tipcv2_broadcast_ack_no;
+static int hf_tipcv2_link_level_ack_no;
+static int hf_tipcv2_link_level_seq_no;
+/* static int hf_tipcv2_bcast_seq_no; */
+static int hf_tipcv2_prev_node;
+static int hf_tipcv2_orig_node;
+static int hf_tipcv2_dest_node;
+static int hf_tipcv2_port_name_type;
+static int hf_tipcv2_port_name_instance;
+static int hf_tipcv2_multicast_lower;
+static int hf_tipcv2_multicast_upper;
+
+static int hf_tipcv2_sequence_gap;
+static int hf_tipcv2_next_sent_broadcast;
+static int hf_tipcv2_fragment_number;
+static int hf_tipcv2_fragment_msg_number;
+static int hf_tipcv2_next_sent_packet;
+static int hf_tipcv2_session_no;
+static int hf_tipcv2_link_prio;
+static int hf_tipcv2_network_plane;
+static int hf_tipcv2_probe;
+static int hf_tipcv2_link_tolerance;
+static int hf_tipcv2_bearer_instance;
+static int hf_tipcv2_padding;
+static int hf_tipcv2_bearer_level_orig_addr;
+static int hf_tipcv2_cluster_address;
+static int hf_tipcv2_bitmap;
+static int hf_tipcv2_node_address;
+static int hf_tipcv2_destination_domain;
+static int hf_tipcv2_network_id;
+
+static int hf_tipcv2_bcast_tag;
+static int hf_tipcv2_msg_count;
+static int hf_tipcv2_max_packet;
+static int hf_tipcv2_transport_seq_no;
+static int hf_tipcv2_redundant_link;
+static int hf_tipcv2_bearer_id;
+static int hf_tipcv2_conn_mgr_msg_ack;
+static int hf_tipcv2_minor_pv;
+static int hf_tipcv2_node_sig;
+static int hf_tipcv2_filler_mtu_discovery;
+static int hf_tipcv2_vendor_specific_data;
+static int hf_tipcv2_options;
/* added for TIPC v1.7 */
-static int hf_tipcv2_timestamp = -1;
-static int hf_tipcv2_item_size = -1;
-static int hf_tipcv2_network_region = -1;
-static int hf_tipcv2_local_router = -1;
-static int hf_tipcv2_remote_router = -1;
-static int hf_tipcv2_dist_dist = -1;
-static int hf_tipcv2_dist_scope = -1;
-static int hf_tipcv2_name_dist_port_id_node = -1;
-static int hf_tipcv2_media_id = -1;
+static int hf_tipcv2_timestamp;
+static int hf_tipcv2_item_size;
+static int hf_tipcv2_network_region;
+static int hf_tipcv2_local_router;
+static int hf_tipcv2_remote_router;
+static int hf_tipcv2_dist_dist;
+static int hf_tipcv2_dist_scope;
+static int hf_tipcv2_name_dist_port_id_node;
+static int hf_tipcv2_media_id;
/* added in minor PV 1 */
-static int hf_tipcv2_syn = -1;
+static int hf_tipcv2_syn;
-static gint ett_tipc_msg_fragment = -1;
-static gint ett_tipc_msg_fragments = -1;
+static int ett_tipc_msg_fragment;
+static int ett_tipc_msg_fragments;
/* Initialize the subtree pointer */
-static gint ett_tipc = -1;
-static gint ett_tipc_data = -1;
+static int ett_tipc;
+static int ett_tipc_data;
-static expert_field ei_tipc_field_not_specified = EI_INIT;
-static expert_field ei_tipc_invalid_bundle_size = EI_INIT;
-static expert_field ei_tipc_max_recursion_depth_reached = EI_INIT;
+static expert_field ei_tipc_field_not_specified;
+static expert_field ei_tipc_invalid_bundle_size;
+static expert_field ei_tipc_max_recursion_depth_reached;
static int tipc_address_type = -1;
/* protocol preferences */
-static gboolean tipc_defragment = TRUE;
-static gboolean dissect_tipc_data = TRUE;
-static gboolean try_heuristic_first = FALSE;
+static bool tipc_defragment = true;
+static bool dissect_tipc_data = true;
+static bool try_heuristic_first;
#define V2_AS_ALL 0x1
#define V2_AS_1_6 0x2
#define V2_AS_1_7 0x4
-static gint handle_v2_as = V2_AS_ALL;
-static gboolean tipc_tcp_desegment = TRUE;
+static int handle_v2_as = V2_AS_ALL;
+static bool tipc_tcp_desegment = true;
static dissector_handle_t tipc_handle;
static dissector_handle_t tipc_tcp_handle;
@@ -567,12 +568,12 @@ void proto_reg_handoff_tipc(void);
static reassembly_table tipc_msg_reassembly_table;
-static gchar*
-tipc_addr_value_to_buf(guint tipc_address, gchar *buf, int buf_len)
+static char*
+tipc_addr_value_to_buf(unsigned tipc_address, char *buf, int buf_len)
{
- guint8 zone;
- guint16 subnetwork;
- guint16 processor;
+ uint8_t zone;
+ uint16_t subnetwork;
+ uint16_t processor;
processor = tipc_address & 0x0fff;
@@ -586,20 +587,20 @@ tipc_addr_value_to_buf(guint tipc_address, gchar *buf, int buf_len)
return buf;
}
-static gchar *
-tipc_addr_to_str(guint tipc_address)
+static char *
+tipc_addr_to_str(unsigned tipc_address)
{
- gchar *buf;
+ char *buf;
- buf = (gchar *)wmem_alloc(wmem_packet_scope(), MAX_TIPC_ADDRESS_STR_LEN);
+ buf = (char *)wmem_alloc(wmem_packet_scope(), MAX_TIPC_ADDRESS_STR_LEN);
return tipc_addr_value_to_buf(tipc_address, buf, MAX_TIPC_ADDRESS_STR_LEN);
}
static int
-tipc_addr_to_str_buf(const address* addr, gchar *buf, int buf_len)
+tipc_addr_to_str_buf(const address* addr, char *buf, int buf_len)
{
- const guint8 *data = (const guint8 *)addr->data;
- guint32 tipc_address;
+ const uint8_t *data = (const uint8_t *)addr->data;
+ uint32_t tipc_address;
tipc_address = data[0];
tipc_address = (tipc_address << 8) ^ data[1];
@@ -629,11 +630,11 @@ tipc_addr_str_len(const address* addr _U_)
};
*/
static void
-dissect_tipc_name_dist_data(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, guint8 item_size)
+dissect_tipc_name_dist_data(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, uint8_t item_size)
{
int offset = 0;
- guint32 dword;
- gchar *addr_str_ptr;
+ uint32_t dword;
+ char *addr_str_ptr;
if ((handle_v2_as & V2_AS_1_6) || ((handle_v2_as & (V2_AS_ALL) && item_size == 0))) {
/* TIPC 1.6 */
@@ -680,12 +681,12 @@ dissect_tipc_name_dist_data(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
/* Set message type in COL INFO and return type of message (data or Internal message type */
static void
-tipc_v2_set_info_col(tvbuff_t *tvb, packet_info *pinfo, guint8 user, guint8 msg_type, guint8 hdr_size)
+tipc_v2_set_info_col(tvbuff_t *tvb, packet_info *pinfo, uint8_t user, uint8_t msg_type, uint8_t hdr_size)
{
- guint32 portNameInst, dword;
- guint32 portNameType, portNameInstLow, portNameInstHigh;
- guint8 error;
- /*guint8 item_size = 0;*/
+ uint32_t portNameInst, dword;
+ uint32_t portNameType, portNameInstLow, portNameInstHigh;
+ uint8_t error;
+ /*uint8_t item_size = 0;*/
switch (user) {
case TIPCv2_DATA_LOW:
@@ -771,10 +772,10 @@ tipc_v2_set_info_col(tvbuff_t *tvb, packet_info *pinfo, guint8 user, guint8 msg_
}
/* Set message type in COL INFO and return type of message (data or Internal message type */
-static gboolean
-tipc_v1_set_col_msgtype(packet_info *pinfo, guint8 user, guint8 msg_type)
+static bool
+tipc_v1_set_col_msgtype(packet_info *pinfo, uint8_t user, uint8_t msg_type)
{
- gboolean datatype_hdr = FALSE;
+ bool datatype_hdr = false;
switch (user) {
case TIPC_DATA_PRIO_0:
@@ -784,7 +785,7 @@ tipc_v1_set_col_msgtype(packet_info *pinfo, guint8 user, guint8 msg_type)
/*
* src and dest address will be found at different location depending on User as hdr_size
*/
- datatype_hdr = TRUE;
+ datatype_hdr = true;
col_append_fstr(pinfo->cinfo, COL_INFO, "%s(%u) ", val_to_str_const(msg_type, tipc_data_msg_type_values, "unknown"), msg_type);
break;
case TIPC_NAME_DISTRIBUTOR:
@@ -847,28 +848,30 @@ w9:| msg count | link tolerance |
*/
static int
-dissect_tipc_v2_internal_msg(tvbuff_t *tipc_tvb, proto_tree *tipc_tree, packet_info *pinfo, int offset, guint8 user, guint32 msg_size, guint8 orig_hdr_size)
+// NOLINTNEXTLINE(misc-no-recursion)
+dissect_tipc_v2_internal_msg(tvbuff_t *tipc_tvb, proto_tree *tipc_tree, packet_info *pinfo, int offset, uint8_t user, uint32_t msg_size, uint8_t orig_hdr_size)
{
- guint32 dword;
- gchar *addr_str_ptr;
+ uint32_t dword;
+ char *addr_str_ptr;
tvbuff_t *data_tvb;
- guint8 message_type;
- guint8 item_size = 0;
- guint16 message_count;
- guint msg_no = 0;
- guint32 msg_in_bundle_size;
- guint8 msg_in_bundle_user;
- gint b_inst_strlen, padlen;
+ uint8_t message_type;
+ uint8_t item_size = 0;
+ uint16_t message_count;
+ unsigned msg_no = 0;
+ uint32_t msg_in_bundle_size;
+ uint8_t msg_in_bundle_user;
+ uint32_t b_inst_strlen;
+ int padlen;
/* for fragmented messages */
- gint len, reported_len;
- gboolean save_fragmented;
- guint32 frag_no, frag_msg_no;
+ int len, reported_len;
+ bool save_fragmented;
+ uint32_t frag_no, frag_msg_no;
tvbuff_t* new_tvb = NULL;
fragment_head *frag_msg = NULL;
proto_item *ti;
- message_type = (tvb_get_guint8(tipc_tvb, offset) >>5) & 0x7;
+ message_type = (tvb_get_uint8(tipc_tvb, offset) >>5) & 0x7;
switch (user) {
case TIPCv2_BCAST_PROTOCOL:
@@ -1000,7 +1003,7 @@ dissect_tipc_v2_internal_msg(tvbuff_t *tipc_tvb, proto_tree *tipc_tree, packet_i
offset = offset + 4;
/* This should give equal results like
* while (message_count-- > 0) */
- while ((guint32)offset < msg_size) {
+ while ((uint32_t)offset < msg_size) {
msg_no++;
dword = tvb_get_ntohl(tipc_tvb, offset);
@@ -1095,19 +1098,22 @@ dissect_tipc_v2_internal_msg(tvbuff_t *tipc_tvb, proto_tree *tipc_tree, packet_i
if ((message_type == TIPCv2_RESET_MSG)
|| ((message_type == TIPCv2_STATE_MSG) && ((msg_size-(orig_hdr_size*4)) != 0))){ /* is allowed */
- proto_tree_add_item(tipc_tree, hf_tipcv2_bearer_instance, tipc_tvb, offset, -1, ENC_ASCII);
- /* the bearer instance string is padded with \0 to the next word boundry */
- b_inst_strlen = tvb_strsize(tipc_tvb, offset);
+ proto_tree_add_item_ret_length(tipc_tree, hf_tipcv2_bearer_instance, tipc_tvb, offset, -1, ENC_ASCII, &b_inst_strlen);
offset += b_inst_strlen;
+ /* the bearer instance string is padded with \0 to the next word boundary */
if ((padlen = ((b_inst_strlen%4)?(4-(b_inst_strlen%4)):0)) > 0) {
proto_tree_add_bytes_format_value(tipc_tree, hf_tipcv2_padding, tipc_tvb, offset, padlen, NULL, "%d byte%c", padlen, (padlen!=1?'s':0));
offset += padlen;
}
- if ((offset-msg_size) > 0) {
- int filler_len;
-
- filler_len = tvb_reported_length_remaining(tipc_tvb, offset);
- proto_tree_add_bytes_format_value(tipc_tree, hf_tipcv2_filler_mtu_discovery, tipc_tvb, offset, -1, NULL,
+ /*
+ * If there's any data left, show it as
+ * padding for MTU discovery.
+ */
+ if ((uint32_t)offset < msg_size) {
+ uint32_t filler_len;
+
+ filler_len = msg_size - (uint32_t)offset;
+ proto_tree_add_bytes_format_value(tipc_tree, hf_tipcv2_filler_mtu_discovery, tipc_tvb, offset, filler_len, NULL,
"%d byte%c", filler_len, (filler_len!=1?'s':0));
}
}
@@ -1122,7 +1128,7 @@ dissect_tipc_v2_internal_msg(tvbuff_t *tipc_tvb, proto_tree *tipc_tree, packet_i
/* Options Position: 3 bits */
/* this is not used by this user according to Jon Maloy in tipc-discussion mailing list
- opt_p = tvb_get_guint8(tipc_tvb, offset+1) & 0x7;
+ opt_p = tvb_get_uint8(tipc_tvb, offset+1) & 0x7;
proto_tree_add_item(tipc_tree, hf_tipcv2_opt_p , tipc_tvb, offset, 4, ENC_BIG_ENDIAN);
if (opt_p != 0) {
hdr_size = hdr_size - (opt_p << 2);
@@ -1496,7 +1502,7 @@ dissect_tipc_v2_internal_msg(tvbuff_t *tipc_tvb, proto_tree *tipc_tree, packet_i
if (tipc_defragment) {
/* reassemble fragmented packages */
save_fragmented = pinfo->fragmented;
- pinfo->fragmented = TRUE;
+ pinfo->fragmented = true;
frag_msg = fragment_add_seq_check(&tipc_msg_reassembly_table,
tipc_tvb, offset,
@@ -1656,10 +1662,10 @@ wA:| multicast upper bound |
/* this function tries to call subdissectors for encapsulated data
* @name_type pointer to the used port name type, NULL if not available
- * @user guint8 holding the used TIPC user, is allways available
+ * @user uint8_t holding the used TIPC user, is allways available
*/
static void
-call_tipc_v2_data_subdissectors(tvbuff_t *data_tvb, packet_info *pinfo, guint32 *name_type_p, guint8 user)
+call_tipc_v2_data_subdissectors(tvbuff_t *data_tvb, packet_info *pinfo, uint32_t *name_type_p, uint8_t user)
{
if (dissect_tipc_data) {
heur_dtbl_entry_t *hdtbl_entry;
@@ -1724,19 +1730,20 @@ call_tipc_v2_data_subdissectors(tvbuff_t *data_tvb, packet_info *pinfo, guint32
static void
-dissect_tipc_v2(tvbuff_t *tipc_tvb, proto_tree *tipc_tree, packet_info *pinfo, int offset, guint8 user, guint32 msg_size, guint8 hdr_size, gboolean datatype_hdr)
+// NOLINTNEXTLINE(misc-no-recursion)
+dissect_tipc_v2(tvbuff_t *tipc_tvb, proto_tree *tipc_tree, packet_info *pinfo, int offset, uint8_t user, uint32_t msg_size, uint8_t hdr_size, bool datatype_hdr)
{
- guint32 dword;
- gchar *addr_str_ptr;
- guint8 opt_p = 0;
+ uint32_t dword;
+ char *addr_str_ptr;
+ uint8_t opt_p = 0;
proto_item *item;
/* The unit used is 32 bit words */
- guint8 orig_hdr_size;
+ uint8_t orig_hdr_size;
- guint32 name_type = 0;
- guint32 *name_type_p = NULL;
+ uint32_t name_type = 0;
+ uint32_t *name_type_p = NULL;
tvbuff_t *data_tvb;
- gint len, reported_len;
+ int len, reported_len;
orig_hdr_size = hdr_size;
@@ -1782,7 +1789,7 @@ dissect_tipc_v2(tvbuff_t *tipc_tvb, proto_tree *tipc_tree, packet_info *pinfo, i
/* Options Position: 3 bits */
if (handle_v2_as & (V2_AS_ALL + V2_AS_1_6)) {
- opt_p = tvb_get_guint8(tipc_tvb, offset+1) & 0x7;
+ opt_p = tvb_get_uint8(tipc_tvb, offset+1) & 0x7;
proto_tree_add_item(tipc_tree, hf_tipcv2_opt_p, tipc_tvb, offset, 4, ENC_BIG_ENDIAN);
if (opt_p != 0) {
hdr_size = hdr_size - (opt_p << 2);
@@ -1913,19 +1920,20 @@ NB: Connection Manager and Name Distributor use data message format.
*/
static void
-dissect_tipc_int_prot_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tipc_tree, int offset, guint8 user, guint32 msg_size)
+// NOLINTNEXTLINE(misc-no-recursion)
+dissect_tipc_int_prot_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tipc_tree, int offset, uint8_t user, uint32_t msg_size)
{
- guint8 msg_type;
+ uint8_t msg_type;
tvbuff_t *data_tvb;
- guint32 msg_in_bundle_size;
- guint32 dword;
- guint msg_no = 0;
- guint8 link_sel;
- guint16 link_lev_seq_no;
- guint32 reassembled_msg_length = 0;
- guint32 no_of_segments = 0;
-
- gboolean save_fragmented;
+ uint32_t msg_in_bundle_size;
+ uint32_t dword;
+ unsigned msg_no = 0;
+ uint8_t link_sel;
+ uint16_t link_lev_seq_no;
+ uint32_t reassembled_msg_length = 0;
+ uint32_t no_of_segments = 0;
+
+ bool save_fragmented;
tvbuff_t* new_tvb = NULL;
tvbuff_t* next_tvb = NULL;
fragment_head *frag_msg = NULL;
@@ -1935,7 +1943,7 @@ dissect_tipc_int_prot_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tipc_tr
/* Internal Protocol Header */
/* Unused */
- msg_type = tvb_get_guint8(tvb, 20)>>4;
+ msg_type = tvb_get_uint8(tvb, 20)>>4;
/* W3 */
dword = tvb_get_ntohl(tvb, offset);
link_sel = dword & 0x7;
@@ -2038,7 +2046,7 @@ dissect_tipc_int_prot_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tipc_tr
case TIPC_SEGMENTATION_MANAGER:
save_fragmented = pinfo->fragmented;
if (tipc_defragment) {
- pinfo->fragmented = TRUE;
+ pinfo->fragmented = true;
frag_msg = fragment_add_seq_next(&tipc_msg_reassembly_table,
tvb, offset,
@@ -2046,7 +2054,7 @@ dissect_tipc_int_prot_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tipc_tr
link_sel, /* ID for fragments belonging together - NEEDS IMPROVING? */
NULL,
tvb_captured_length_remaining(tvb, offset), /* fragment length - to the end */
- TRUE); /* More fragments? */
+ true); /* More fragments? */
if (msg_type == TIPC_FIRST_SEGMENT) {
reassembled_msg_length = tvb_get_ntohl(tvb, offset) & 0x1ffff;
/* The number of segments needed for he complete message (Including header) will be
@@ -2093,12 +2101,12 @@ dissect_tipc_int_prot_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tipc_tr
break;
case TIPC_MSG_BUNDLER:
proto_tree_add_item(tipc_tree, hf_tipc_message_bundle, tvb, offset, -1, ENC_NA);
- while ((guint32)offset < msg_size) {
+ while ((uint32_t)offset < msg_size) {
msg_no++;
msg_in_bundle_size = tvb_get_ntohl(tvb, offset) & 0x1FFFF;
item = proto_tree_add_uint_format(tipc_tree, hf_tipc_msg_no_bundle, tvb, offset, 1, msg_no, "%u Message in Bundle", msg_no);
- gint remaining = tvb_reported_length_remaining(tvb, offset);
- if (remaining > 0 && msg_in_bundle_size <= (guint)remaining) {
+ int remaining = tvb_reported_length_remaining(tvb, offset);
+ if (remaining > 0 && msg_in_bundle_size <= (unsigned)remaining) {
proto_item_set_len(item, msg_in_bundle_size);
data_tvb = tvb_new_subset_length(tvb, offset, msg_in_bundle_size);
col_set_fence(pinfo->cinfo, COL_INFO);
@@ -2118,7 +2126,7 @@ dissect_tipc_int_prot_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tipc_tr
/* determines the length of a TIPC package */
-static guint
+static unsigned
get_tipc_pdu_len(packet_info *pinfo _U_, tvbuff_t *tvb, int offset, void *data _U_)
{
return tvb_get_ntohl(tvb, offset) & 0x0001FFFF;
@@ -2136,20 +2144,21 @@ dissect_tipc_tcp(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent_tree, voi
#define TIPC_MAX_RECURSION_DEPTH 10 // Arbitrary
static int
+// NOLINTNEXTLINE(misc-no-recursion)
dissect_tipc(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data _U_)
{
proto_item *ti, *item;
proto_tree *tipc_tree, *tipc_data_tree;
int offset = 0;
- guint32 srcport, destport = 0, dword;
- guint8 version;
- guint32 msg_size;
- guint8 hdr_size;
- guint8 user;
- gchar *addr_str_ptr;
+ uint32_t srcport, destport = 0, dword;
+ uint8_t version;
+ uint32_t msg_size;
+ uint8_t hdr_size;
+ uint8_t user;
+ char *addr_str_ptr;
tvbuff_t *data_tvb, *tipc_tvb;
- gboolean datatype_hdr = FALSE;
- guint8 msg_type = 0;
+ bool datatype_hdr = false;
+ uint8_t msg_type = 0;
/* Make entry in Protocol column on summary display */
col_set_str(pinfo->cinfo, COL_PROTOCOL, "TIPC");
@@ -2170,7 +2179,7 @@ dissect_tipc(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data _U_
}
p_set_proto_depth(pinfo, proto_tipc, recursion_depth);
- if ((guint32)tvb_reported_length_remaining(tvb, offset) < msg_size) {
+ if ((uint32_t)tvb_reported_length_remaining(tvb, offset) < msg_size) {
tipc_tvb = tvb;
} else {
tipc_tvb = tvb_new_subset_length(tvb, offset, msg_size);
@@ -2181,7 +2190,7 @@ dissect_tipc(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data _U_
switch (version) {
case 0:
case TIPCv1:
- msg_type = tvb_get_guint8(tipc_tvb, offset + 20)>>4;
+ msg_type = tvb_get_uint8(tipc_tvb, offset + 20)>>4;
col_append_fstr(pinfo->cinfo, COL_INFO, " %s(%u) ", val_to_str_const(user, tipc_user_values, "unknown"), user);
/* Set msg type in info col and find out if it's a data hdr or not */
datatype_hdr = tipc_v1_set_col_msgtype(pinfo, user, msg_type);
@@ -2204,7 +2213,7 @@ dissect_tipc(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data _U_
}
break;
case TIPCv2:
- msg_type = tvb_get_guint8(tipc_tvb, offset + 4)>>5;
+ msg_type = tvb_get_uint8(tipc_tvb, offset + 4)>>5;
col_append_fstr(pinfo->cinfo, COL_INFO, "%-12s", val_to_str_const(user, tipcv2_user_short_str_vals, "unknown"));
/* Set msg type in info col */
tipc_v2_set_info_col(tvb, pinfo, user, msg_type, hdr_size);
@@ -2215,10 +2224,10 @@ dissect_tipc(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data _U_
case TIPCv2_DATA_NORMAL:
case TIPCv2_DATA_HIGH:
case TIPCv2_DATA_NON_REJECTABLE:
- datatype_hdr = TRUE;
+ datatype_hdr = true;
break;
default:
- datatype_hdr = FALSE;
+ datatype_hdr = false;
break;
}
@@ -2387,8 +2396,8 @@ dissect_tipc(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data _U_
if (user < 4 && dissect_tipc_data) { /* DATA type user */
tvbuff_t *next_tvb;
- guint32 msg_type32 = msg_type;
- guint32 *name_type_p = &msg_type32;
+ uint32_t msg_type32 = msg_type;
+ uint32_t *name_type_p = &msg_type32;
switch (msg_type) {
case TIPC_CONNECTED_MSG:
proto_tree_add_item(tipc_tree, hf_tipc_data, tipc_tvb, offset, -1, ENC_NA);
@@ -3054,7 +3063,7 @@ proto_register_tipc(void)
};
/* Setup protocol subtree array */
- static gint *ett[] = {
+ static int *ett[] = {
&ett_tipc,
&ett_tipc_data,
&ett_tipc_msg_fragment,
@@ -3100,7 +3109,7 @@ proto_register_tipc(void)
"TIPC port name type", proto_tipc, FT_UINT32, BASE_DEC);
/* make heuristic dissectors possible */
- tipc_heur_subdissector_list = register_heur_dissector_list("tipc", proto_tipc);
+ tipc_heur_subdissector_list = register_heur_dissector_list_with_description("tipc", "TIPC v2 data", proto_tipc);
/* Register by name */
tipc_handle = register_dissector("tipc", dissect_tipc, proto_tipc);
@@ -3135,7 +3144,7 @@ proto_register_tipc(void)
"TIPC 1.7 removes/adds fields (not) available in TIPC 1.5/1.6 while keeping the version number 2 in the packages. \"ALL\" shows all fields that were ever used in both versions.",
&handle_v2_as,
handle_v2_as_options,
- TRUE);
+ true);
prefs_register_bool_preference(tipc_module, "desegment",
"Reassemble TIPC-over-TCP messages spanning multiple TCP segments",