diff options
Diffstat (limited to 'epan/dissectors/packet-btmesh-pbadv.c')
-rw-r--r-- | epan/dissectors/packet-btmesh-pbadv.c | 140 |
1 files changed, 67 insertions, 73 deletions
diff --git a/epan/dissectors/packet-btmesh-pbadv.c b/epan/dissectors/packet-btmesh-pbadv.c index 5bd55c49..39ced414 100644 --- a/epan/dissectors/packet-btmesh-pbadv.c +++ b/epan/dissectors/packet-btmesh-pbadv.c @@ -36,44 +36,44 @@ void proto_register_btmesh_pbadv(void); void proto_reg_handoff_btmesh_pbadv(void); -static int proto_btmesh_pbadv = -1; +static int proto_btmesh_pbadv; static dissector_handle_t btmesh_provisioning_handle; -static int hf_btmesh_pbadv_linkid = -1; -static int hf_btmesh_pbadv_trnumber = -1; +static int hf_btmesh_pbadv_linkid; +static int hf_btmesh_pbadv_trnumber; -static int hf_btmesh_generic_provisioning_control_format = -1; -static int hf_btmesh_gpcf_segn = -1; -static int hf_btmesh_gpcf_total_length = -1; +static int hf_btmesh_generic_provisioning_control_format; +static int hf_btmesh_gpcf_segn; +static int hf_btmesh_gpcf_total_length; //TODO - check FCS -static int hf_btmesh_gpcf_fcs = -1; -static int hf_btmesh_gpcf_padding = -1; -static int hf_btmesh_gpcf_segment_index = -1; -static int hf_btmesh_gpcf_bearer_opcode = -1; -static int hf_btmesh_gpcf_bearer_opcode_device_UUID = -1; -static int hf_btmesh_gpcf_bearer_opcode_reason = -1; -static int hf_btmesh_gpcf_bearer_unknown_data = -1; - -static int hf_btmesh_gpp_payload = -1; -static int hf_btmesh_gpp_payload_fragment = -1; -static int hf_btmesh_gpp_fragments = -1; -static int hf_btmesh_gpp_fragment = -1; -static int hf_btmesh_gpp_fragment_overlap = -1; -static int hf_btmesh_gpp_fragment_overlap_conflict = -1; -static int hf_btmesh_gpp_fragment_multiple_tails = -1; -static int hf_btmesh_gpp_fragment_too_long_fragment = -1; -static int hf_btmesh_gpp_fragment_error = -1; -static int hf_btmesh_gpp_fragment_count = -1; -static int hf_btmesh_gpp_reassembled_length = -1; - -static int ett_btmesh_pbadv = -1; -static int ett_btmesh_generic_provisioning = -1; -static int ett_btmesh_gpp_fragments = -1; -static int ett_btmesh_gpp_fragment = -1; - -static expert_field ei_btmesh_gpcf_unknown_opcode = EI_INIT; -static expert_field ei_btmesh_gpcf_unknown_payload = EI_INIT; +static int hf_btmesh_gpcf_fcs; +static int hf_btmesh_gpcf_padding; +static int hf_btmesh_gpcf_segment_index; +static int hf_btmesh_gpcf_bearer_opcode; +static int hf_btmesh_gpcf_bearer_opcode_device_UUID; +static int hf_btmesh_gpcf_bearer_opcode_reason; +static int hf_btmesh_gpcf_bearer_unknown_data; + +static int hf_btmesh_gpp_payload; +static int hf_btmesh_gpp_payload_fragment; +static int hf_btmesh_gpp_fragments; +static int hf_btmesh_gpp_fragment; +static int hf_btmesh_gpp_fragment_overlap; +static int hf_btmesh_gpp_fragment_overlap_conflict; +static int hf_btmesh_gpp_fragment_multiple_tails; +static int hf_btmesh_gpp_fragment_too_long_fragment; +static int hf_btmesh_gpp_fragment_error; +static int hf_btmesh_gpp_fragment_count; +static int hf_btmesh_gpp_reassembled_length; + +static int ett_btmesh_pbadv; +static int ett_btmesh_generic_provisioning; +static int ett_btmesh_gpp_fragments; +static int ett_btmesh_gpp_fragment; + +static expert_field ei_btmesh_gpcf_unknown_opcode; +static expert_field ei_btmesh_gpcf_unknown_payload; static const fragment_items btmesh_gpp_frag_items = { &ett_btmesh_gpp_fragments, @@ -120,15 +120,15 @@ static const value_string btmesh_gpcf_bearer_opcode_reason_format[] = { static reassembly_table pbadv_reassembly_table; typedef struct _pbadv_fragment_key { - guint32 link_id; - guint8 transaction_number; + uint32_t link_id; + uint8_t transaction_number; } pbadv_fragment_key; -static guint -pbadv_fragment_hash(gconstpointer k) +static unsigned +pbadv_fragment_hash(const void *k) { const pbadv_fragment_key* key = (const pbadv_fragment_key*) k; - guint hash_val; + unsigned hash_val; hash_val = 0; @@ -137,18 +137,18 @@ pbadv_fragment_hash(gconstpointer k) return hash_val; } -static gint -pbadv_fragment_equal(gconstpointer k1, gconstpointer k2) +static int +pbadv_fragment_equal(const void *k1, const void *k2) { const pbadv_fragment_key* key1 = (const pbadv_fragment_key*) k1; const pbadv_fragment_key* key2 = (const pbadv_fragment_key*) k2; return ((key1->link_id == key2->link_id) && (key1->transaction_number == key2->transaction_number) - ? TRUE : FALSE); + ? true : false); } static void * -pbadv_fragment_temporary_key(const packet_info *pinfo _U_, const guint32 id _U_, +pbadv_fragment_temporary_key(const packet_info *pinfo _U_, const uint32_t id _U_, const void *data) { pbadv_fragment_key *key = g_slice_new(pbadv_fragment_key); @@ -161,7 +161,7 @@ pbadv_fragment_temporary_key(const packet_info *pinfo _U_, const guint32 id _U_, } static void -pbadv_fragment_free_temporary_key(gpointer ptr) +pbadv_fragment_free_temporary_key(void *ptr) { pbadv_fragment_key *key = (pbadv_fragment_key *)ptr; @@ -169,7 +169,7 @@ pbadv_fragment_free_temporary_key(gpointer ptr) } static void * -pbadv_fragment_persistent_key(const packet_info *pinfo _U_, const guint32 id _U_, +pbadv_fragment_persistent_key(const packet_info *pinfo _U_, const uint32_t id _U_, const void *data) { pbadv_fragment_key *key = g_slice_new(pbadv_fragment_key); @@ -182,7 +182,7 @@ pbadv_fragment_persistent_key(const packet_info *pinfo _U_, const guint32 id _U_ } static void -pbadv_fragment_free_persistent_key(gpointer ptr) +pbadv_fragment_free_persistent_key(void *ptr) { pbadv_fragment_key *key = (pbadv_fragment_key *)ptr; if (key) { @@ -199,30 +199,30 @@ static const reassembly_table_functions pbadv_reassembly_table_functions = { pbadv_fragment_free_persistent_key }; -static gint +static int dissect_btmesh_pbadv_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data _U_) { proto_item *item; proto_tree *sub_tree, *sub_tree_generic_provisioning; proto_item *ti; - gboolean defragment = FALSE; + bool defragment = false; int offset = 0; btle_mesh_transport_ctx_t tr_ctx; - guint8 segn, length; - guint32 total_length; - guint8 gpcf_bearer_opcode; + uint8_t segn, length; + uint32_t total_length; + uint8_t gpcf_bearer_opcode; col_set_str(pinfo->cinfo, COL_PROTOCOL, "BT Mesh PB-ADV"); item = proto_tree_add_item(tree, proto_btmesh_pbadv, tvb, offset, -1, ENC_NA); sub_tree = proto_item_add_subtree(item, ett_btmesh_pbadv); - guint32 pbadv_link_id = tvb_get_guint32(tvb, offset, ENC_BIG_ENDIAN); + uint32_t pbadv_link_id = tvb_get_uint32(tvb, offset, ENC_BIG_ENDIAN); proto_tree_add_item(sub_tree, hf_btmesh_pbadv_linkid, tvb, offset, 4, ENC_NA); offset += 4; - guint8 pbadv_trnumber = tvb_get_guint8(tvb, offset); + uint8_t pbadv_trnumber = tvb_get_uint8(tvb, offset); proto_tree_add_item(sub_tree, hf_btmesh_pbadv_trnumber, tvb, offset, 1, ENC_NA); offset += 1; @@ -233,31 +233,31 @@ dissect_btmesh_pbadv_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, vo sub_tree_generic_provisioning = proto_tree_add_subtree(sub_tree, tvb, offset, -1, ett_btmesh_generic_provisioning, &ti, "Generic Provisioning PDU"); proto_tree_add_item(sub_tree_generic_provisioning, hf_btmesh_generic_provisioning_control_format, tvb, offset, 1, ENC_NA); - guint8 gpcf = tvb_get_guint8(tvb, offset) & 0x03; + uint8_t gpcf = tvb_get_uint8(tvb, offset) & 0x03; col_set_str(pinfo->cinfo, COL_INFO, val_to_str_const(gpcf, btmesh_generic_provisioning_control_format, "Unknown PDU")); fragment_head *fd_head = NULL; - gint segment_index = -1; + int segment_index = -1; switch (gpcf) { //Transaction Start case TRANSACTION_START: proto_tree_add_item(sub_tree_generic_provisioning, hf_btmesh_gpcf_segn, tvb, offset, 1, ENC_NA); - segn = (tvb_get_guint8(tvb, offset) & 0xFC) >> 2; + segn = (tvb_get_uint8(tvb, offset) & 0xFC) >> 2; offset += 1; - total_length = (guint32)tvb_get_guint16(tvb, offset, ENC_BIG_ENDIAN); + total_length = (uint32_t)tvb_get_uint16(tvb, offset, ENC_BIG_ENDIAN); proto_tree_add_item(sub_tree_generic_provisioning, hf_btmesh_gpcf_total_length, tvb, offset, 2, ENC_NA); offset += 2; proto_tree_add_item(sub_tree_generic_provisioning, hf_btmesh_gpcf_fcs, tvb, offset, 1, ENC_NA); offset += 1; segment_index = 0; - defragment = TRUE; + defragment = true; if (segn == 0) { if (btmesh_provisioning_handle) { length = tvb_reported_length(tvb); tr_ctx.transport = E_BTMESH_TR_ADV; - tr_ctx.fragmented = FALSE; + tr_ctx.fragmented = false; tr_ctx.segment_index = 0; call_dissector_with_data(btmesh_provisioning_handle, tvb_new_subset_length(tvb, offset, length), pinfo, proto_tree_get_root(sub_tree_generic_provisioning), &tr_ctx); @@ -277,7 +277,7 @@ dissect_btmesh_pbadv_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, vo BTMESH_PB_ADV_NOT_USED, &frg_key, 0, tvb_captured_length_remaining(tvb, offset), - TRUE); + true); if (!fd_head) { //Set the length only when not reassembled fragment_set_tot_len(&pbadv_reassembly_table, pinfo, BTMESH_PB_ADV_NOT_USED, &frg_key, total_length); @@ -296,8 +296,8 @@ dissect_btmesh_pbadv_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, vo //Transaction Continuation case TRANSACTION_CONTINUATION: proto_tree_add_item(sub_tree_generic_provisioning, hf_btmesh_gpcf_segment_index, tvb, offset, 1, ENC_NA); - segment_index = (tvb_get_guint8(tvb, offset) & 0xFC) >> 2; - defragment = TRUE; + segment_index = (tvb_get_uint8(tvb, offset) & 0xFC) >> 2; + defragment = true; offset += 1; //Segmentation if (!pinfo->fd->visited) { @@ -306,7 +306,7 @@ dissect_btmesh_pbadv_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, vo BTMESH_PB_ADV_NOT_USED, &frg_key, 20 + (segment_index - 1) * 23, tvb_captured_length_remaining(tvb, offset), - TRUE); + true); } else { proto_tree_add_item(sub_tree_generic_provisioning, hf_btmesh_gpp_payload_fragment, tvb, offset, -1, ENC_NA); } @@ -315,7 +315,7 @@ dissect_btmesh_pbadv_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, vo //Provisioning Bearer Control case PROVISIONING_BEARER_CONTROL: proto_tree_add_item(sub_tree_generic_provisioning, hf_btmesh_gpcf_bearer_opcode, tvb, offset, 1, ENC_NA); - gpcf_bearer_opcode = (tvb_get_guint8(tvb, offset) & 0xFC) >> 2; + gpcf_bearer_opcode = (tvb_get_uint8(tvb, offset) & 0xFC) >> 2; offset += 1; switch(gpcf_bearer_opcode) { case LINK_OPEN: @@ -356,7 +356,7 @@ dissect_btmesh_pbadv_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, vo col_append_str(pinfo->cinfo, COL_INFO, " (Message Reassembled)"); if (btmesh_provisioning_handle) { tr_ctx.transport = E_BTMESH_TR_ADV; - tr_ctx.fragmented = TRUE; + tr_ctx.fragmented = true; tr_ctx.segment_index = segment_index; call_dissector_with_data(btmesh_provisioning_handle, next_tvb, pinfo, proto_tree_get_root(sub_tree_generic_provisioning), &tr_ctx); @@ -372,12 +372,6 @@ dissect_btmesh_pbadv_msg(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, vo return tvb_reported_length(tvb); } -static void -pbadv_init_routine(void) -{ - reassembly_table_register(&pbadv_reassembly_table, &pbadv_reassembly_table_functions); -} - void proto_register_btmesh_pbadv(void) { @@ -459,7 +453,7 @@ proto_register_btmesh_pbadv(void) { &hf_btmesh_gpp_fragments, { "Reassembled Generic Provisioning Payload Fragments", "pbadv.gen_prov.gpp.fragments", FT_NONE, BASE_NONE, NULL, 0x0, - "Generic Provisioning Payload Fragments", HFILL } + NULL, HFILL } }, { &hf_btmesh_gpp_fragment, { "Generic Provisioning Payload Fragment", "pbadv.gen_prov.gpp.fragment", @@ -503,7 +497,7 @@ proto_register_btmesh_pbadv(void) }, }; - static gint *ett[] = { + static int *ett[] = { &ett_btmesh_pbadv, &ett_btmesh_generic_provisioning, &ett_btmesh_gpp_fragments, @@ -528,7 +522,7 @@ proto_register_btmesh_pbadv(void) prefs_register_protocol_subtree("Bluetooth", proto_btmesh_pbadv, NULL); register_dissector("btmesh.pbadv", dissect_btmesh_pbadv_msg, proto_btmesh_pbadv); - register_init_routine(&pbadv_init_routine); + reassembly_table_register(&pbadv_reassembly_table, &pbadv_reassembly_table_functions); } void |