diff options
author | Michael Mann <mmann78@netscape.net> | 2015-11-24 08:22:57 -0500 |
---|---|---|
committer | Michael Mann <mmann78@netscape.net> | 2015-11-24 14:52:17 +0000 |
commit | 8a999d7bb843790ec069baf02cc4fbb2ea530605 (patch) | |
tree | 99552386aa0d555f1abc66bcb38d89992fea3630 /epan/dissectors/packet-rdp.c | |
parent | dc93041dfe788af0aed776e1ec69fa3017424df2 (diff) |
Convert T.124 API to use "new style" dissectors.
This seems like an unnecessary encapsulation of registering a dissector, but it can be used at runtime and not just a handoff function.
Change-Id: Ic13e34b5cecf493115f27a984bb886f2f76bc7de
Reviewed-on: https://code.wireshark.org/review/12096
Reviewed-by: Michael Mann <mmann78@netscape.net>
Diffstat (limited to 'epan/dissectors/packet-rdp.c')
-rw-r--r-- | epan/dissectors/packet-rdp.c | 20 |
1 files changed, 12 insertions, 8 deletions
diff --git a/epan/dissectors/packet-rdp.c b/epan/dissectors/packet-rdp.c index 7bccabacdd..3e77b1aa9c 100644 --- a/epan/dissectors/packet-rdp.c +++ b/epan/dissectors/packet-rdp.c @@ -1377,8 +1377,8 @@ dissect_rdp(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent_tree) return tree; } -static void -dissect_rdp_SendData(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) { +static int +dissect_rdp_SendData(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data _U_) { proto_item *pi; int offset = 0; guint32 flags = 0; @@ -1575,7 +1575,7 @@ dissect_rdp_SendData(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) { break; } - return; + return tvb_captured_length(tvb); } /* licensing stage */ if (rdp_info && (t124_get_last_channelId() == rdp_info->staticChannelId)) { @@ -1619,7 +1619,7 @@ dissect_rdp_SendData(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) { /* we may get multiple control headers in a single frame */ col_set_fence(pinfo->cinfo, COL_INFO); - return; + return tvb_captured_length(tvb); } /* (rdp_info && (t124_get_last_channelId() == rdp_info->staticChannelId)) */ /* Virtual Channel */ @@ -1631,10 +1631,12 @@ dissect_rdp_SendData(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) { /*offset =*/ dissect_rdp_channelPDU(tvb, offset, pinfo, tree); else /*offset =*/ dissect_rdp_encrypted(tvb, offset, pinfo, tree, "Channel PDU"); + + return tvb_captured_length(tvb); } -static void -dissect_rdp_ClientData(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) { +static int +dissect_rdp_ClientData(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data _U_) { int offset = 0; proto_item *pi; proto_tree *next_tree; @@ -1802,10 +1804,11 @@ dissect_rdp_ClientData(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) { } offset += MAX(4, length); /* Use length from header, but advance at least 4 bytes */ } + return tvb_captured_length(tvb); } -static void -dissect_rdp_ServerData(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) { +static int +dissect_rdp_ServerData(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data _U_) { int offset = 0; proto_item *pi; proto_tree *next_tree; @@ -1985,6 +1988,7 @@ dissect_rdp_ServerData(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) { } offset += MAX(4, length); /* Use length from header, but advance at least 4 bytes */ } + return tvb_captured_length(tvb); } /*--- proto_register_rdp -------------------------------------------*/ |