2009-11-24 23:11:11 +00:00
|
|
|
/* packet-flip.c
|
|
|
|
* Routines for FLIP packet dissection
|
|
|
|
*
|
|
|
|
* Copyright 2009, Juha Siltanen <juha.siltanen@nsn.com>
|
2011-06-22 23:03:56 +00:00
|
|
|
*
|
2009-11-24 23:11:11 +00:00
|
|
|
* Wireshark - Network traffic analyzer
|
|
|
|
* By Gerald Combs <gerald@wireshark.org>
|
|
|
|
* Copyright 1998 Gerald Combs
|
|
|
|
*
|
2018-02-12 11:23:27 +00:00
|
|
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
2009-11-24 23:11:11 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* FLIP (Flow Layer Internal Protocol) is a proprietary protocol
|
2015-01-19 08:33:22 +00:00
|
|
|
* developed by Nokia Solutions and Networks (previous was 'Nokia Siemens Networks').
|
2009-11-24 23:11:11 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Version information
|
|
|
|
*
|
|
|
|
* Version 0.0.1, November 23rd, 2009.
|
|
|
|
*
|
|
|
|
* Support for the basic and checksum headers.
|
2010-08-26 13:49:23 +00:00
|
|
|
*
|
|
|
|
* Version 0.0.2, August 26th, 2010.
|
|
|
|
*
|
|
|
|
* Support for payload dissecting.
|
2010-09-15 21:17:35 +00:00
|
|
|
*
|
|
|
|
* Version 0.0.3, September 14th, 2010.
|
|
|
|
*
|
|
|
|
* Bugfix: sorting by protocol didn't always fill in the protocol column.
|
2009-11-24 23:11:11 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include <epan/packet.h>
|
|
|
|
#include <epan/etypes.h>
|
2015-04-02 23:33:39 +00:00
|
|
|
#include <epan/decode_as.h>
|
2009-11-24 23:11:11 +00:00
|
|
|
#include <epan/in_cksum.h>
|
|
|
|
|
2010-08-26 13:49:23 +00:00
|
|
|
#include <epan/prefs.h>
|
|
|
|
|
|
|
|
#include <epan/rtp_pt.h>
|
|
|
|
|
2013-12-15 23:44:12 +00:00
|
|
|
void proto_register_flip(void);
|
|
|
|
void proto_reg_handoff_flip(void);
|
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
static int proto_flip = -1;
|
|
|
|
|
|
|
|
/* BASIC */
|
|
|
|
static int hf_flip_basic_e = -1;
|
|
|
|
static int hf_flip_basic_reserved = -1;
|
|
|
|
static int hf_flip_basic_flowid = -1;
|
|
|
|
static int hf_flip_basic_seqnum = -1;
|
|
|
|
static int hf_flip_basic_len = -1;
|
|
|
|
|
|
|
|
/* CHECKSUM */
|
|
|
|
static int hf_flip_chksum_etype = -1;
|
|
|
|
static int hf_flip_chksum_spare = -1;
|
|
|
|
static int hf_flip_chksum_e = -1;
|
|
|
|
static int hf_flip_chksum_chksum = -1;
|
|
|
|
|
|
|
|
#define FLIP_BASIC (0)
|
|
|
|
#define FLIP_CHKSUM (1)
|
|
|
|
|
|
|
|
#define FLIP_BASIC_HDR_LEN (8)
|
|
|
|
#define FLIP_CHKSUM_HDR_LEN (4)
|
|
|
|
#define FLIP_EXTENSION_HDR_MIN_LEN (4)
|
|
|
|
|
|
|
|
static const value_string flip_etype[] = {
|
|
|
|
{ FLIP_CHKSUM, "Checksum" },
|
|
|
|
{ 0, NULL }
|
|
|
|
};
|
|
|
|
|
2015-04-02 23:33:39 +00:00
|
|
|
static dissector_table_t subdissector_table;
|
2010-08-26 13:49:23 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
static gint ett_flip = -1;
|
|
|
|
static gint ett_flip_basic = -1;
|
|
|
|
static gint ett_flip_chksum = -1;
|
|
|
|
static gint ett_flip_payload = -1;
|
|
|
|
|
2015-04-02 23:33:39 +00:00
|
|
|
static void flip_prompt(packet_info *pinfo _U_, gchar* result)
|
|
|
|
{
|
|
|
|
g_snprintf(result, MAX_DECODE_AS_PROMPT_LEN, "Decode FLIP payload protocol as");
|
|
|
|
}
|
2010-08-26 13:49:23 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
/* Dissect the checksum extension header. */
|
|
|
|
static int
|
|
|
|
dissect_flip_chksum_hdr(tvbuff_t *tvb,
|
|
|
|
packet_info *pinfo,
|
|
|
|
proto_tree *tree,
|
|
|
|
guint16 computed_chksum,
|
|
|
|
gboolean *ext_hdr_follows_ptr)
|
|
|
|
{
|
|
|
|
proto_tree *chksum_hdr_tree;
|
|
|
|
guint32 dw;
|
|
|
|
guint8 chksum_hdr_etype;
|
|
|
|
guint8 chksum_hdr_ext;
|
|
|
|
guint16 chksum_hdr_chksum;
|
|
|
|
|
|
|
|
gint bytes_dissected;
|
|
|
|
gint offset;
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
chksum_hdr_tree = NULL;
|
|
|
|
|
|
|
|
bytes_dissected = 0;
|
|
|
|
offset = 0;
|
|
|
|
|
|
|
|
dw = tvb_get_ntohl(tvb, offset);
|
|
|
|
chksum_hdr_etype = (guint8) ((dw & 0xFF000000) >> 24);
|
|
|
|
chksum_hdr_ext = (guint8) ((dw & 0x00010000) >> 16);
|
|
|
|
chksum_hdr_chksum = (guint16) (dw & 0x0000FFFF);
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
/* The actually shouldn't be any headers after checksum. */
|
|
|
|
if (chksum_hdr_ext == 1) {
|
|
|
|
*ext_hdr_follows_ptr = TRUE;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
*ext_hdr_follows_ptr = FALSE;
|
|
|
|
}
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
if (tree) {
|
2014-06-26 02:59:50 +00:00
|
|
|
chksum_hdr_tree = proto_tree_add_subtree(tree, tvb, offset + 0, 4,
|
|
|
|
ett_flip_chksum, NULL, "Checksum Header");
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
/* ETYPE: 8 bits */
|
|
|
|
proto_tree_add_uint_format_value(chksum_hdr_tree, hf_flip_chksum_etype,
|
|
|
|
tvb, offset + 0, 1, dw,
|
2012-08-10 22:55:02 +00:00
|
|
|
"%s", val_to_str_const(chksum_hdr_etype,
|
|
|
|
flip_etype,
|
|
|
|
"Unknown"));
|
2009-11-24 23:11:11 +00:00
|
|
|
/* SPARE: 7 bits */
|
2015-04-02 23:33:39 +00:00
|
|
|
proto_tree_add_item(chksum_hdr_tree, hf_flip_chksum_spare, tvb, offset, 4, ENC_BIG_ENDIAN);
|
2009-11-24 23:11:11 +00:00
|
|
|
|
|
|
|
/* EXT HDR: 1 bit */
|
2015-04-02 23:33:39 +00:00
|
|
|
proto_tree_add_item(chksum_hdr_tree, hf_flip_chksum_e,
|
|
|
|
tvb, offset, 4, ENC_BIG_ENDIAN);
|
2009-11-24 23:11:11 +00:00
|
|
|
/* CHKSUM: 16 bits. */
|
|
|
|
proto_tree_add_uint_format_value(
|
|
|
|
chksum_hdr_tree,
|
|
|
|
hf_flip_chksum_chksum,
|
|
|
|
tvb, offset + 2, 2,
|
|
|
|
chksum_hdr_chksum,
|
|
|
|
"0x%04x [%s] (computed 0x%04x)",
|
|
|
|
chksum_hdr_chksum,
|
|
|
|
((chksum_hdr_chksum == computed_chksum) ? "Correct" : "Incorrect"),
|
|
|
|
computed_chksum);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Show faulty checksums. */
|
|
|
|
if (computed_chksum != chksum_hdr_chksum) {
|
|
|
|
col_add_fstr(pinfo->cinfo, COL_INFO,
|
|
|
|
"Checksum 0x%04x [%s] (computed 0x%04x)",
|
|
|
|
chksum_hdr_chksum,
|
|
|
|
((chksum_hdr_chksum == computed_chksum) ?
|
|
|
|
"Correct" : "Incorrect"),
|
|
|
|
computed_chksum);
|
|
|
|
}
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
bytes_dissected += FLIP_CHKSUM_HDR_LEN;
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
return bytes_dissected;
|
|
|
|
|
|
|
|
} /* dissect_flip_chksum_hdr() */
|
|
|
|
|
|
|
|
/* Protocol dissection */
|
|
|
|
static int
|
2012-09-10 21:40:21 +00:00
|
|
|
dissect_flip(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data _U_)
|
2009-11-24 23:11:11 +00:00
|
|
|
{
|
2015-04-02 23:33:39 +00:00
|
|
|
proto_item *ti = NULL;
|
|
|
|
proto_tree *flip_tree = NULL;
|
|
|
|
proto_tree *basic_hdr_tree = NULL;
|
2009-11-24 23:11:11 +00:00
|
|
|
tvbuff_t *flip_tvb;
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
guint32 dw1;
|
|
|
|
|
|
|
|
/* Basic header fields. */
|
|
|
|
guint8 basic_hdr_ext;
|
|
|
|
guint32 basic_hdr_flow_id;
|
|
|
|
guint16 basic_hdr_len;
|
|
|
|
|
2015-04-02 23:33:39 +00:00
|
|
|
gboolean ext_hdr = FALSE;
|
2009-11-24 23:11:11 +00:00
|
|
|
|
2015-04-02 23:33:39 +00:00
|
|
|
gint bytes_dissected = 0;
|
2009-11-24 23:11:11 +00:00
|
|
|
gint payload_len;
|
|
|
|
gint frame_len;
|
|
|
|
gint flip_len;
|
2015-04-02 23:33:39 +00:00
|
|
|
gint offset = 0;
|
2009-11-24 23:11:11 +00:00
|
|
|
|
|
|
|
/* Error handling for basic header. */
|
2015-04-02 23:33:39 +00:00
|
|
|
gboolean is_faulty_frame = FALSE;
|
2009-11-24 23:11:11 +00:00
|
|
|
|
|
|
|
/* Show this protocol as FLIP. */
|
|
|
|
col_set_str(pinfo->cinfo, COL_PROTOCOL, "FLIP");
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The frame can be faulty in several ways:
|
|
|
|
* - too short (even for the basic header)
|
|
|
|
* - length inconsistent (header and frame info different)
|
|
|
|
* - checksum doesn't check out
|
|
|
|
* - extension header is indicated, but the frame is too short for it
|
|
|
|
* - unknown extension header type
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Check that there's enough data at least for the basic header. */
|
2015-04-02 23:33:39 +00:00
|
|
|
frame_len = tvb_captured_length(tvb);
|
2009-11-24 23:11:11 +00:00
|
|
|
if (frame_len < FLIP_BASIC_HDR_LEN) {
|
2015-04-02 23:33:39 +00:00
|
|
|
return 0;
|
2009-11-24 23:11:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
bytes_dissected += FLIP_BASIC_HDR_LEN;
|
|
|
|
|
|
|
|
/* Process the first 32 bits of the basic header. */
|
|
|
|
dw1 = tvb_get_ntohl(tvb, offset + 0);
|
|
|
|
basic_hdr_ext = ((dw1 & 0x80000000) >> 31);
|
|
|
|
basic_hdr_flow_id = (dw1 & 0x0FFFFFFF);
|
|
|
|
|
2009-11-27 20:52:21 +00:00
|
|
|
/* Process the second 32 bits of the basic header. */
|
2015-04-02 23:33:39 +00:00
|
|
|
basic_hdr_len = (guint16) (tvb_get_ntohl(tvb, offset + 4) & 0x0000FFFF);
|
|
|
|
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
/* Does the basic header indicate that an extension is next? */
|
|
|
|
if (basic_hdr_ext == 1) {
|
|
|
|
ext_hdr = TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
flip_len = basic_hdr_len;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Check the length value.
|
|
|
|
*/
|
|
|
|
if ((flip_len < FLIP_BASIC_HDR_LEN) || (flip_len > frame_len)) {
|
|
|
|
/* Faulty frame. Show the basic header anyway for debugging. */
|
|
|
|
is_faulty_frame = TRUE;
|
|
|
|
}
|
|
|
|
|
2009-11-27 20:52:21 +00:00
|
|
|
/* Fill in the info column. */
|
2009-11-24 23:11:11 +00:00
|
|
|
col_add_fstr(pinfo->cinfo, COL_INFO,
|
|
|
|
"FlowID %s", val_to_str(basic_hdr_flow_id, NULL, "0x%08x"));
|
|
|
|
|
2014-06-06 14:35:50 +00:00
|
|
|
flip_tvb = tvb_new_subset_length(tvb, 0, frame_len);
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
/* We are asked for details. */
|
|
|
|
if (tree) {
|
2015-04-02 23:33:39 +00:00
|
|
|
ti = proto_tree_add_protocol_format(
|
2010-08-26 13:49:23 +00:00
|
|
|
tree, proto_flip, flip_tvb, 0, flip_len,
|
2010-09-15 21:17:35 +00:00
|
|
|
"NSN FLIP, FlowID %s",
|
2010-08-26 13:49:23 +00:00
|
|
|
val_to_str(basic_hdr_flow_id, NULL, "0x%08x"));
|
2009-11-24 23:11:11 +00:00
|
|
|
flip_tree = proto_item_add_subtree(ti, ett_flip);
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
/* basic header */
|
2015-04-02 23:33:39 +00:00
|
|
|
basic_hdr_tree = proto_tree_add_subtree(flip_tree, flip_tvb, offset, 8, ett_flip_basic, NULL, "Basic Header");
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
/* Extension header follows? 1 bit. */
|
2015-04-02 23:33:39 +00:00
|
|
|
proto_tree_add_item(basic_hdr_tree, hf_flip_basic_e, flip_tvb, offset, 4, ENC_BIG_ENDIAN);
|
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
/* Reserved: 3 bits. */
|
2015-04-02 23:33:39 +00:00
|
|
|
proto_tree_add_item(basic_hdr_tree, hf_flip_basic_reserved, flip_tvb, offset, 4, ENC_BIG_ENDIAN);
|
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
/* Flow ID: 28 bits. */
|
2015-04-02 23:33:39 +00:00
|
|
|
proto_tree_add_item(basic_hdr_tree, hf_flip_basic_flowid, flip_tvb, offset, 4, ENC_BIG_ENDIAN);
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
/* Sequence number: 16 bits. */
|
2015-04-02 23:33:39 +00:00
|
|
|
proto_tree_add_item(basic_hdr_tree, hf_flip_basic_seqnum, flip_tvb, offset + 4, 2, ENC_BIG_ENDIAN);
|
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
/* Packet length: 16 bits. */
|
2015-04-02 23:33:39 +00:00
|
|
|
proto_tree_add_item(basic_hdr_tree, hf_flip_basic_len, flip_tvb, offset + 6, 2, ENC_BIG_ENDIAN);
|
2009-11-24 23:11:11 +00:00
|
|
|
}
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
offset += FLIP_BASIC_HDR_LEN;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Process faults found when parsing the basic header.
|
|
|
|
*/
|
|
|
|
if (is_faulty_frame == TRUE) {
|
|
|
|
if (flip_len > frame_len) {
|
|
|
|
col_add_fstr(pinfo->cinfo, COL_INFO,
|
|
|
|
"Length mismatch: frame %d bytes, hdr %d bytes",
|
|
|
|
frame_len, flip_len);
|
|
|
|
}
|
2011-06-22 23:03:56 +00:00
|
|
|
else if (flip_len < FLIP_BASIC_HDR_LEN) {
|
2009-11-24 23:11:11 +00:00
|
|
|
col_add_fstr(pinfo->cinfo, COL_INFO,
|
|
|
|
"Invalid length in basic header: %d bytes", flip_len);
|
|
|
|
}
|
|
|
|
|
|
|
|
goto DISSECT_FLIP_EXIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Now we know that the basic header is sensible.
|
|
|
|
*/
|
2015-04-02 23:33:39 +00:00
|
|
|
payload_len = basic_hdr_len - FLIP_BASIC_HDR_LEN;
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
/*
|
|
|
|
* Dissect extension headers (if any).
|
|
|
|
*/
|
|
|
|
if ((ext_hdr == TRUE) && (payload_len < FLIP_EXTENSION_HDR_MIN_LEN)) {
|
|
|
|
col_add_fstr(pinfo->cinfo, COL_INFO,
|
|
|
|
"Extension header indicated, but not enough data");
|
|
|
|
goto DISSECT_FLIP_EXIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
while ((ext_hdr == TRUE) && (payload_len >= FLIP_EXTENSION_HDR_MIN_LEN)) {
|
|
|
|
/* Detect the next header type. */
|
|
|
|
guint8 ext_hdr_type;
|
|
|
|
gint bytes_handled;
|
|
|
|
guint16 computed_chksum;
|
|
|
|
|
|
|
|
tvbuff_t *chksum_tvb;
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
ext_hdr_type = tvb_get_guint8(flip_tvb, offset);
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
switch (ext_hdr_type) {
|
|
|
|
case FLIP_CHKSUM:
|
|
|
|
/* Calculate checksum, let the chksum dissector verify it. */
|
|
|
|
{
|
|
|
|
vec_t vec[2];
|
|
|
|
|
Clean up Internet checksum handling.
Add macros to set entries of a vec_t, one for use when you have a
pointer to private data, and one for use when you have data in a tvbuff.
The latter wraps the use of tvb_get_ptr(), so that you're not directly
calling it in a dissector.
Move ip_checksum() to epan/in_cksum.c, and add an ip_checksum_tvb() that
wraps the use of tvb_get_ptr().
In the CARP dissector, give the length variable an unsigned type -
there's no benefit to it being signed, and that requires some casts to
be thrown around.
In the DCCP dissector, check only against the coverage length to see if
we have enough data, combine the "should we check the checksum?" check
with the "*can* we check the checksum?" check in a single if, and throw
a dissector assertion if the source network address type isn't IPv4 or
IPv6.
Get rid of inclues of <epan/in_cksum.h> in dissectors that don't use any
of the Internet checksum routines.
In the HIP dissector, make sure we have the data to calculate the
checksum before doing so.
Change-Id: I2f9674775dbb54c533d33082632809f7d32ec8ae
Reviewed-on: https://code.wireshark.org/review/3517
Reviewed-by: Guy Harris <guy@alum.mit.edu>
2014-08-09 01:09:00 +00:00
|
|
|
SET_CKSUM_VEC_TVB(vec[0], flip_tvb, 0, bytes_dissected + 2);
|
|
|
|
SET_CKSUM_VEC_TVB(vec[1], flip_tvb, bytes_dissected + 4,
|
|
|
|
flip_len - (bytes_dissected + 4));
|
2009-11-24 23:11:11 +00:00
|
|
|
computed_chksum = in_cksum(&vec[0], 2);
|
|
|
|
|
|
|
|
/* Checksums handled in network order. */
|
|
|
|
computed_chksum = g_htons(computed_chksum);
|
|
|
|
}
|
|
|
|
|
2014-06-06 14:35:50 +00:00
|
|
|
chksum_tvb = tvb_new_subset_length(flip_tvb, offset,
|
2009-11-24 23:11:11 +00:00
|
|
|
FLIP_CHKSUM_HDR_LEN);
|
|
|
|
|
|
|
|
/* Note that flip_tree is NULL if no details are requested. */
|
|
|
|
bytes_handled = dissect_flip_chksum_hdr(chksum_tvb,
|
|
|
|
pinfo,
|
|
|
|
flip_tree,
|
|
|
|
computed_chksum,
|
|
|
|
&ext_hdr);
|
|
|
|
bytes_dissected += bytes_handled;
|
|
|
|
payload_len -= bytes_handled;
|
|
|
|
offset += bytes_handled;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
/* Unknown header type. */
|
|
|
|
col_add_fstr(pinfo->cinfo, COL_INFO,
|
|
|
|
"Invalid extension header type 0x%02x", ext_hdr_type);
|
|
|
|
goto DISSECT_FLIP_EXIT;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Show payload (if any) as bytes.
|
|
|
|
*/
|
|
|
|
if (payload_len > 0) {
|
2010-09-15 21:17:35 +00:00
|
|
|
|
|
|
|
tvbuff_t *payload_tvb;
|
|
|
|
gint data_len;
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2015-04-02 23:33:39 +00:00
|
|
|
payload_tvb = tvb_new_subset_length(flip_tvb, offset, payload_len);
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2017-07-09 17:47:59 +00:00
|
|
|
data_len = dissector_try_payload(subdissector_table, payload_tvb, pinfo, tree);
|
2015-04-02 23:33:39 +00:00
|
|
|
if (data_len <= 0)
|
|
|
|
{
|
2016-03-20 00:33:14 +00:00
|
|
|
data_len = call_data_dissector(payload_tvb, pinfo, tree);
|
2010-09-15 21:17:35 +00:00
|
|
|
}
|
2010-08-26 13:49:23 +00:00
|
|
|
|
|
|
|
bytes_dissected += data_len;
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2010-08-26 13:49:23 +00:00
|
|
|
} /* if (payload_len > 0) */
|
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
DISSECT_FLIP_EXIT:
|
|
|
|
return bytes_dissected;
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
} /* dissect_flip() */
|
|
|
|
|
2010-08-26 13:49:23 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
/* Protocol initialization */
|
|
|
|
void
|
|
|
|
proto_register_flip(void)
|
|
|
|
{
|
|
|
|
static hf_register_info hf[] = {
|
|
|
|
/*
|
|
|
|
* Basic header.
|
|
|
|
*/
|
|
|
|
{&hf_flip_basic_e,
|
2015-04-02 23:33:39 +00:00
|
|
|
{"Extension Header Follows", "flip.basic.e", FT_BOOLEAN, 32,
|
|
|
|
TFS(&tfs_yes_no), 0x80000000, NULL, HFILL}
|
2009-11-24 23:11:11 +00:00
|
|
|
},
|
|
|
|
{&hf_flip_basic_reserved,
|
|
|
|
{"Reserved", "flip.basic.reserved", FT_UINT32, BASE_DEC,
|
|
|
|
NULL, 0x70000000, "Basic Header Reserved", HFILL}
|
|
|
|
},
|
|
|
|
{&hf_flip_basic_flowid,
|
|
|
|
{"FlowID", "flip.basic.flowid", FT_UINT32, BASE_HEX,
|
|
|
|
NULL, 0x0FFFFFFF, "Basic Header Flow ID", HFILL}
|
|
|
|
},
|
|
|
|
{&hf_flip_basic_seqnum,
|
2015-04-02 23:33:39 +00:00
|
|
|
{"Seqnum", "flip.basic.seqnum", FT_UINT16, BASE_DEC_HEX,
|
|
|
|
NULL, 0x0, "Basic Header Sequence Number", HFILL}
|
2009-11-24 23:11:11 +00:00
|
|
|
},
|
|
|
|
{&hf_flip_basic_len,
|
2015-04-02 23:33:39 +00:00
|
|
|
{"Len", "flip.basic.len", FT_UINT16, BASE_DEC_HEX,
|
|
|
|
NULL, 0x0, "Basic Header Packet Length", HFILL}
|
2009-11-24 23:11:11 +00:00
|
|
|
},
|
|
|
|
/*
|
|
|
|
* Checksum header.
|
|
|
|
*/
|
|
|
|
{&hf_flip_chksum_etype,
|
|
|
|
{"Extension Type", "flip.chksum.etype", FT_UINT32, BASE_DEC,
|
|
|
|
VALS(flip_etype), 0xFF000000, "Checksum Header Extension Type", HFILL}
|
|
|
|
},
|
|
|
|
{&hf_flip_chksum_spare,
|
2015-04-02 23:33:39 +00:00
|
|
|
{"Spare", "flip.chksum.spare", FT_UINT32, BASE_DEC_HEX,
|
2009-11-24 23:11:11 +00:00
|
|
|
NULL, 0x00FE0000, "Checksum Header Spare", HFILL}
|
|
|
|
},
|
|
|
|
{&hf_flip_chksum_e,
|
2015-04-02 23:33:39 +00:00
|
|
|
{"Extension Header Follows", "flip.chksum.e", FT_BOOLEAN, 32,
|
|
|
|
TFS(&tfs_yes_no), 0x00010000, NULL, HFILL}
|
2009-11-24 23:11:11 +00:00
|
|
|
},
|
|
|
|
{&hf_flip_chksum_chksum,
|
|
|
|
{"Checksum", "flip.chksum.chksum", FT_UINT32, BASE_HEX,
|
|
|
|
NULL, 0x0000FFFF, NULL, HFILL}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
static gint *ett[] = {
|
|
|
|
&ett_flip,
|
|
|
|
&ett_flip_basic,
|
|
|
|
&ett_flip_chksum,
|
|
|
|
&ett_flip_payload
|
|
|
|
};
|
2010-08-26 13:49:23 +00:00
|
|
|
|
|
|
|
module_t *flip_module;
|
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
proto_flip = proto_register_protocol(
|
|
|
|
"NSN FLIP", /* name */
|
|
|
|
"FLIP", /* short name */
|
|
|
|
"flip" /* abbrev */
|
|
|
|
);
|
|
|
|
|
|
|
|
proto_register_field_array(proto_flip, hf, array_length(hf));
|
|
|
|
proto_register_subtree_array(ett, array_length(ett));
|
|
|
|
|
2015-04-02 23:33:39 +00:00
|
|
|
flip_module = prefs_register_protocol(proto_flip, NULL);
|
|
|
|
|
|
|
|
/* Register preferences - now obsolete because of Decode As*/
|
|
|
|
prefs_register_obsolete_preference(flip_module, "decoding_mode");
|
|
|
|
prefs_register_obsolete_preference(flip_module, "heur_enabled_protocols");
|
|
|
|
prefs_register_obsolete_preference(flip_module, "heur_decode_rtp");
|
|
|
|
prefs_register_obsolete_preference(flip_module, "heur_decode_rtcp");
|
|
|
|
prefs_register_obsolete_preference(flip_module, "forced_protocol");
|
|
|
|
prefs_register_obsolete_preference(flip_module, "forced_decode");
|
2010-08-26 13:49:23 +00:00
|
|
|
|
2019-06-12 20:54:01 +00:00
|
|
|
subdissector_table = register_decode_as_next_proto(proto_flip, "flip.payload", "FLIP payload", flip_prompt);
|
2011-06-22 23:03:56 +00:00
|
|
|
|
2009-11-24 23:11:11 +00:00
|
|
|
} /* proto_register_flip() */
|
|
|
|
|
|
|
|
/* Protocol handoff */
|
|
|
|
void
|
|
|
|
proto_reg_handoff_flip(void)
|
|
|
|
{
|
|
|
|
dissector_handle_t flip_handle;
|
|
|
|
|
2015-12-09 03:49:44 +00:00
|
|
|
flip_handle = create_dissector_handle(dissect_flip, proto_flip);
|
2015-04-02 23:33:39 +00:00
|
|
|
dissector_add_uint("ethertype", ETHERTYPE_FLIP, flip_handle);
|
2009-11-24 23:11:11 +00:00
|
|
|
} /* proto_reg_handoff_flip() */
|
|
|
|
|
2014-09-28 23:25:09 +00:00
|
|
|
/*
|
|
|
|
* Editor modelines - http://www.wireshark.org/tools/modelines.html
|
|
|
|
*
|
|
|
|
* Local variables:
|
|
|
|
* c-basic-offset: 4
|
|
|
|
* tab-width: 8
|
|
|
|
* indent-tabs-mode: nil
|
|
|
|
* End:
|
|
|
|
*
|
|
|
|
* vi: set shiftwidth=4 tabstop=8 expandtab:
|
|
|
|
* :indentSize=4:tabSize=8:noTabs=true:
|
|
|
|
*/
|