diff options
Diffstat (limited to 'epan/dissectors/packet-dvb-data-mpe.c')
-rw-r--r-- | epan/dissectors/packet-dvb-data-mpe.c | 47 |
1 files changed, 22 insertions, 25 deletions
diff --git a/epan/dissectors/packet-dvb-data-mpe.c b/epan/dissectors/packet-dvb-data-mpe.c index ad947838ac..21ef8b3e8e 100644 --- a/epan/dissectors/packet-dvb-data-mpe.c +++ b/epan/dissectors/packet-dvb-data-mpe.c @@ -30,7 +30,7 @@ #include <glib.h> #include <epan/packet.h> -#include <epan/prefs.h> +#include <epan/dissectors/packet-mpeg-sect.h> static int proto_dvb_data_mpe = -1; static int hf_dvb_data_mpe_reserved = -1; @@ -47,7 +47,7 @@ static gint ett_dvb_data_mpe = -1; static dissector_handle_t ip_handle; static dissector_handle_t llc_handle; -#define DVB_DATA_MPE_TID 0x3E +#define DVB_DATA_MPE_TID 0x3E #define DVB_DATA_MPE_RESERVED_MASK 0xC0 @@ -57,7 +57,7 @@ static dissector_handle_t llc_handle; #define DVB_DATA_MPE_CURRENT_NEXT_INDICATOR_MASK 0x01 static const value_string dvb_rcs_cur_next_vals[] = { - + { 0x0, "Not yet applicable" }, { 0x1, "Currently applicable" }, { 0, NULL }, @@ -65,33 +65,31 @@ static const value_string dvb_rcs_cur_next_vals[] = { }; -void +static void dissect_dvb_data_mpe(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) { - guint offset = 0; - guint8 llc_snap_flag = 0; - int i; + guint offset = 0, tot_len = 0; + guint8 llc_snap_flag = 0; + int i; - proto_item *ti = NULL; + proto_item *ti = NULL; proto_tree *dvb_data_mpe_tree = NULL; - tvbuff_t *mac_tvb = NULL; - tvbuff_t *mac_bytes_tvb[6] = {0}; - tvbuff_t *data_tvb = NULL; + tvbuff_t *mac_tvb = NULL; + tvbuff_t *mac_bytes_tvb[6]; + tvbuff_t *data_tvb = NULL; /* The TVB should start right after the section_length in the Section packet */ - col_clear(pinfo->cinfo, COL_PROTOCOL); col_set_str(pinfo->cinfo, COL_PROTOCOL, "DVB-DATA"); - col_clear(pinfo->cinfo, COL_INFO); col_set_str(pinfo->cinfo, COL_INFO, "MultiProtocol Encapsulation"); - if (!tree) - return; - ti = proto_tree_add_item(tree, proto_dvb_data_mpe, tvb, offset, -1, ENC_NA); dvb_data_mpe_tree = proto_item_add_subtree(ti, ett_dvb_data_mpe); + offset += packet_mpeg_sect_header(tvb, offset, dvb_data_mpe_tree, &tot_len, NULL); + + /* Parse the DMC-CC private section header */ mac_bytes_tvb[5] = tvb_new_subset(tvb, offset, 1, 1); @@ -126,10 +124,9 @@ dissect_dvb_data_mpe(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) tvb_composite_finalize(mac_tvb); proto_tree_add_item(dvb_data_mpe_tree, hf_dvb_data_mpe_dst_mac, mac_tvb, 0 , 6, ENC_NA); - col_clear(pinfo->cinfo, COL_RES_DL_DST); col_add_str(pinfo->cinfo, COL_RES_DL_DST, tvb_ether_to_str(mac_tvb, 0)); - data_tvb = tvb_new_subset(tvb, offset, -1, -1); + data_tvb = tvb_new_subset_remaining(tvb, offset); if (llc_snap_flag) { call_dissector(llc_handle, data_tvb, pinfo, tree); @@ -137,8 +134,7 @@ dissect_dvb_data_mpe(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) call_dissector(ip_handle, data_tvb, pinfo, tree); } - - + packet_mpeg_sect_crc(tvb, pinfo, dvb_data_mpe_tree, 0, tot_len - 1); return; } @@ -148,7 +144,7 @@ proto_register_dvb_data_mpe(void) { static hf_register_info hf[] = { - + /* DSM-CC common fields */ { &hf_dvb_data_mpe_reserved, { "Reserved", "dvb_data_mpe.reserved", @@ -164,7 +160,7 @@ proto_register_dvb_data_mpe(void) "Address Scrambling Control", "dvb_data_mpe.addr_scrambling", FT_UINT8, BASE_HEX, NULL, DVB_DATA_MPE_ADDRESS_SCRAMBLING_MASK, NULL, HFILL } }, - + { &hf_dvb_data_mpe_llc_snap_flag, { "LLC SNAP Flag", "dvb_data_mpe.llc_snap_flag", FT_UINT8, BASE_HEX, NULL, DVB_DATA_MPE_LLC_SNAP_FLAG_MASK, NULL, HFILL @@ -179,7 +175,7 @@ proto_register_dvb_data_mpe(void) "Section Number", "dvb_data_mpe.sect_num", FT_UINT8, BASE_DEC, NULL, 0, NULL, HFILL } }, - + { &hf_dvb_data_mpe_last_section_number, { "Last Section Number", "dvb_data_mpe.last_sect_num", FT_UINT8, BASE_DEC, NULL, 0, NULL, HFILL @@ -201,19 +197,20 @@ proto_register_dvb_data_mpe(void) proto_register_field_array(proto_dvb_data_mpe, hf, array_length(hf)); proto_register_subtree_array(ett, array_length(ett)); - + } void proto_reg_handoff_dvb_data_mpe(void) { + dissector_handle_t dvb_data_mpe_handle; dvb_data_mpe_handle = create_dissector_handle(dissect_dvb_data_mpe, proto_dvb_data_mpe); dissector_add_uint("mpeg_sect.tid", DVB_DATA_MPE_TID, dvb_data_mpe_handle); - ip_handle = find_dissector("ip"); + ip_handle = find_dissector("ip"); llc_handle = find_dissector("llc"); } |