aboutsummaryrefslogtreecommitdiffstats
path: root/epan/dissectors/packet-MAP_DialoguePDU.c
diff options
context:
space:
mode:
authorGuy Harris <guy@alum.mit.edu>2004-10-27 21:16:18 +0000
committerGuy Harris <guy@alum.mit.edu>2004-10-27 21:16:18 +0000
commit21e7c6bc78dd27c84e4eec6470c2fb5084f35c56 (patch)
tree69624fd48db08f0a4e29c98d95636e372e7227b0 /epan/dissectors/packet-MAP_DialoguePDU.c
parentba80dd691f745c8fd88851f668dd1ca95749302e (diff)
"dissect_MAP_Dialogue()" returns no value; declare its return value as
"void". Fix a typo in the MAP Dialogue dissector template .h file. Re-generate the MAP Dialogue dissector files and set svn:keywords to Id and svn:eol-style to native for them. svn path=/trunk/; revision=12419
Diffstat (limited to 'epan/dissectors/packet-MAP_DialoguePDU.c')
-rw-r--r--epan/dissectors/packet-MAP_DialoguePDU.c1212
1 files changed, 606 insertions, 606 deletions
diff --git a/epan/dissectors/packet-MAP_DialoguePDU.c b/epan/dissectors/packet-MAP_DialoguePDU.c
index e3b037cc80..e0aa2eeb43 100644
--- a/epan/dissectors/packet-MAP_DialoguePDU.c
+++ b/epan/dissectors/packet-MAP_DialoguePDU.c
@@ -1,606 +1,606 @@
-/* Do not modify this file. */
-/* It is created automatically by the ASN.1 to Ethereal dissector compiler */
-/* .\packet-MAP_DialoguePDU.c */
-/* ../../tools/asn2eth.py -X -b -e -p MAP_DialoguePDU -c MAP_DialoguePDU.cnf -s packet-MAP-DialoguePDU-template MAP_DialoguePDU.asn */
-
-/* Input file: packet-MAP-DialoguePDU-template.c */
-
-/* packet-MAP_DialoguePDU_asn1.c
- * Routines for MAP_DialoguePDU packet dissection
- *
- * $Id: packet-MAP_DialoguePDU_asn1-template.c 12203 2004-10-05 09:18:55Z guy $
- *
- * 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.
- */
-
-#ifdef HAVE_CONFIG_H
-# include "config.h"
-#endif
-
-#include <glib.h>
-#include <epan/packet.h>
-#include <epan/conversation.h>
-
-#include <stdio.h>
-#include <string.h>
-
-#include "packet-ber.h"
-
-#define PNAME "MAP_DialoguePDU"
-#define PSNAME "MAP_DialoguePDU"
-#define PFNAME "MAP_DialoguePDU"
-
-/* Initialize the protocol and registered fields */
-int proto_MAP_DialoguePDU = -1;
-
-/*--- Included file: packet-MAP_DialoguePDU-hf.c ---*/
-
-static int hf_MAP_DialoguePDU_map_open = -1; /* T_map_open */
-static int hf_MAP_DialoguePDU_destinationReference = -1; /* DestinationReference */
-static int hf_MAP_DialoguePDU_originationReference = -1; /* OriginationReference */
-static int hf_MAP_DialoguePDU_map_accept = -1; /* T_map_accept */
-static int hf_MAP_DialoguePDU_map_close = -1; /* T_map_close */
-static int hf_MAP_DialoguePDU_map_refuse = -1; /* T_map_refuse */
-static int hf_MAP_DialoguePDU_reason = -1; /* Reason */
-static int hf_MAP_DialoguePDU_map_userAbort = -1; /* T_map_userAbort */
-static int hf_MAP_DialoguePDU_map_UserAbortChoice = -1; /* MAP_UserAbortChoice */
-static int hf_MAP_DialoguePDU_map_providerAbort = -1; /* T_map_providerAbort */
-static int hf_MAP_DialoguePDU_map_ProviderAbortReason = -1; /* MAP_ProviderAbortReason */
-static int hf_MAP_DialoguePDU_userSpecificReason = -1; /* NULL */
-static int hf_MAP_DialoguePDU_userResourceLimitation = -1; /* NULL */
-static int hf_MAP_DialoguePDU_resourceUnavailable = -1; /* ResourceUnavailable */
-static int hf_MAP_DialoguePDU_applicationProcedureCancellation = -1; /* ApplicationProcedureCancellation */
-
-/*--- End of included file: packet-MAP_DialoguePDU-hf.c ---*/
-
-
-/* Initialize the subtree pointers */
-
-/*--- Included file: packet-MAP_DialoguePDU-ett.c ---*/
-
-static gint ett_MAP_DialoguePDU_MAP_DialoguePDU = -1;
-static gint ett_MAP_DialoguePDU_T_map_open = -1;
-static gint ett_MAP_DialoguePDU_T_map_accept = -1;
-static gint ett_MAP_DialoguePDU_T_map_close = -1;
-static gint ett_MAP_DialoguePDU_T_map_refuse = -1;
-static gint ett_MAP_DialoguePDU_T_map_userAbort = -1;
-static gint ett_MAP_DialoguePDU_T_map_providerAbort = -1;
-static gint ett_MAP_DialoguePDU_MAP_OpenInfo = -1;
-static gint ett_MAP_DialoguePDU_MAP_AcceptInfo = -1;
-static gint ett_MAP_DialoguePDU_MAP_CloseInfo = -1;
-static gint ett_MAP_DialoguePDU_MAP_RefuseInfo = -1;
-static gint ett_MAP_DialoguePDU_MAP_UserAbortInfo = -1;
-static gint ett_MAP_DialoguePDU_MAP_UserAbortChoice = -1;
-static gint ett_MAP_DialoguePDU_MAP_ProviderAbortInfo = -1;
-
-/*--- End of included file: packet-MAP_DialoguePDU-ett.c ---*/
-
-
-
-/*--- Included file: packet-MAP_DialoguePDU-fn.c ---*/
-
-/*--- Fields for imported types ---*/
-
-
-
-static int
-dissect_MAP_DialoguePDU_DestinationReference(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_octet_string(implicit_tag, pinfo, tree, tvb, offset, hf_index,
- NULL);
-
- return offset;
-}
-static int dissect_destinationReference_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_DestinationReference(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_destinationReference);
-}
-
-
-static int
-dissect_MAP_DialoguePDU_OriginationReference(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_octet_string(implicit_tag, pinfo, tree, tvb, offset, hf_index,
- NULL);
-
- return offset;
-}
-static int dissect_originationReference_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_OriginationReference(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_originationReference);
-}
-
-static const ber_sequence T_map_open_sequence[] = {
- { BER_CLASS_CON, 0, BER_FLAGS_OPTIONAL|BER_FLAGS_IMPLTAG, dissect_destinationReference_impl },
- { BER_CLASS_CON, 1, BER_FLAGS_OPTIONAL|BER_FLAGS_IMPLTAG, dissect_originationReference_impl },
- { 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_T_map_open(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
- T_map_open_sequence, hf_index, ett_MAP_DialoguePDU_T_map_open);
-
- return offset;
-}
-static int dissect_map_open_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_T_map_open(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_open);
-}
-
-static const ber_sequence T_map_accept_sequence[] = {
- { 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_T_map_accept(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
- T_map_accept_sequence, hf_index, ett_MAP_DialoguePDU_T_map_accept);
-
- return offset;
-}
-static int dissect_map_accept_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_T_map_accept(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_accept);
-}
-
-static const ber_sequence T_map_close_sequence[] = {
- { 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_T_map_close(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
- T_map_close_sequence, hf_index, ett_MAP_DialoguePDU_T_map_close);
-
- return offset;
-}
-static int dissect_map_close_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_T_map_close(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_close);
-}
-
-
-static const value_string Reason_vals[] = {
- { 0, "noReasonGiven" },
- { 1, "invalidDestinationReference" },
- { 2, "invalidOriginatingReference" },
- { 0, NULL }
-};
-
-
-static int
-dissect_MAP_DialoguePDU_Reason(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_integer(pinfo, tree, tvb, offset, hf_index, NULL);
-
- return offset;
-}
-static int dissect_reason(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_Reason(FALSE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_reason);
-}
-
-static const ber_sequence T_map_refuse_sequence[] = {
- { BER_CLASS_UNI, BER_UNI_TAG_ENUMERATED, BER_FLAGS_NOOWNTAG, dissect_reason },
- { 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_T_map_refuse(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
- T_map_refuse_sequence, hf_index, ett_MAP_DialoguePDU_T_map_refuse);
-
- return offset;
-}
-static int dissect_map_refuse_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_T_map_refuse(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_refuse);
-}
-
-
-static int
-dissect_MAP_DialoguePDU_NULL(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- { proto_item *ti_tmp;
- ti_tmp = proto_tree_add_item(tree, hf_index, tvb, offset>>8, 0, FALSE);
- proto_item_append_text(ti_tmp, ": NULL");
- }
-
- return offset;
-}
-static int dissect_userSpecificReason_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_NULL(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_userSpecificReason);
-}
-static int dissect_userResourceLimitation_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_NULL(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_userResourceLimitation);
-}
-
-
-static const value_string ResourceUnavailable_vals[] = {
- { 0, "shortTermResourceLimitation" },
- { 1, "longTermResourceLimitation" },
- { 0, NULL }
-};
-
-
-static int
-dissect_MAP_DialoguePDU_ResourceUnavailable(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_integer(pinfo, tree, tvb, offset, hf_index, NULL);
-
- return offset;
-}
-static int dissect_resourceUnavailable_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_ResourceUnavailable(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_resourceUnavailable);
-}
-
-
-static const value_string ApplicationProcedureCancellation_vals[] = {
- { 0, "handoverCancellation" },
- { 1, "radioChannelRelease" },
- { 2, "networkPathRelease" },
- { 3, "callRelease" },
- { 4, "associatedProcedureFailure" },
- { 5, "tandemDialogueRelease" },
- { 6, "remoteOperationsFailure" },
- { 0, NULL }
-};
-
-
-static int
-dissect_MAP_DialoguePDU_ApplicationProcedureCancellation(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_integer(pinfo, tree, tvb, offset, hf_index, NULL);
-
- return offset;
-}
-static int dissect_applicationProcedureCancellation_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_ApplicationProcedureCancellation(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_applicationProcedureCancellation);
-}
-
-
-static const value_string MAP_UserAbortChoice_vals[] = {
- { 0, "userSpecificReason" },
- { 1, "userResourceLimitation" },
- { 2, "resourceUnavailable" },
- { 3, "applicationProcedureCancellation" },
- { 0, NULL }
-};
-
-static const ber_choice MAP_UserAbortChoice_choice[] = {
- { 0, BER_CLASS_CON, 0, BER_FLAGS_IMPLTAG, dissect_userSpecificReason_impl },
- { 1, BER_CLASS_CON, 1, BER_FLAGS_IMPLTAG, dissect_userResourceLimitation_impl },
- { 2, BER_CLASS_CON, 2, BER_FLAGS_IMPLTAG, dissect_resourceUnavailable_impl },
- { 3, BER_CLASS_CON, 3, BER_FLAGS_IMPLTAG, dissect_applicationProcedureCancellation_impl },
- { 0, 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_MAP_UserAbortChoice(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_choice(pinfo, tree, tvb, offset,
- MAP_UserAbortChoice_choice, hf_index, ett_MAP_DialoguePDU_MAP_UserAbortChoice);
-
- return offset;
-}
-static int dissect_map_UserAbortChoice(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_MAP_UserAbortChoice(FALSE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_UserAbortChoice);
-}
-
-static const ber_sequence T_map_userAbort_sequence[] = {
- { BER_CLASS_CON, -1/*choice*/, BER_FLAGS_NOOWNTAG|BER_FLAGS_NOTCHKTAG, dissect_map_UserAbortChoice },
- { 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_T_map_userAbort(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
- T_map_userAbort_sequence, hf_index, ett_MAP_DialoguePDU_T_map_userAbort);
-
- return offset;
-}
-static int dissect_map_userAbort_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_T_map_userAbort(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_userAbort);
-}
-
-
-static const value_string MAP_ProviderAbortReason_vals[] = {
- { 0, "abnormalDialogue" },
- { 1, "invalidPDU" },
- { 0, NULL }
-};
-
-
-static int
-dissect_MAP_DialoguePDU_MAP_ProviderAbortReason(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_integer(pinfo, tree, tvb, offset, hf_index, NULL);
-
- return offset;
-}
-static int dissect_map_ProviderAbortReason(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_MAP_ProviderAbortReason(FALSE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_ProviderAbortReason);
-}
-
-static const ber_sequence T_map_providerAbort_sequence[] = {
- { BER_CLASS_UNI, BER_UNI_TAG_ENUMERATED, BER_FLAGS_NOOWNTAG, dissect_map_ProviderAbortReason },
- { 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_T_map_providerAbort(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
- T_map_providerAbort_sequence, hf_index, ett_MAP_DialoguePDU_T_map_providerAbort);
-
- return offset;
-}
-static int dissect_map_providerAbort_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
- return dissect_MAP_DialoguePDU_T_map_providerAbort(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_providerAbort);
-}
-
-
-static const value_string MAP_DialoguePDU_vals[] = {
- { 0, "map-open" },
- { 1, "map-accept" },
- { 2, "map-close" },
- { 3, "map-refuse" },
- { 4, "map-userAbort" },
- { 5, "map-providerAbort" },
- { 0, NULL }
-};
-
-static const ber_choice MAP_DialoguePDU_choice[] = {
- { 0, BER_CLASS_CON, 0, BER_FLAGS_IMPLTAG, dissect_map_open_impl },
- { 1, BER_CLASS_CON, 1, BER_FLAGS_IMPLTAG, dissect_map_accept_impl },
- { 2, BER_CLASS_CON, 2, BER_FLAGS_IMPLTAG, dissect_map_close_impl },
- { 3, BER_CLASS_CON, 3, BER_FLAGS_IMPLTAG, dissect_map_refuse_impl },
- { 4, BER_CLASS_CON, 4, BER_FLAGS_IMPLTAG, dissect_map_userAbort_impl },
- { 5, BER_CLASS_CON, 5, BER_FLAGS_IMPLTAG, dissect_map_providerAbort_impl },
- { 0, 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_MAP_DialoguePDU(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_choice(pinfo, tree, tvb, offset,
- MAP_DialoguePDU_choice, hf_index, ett_MAP_DialoguePDU_MAP_DialoguePDU);
-
- return offset;
-}
-
-static const ber_sequence MAP_OpenInfo_sequence[] = {
- { BER_CLASS_CON, 0, BER_FLAGS_OPTIONAL|BER_FLAGS_IMPLTAG, dissect_destinationReference_impl },
- { BER_CLASS_CON, 1, BER_FLAGS_OPTIONAL|BER_FLAGS_IMPLTAG, dissect_originationReference_impl },
- { 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_MAP_OpenInfo(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
- MAP_OpenInfo_sequence, hf_index, ett_MAP_DialoguePDU_MAP_OpenInfo);
-
- return offset;
-}
-
-static const ber_sequence MAP_AcceptInfo_sequence[] = {
- { 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_MAP_AcceptInfo(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
- MAP_AcceptInfo_sequence, hf_index, ett_MAP_DialoguePDU_MAP_AcceptInfo);
-
- return offset;
-}
-
-static const ber_sequence MAP_CloseInfo_sequence[] = {
- { 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_MAP_CloseInfo(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
- MAP_CloseInfo_sequence, hf_index, ett_MAP_DialoguePDU_MAP_CloseInfo);
-
- return offset;
-}
-
-static const ber_sequence MAP_RefuseInfo_sequence[] = {
- { BER_CLASS_UNI, BER_UNI_TAG_ENUMERATED, BER_FLAGS_NOOWNTAG, dissect_reason },
- { 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_MAP_RefuseInfo(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
- MAP_RefuseInfo_sequence, hf_index, ett_MAP_DialoguePDU_MAP_RefuseInfo);
-
- return offset;
-}
-
-static const ber_sequence MAP_UserAbortInfo_sequence[] = {
- { BER_CLASS_CON, -1/*choice*/, BER_FLAGS_NOOWNTAG|BER_FLAGS_NOTCHKTAG, dissect_map_UserAbortChoice },
- { 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_MAP_UserAbortInfo(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
- MAP_UserAbortInfo_sequence, hf_index, ett_MAP_DialoguePDU_MAP_UserAbortInfo);
-
- return offset;
-}
-
-
-static const value_string ResourceUnavailableReason_vals[] = {
- { 0, "shortTermResourceLimitation" },
- { 1, "longTermResourceLimitation" },
- { 0, NULL }
-};
-
-
-static int
-dissect_MAP_DialoguePDU_ResourceUnavailableReason(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_integer(pinfo, tree, tvb, offset, hf_index, NULL);
-
- return offset;
-}
-
-
-static const value_string ProcedureCancellationReason_vals[] = {
- { 0, "handoverCancellation" },
- { 1, "radioChannelRelease" },
- { 2, "networkPathRelease" },
- { 3, "callRelease" },
- { 4, "associatedProcedureFailure" },
- { 5, "tandemDialogueRelease" },
- { 6, "remoteOperationsFailure" },
- { 0, NULL }
-};
-
-
-static int
-dissect_MAP_DialoguePDU_ProcedureCancellationReason(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_integer(pinfo, tree, tvb, offset, hf_index, NULL);
-
- return offset;
-}
-
-static const ber_sequence MAP_ProviderAbortInfo_sequence[] = {
- { BER_CLASS_UNI, BER_UNI_TAG_ENUMERATED, BER_FLAGS_NOOWNTAG, dissect_map_ProviderAbortReason },
- { 0, 0, 0, NULL }
-};
-
-static int
-dissect_MAP_DialoguePDU_MAP_ProviderAbortInfo(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
- offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
- MAP_ProviderAbortInfo_sequence, hf_index, ett_MAP_DialoguePDU_MAP_ProviderAbortInfo);
-
- return offset;
-}
-
-
-/*--- End of included file: packet-MAP_DialoguePDU-fn.c ---*/
-
-
-dissect_MAP_Dialogue(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent_tree)
-{
- dissect_MAP_DialoguePDU_MAP_DialoguePDU(FALSE, tvb, 0, pinfo, parent_tree, -1);
-}
-
-/*--- proto_register_MAP_DialoguePDU -------------------------------------------*/
-void proto_register_MAP_DialoguePDU(void) {
-
- /* List of fields */
- static hf_register_info hf[] = {
-
-/*--- Included file: packet-MAP_DialoguePDU-hfarr.c ---*/
-
- { &hf_MAP_DialoguePDU_map_open,
- { "map-open", "MAP_DialoguePDU.map_open",
- FT_NONE, BASE_NONE, NULL, 0,
- "MAP-DialoguePDU/map-open", HFILL }},
- { &hf_MAP_DialoguePDU_destinationReference,
- { "destinationReference", "MAP_DialoguePDU.destinationReference",
- FT_BYTES, BASE_HEX, NULL, 0,
- "", HFILL }},
- { &hf_MAP_DialoguePDU_originationReference,
- { "originationReference", "MAP_DialoguePDU.originationReference",
- FT_BYTES, BASE_HEX, NULL, 0,
- "", HFILL }},
- { &hf_MAP_DialoguePDU_map_accept,
- { "map-accept", "MAP_DialoguePDU.map_accept",
- FT_NONE, BASE_NONE, NULL, 0,
- "MAP-DialoguePDU/map-accept", HFILL }},
- { &hf_MAP_DialoguePDU_map_close,
- { "map-close", "MAP_DialoguePDU.map_close",
- FT_NONE, BASE_NONE, NULL, 0,
- "MAP-DialoguePDU/map-close", HFILL }},
- { &hf_MAP_DialoguePDU_map_refuse,
- { "map-refuse", "MAP_DialoguePDU.map_refuse",
- FT_NONE, BASE_NONE, NULL, 0,
- "MAP-DialoguePDU/map-refuse", HFILL }},
- { &hf_MAP_DialoguePDU_reason,
- { "reason", "MAP_DialoguePDU.reason",
- FT_UINT32, BASE_DEC, VALS(Reason_vals), 0,
- "", HFILL }},
- { &hf_MAP_DialoguePDU_map_userAbort,
- { "map-userAbort", "MAP_DialoguePDU.map_userAbort",
- FT_NONE, BASE_NONE, NULL, 0,
- "MAP-DialoguePDU/map-userAbort", HFILL }},
- { &hf_MAP_DialoguePDU_map_UserAbortChoice,
- { "map-UserAbortChoice", "MAP_DialoguePDU.map_UserAbortChoice",
- FT_UINT32, BASE_DEC, VALS(MAP_UserAbortChoice_vals), 0,
- "", HFILL }},
- { &hf_MAP_DialoguePDU_map_providerAbort,
- { "map-providerAbort", "MAP_DialoguePDU.map_providerAbort",
- FT_NONE, BASE_NONE, NULL, 0,
- "MAP-DialoguePDU/map-providerAbort", HFILL }},
- { &hf_MAP_DialoguePDU_map_ProviderAbortReason,
- { "map-ProviderAbortReason", "MAP_DialoguePDU.map_ProviderAbortReason",
- FT_UINT32, BASE_DEC, VALS(MAP_ProviderAbortReason_vals), 0,
- "", HFILL }},
- { &hf_MAP_DialoguePDU_userSpecificReason,
- { "userSpecificReason", "MAP_DialoguePDU.userSpecificReason",
- FT_NONE, BASE_NONE, NULL, 0,
- "MAP-UserAbortChoice/userSpecificReason", HFILL }},
- { &hf_MAP_DialoguePDU_userResourceLimitation,
- { "userResourceLimitation", "MAP_DialoguePDU.userResourceLimitation",
- FT_NONE, BASE_NONE, NULL, 0,
- "MAP-UserAbortChoice/userResourceLimitation", HFILL }},
- { &hf_MAP_DialoguePDU_resourceUnavailable,
- { "resourceUnavailable", "MAP_DialoguePDU.resourceUnavailable",
- FT_UINT32, BASE_DEC, VALS(ResourceUnavailable_vals), 0,
- "MAP-UserAbortChoice/resourceUnavailable", HFILL }},
- { &hf_MAP_DialoguePDU_applicationProcedureCancellation,
- { "applicationProcedureCancellation", "MAP_DialoguePDU.applicationProcedureCancellation",
- FT_UINT32, BASE_DEC, VALS(ApplicationProcedureCancellation_vals), 0,
- "MAP-UserAbortChoice/applicationProcedureCancellation", HFILL }},
-
-/*--- End of included file: packet-MAP_DialoguePDU-hfarr.c ---*/
-
- };
-
- /* List of subtrees */
- static gint *ett[] = {
-
-/*--- Included file: packet-MAP_DialoguePDU-ettarr.c ---*/
-
- &ett_MAP_DialoguePDU_MAP_DialoguePDU,
- &ett_MAP_DialoguePDU_T_map_open,
- &ett_MAP_DialoguePDU_T_map_accept,
- &ett_MAP_DialoguePDU_T_map_close,
- &ett_MAP_DialoguePDU_T_map_refuse,
- &ett_MAP_DialoguePDU_T_map_userAbort,
- &ett_MAP_DialoguePDU_T_map_providerAbort,
- &ett_MAP_DialoguePDU_MAP_OpenInfo,
- &ett_MAP_DialoguePDU_MAP_AcceptInfo,
- &ett_MAP_DialoguePDU_MAP_CloseInfo,
- &ett_MAP_DialoguePDU_MAP_RefuseInfo,
- &ett_MAP_DialoguePDU_MAP_UserAbortInfo,
- &ett_MAP_DialoguePDU_MAP_UserAbortChoice,
- &ett_MAP_DialoguePDU_MAP_ProviderAbortInfo,
-
-/*--- End of included file: packet-MAP_DialoguePDU-ettarr.c ---*/
-
- };
-
- /* Register protocol */
- proto_MAP_DialoguePDU = proto_register_protocol(PNAME, PSNAME, PFNAME);
- register_dissector("MAP_DialoguePDU", dissect_MAP_Dialogue, proto_MAP_DialoguePDU);
- /* Register fields and subtrees */
- proto_register_field_array(proto_MAP_DialoguePDU, hf, array_length(hf));
- proto_register_subtree_array(ett, array_length(ett));
-
-}
-
-
-/*--- proto_reg_handoff_MAP_DialoguePDU ---------------------------------------*/
-void proto_reg_handoff_MAP_DialoguePDU(void) {
- register_ber_oid_dissector("0.4.0.0.1.1.1.1", dissect_MAP_Dialogue, proto_MAP_DialoguePDU,
- "itu-t(0) identified-organization(4) etsi(0) mobileDomain(0) gsm-Network(1) abstractSyntax(1) map-DialoguePDU(1) version1(1)");
-
-}
-
+/* Do not modify this file. */
+/* It is created automatically by the ASN.1 to Ethereal dissector compiler */
+/* ./packet-MAP_DialoguePDU.c */
+/* ../../tools/asn2eth.py -X -b -e -p MAP_DialoguePDU -c MAP_DialoguePDU.cnf -s packet-MAP-DialoguePDU-template MAP_DialoguePDU.asn */
+
+/* Input file: packet-MAP-DialoguePDU-template.c */
+
+/* packet-MAP_DialoguePDU_asn1.c
+ * Routines for MAP_DialoguePDU packet dissection
+ *
+ * $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.
+ */
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include <glib.h>
+#include <epan/packet.h>
+#include <epan/conversation.h>
+
+#include <stdio.h>
+#include <string.h>
+
+#include "packet-ber.h"
+
+#define PNAME "MAP_DialoguePDU"
+#define PSNAME "MAP_DialoguePDU"
+#define PFNAME "MAP_DialoguePDU"
+
+/* Initialize the protocol and registered fields */
+int proto_MAP_DialoguePDU = -1;
+
+/*--- Included file: packet-MAP_DialoguePDU-hf.c ---*/
+
+static int hf_MAP_DialoguePDU_map_open = -1; /* T_map_open */
+static int hf_MAP_DialoguePDU_destinationReference = -1; /* DestinationReference */
+static int hf_MAP_DialoguePDU_originationReference = -1; /* OriginationReference */
+static int hf_MAP_DialoguePDU_map_accept = -1; /* T_map_accept */
+static int hf_MAP_DialoguePDU_map_close = -1; /* T_map_close */
+static int hf_MAP_DialoguePDU_map_refuse = -1; /* T_map_refuse */
+static int hf_MAP_DialoguePDU_reason = -1; /* Reason */
+static int hf_MAP_DialoguePDU_map_userAbort = -1; /* T_map_userAbort */
+static int hf_MAP_DialoguePDU_map_UserAbortChoice = -1; /* MAP_UserAbortChoice */
+static int hf_MAP_DialoguePDU_map_providerAbort = -1; /* T_map_providerAbort */
+static int hf_MAP_DialoguePDU_map_ProviderAbortReason = -1; /* MAP_ProviderAbortReason */
+static int hf_MAP_DialoguePDU_userSpecificReason = -1; /* NULL */
+static int hf_MAP_DialoguePDU_userResourceLimitation = -1; /* NULL */
+static int hf_MAP_DialoguePDU_resourceUnavailable = -1; /* ResourceUnavailable */
+static int hf_MAP_DialoguePDU_applicationProcedureCancellation = -1; /* ApplicationProcedureCancellation */
+
+/*--- End of included file: packet-MAP_DialoguePDU-hf.c ---*/
+
+
+/* Initialize the subtree pointers */
+
+/*--- Included file: packet-MAP_DialoguePDU-ett.c ---*/
+
+static gint ett_MAP_DialoguePDU_MAP_DialoguePDU = -1;
+static gint ett_MAP_DialoguePDU_T_map_open = -1;
+static gint ett_MAP_DialoguePDU_T_map_accept = -1;
+static gint ett_MAP_DialoguePDU_T_map_close = -1;
+static gint ett_MAP_DialoguePDU_T_map_refuse = -1;
+static gint ett_MAP_DialoguePDU_T_map_userAbort = -1;
+static gint ett_MAP_DialoguePDU_T_map_providerAbort = -1;
+static gint ett_MAP_DialoguePDU_MAP_OpenInfo = -1;
+static gint ett_MAP_DialoguePDU_MAP_AcceptInfo = -1;
+static gint ett_MAP_DialoguePDU_MAP_CloseInfo = -1;
+static gint ett_MAP_DialoguePDU_MAP_RefuseInfo = -1;
+static gint ett_MAP_DialoguePDU_MAP_UserAbortInfo = -1;
+static gint ett_MAP_DialoguePDU_MAP_UserAbortChoice = -1;
+static gint ett_MAP_DialoguePDU_MAP_ProviderAbortInfo = -1;
+
+/*--- End of included file: packet-MAP_DialoguePDU-ett.c ---*/
+
+
+
+/*--- Included file: packet-MAP_DialoguePDU-fn.c ---*/
+
+/*--- Fields for imported types ---*/
+
+
+
+static int
+dissect_MAP_DialoguePDU_DestinationReference(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_octet_string(implicit_tag, pinfo, tree, tvb, offset, hf_index,
+ NULL);
+
+ return offset;
+}
+static int dissect_destinationReference_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_DestinationReference(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_destinationReference);
+}
+
+
+static int
+dissect_MAP_DialoguePDU_OriginationReference(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_octet_string(implicit_tag, pinfo, tree, tvb, offset, hf_index,
+ NULL);
+
+ return offset;
+}
+static int dissect_originationReference_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_OriginationReference(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_originationReference);
+}
+
+static const ber_sequence T_map_open_sequence[] = {
+ { BER_CLASS_CON, 0, BER_FLAGS_OPTIONAL|BER_FLAGS_IMPLTAG, dissect_destinationReference_impl },
+ { BER_CLASS_CON, 1, BER_FLAGS_OPTIONAL|BER_FLAGS_IMPLTAG, dissect_originationReference_impl },
+ { 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_T_map_open(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
+ T_map_open_sequence, hf_index, ett_MAP_DialoguePDU_T_map_open);
+
+ return offset;
+}
+static int dissect_map_open_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_T_map_open(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_open);
+}
+
+static const ber_sequence T_map_accept_sequence[] = {
+ { 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_T_map_accept(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
+ T_map_accept_sequence, hf_index, ett_MAP_DialoguePDU_T_map_accept);
+
+ return offset;
+}
+static int dissect_map_accept_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_T_map_accept(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_accept);
+}
+
+static const ber_sequence T_map_close_sequence[] = {
+ { 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_T_map_close(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
+ T_map_close_sequence, hf_index, ett_MAP_DialoguePDU_T_map_close);
+
+ return offset;
+}
+static int dissect_map_close_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_T_map_close(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_close);
+}
+
+
+static const value_string Reason_vals[] = {
+ { 0, "noReasonGiven" },
+ { 1, "invalidDestinationReference" },
+ { 2, "invalidOriginatingReference" },
+ { 0, NULL }
+};
+
+
+static int
+dissect_MAP_DialoguePDU_Reason(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_integer(pinfo, tree, tvb, offset, hf_index, NULL);
+
+ return offset;
+}
+static int dissect_reason(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_Reason(FALSE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_reason);
+}
+
+static const ber_sequence T_map_refuse_sequence[] = {
+ { BER_CLASS_UNI, BER_UNI_TAG_ENUMERATED, BER_FLAGS_NOOWNTAG, dissect_reason },
+ { 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_T_map_refuse(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
+ T_map_refuse_sequence, hf_index, ett_MAP_DialoguePDU_T_map_refuse);
+
+ return offset;
+}
+static int dissect_map_refuse_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_T_map_refuse(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_refuse);
+}
+
+
+static int
+dissect_MAP_DialoguePDU_NULL(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ { proto_item *ti_tmp;
+ ti_tmp = proto_tree_add_item(tree, hf_index, tvb, offset>>8, 0, FALSE);
+ proto_item_append_text(ti_tmp, ": NULL");
+ }
+
+ return offset;
+}
+static int dissect_userSpecificReason_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_NULL(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_userSpecificReason);
+}
+static int dissect_userResourceLimitation_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_NULL(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_userResourceLimitation);
+}
+
+
+static const value_string ResourceUnavailable_vals[] = {
+ { 0, "shortTermResourceLimitation" },
+ { 1, "longTermResourceLimitation" },
+ { 0, NULL }
+};
+
+
+static int
+dissect_MAP_DialoguePDU_ResourceUnavailable(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_integer(pinfo, tree, tvb, offset, hf_index, NULL);
+
+ return offset;
+}
+static int dissect_resourceUnavailable_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_ResourceUnavailable(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_resourceUnavailable);
+}
+
+
+static const value_string ApplicationProcedureCancellation_vals[] = {
+ { 0, "handoverCancellation" },
+ { 1, "radioChannelRelease" },
+ { 2, "networkPathRelease" },
+ { 3, "callRelease" },
+ { 4, "associatedProcedureFailure" },
+ { 5, "tandemDialogueRelease" },
+ { 6, "remoteOperationsFailure" },
+ { 0, NULL }
+};
+
+
+static int
+dissect_MAP_DialoguePDU_ApplicationProcedureCancellation(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_integer(pinfo, tree, tvb, offset, hf_index, NULL);
+
+ return offset;
+}
+static int dissect_applicationProcedureCancellation_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_ApplicationProcedureCancellation(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_applicationProcedureCancellation);
+}
+
+
+static const value_string MAP_UserAbortChoice_vals[] = {
+ { 0, "userSpecificReason" },
+ { 1, "userResourceLimitation" },
+ { 2, "resourceUnavailable" },
+ { 3, "applicationProcedureCancellation" },
+ { 0, NULL }
+};
+
+static const ber_choice MAP_UserAbortChoice_choice[] = {
+ { 0, BER_CLASS_CON, 0, BER_FLAGS_IMPLTAG, dissect_userSpecificReason_impl },
+ { 1, BER_CLASS_CON, 1, BER_FLAGS_IMPLTAG, dissect_userResourceLimitation_impl },
+ { 2, BER_CLASS_CON, 2, BER_FLAGS_IMPLTAG, dissect_resourceUnavailable_impl },
+ { 3, BER_CLASS_CON, 3, BER_FLAGS_IMPLTAG, dissect_applicationProcedureCancellation_impl },
+ { 0, 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_MAP_UserAbortChoice(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_choice(pinfo, tree, tvb, offset,
+ MAP_UserAbortChoice_choice, hf_index, ett_MAP_DialoguePDU_MAP_UserAbortChoice);
+
+ return offset;
+}
+static int dissect_map_UserAbortChoice(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_MAP_UserAbortChoice(FALSE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_UserAbortChoice);
+}
+
+static const ber_sequence T_map_userAbort_sequence[] = {
+ { BER_CLASS_CON, -1/*choice*/, BER_FLAGS_NOOWNTAG|BER_FLAGS_NOTCHKTAG, dissect_map_UserAbortChoice },
+ { 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_T_map_userAbort(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
+ T_map_userAbort_sequence, hf_index, ett_MAP_DialoguePDU_T_map_userAbort);
+
+ return offset;
+}
+static int dissect_map_userAbort_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_T_map_userAbort(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_userAbort);
+}
+
+
+static const value_string MAP_ProviderAbortReason_vals[] = {
+ { 0, "abnormalDialogue" },
+ { 1, "invalidPDU" },
+ { 0, NULL }
+};
+
+
+static int
+dissect_MAP_DialoguePDU_MAP_ProviderAbortReason(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_integer(pinfo, tree, tvb, offset, hf_index, NULL);
+
+ return offset;
+}
+static int dissect_map_ProviderAbortReason(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_MAP_ProviderAbortReason(FALSE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_ProviderAbortReason);
+}
+
+static const ber_sequence T_map_providerAbort_sequence[] = {
+ { BER_CLASS_UNI, BER_UNI_TAG_ENUMERATED, BER_FLAGS_NOOWNTAG, dissect_map_ProviderAbortReason },
+ { 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_T_map_providerAbort(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
+ T_map_providerAbort_sequence, hf_index, ett_MAP_DialoguePDU_T_map_providerAbort);
+
+ return offset;
+}
+static int dissect_map_providerAbort_impl(packet_info *pinfo, proto_tree *tree, tvbuff_t *tvb, int offset) {
+ return dissect_MAP_DialoguePDU_T_map_providerAbort(TRUE, tvb, offset, pinfo, tree, hf_MAP_DialoguePDU_map_providerAbort);
+}
+
+
+static const value_string MAP_DialoguePDU_vals[] = {
+ { 0, "map-open" },
+ { 1, "map-accept" },
+ { 2, "map-close" },
+ { 3, "map-refuse" },
+ { 4, "map-userAbort" },
+ { 5, "map-providerAbort" },
+ { 0, NULL }
+};
+
+static const ber_choice MAP_DialoguePDU_choice[] = {
+ { 0, BER_CLASS_CON, 0, BER_FLAGS_IMPLTAG, dissect_map_open_impl },
+ { 1, BER_CLASS_CON, 1, BER_FLAGS_IMPLTAG, dissect_map_accept_impl },
+ { 2, BER_CLASS_CON, 2, BER_FLAGS_IMPLTAG, dissect_map_close_impl },
+ { 3, BER_CLASS_CON, 3, BER_FLAGS_IMPLTAG, dissect_map_refuse_impl },
+ { 4, BER_CLASS_CON, 4, BER_FLAGS_IMPLTAG, dissect_map_userAbort_impl },
+ { 5, BER_CLASS_CON, 5, BER_FLAGS_IMPLTAG, dissect_map_providerAbort_impl },
+ { 0, 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_MAP_DialoguePDU(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_choice(pinfo, tree, tvb, offset,
+ MAP_DialoguePDU_choice, hf_index, ett_MAP_DialoguePDU_MAP_DialoguePDU);
+
+ return offset;
+}
+
+static const ber_sequence MAP_OpenInfo_sequence[] = {
+ { BER_CLASS_CON, 0, BER_FLAGS_OPTIONAL|BER_FLAGS_IMPLTAG, dissect_destinationReference_impl },
+ { BER_CLASS_CON, 1, BER_FLAGS_OPTIONAL|BER_FLAGS_IMPLTAG, dissect_originationReference_impl },
+ { 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_MAP_OpenInfo(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
+ MAP_OpenInfo_sequence, hf_index, ett_MAP_DialoguePDU_MAP_OpenInfo);
+
+ return offset;
+}
+
+static const ber_sequence MAP_AcceptInfo_sequence[] = {
+ { 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_MAP_AcceptInfo(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
+ MAP_AcceptInfo_sequence, hf_index, ett_MAP_DialoguePDU_MAP_AcceptInfo);
+
+ return offset;
+}
+
+static const ber_sequence MAP_CloseInfo_sequence[] = {
+ { 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_MAP_CloseInfo(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
+ MAP_CloseInfo_sequence, hf_index, ett_MAP_DialoguePDU_MAP_CloseInfo);
+
+ return offset;
+}
+
+static const ber_sequence MAP_RefuseInfo_sequence[] = {
+ { BER_CLASS_UNI, BER_UNI_TAG_ENUMERATED, BER_FLAGS_NOOWNTAG, dissect_reason },
+ { 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_MAP_RefuseInfo(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
+ MAP_RefuseInfo_sequence, hf_index, ett_MAP_DialoguePDU_MAP_RefuseInfo);
+
+ return offset;
+}
+
+static const ber_sequence MAP_UserAbortInfo_sequence[] = {
+ { BER_CLASS_CON, -1/*choice*/, BER_FLAGS_NOOWNTAG|BER_FLAGS_NOTCHKTAG, dissect_map_UserAbortChoice },
+ { 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_MAP_UserAbortInfo(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
+ MAP_UserAbortInfo_sequence, hf_index, ett_MAP_DialoguePDU_MAP_UserAbortInfo);
+
+ return offset;
+}
+
+
+static const value_string ResourceUnavailableReason_vals[] = {
+ { 0, "shortTermResourceLimitation" },
+ { 1, "longTermResourceLimitation" },
+ { 0, NULL }
+};
+
+
+static int
+dissect_MAP_DialoguePDU_ResourceUnavailableReason(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_integer(pinfo, tree, tvb, offset, hf_index, NULL);
+
+ return offset;
+}
+
+
+static const value_string ProcedureCancellationReason_vals[] = {
+ { 0, "handoverCancellation" },
+ { 1, "radioChannelRelease" },
+ { 2, "networkPathRelease" },
+ { 3, "callRelease" },
+ { 4, "associatedProcedureFailure" },
+ { 5, "tandemDialogueRelease" },
+ { 6, "remoteOperationsFailure" },
+ { 0, NULL }
+};
+
+
+static int
+dissect_MAP_DialoguePDU_ProcedureCancellationReason(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_integer(pinfo, tree, tvb, offset, hf_index, NULL);
+
+ return offset;
+}
+
+static const ber_sequence MAP_ProviderAbortInfo_sequence[] = {
+ { BER_CLASS_UNI, BER_UNI_TAG_ENUMERATED, BER_FLAGS_NOOWNTAG, dissect_map_ProviderAbortReason },
+ { 0, 0, 0, NULL }
+};
+
+static int
+dissect_MAP_DialoguePDU_MAP_ProviderAbortInfo(gboolean implicit_tag _U_, tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_tree *tree, int hf_index) {
+ offset = dissect_ber_sequence(implicit_tag, pinfo, tree, tvb, offset,
+ MAP_ProviderAbortInfo_sequence, hf_index, ett_MAP_DialoguePDU_MAP_ProviderAbortInfo);
+
+ return offset;
+}
+
+
+/*--- End of included file: packet-MAP_DialoguePDU-fn.c ---*/
+
+
+void
+dissect_MAP_Dialogue(tvbuff_t *tvb, packet_info *pinfo, proto_tree *parent_tree)
+{
+ dissect_MAP_DialoguePDU_MAP_DialoguePDU(FALSE, tvb, 0, pinfo, parent_tree, -1);
+}
+
+/*--- proto_register_MAP_DialoguePDU -------------------------------------------*/
+void proto_register_MAP_DialoguePDU(void) {
+
+ /* List of fields */
+ static hf_register_info hf[] = {
+
+/*--- Included file: packet-MAP_DialoguePDU-hfarr.c ---*/
+
+ { &hf_MAP_DialoguePDU_map_open,
+ { "map-open", "MAP_DialoguePDU.map_open",
+ FT_NONE, BASE_NONE, NULL, 0,
+ "MAP-DialoguePDU/map-open", HFILL }},
+ { &hf_MAP_DialoguePDU_destinationReference,
+ { "destinationReference", "MAP_DialoguePDU.destinationReference",
+ FT_BYTES, BASE_HEX, NULL, 0,
+ "", HFILL }},
+ { &hf_MAP_DialoguePDU_originationReference,
+ { "originationReference", "MAP_DialoguePDU.originationReference",
+ FT_BYTES, BASE_HEX, NULL, 0,
+ "", HFILL }},
+ { &hf_MAP_DialoguePDU_map_accept,
+ { "map-accept", "MAP_DialoguePDU.map_accept",
+ FT_NONE, BASE_NONE, NULL, 0,
+ "MAP-DialoguePDU/map-accept", HFILL }},
+ { &hf_MAP_DialoguePDU_map_close,
+ { "map-close", "MAP_DialoguePDU.map_close",
+ FT_NONE, BASE_NONE, NULL, 0,
+ "MAP-DialoguePDU/map-close", HFILL }},
+ { &hf_MAP_DialoguePDU_map_refuse,
+ { "map-refuse", "MAP_DialoguePDU.map_refuse",
+ FT_NONE, BASE_NONE, NULL, 0,
+ "MAP-DialoguePDU/map-refuse", HFILL }},
+ { &hf_MAP_DialoguePDU_reason,
+ { "reason", "MAP_DialoguePDU.reason",
+ FT_UINT32, BASE_DEC, VALS(Reason_vals), 0,
+ "", HFILL }},
+ { &hf_MAP_DialoguePDU_map_userAbort,
+ { "map-userAbort", "MAP_DialoguePDU.map_userAbort",
+ FT_NONE, BASE_NONE, NULL, 0,
+ "MAP-DialoguePDU/map-userAbort", HFILL }},
+ { &hf_MAP_DialoguePDU_map_UserAbortChoice,
+ { "map-UserAbortChoice", "MAP_DialoguePDU.map_UserAbortChoice",
+ FT_UINT32, BASE_DEC, VALS(MAP_UserAbortChoice_vals), 0,
+ "", HFILL }},
+ { &hf_MAP_DialoguePDU_map_providerAbort,
+ { "map-providerAbort", "MAP_DialoguePDU.map_providerAbort",
+ FT_NONE, BASE_NONE, NULL, 0,
+ "MAP-DialoguePDU/map-providerAbort", HFILL }},
+ { &hf_MAP_DialoguePDU_map_ProviderAbortReason,
+ { "map-ProviderAbortReason", "MAP_DialoguePDU.map_ProviderAbortReason",
+ FT_UINT32, BASE_DEC, VALS(MAP_ProviderAbortReason_vals), 0,
+ "", HFILL }},
+ { &hf_MAP_DialoguePDU_userSpecificReason,
+ { "userSpecificReason", "MAP_DialoguePDU.userSpecificReason",
+ FT_NONE, BASE_NONE, NULL, 0,
+ "MAP-UserAbortChoice/userSpecificReason", HFILL }},
+ { &hf_MAP_DialoguePDU_userResourceLimitation,
+ { "userResourceLimitation", "MAP_DialoguePDU.userResourceLimitation",
+ FT_NONE, BASE_NONE, NULL, 0,
+ "MAP-UserAbortChoice/userResourceLimitation", HFILL }},
+ { &hf_MAP_DialoguePDU_resourceUnavailable,
+ { "resourceUnavailable", "MAP_DialoguePDU.resourceUnavailable",
+ FT_UINT32, BASE_DEC, VALS(ResourceUnavailable_vals), 0,
+ "MAP-UserAbortChoice/resourceUnavailable", HFILL }},
+ { &hf_MAP_DialoguePDU_applicationProcedureCancellation,
+ { "applicationProcedureCancellation", "MAP_DialoguePDU.applicationProcedureCancellation",
+ FT_UINT32, BASE_DEC, VALS(ApplicationProcedureCancellation_vals), 0,
+ "MAP-UserAbortChoice/applicationProcedureCancellation", HFILL }},
+
+/*--- End of included file: packet-MAP_DialoguePDU-hfarr.c ---*/
+
+ };
+
+ /* List of subtrees */
+ static gint *ett[] = {
+
+/*--- Included file: packet-MAP_DialoguePDU-ettarr.c ---*/
+
+ &ett_MAP_DialoguePDU_MAP_DialoguePDU,
+ &ett_MAP_DialoguePDU_T_map_open,
+ &ett_MAP_DialoguePDU_T_map_accept,
+ &ett_MAP_DialoguePDU_T_map_close,
+ &ett_MAP_DialoguePDU_T_map_refuse,
+ &ett_MAP_DialoguePDU_T_map_userAbort,
+ &ett_MAP_DialoguePDU_T_map_providerAbort,
+ &ett_MAP_DialoguePDU_MAP_OpenInfo,
+ &ett_MAP_DialoguePDU_MAP_AcceptInfo,
+ &ett_MAP_DialoguePDU_MAP_CloseInfo,
+ &ett_MAP_DialoguePDU_MAP_RefuseInfo,
+ &ett_MAP_DialoguePDU_MAP_UserAbortInfo,
+ &ett_MAP_DialoguePDU_MAP_UserAbortChoice,
+ &ett_MAP_DialoguePDU_MAP_ProviderAbortInfo,
+
+/*--- End of included file: packet-MAP_DialoguePDU-ettarr.c ---*/
+
+ };
+
+ /* Register protocol */
+ proto_MAP_DialoguePDU = proto_register_protocol(PNAME, PSNAME, PFNAME);
+ register_dissector("MAP_DialoguePDU", dissect_MAP_Dialogue, proto_MAP_DialoguePDU);
+ /* Register fields and subtrees */
+ proto_register_field_array(proto_MAP_DialoguePDU, hf, array_length(hf));
+ proto_register_subtree_array(ett, array_length(ett));
+
+}
+
+
+/*--- proto_reg_handoff_MAP_DialoguePDU ---------------------------------------*/
+void proto_reg_handoff_MAP_DialoguePDU(void) {
+ register_ber_oid_dissector("0.4.0.0.1.1.1.1", dissect_MAP_Dialogue, proto_MAP_DialoguePDU,
+ "itu-t(0) identified-organization(4) etsi(0) mobileDomain(0) gsm-Network(1) abstractSyntax(1) map-DialoguePDU(1) version1(1)");
+
+}