diff options
author | Martin Kaiser <wireshark@kaiser.cx> | 2016-07-10 13:48:27 +0200 |
---|---|---|
committer | Martin Kaiser <wireshark@kaiser.cx> | 2016-07-10 11:52:43 +0000 |
commit | d68043a66bcedfa8f7070bb597cbfa8b903e570a (patch) | |
tree | 6784c72e00842d006be4e1dca020b5c145b6cda3 | |
parent | 3faf0dde7672d26270eb373e8596830c7c9e1511 (diff) |
iso14443: expert info for invalid uid size
Change-Id: I3181375c3a2c8a905e1fd8bb722ac27902735ff0
Reviewed-on: https://code.wireshark.org/review/16365
Reviewed-by: Martin Kaiser <wireshark@kaiser.cx>
-rw-r--r-- | epan/dissectors/packet-iso14443.c | 21 |
1 files changed, 16 insertions, 5 deletions
diff --git a/epan/dissectors/packet-iso14443.c b/epan/dissectors/packet-iso14443.c index 4be4af380a..bc5c341223 100644 --- a/epan/dissectors/packet-iso14443.c +++ b/epan/dissectors/packet-iso14443.c @@ -264,6 +264,7 @@ static int hf_iso14443_crc = -1; static expert_field ei_iso14443_unknown_cmd = EI_INIT; static expert_field ei_iso14443_wrong_crc = EI_INIT; +static expert_field ei_iso14443_uid_inval_size = EI_INIT; /* dissect and verify the CRC @@ -290,7 +291,7 @@ static int dissect_iso14443_crc(tvbuff_t *tvb, gint crc_offset, " (correct)" : " (wrong)"); /* add an expert info to allow filtering on packets with wrong crc */ if (crc_recv != crc_calc) - expert_add_info(pinfo, crc_pi,&ei_iso14443_wrong_crc); + expert_add_info(pinfo, crc_pi, &ei_iso14443_wrong_crc); return CRC_LEN; } @@ -318,6 +319,7 @@ dissect_iso14443_cmd_type_wupa(tvbuff_t *tvb, packet_info *pinfo, } else if (pinfo->p2p_dir == P2P_DIR_RECV) { guint16 atqa; + proto_item *pi_uid; atqa = tvb_get_letohs(tvb, offset); col_set_str(pinfo->cinfo, COL_INFO, "ATQA"); @@ -335,11 +337,16 @@ dissect_iso14443_cmd_type_wupa(tvbuff_t *tvb, packet_info *pinfo, uid_size = 7; else if (uid_bits == 0x02) uid_size = 10; - /* XXX- expert info for invalid uid size */ - proto_tree_add_item(tree, hf_iso14443_uid_bits, + + pi_uid = proto_tree_add_item(tree, hf_iso14443_uid_bits, tvb, offset, 2, ENC_LITTLE_ENDIAN); - proto_tree_add_uint(tree, hf_iso14443_uid_size, - tvb, offset+1, 1, uid_size); + if (uid_size != 0) { + proto_tree_add_uint(tree, hf_iso14443_uid_size, + tvb, offset+1, 1, uid_size); + } + else { + expert_add_info(pinfo, pi_uid, &ei_iso14443_uid_inval_size); + } proto_tree_add_item(tree, hf_iso14443_atqa_rfu2, tvb, offset, 2, ENC_LITTLE_ENDIAN); @@ -1592,6 +1599,10 @@ proto_register_iso14443(void) }, { &ei_iso14443_wrong_crc, { "iso14443.crc.wrong", PI_PROTOCOL, PI_WARN, "Wrong CRC", EXPFILL } + }, + { &ei_iso14443_uid_inval_size, + { "iso14443.uid.invalid_size", PI_PROTOCOL, PI_WARN, + "Invalid UID size", EXPFILL } } }; |