diff options
Diffstat (limited to 'plugins/docsis/packet-dscrsp.c')
-rw-r--r-- | plugins/docsis/packet-dscrsp.c | 31 |
1 files changed, 10 insertions, 21 deletions
diff --git a/plugins/docsis/packet-dscrsp.c b/plugins/docsis/packet-dscrsp.c index 684d98e69d..dba96622b5 100644 --- a/plugins/docsis/packet-dscrsp.c +++ b/plugins/docsis/packet-dscrsp.c @@ -46,34 +46,23 @@ static int dissect_dscrsp (tvbuff_t * tvb, packet_info * pinfo, proto_tree * tree, void* data _U_) { proto_item *it; - proto_tree *dscrsp_tree = NULL; - guint16 transid; - guint8 response; + proto_tree *dscrsp_tree; + guint32 transid, response; tvbuff_t *next_tvb; - transid = tvb_get_ntohs (tvb, 0); - response = tvb_get_guint8 (tvb, 2); + it = proto_tree_add_item(tree, proto_docsis_dscrsp, tvb, 0, -1, ENC_NA); + dscrsp_tree = proto_item_add_subtree (it, ett_docsis_dscrsp); + proto_tree_add_item_ret_uint (dscrsp_tree, hf_docsis_dscrsp_tranid, tvb, 0, 2, ENC_BIG_ENDIAN, &transid); + proto_tree_add_item_ret_uint (dscrsp_tree, hf_docsis_dscrsp_response, tvb, 2, 1, ENC_BIG_ENDIAN, &response); col_add_fstr (pinfo->cinfo, COL_INFO, "Dynamic Service Change Response ID = %u (%s)", transid, val_to_str (response, docsis_conf_code, "%d")); - if (tree) - { - it = - proto_tree_add_protocol_format (tree, proto_docsis_dscrsp, tvb, 0, -1, - "DSC Response"); - dscrsp_tree = proto_item_add_subtree (it, ett_docsis_dscrsp); - proto_tree_add_item (dscrsp_tree, hf_docsis_dscrsp_tranid, tvb, 0, 2, - ENC_BIG_ENDIAN); - proto_tree_add_item (dscrsp_tree, hf_docsis_dscrsp_response, tvb, 2, 1, - ENC_BIG_ENDIAN); - - } - /* Call Dissector for Appendix C TLV's */ - next_tvb = tvb_new_subset_remaining (tvb, 3); - call_dissector (docsis_tlv_handle, next_tvb, pinfo, dscrsp_tree); - return tvb_captured_length(tvb); + /* Call Dissector for Appendix C TLV's */ + next_tvb = tvb_new_subset_remaining (tvb, 3); + call_dissector (docsis_tlv_handle, next_tvb, pinfo, dscrsp_tree); + return tvb_captured_length(tvb); } /* Register the protocol with Wireshark */ |