diff options
author | Gilbert Ramirez <gram@alumni.rice.edu> | 2004-07-18 18:06:47 +0000 |
---|---|---|
committer | Gilbert Ramirez <gram@alumni.rice.edu> | 2004-07-18 18:06:47 +0000 |
commit | 669db206cb1f270046ad400fff7655e20c63e723 (patch) | |
tree | 4eff24a2e16c8963e497e1fc575f35e6af59bd26 /epan/dissectors/packet-dcerpc-tapi.c | |
parent | ae46c27a38700af669ef907491081f09df6f6b2c (diff) |
Move dissectors to epan/dissectors directory.
Also move ncp222.py, x11-fields, process-x11-fields.pl,
make-reg-dotc, and make-reg-dotc.py.
Adjust #include lines in files that include packet-*.h
files.
svn path=/trunk/; revision=11410
Diffstat (limited to 'epan/dissectors/packet-dcerpc-tapi.c')
-rw-r--r-- | epan/dissectors/packet-dcerpc-tapi.c | 248 |
1 files changed, 248 insertions, 0 deletions
diff --git a/epan/dissectors/packet-dcerpc-tapi.c b/epan/dissectors/packet-dcerpc-tapi.c new file mode 100644 index 0000000000..628b04841d --- /dev/null +++ b/epan/dissectors/packet-dcerpc-tapi.c @@ -0,0 +1,248 @@ +/* packet-dcerpc-tapi.c + * Routines for DCERPC TAPI packet disassembly + * Copyright 2002, Ronnie Sahlberg + * + * $Id$ + * + * Ethereal - Network traffic analyzer + * By Gerald Combs <gerald@ethereal.com> + * Copyright 1998 Gerald Combs + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + */ +/* The IDL file for this interface can be extracted by grepping for idl + * in capitals. + */ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include <glib.h> +#include <epan/packet.h> +#include "packet-dcerpc.h" +#include "packet-dcerpc-nt.h" +#include "packet-dcerpc-tapi.h" +#include "smb.h" + +static int proto_dcerpc_tapi = -1; +static int hf_tapi_opnum = -1; +static int hf_tapi_rc = -1; +static int hf_tapi_hnd = -1; +static int hf_tapi_unknown_long = -1; +static int hf_tapi_unknown_string = -1; +static int hf_tapi_unknown_bytes = -1; + +static gint ett_dcerpc_tapi = -1; + +/* + IDL [ uuid(2f5f6520-ca46-1067-b319-00dd010662da), + IDL version(1.0), + IDL implicit_handle(handle_t rpc_binding) + IDL ] interface tapi + IDL { +*/ +static e_uuid_t uuid_dcerpc_tapi = { + 0x2f5f6520, 0xca46, 0x1067, + { 0xb3, 0x19, 0x00, 0xdd, 0x01, 0x06, 0x62, 0xda } +}; + +static guint16 ver_dcerpc_tapi = 1; + +/* + IDL long ClientAttach( + IDL [out] [context_handle] void *element_1, + IDL [in] long element_2, + IDL [out] long element_3, + IDL [in] [string] [ref] wchar_t *element_4, + IDL [in] [string] [ref] wchar_t *element_5 + IDL ); +*/ +static int +dissect_tapi_client_attach_rqst(tvbuff_t *tvb, int offset, + packet_info *pinfo, proto_tree *tree, + guint8 *drep) +{ + offset = dissect_ndr_uint32(tvb, offset, pinfo, tree, drep, + hf_tapi_unknown_long, NULL); + + offset = dissect_ndr_str_pointer_item(tvb, offset, pinfo, tree, drep, + NDR_POINTER_REF, "unknown string", + hf_tapi_unknown_string, 0); + + offset = dissect_ndr_str_pointer_item(tvb, offset, pinfo, tree, drep, + NDR_POINTER_REF, "unknown string", + hf_tapi_unknown_string, 0); + + return offset; +} +static int +dissect_tapi_client_attach_reply(tvbuff_t *tvb, int offset, + packet_info *pinfo, proto_tree *tree, + guint8 *drep) +{ + offset = dissect_ndr_ctx_hnd(tvb, offset, pinfo, tree, drep, + hf_tapi_hnd, NULL); + + offset = dissect_ndr_uint32(tvb, offset, pinfo, tree, drep, + hf_tapi_unknown_long, NULL); + + offset = dissect_ndr_uint32(tvb, offset, pinfo, tree, drep, + hf_tapi_rc, NULL); + + return offset; +} + +/* + IDL long ClientRequest( + IDL [in] [context_handle] void *element_6, + IDL [in,out] [size_is(element_8)] [length_is(???)] char element_7[*], + IDL [in] long element_8 + IDL ); +*/ +static int +dissect_tapi_TYPE_1(tvbuff_t *tvb, int offset, + packet_info *pinfo, proto_tree *tree, + guint8 *drep) +{ + dcerpc_info *di; + + di=pinfo->private_data; + if(di->conformant_run){ + /* this call is to make ethereal eat the array header for the conformant run */ + offset =dissect_ndr_ucvarray(tvb, offset, pinfo, tree, drep, NULL); + + return offset; + } + + proto_tree_add_item(tree, hf_tapi_unknown_bytes, tvb, offset, + di->array_actual_count, FALSE); + offset += di->array_actual_count; + + return offset; +} + +static int +dissect_tapi_client_request_rqst(tvbuff_t *tvb, int offset, + packet_info *pinfo, proto_tree *tree, + guint8 *drep) +{ + offset = dissect_ndr_ctx_hnd(tvb, offset, pinfo, tree, drep, + hf_tapi_hnd, NULL); + + offset = dissect_ndr_pointer(tvb, offset, pinfo, tree, drep, + dissect_tapi_TYPE_1, NDR_POINTER_REF, + "unknown array", -1); + + offset = dissect_ndr_uint32(tvb, offset, pinfo, tree, drep, + hf_tapi_unknown_long, NULL); + + return offset; +} +static int +dissect_tapi_client_request_reply(tvbuff_t *tvb, int offset, + packet_info *pinfo, proto_tree *tree, + guint8 *drep) +{ + offset = dissect_ndr_uint32(tvb, offset, pinfo, tree, drep, + hf_tapi_rc, NULL); + + return offset; +} + + +/* + IDL void ClientDetach( + IDL void + IDL ); +*/ +static int +dissect_tapi_client_detach_rqst(tvbuff_t *tvb _U_, int offset _U_, + packet_info *pinfo _U_, proto_tree *tree _U_, + guint8 *drep _U_) +{ + return offset; +} +static int +dissect_tapi_client_detach_reply(tvbuff_t *tvb _U_, int offset _U_, + packet_info *pinfo _U_, proto_tree *tree _U_, + guint8 *drep _U_) +{ + return offset; +} + +/* + IDL } +*/ +static dcerpc_sub_dissector dcerpc_tapi_dissectors[] = { + { TAPI_CLIENT_ATTACH, "ClientAttach", + dissect_tapi_client_attach_rqst, + dissect_tapi_client_attach_reply }, + { TAPI_CLIENT_REQUEST, "ClientRequest", + dissect_tapi_client_request_rqst, + dissect_tapi_client_request_reply }, + { TAPI_CLIENT_DETACH, "ClientDetach", + dissect_tapi_client_detach_rqst, + dissect_tapi_client_detach_reply }, + + {0, NULL, NULL, NULL } +}; + +void +proto_register_dcerpc_tapi(void) +{ +static hf_register_info hf[] = { + { &hf_tapi_opnum, { + "Operation", "tapi.opnum", FT_UINT16, BASE_DEC, + NULL, 0x0, "", HFILL }}, + { &hf_tapi_rc, { + "Return code", "tapi.rc", FT_UINT32, BASE_HEX, + VALS(NT_errors), 0x0, "TAPI return code", HFILL }}, + { &hf_tapi_hnd, { + "Context Handle", "tapi.hnd", FT_BYTES, BASE_NONE, + NULL, 0x0, "Context handle", HFILL }}, + { &hf_tapi_unknown_long, { + "Unknown long", "tapi.unknown.long", FT_UINT32, BASE_HEX, + NULL, 0x0, "Unknown long. If you know what this is, contact ethereal developers.", HFILL }}, + { &hf_tapi_unknown_string, { + "Unknown string", "tapi.unknown.string", FT_STRING, BASE_HEX, + NULL, 0x0, "Unknown string. If you know what this is, contact ethereal developers.", HFILL }}, + { &hf_tapi_unknown_bytes, { + "Unknown bytes", "tapi.unknown.bytes", FT_BYTES, BASE_HEX, + NULL, 0x0, "Unknown bytes. If you know what this is, contact ethereal developers.", HFILL }} + }; + + static gint *ett[] = { + &ett_dcerpc_tapi + }; + + proto_dcerpc_tapi = proto_register_protocol( + "Microsoft Telephony API Service", "TAPI", "tapi"); + + proto_register_field_array(proto_dcerpc_tapi, hf, + array_length(hf)); + + proto_register_subtree_array(ett, array_length(ett)); +} + +void +proto_reg_handoff_dcerpc_tapi(void) +{ + /* Register protocol as dcerpc */ + + dcerpc_init_uuid(proto_dcerpc_tapi, ett_dcerpc_tapi, + &uuid_dcerpc_tapi, ver_dcerpc_tapi, + dcerpc_tapi_dissectors, hf_tapi_opnum); +} |