diff options
author | Guy Harris <guy@alum.mit.edu> | 2014-08-08 10:10:36 -0700 |
---|---|---|
committer | Guy Harris <guy@alum.mit.edu> | 2014-08-08 17:11:03 +0000 |
commit | 9b9005eb94d9c89a02d93e8dda0c19b8e2d1a6d7 (patch) | |
tree | f5a9c6f552bec38fff10c479f6fd1a1755b80af9 /epan/dissectors/packet-dcp-etsi.c | |
parent | 57927c8a56ad132c3a9ca507bdb1584043a94abb (diff) |
The DRM DCP CRC-16 is the same as the X.25 CRC-16.
So just use crc16_x25_ccitt_tvb(), which goes a byte at a time rather
than a bit at a time, and which takes a tvbuff rather than requiring you
to call tvb_get_ptr().
It also doesn't 1's-complement the result, so we can compare it against the
0x1D0F in ETSI TS 102 821 V1.4.1 (2012-10) rather than against a
1's-complement version, 0xE2F0.
Change-Id: Ia513f851f0a8ff1e7853278ddf3618c532fb2aba
Reviewed-on: https://code.wireshark.org/review/3507
Reviewed-by: Guy Harris <guy@alum.mit.edu>
Diffstat (limited to 'epan/dissectors/packet-dcp-etsi.c')
-rw-r--r-- | epan/dissectors/packet-dcp-etsi.c | 16 |
1 files changed, 7 insertions, 9 deletions
diff --git a/epan/dissectors/packet-dcp-etsi.c b/epan/dissectors/packet-dcp-etsi.c index 2b30b1c8f4..9a41e96db3 100644 --- a/epan/dissectors/packet-dcp-etsi.c +++ b/epan/dissectors/packet-dcp-etsi.c @@ -28,7 +28,7 @@ #include <epan/packet.h> #include <epan/reassemble.h> -#include <wsutil/crcdrm.h> +#include <epan/crc16-tvb.h> #include <epan/reedsolomon.h> #include <epan/wmem/wmem.h> #include <string.h> @@ -494,11 +494,10 @@ dissect_pft(tvbuff_t * tvb, packet_info * pinfo, proto_tree * tree) if (tree) { proto_item *ci = NULL; guint header_len = offset+2; - const char *crc_buf = (const char *) tvb_get_ptr(tvb, 0, header_len); - unsigned long c = crc_drm(crc_buf, header_len, 16, 0x11021, 1); + guint16 c = crc16_x25_ccitt_tvb(tvb, header_len); ci = proto_tree_add_item (pft_tree, hf_edcp_hcrc, tvb, offset, 2, ENC_BIG_ENDIAN); - proto_item_append_text(ci, " (%s)", (c==0xe2f0)?"Ok":"bad"); - proto_tree_add_boolean(pft_tree, hf_edcp_hcrc_ok, tvb, offset, 2, c==0xe2f0); + proto_item_append_text(ci, " (%s)", (c==0x1D0F)?"Ok":"bad"); + proto_tree_add_boolean(pft_tree, hf_edcp_hcrc_ok, tvb, offset, 2, c==0x1D0F); } offset += 2; if (fcount > 1) { /* fragmented*/ @@ -580,10 +579,9 @@ dissect_af (tvbuff_t * tvb, packet_info * pinfo, proto_tree * tree) ci = proto_tree_add_item (af_tree, hf_edcp_crc, tvb, offset, 2, ENC_BIG_ENDIAN); if (ver & 0x80) { /* crc valid */ guint len = offset+2; - const char *crc_buf = (const char *) tvb_get_ptr(tvb, 0, len); - unsigned long c = crc_drm(crc_buf, len, 16, 0x11021, 1); - proto_item_append_text(ci, " (%s)", (c==0xe2f0)?"Ok":"bad"); - proto_tree_add_boolean(af_tree, hf_edcp_crc_ok, tvb, offset, 2, c==0xe2f0); + guint16 c = crc16_x25_ccitt_tvb(tvb, len); + proto_item_append_text(ci, " (%s)", (c==0x1D0F)?"Ok":"bad"); + proto_tree_add_boolean(af_tree, hf_edcp_crc_ok, tvb, offset, 2, c==0x1D0F); } /*offset += 2;*/ |