diff options
author | stig <stig@f5534014-38df-0310-8fa8-9805f1628bb7> | 2007-08-15 22:34:56 +0000 |
---|---|---|
committer | stig <stig@f5534014-38df-0310-8fa8-9805f1628bb7> | 2007-08-15 22:34:56 +0000 |
commit | 17e2603789b76d468d5b4bc75a10bc468cd0f79c (patch) | |
tree | 8009a989efa5ecbb4d5d9bae7f7252ca8e6ae486 /epan | |
parent | 70aab5888161d46f9eabb8b039d2c5650c0c5cf3 (diff) |
Improved dumping of unexpected data when dissector for OID not implemented.
git-svn-id: http://anonsvn.wireshark.org/wireshark/trunk@22517 f5534014-38df-0310-8fa8-9805f1628bb7
Diffstat (limited to 'epan')
-rw-r--r-- | epan/dissectors/packet-ber.c | 28 |
1 files changed, 24 insertions, 4 deletions
diff --git a/epan/dissectors/packet-ber.c b/epan/dissectors/packet-ber.c index 32f112c08a..d920d05b51 100644 --- a/epan/dissectors/packet-ber.c +++ b/epan/dissectors/packet-ber.c @@ -572,20 +572,40 @@ call_ber_oid_callback(const char *oid, tvbuff_t *tvb, int offset, packet_info *p !dissector_try_string(ber_oid_dissector_table, oid, next_tvb, pinfo, tree)){ proto_item *item=NULL; proto_tree *next_tree=NULL; + gint length_remaining; + + length_remaining = tvb_length_remaining(tvb, offset); if (oid == NULL) { - item=proto_tree_add_text(tree, next_tvb, 0, tvb_length_remaining(tvb, offset), "BER: No OID supplied to call_ber_oid_callback"); + item=proto_tree_add_text(tree, next_tvb, 0, length_remaining, "BER: No OID supplied to call_ber_oid_callback"); proto_item_set_expert_flags(item, PI_MALFORMED, PI_WARN); expert_add_info_format(pinfo, item, PI_MALFORMED, PI_WARN, "BER Error: No OID supplied"); } else { - item=proto_tree_add_text(tree, next_tvb, 0, tvb_length_remaining(tvb, offset), "BER: Dissector for OID:%s not implemented. Contact Wireshark developers if you want this supported", oid); + item=proto_tree_add_text(tree, next_tvb, 0, length_remaining, "BER: Dissector for OID:%s not implemented. Contact Wireshark developers if you want this supported", oid); proto_item_set_expert_flags(item, PI_MALFORMED, PI_WARN); expert_add_info_format(pinfo, item, PI_MALFORMED, PI_WARN, "BER Error Dissector for OID not implemented"); } - if(item){ + if (decode_unexpected) { + int ber_offset; + gint32 ber_len; + + if(item){ next_tree=proto_item_add_subtree(item, ett_ber_unknown); + } + ber_offset = get_ber_identifier(next_tvb, 0, NULL, NULL, NULL); + ber_offset = get_ber_length(NULL, next_tvb, ber_offset, &ber_len, NULL); + if ((ber_len + ber_offset) == length_remaining) { + /* Decoded an ASN.1 tag with a length indicating this + * could be BER encoded data. Try dissecting as unknown BER. + */ + dissect_unknown_ber(pinfo, next_tvb, 0, next_tree); + } else { + proto_tree_add_text(next_tree, next_tvb, 0, length_remaining, + "Unknown Data (%d byte%s)", length_remaining, + plurality(length_remaining, "", "s")); + } } - dissect_unknown_ber(pinfo, next_tvb, 0, next_tree); + } /*XXX until we change the #.REGISTER signature for _PDU()s |