aboutsummaryrefslogtreecommitdiffstats
path: root/packet-m3ua.c
diff options
context:
space:
mode:
authortuexen <tuexen@f5534014-38df-0310-8fa8-9805f1628bb7>2003-01-22 09:07:26 +0000
committertuexen <tuexen@f5534014-38df-0310-8fa8-9805f1628bb7>2003-01-22 09:07:26 +0000
commit06a36173574fb81ed6a7341661e282485c17176f (patch)
tree095822e517f5c084384c3232e1af61acebc55294 /packet-m3ua.c
parent6258d4d9fbf7248b6a7ad9df9f670d9c16bb5f2b (diff)
Added support for version 05 of the (expired) ID describing M3UA.
Updated to support RFC 3332. Better handling of padding. git-svn-id: http://anonsvn.wireshark.org/wireshark/trunk@6976 f5534014-38df-0310-8fa8-9805f1628bb7
Diffstat (limited to 'packet-m3ua.c')
-rw-r--r--packet-m3ua.c1957
1 files changed, 908 insertions, 1049 deletions
diff --git a/packet-m3ua.c b/packet-m3ua.c
index 4c6bd2bdc6..51921624ea 100644
--- a/packet-m3ua.c
+++ b/packet-m3ua.c
@@ -1,15 +1,13 @@
/* packet-m3ua.c
* Routines for MTP3 User Adaptation Layer dissection
* It is hopefully (needs testing) compilant to
- * http://www.ietf.org/internet-drafts/draft-ietf-sigtran-m3ua-06.txt
- * http://www.ietf.org/internet-drafts/draft-ietf-sigtran-m3ua-12.txt
- * To do: - clean up the code
- * - provide better handling of length parameters
- * - provide good information in summary window
+ * http://www.ietf.org/internet-drafts/draft-ietf-sigtran-m3ua-05.txt (expired)
+ * http://www.ietf.org/internet-drafts/draft-ietf-sigtran-m3ua-06.txt (expired)
+ * http://www.ietf.org/rfc/rfc3332.txt
*
- * Copyright 2000, 2001, 2002, Michael Tuexen <Michael.Tuexen [AT] siemens.com>
+ * Copyright 2000, 2001, 2002, 2003 Michael Tuexen <Michael.Tuexen [AT] siemens.com>
*
- * $Id: packet-m3ua.c,v 1.23 2003/01/14 23:53:32 guy Exp $
+ * $Id: packet-m3ua.c,v 1.24 2003/01/22 09:07:26 tuexen Exp $
*
* Ethereal - Network traffic analyzer
* By Gerald Combs <gerald@ethereal.com>
@@ -48,6 +46,8 @@
#include "sctpppids.h"
#define SCTP_PORT_M3UA 2905
+#define NETWORK_BYTE_ORDER FALSE
+#define ADD_PADDING(x) ((((x) + 3) >> 2) << 2)
#define VERSION_LENGTH 1
#define RESERVED_LENGTH 1
@@ -72,120 +72,9 @@
#define PARAMETER_VALUE_OFFSET (PARAMETER_LENGTH_OFFSET + PARAMETER_LENGTH_LENGTH)
#define PARAMETER_HEADER_OFFSET PARAMETER_TAG_OFFSET
-#define V6_NETWORK_APPEARANCE_PARAMETER_TAG 1
-#define V6_PROTOCOL_DATA_1_PARAMETER_TAG 2
-#define V6_PROTOCOL_DATA_2_PARAMETER_TAG 3
-#define V6_INFO_PARAMETER_TAG 4
-#define V6_AFFECTED_DESTINATIONS_PARAMETER_TAG 5
-#define V6_ROUTING_CONTEXT_PARAMETER_TAG 6
-#define V6_DIAGNOSTIC_INFORMATION_PARAMETER_TAG 7
-#define V6_HEARTBEAT_DATA_PARAMETER_TAG 8
-#define V6_USER_CAUSE_PARAMETER_TAG 9
-#define V6_REASON_PARAMETER_TAG 10
-#define V6_TRAFFIC_MODE_TYPE_PARAMETER_TAG 11
-#define V6_ERROR_CODE_PARAMETER_TAG 12
-#define V6_STATUS_PARAMETER_TAG 13
-#define V6_CONGESTION_INDICATION_PARAMETER_TAG 14
-#define V6_CONCERNED_DESTINATION_PARAMETER_TAG 15
-#define V6_ROUTING_KEY_PARAMETER_TAG 16
-#define V6_REGISTRATION_RESULT_PARAMETER_TAG 17
-#define V6_DEREGISTRATION_RESULT_PARAMETER_TAG 18
-#define V6_LOCAL_ROUTING_KEY_IDENTIFIER_PARAMETER_TAG 19
-#define V6_DESTINATION_POINT_CODE_PARAMETER_TAG 20
-#define V6_SERVICE_INDICATORS_PARAMETER_TAG 21
-#define V6_SUBSYSTEM_NUMBERS_PARAMETER_TAG 22
-#define V6_ORIGINATING_POINT_CODE_LIST_PARAMETER_TAG 23
-#define V6_CIRCUIT_RANGE_PARAMETER_TAG 24
-#define V6_REGISTRATION_RESULTS_PARAMETER_TAG 25
-#define V6_DEREGISTRATION_RESULTS_PARAMETER_TAG 26
-
-static const value_string m3ua_v6_parameter_tag_values[] = {
- { V6_NETWORK_APPEARANCE_PARAMETER_TAG, "Network appearance" },
- { V6_PROTOCOL_DATA_1_PARAMETER_TAG, "Protocol data 1" },
- { V6_PROTOCOL_DATA_2_PARAMETER_TAG, "Protocol data 2" },
- { V6_INFO_PARAMETER_TAG, "Info" },
- { V6_AFFECTED_DESTINATIONS_PARAMETER_TAG, "Affected destinations" },
- { V6_ROUTING_CONTEXT_PARAMETER_TAG, "Routing context" },
- { V6_DIAGNOSTIC_INFORMATION_PARAMETER_TAG, "Diagnostic information" },
- { V6_HEARTBEAT_DATA_PARAMETER_TAG, "Heartbeat data" },
- { V6_USER_CAUSE_PARAMETER_TAG, "User / Cause" },
- { V6_REASON_PARAMETER_TAG, "Reason" },
- { V6_TRAFFIC_MODE_TYPE_PARAMETER_TAG, "Traffic mode type" },
- { V6_ERROR_CODE_PARAMETER_TAG, "Error code" },
- { V6_STATUS_PARAMETER_TAG, "Status" },
- { V6_CONGESTION_INDICATION_PARAMETER_TAG, "Congestion indication" },
- { V6_CONCERNED_DESTINATION_PARAMETER_TAG, "Concerned destination" },
- { V6_ROUTING_KEY_PARAMETER_TAG, "Routing Key" },
- { V6_REGISTRATION_RESULT_PARAMETER_TAG, "Registration result" },
- { V6_DEREGISTRATION_RESULT_PARAMETER_TAG, "De-registration result" },
- { V6_LOCAL_ROUTING_KEY_IDENTIFIER_PARAMETER_TAG, "Local routing key identifier" },
- { V6_DESTINATION_POINT_CODE_PARAMETER_TAG, "Destination point code" },
- { V6_SERVICE_INDICATORS_PARAMETER_TAG, "Service indicators" },
- { V6_SUBSYSTEM_NUMBERS_PARAMETER_TAG, "Subsystem numbers" },
- { V6_ORIGINATING_POINT_CODE_LIST_PARAMETER_TAG, "Originating point code list" },
- { V6_CIRCUIT_RANGE_PARAMETER_TAG, "Circuit range" },
- { V6_REGISTRATION_RESULTS_PARAMETER_TAG, "Registration results" },
- { V6_DEREGISTRATION_RESULTS_PARAMETER_TAG, "De-registration results" },
- { 0, NULL } };
-
-#define V12_INFO_STRING_PARAMETER_TAG 0x0004
-#define V12_ROUTING_CONTEXT_PARAMETER_TAG 0x0006
-#define V12_DIAGNOSTIC_INFORMATION_PARAMETER_TAG 0x0007
-#define V12_HEARTBEAT_DATA_PARAMETER_TAG 0x0009
-#define V12_TRAFFIC_MODE_TYPE_PARAMETER_TAG 0x000b
-#define V12_ERROR_CODE_PARAMETER_TAG 0x000c
-#define V12_STATUS_PARAMETER_TAG 0x000d
-#define V12_ASP_IDENTIFIER_PARAMETER_TAG 0x0011
-#define V12_AFFECTED_POINT_CODE_PARAMETER_TAG 0x0012
-#define V12_CORRELATION_IDENTIFIER_PARAMETER_TAG 0x0013
-
-#define V12_NETWORK_APPEARANCE_PARAMETER_TAG 0x0200
-#define V12_USER_CAUSE_PARAMETER_TAG 0x0204
-#define V12_CONGESTION_INDICATIONS_PARAMETER_TAG 0x0205
-#define V12_CONCERNED_DESTINATION_PARAMETER_TAG 0x0206
-#define V12_ROUTING_KEY_PARAMETER_TAG 0x0207
-#define V12_REGISTRATION_RESULT_PARAMETER_TAG 0x0208
-#define V12_DEREGISTRATION_RESULT_PARAMETER_TAG 0x0209
-#define V12_LOCAL_ROUTING_KEY_IDENTIFIER_PARAMETER_TAG 0x020a
-#define V12_DESTINATION_POINT_CODE_PARAMETER_TAG 0x020b
-#define V12_SERVICE_INDICATORS_PARAMETER_TAG 0x020c
-#define V12_ORIGINATING_POINT_CODE_LIST_PARAMETER_TAG 0x020e
-#define V12_CIRCUIT_RANGE_PARAMETER_TAG 0x020f
-#define V12_PROTOCOL_DATA_PARAMETER_TAG 0x0210
-#define V12_REGISTRATION_STATUS_PARAMETER_TAG 0x0212
-#define V12_DEREGISTRATION_STATUS_PARAMETER_TAG 0x0213
-
-static const value_string m3ua_v12_parameter_tag_values[] = {
- { V12_INFO_STRING_PARAMETER_TAG, "Info string" } ,
- { V12_ROUTING_CONTEXT_PARAMETER_TAG, "Routing context" } ,
- { V12_DIAGNOSTIC_INFORMATION_PARAMETER_TAG, "Diagnostic Information" } ,
- { V12_HEARTBEAT_DATA_PARAMETER_TAG, "Heartbeat data" } ,
- { V12_TRAFFIC_MODE_TYPE_PARAMETER_TAG, "Traffic mode type" } ,
- { V12_ERROR_CODE_PARAMETER_TAG, "Error code" } ,
- { V12_STATUS_PARAMETER_TAG, "Status" } ,
- { V12_ASP_IDENTIFIER_PARAMETER_TAG, "ASP identifier" } ,
- { V12_AFFECTED_POINT_CODE_PARAMETER_TAG, "Affected point code" } ,
- { V12_CORRELATION_IDENTIFIER_PARAMETER_TAG, "Correlation identifier" } ,
- { V12_NETWORK_APPEARANCE_PARAMETER_TAG, "Network appearance" } ,
- { V12_USER_CAUSE_PARAMETER_TAG, "User / cause" } ,
- { V12_CONGESTION_INDICATIONS_PARAMETER_TAG, "Congestion indications" } ,
- { V12_CONCERNED_DESTINATION_PARAMETER_TAG, "Concerned destination" } ,
- { V12_ROUTING_KEY_PARAMETER_TAG, "Routing key" } ,
- { V12_REGISTRATION_RESULT_PARAMETER_TAG, "Registration result" } ,
- { V12_DEREGISTRATION_RESULT_PARAMETER_TAG, "Deregistration result" } ,
- { V12_LOCAL_ROUTING_KEY_IDENTIFIER_PARAMETER_TAG, "Local routing key identifier" } ,
- { V12_DESTINATION_POINT_CODE_PARAMETER_TAG, "Destination point code" } ,
- { V12_SERVICE_INDICATORS_PARAMETER_TAG, "Service indicators" } ,
- { V12_ORIGINATING_POINT_CODE_LIST_PARAMETER_TAG, "Originating point code list" } ,
- { V12_CIRCUIT_RANGE_PARAMETER_TAG, "Circuit range" } ,
- { V12_PROTOCOL_DATA_PARAMETER_TAG, "Protocol data" } ,
- { V12_REGISTRATION_STATUS_PARAMETER_TAG, "Registration status" } ,
- { V12_DEREGISTRATION_STATUS_PARAMETER_TAG, "Deregistration status" } ,
- { 0, NULL } };
-
#define PROTOCOL_VERSION_RELEASE_1 1
-static const value_string m3ua_protocol_version_values[] = {
+static const value_string protocol_version_values[] = {
{ PROTOCOL_VERSION_RELEASE_1, "Release 1" },
{ 0, NULL } };
@@ -196,7 +85,7 @@ static const value_string m3ua_protocol_version_values[] = {
#define MESSAGE_CLASS_ASPTM_MESSAGE 4
#define MESSAGE_CLASS_RKM_MESSAGE 9
-static const value_string m3ua_message_class_values[] = {
+static const value_string message_class_values[] = {
{ MESSAGE_CLASS_MGMT_MESSAGE, "Management messages" },
{ MESSAGE_CLASS_TFER_MESSAGE, "Transfer messages" },
{ MESSAGE_CLASS_SSNM_MESSAGE, "SS7 signalling network management messages" },
@@ -205,6 +94,14 @@ static const value_string m3ua_message_class_values[] = {
{ MESSAGE_CLASS_RKM_MESSAGE, "Routing key management messages" },
{ 0, NULL } };
+static const value_string v5_message_class_values[] = {
+ { MESSAGE_CLASS_MGMT_MESSAGE, "Management messages" },
+ { MESSAGE_CLASS_TFER_MESSAGE, "Transfer messages" },
+ { MESSAGE_CLASS_SSNM_MESSAGE, "SS7 signalling network management messages" },
+ { MESSAGE_CLASS_ASPSM_MESSAGE, "ASP state maintenance messages" },
+ { MESSAGE_CLASS_ASPTM_MESSAGE, "ASP traffic maintenance messages" },
+ { 0, NULL } };
+
#define MESSAGE_TYPE_ERR 0
#define MESSAGE_TYPE_NTFY 1
@@ -234,8 +131,7 @@ static const value_string m3ua_message_class_values[] = {
#define MESSAGE_TYPE_DEREG_REQ 3
#define MESSAGE_TYPE_DEREG_RSP 4
-
-static const value_string m3ua_message_class_type_values[] = {
+static const value_string v5_message_class_type_values[] = {
{ MESSAGE_CLASS_MGMT_MESSAGE * 256 + MESSAGE_TYPE_ERR, "Error (ERR)" },
{ MESSAGE_CLASS_MGMT_MESSAGE * 256 + MESSAGE_TYPE_NTFY, "Notify (NTFY)" },
{ MESSAGE_CLASS_TFER_MESSAGE * 256 + MESSAGE_TYPE_DATA, "Payload data (DATA)" },
@@ -244,7 +140,6 @@ static const value_string m3ua_message_class_type_values[] = {
{ MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DAUD, "Destination state audit (DAUD)" },
{ MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_SCON, "SS7 Network congestion state (SCON)" },
{ MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DUPU, "Destination userpart unavailable (DUPU)" },
- { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DRST, "Destination Restricted (DRST)" },
{ MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_UP, "ASP up (UP)" },
{ MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_DOWN, "ASP down (DOWN)" },
{ MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_BEAT, "Heartbeat (BEAT)" },
@@ -255,13 +150,35 @@ static const value_string m3ua_message_class_type_values[] = {
{ MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_INACTIVE , "ASP inactive (INACTIVE)" },
{ MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_ACTIVE_ACK , "ASP active ack (ACTIVE ACK)" },
{ MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_INACTIVE_ACK , "ASP inactive ack (INACTIVE ACK)" },
+ { 0, NULL } };
+
+static const value_string message_class_type_values[] = {
+ { MESSAGE_CLASS_MGMT_MESSAGE * 256 + MESSAGE_TYPE_ERR, "Error (ERR)" },
+ { MESSAGE_CLASS_MGMT_MESSAGE * 256 + MESSAGE_TYPE_NTFY, "Notify (NTFY)" },
+ { MESSAGE_CLASS_TFER_MESSAGE * 256 + MESSAGE_TYPE_DATA, "Payload data (DATA)" },
+ { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DUNA, "Destination unavailable (DUNA)" },
+ { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DAVA, "Destination available (DAVA)" },
+ { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DAUD, "Destination state audit (DAUD)" },
+ { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_SCON, "SS7 Network congestion state (SCON)" },
+ { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DUPU, "Destination userpart unavailable (DUPU)" },
+ { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DRST, "Destination Restricted (DRST)" },
+ { MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_UP, "ASP up (ASPUP)" },
+ { MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_DOWN, "ASP down (ASPDN)" },
+ { MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_BEAT, "Heartbeat (BEAT)" },
+ { MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_UP_ACK, "ASP up ack (ASPUP_ACK)" },
+ { MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_DOWN_ACK, "ASP down ack (ASPDN_ACK)" },
+ { MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_BEAT_ACK, "Heartbeat ack (BEAT_ACK)" },
+ { MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_ACTIVE , "ASP active (ASPAC)" },
+ { MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_INACTIVE , "ASP inactive (ASPIA)" },
+ { MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_ACTIVE_ACK , "ASP active ack (ASPAC_ACK)" },
+ { MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_INACTIVE_ACK , "ASP inactive ack (ASPIA_ACK)" },
{ MESSAGE_CLASS_RKM_MESSAGE * 256 + MESSAGE_TYPE_REG_REQ , "Registration request (REG_REQ)" },
{ MESSAGE_CLASS_RKM_MESSAGE * 256 + MESSAGE_TYPE_REG_RSP , "Registration response (REG_RSP)" },
{ MESSAGE_CLASS_RKM_MESSAGE * 256 + MESSAGE_TYPE_DEREG_REQ , "Deregistration request (DEREG_REQ)" },
{ MESSAGE_CLASS_RKM_MESSAGE * 256 + MESSAGE_TYPE_DEREG_RSP , "Deregistration response (DEREG_RSP)" },
{ 0, NULL } };
-static const value_string m3ua_message_class_type_acro_values[] = {
+static const value_string v5_message_class_type_acro_values[] = {
{ MESSAGE_CLASS_MGMT_MESSAGE * 256 + MESSAGE_TYPE_ERR, "ERR" },
{ MESSAGE_CLASS_MGMT_MESSAGE * 256 + MESSAGE_TYPE_NTFY, "NTFY" },
{ MESSAGE_CLASS_TFER_MESSAGE * 256 + MESSAGE_TYPE_DATA, "DATA" },
@@ -270,7 +187,6 @@ static const value_string m3ua_message_class_type_acro_values[] = {
{ MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DAUD, "DAUD" },
{ MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_SCON, "SCON" },
{ MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DUPU, "DUPU" },
- { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DRST, "DRST" },
{ MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_UP, "ASP_UP" },
{ MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_DOWN, "ASP_DOWN" },
{ MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_BEAT, "BEAT" },
@@ -281,6 +197,28 @@ static const value_string m3ua_message_class_type_acro_values[] = {
{ MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_INACTIVE , "ASP_INACTIVE" },
{ MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_ACTIVE_ACK , "ASP_ACTIVE_ACK" },
{ MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_INACTIVE_ACK , "ASP_INACTIVE_ACK" },
+ { 0, NULL } };
+
+static const value_string message_class_type_acro_values[] = {
+ { MESSAGE_CLASS_MGMT_MESSAGE * 256 + MESSAGE_TYPE_ERR, "ERR" },
+ { MESSAGE_CLASS_MGMT_MESSAGE * 256 + MESSAGE_TYPE_NTFY, "NTFY" },
+ { MESSAGE_CLASS_TFER_MESSAGE * 256 + MESSAGE_TYPE_DATA, "DATA" },
+ { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DUNA, "DUNA" },
+ { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DAVA, "DAVA" },
+ { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DAUD, "DAUD" },
+ { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_SCON, "SCON" },
+ { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DUPU, "DUPU" },
+ { MESSAGE_CLASS_SSNM_MESSAGE * 256 + MESSAGE_TYPE_DRST, "DRST" },
+ { MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_UP, "ASPUP" },
+ { MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_DOWN, "ASPDN" },
+ { MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_BEAT, "BEAT" },
+ { MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_UP_ACK, "ASPUP_ACK" },
+ { MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_DOWN_ACK, "ASPDN_ACK" },
+ { MESSAGE_CLASS_ASPSM_MESSAGE * 256 + MESSAGE_TYPE_BEAT_ACK, "BEAT_ACK" },
+ { MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_ACTIVE , "ASPAC" },
+ { MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_INACTIVE , "ASPIA" },
+ { MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_ACTIVE_ACK , "ASPAC_ACK" },
+ { MESSAGE_CLASS_ASPTM_MESSAGE * 256 + MESSAGE_TYPE_INACTIVE_ACK , "ASPIA_ACK" },
{ MESSAGE_CLASS_RKM_MESSAGE * 256 + MESSAGE_TYPE_REG_REQ , "REG_REQ" },
{ MESSAGE_CLASS_RKM_MESSAGE * 256 + MESSAGE_TYPE_REG_RSP , "REG_RSP" },
{ MESSAGE_CLASS_RKM_MESSAGE * 256 + MESSAGE_TYPE_DEREG_REQ , "DEREG_REQ" },
@@ -294,343 +232,434 @@ static const value_string m3ua_message_class_type_acro_values[] = {
#define PROTOCOL_DATA_OFFSET PARAMETER_VALUE_OFFSET
-#define UNSPECIFIED_REASON 0
-#define USER_UNAVAILABLE_REASON 1
-#define MANAGEMENT_BLOCKING_REASON 2
-
-static const value_string m3ua_reason_values[] = {
- { UNSPECIFIED_REASON, "Unspecified" },
- { USER_UNAVAILABLE_REASON, "User unavailable" },
- { MANAGEMENT_BLOCKING_REASON, "Management blocking" },
- {0, NULL } };
-
-#define REASON_LENGTH 4
-#define REASON_OFFSET PARAMETER_VALUE_OFFSET
#define TRAFFIC_MODE_TYPE_LENGTH 4
#define TRAFFIC_MODE_TYPE_OFFSET PARAMETER_VALUE_OFFSET
/* Initialize the protocol and registered fields */
static int proto_m3ua = -1;
-static int hf_m3ua_version = -1;
-static int hf_m3ua_reserved = -1;
-static int hf_m3ua_message_class = -1;
-static int hf_m3ua_message_type = -1;
-static int hf_m3ua_message_length = -1;
-static int hf_m3ua_parameter_tag = -1;
-static int hf_m3ua_parameter_length = -1;
-static int hf_m3ua_parameter_value = -1;
-static int hf_m3ua_parameter_padding = -1;
-static int hf_m3ua_network_appearance = -1;
-static int hf_m3ua_info_string = -1;
-static int hf_m3ua_routing_context = -1;
-static int hf_m3ua_diagnostic_information = -1;
-static int hf_m3ua_heartbeat_data = -1;
-static int hf_m3ua_error_code = -1;
-static int hf_m3ua_status_type = -1;
-static int hf_m3ua_status_info = -1;
-static int hf_m3ua_asp_identifier = -1;
-static int hf_m3ua_affected_point_code_mask = -1;
-static int hf_m3ua_affected_point_code_pc = -1;
-static int hf_m3ua_unavailability_cause = -1;
-static int hf_m3ua_user_identity = -1;
-static int hf_m3ua_reason = -1;
-static int hf_m3ua_traffic_mode_type = -1;
-static int hf_m3ua_congestion_reserved = -1;
-static int hf_m3ua_congestion_level = -1;
-static int hf_m3ua_concerned_dest_reserved = -1;
-static int hf_m3ua_concerned_dest_pc = -1;
-static int hf_m3ua_local_rk_identifier = -1;
-static int hf_m3ua_dpc_mask = -1;
-static int hf_m3ua_dpc_pc = -1;
-static int hf_m3ua_si = -1;
-static int hf_m3ua_ssn = -1;
-static int hf_m3ua_opc_list_mask = -1;
-static int hf_m3ua_opc_list_pc = -1;
-static int hf_m3ua_cic_range_mask = -1;
-static int hf_m3ua_cic_range_pc = -1;
-static int hf_m3ua_cic_range_upper = -1;
-static int hf_m3ua_cic_range_lower = -1;
-static int hf_m3ua_protocol_data_opc = -1;
-static int hf_m3ua_protocol_data_dpc = -1;
-static int hf_m3ua_protocol_data_si = -1;
-static int hf_m3ua_protocol_data_ni = -1;
-static int hf_m3ua_protocol_data_mp = -1;
-static int hf_m3ua_protocol_data_sls = -1;
-static int hf_m3ua_correlation_identifier = -1;
-static int hf_m3ua_registration_status = -1;
-static int hf_m3ua_deregistration_status = -1;
-static int hf_m3ua_registration_result_identifier = -1;
-static int hf_m3ua_registration_result_status = -1;
-static int hf_m3ua_registration_result_context = -1;
-static int hf_m3ua_deregistration_result_status = -1;
-static int hf_m3ua_deregistration_result_context = -1;
-static int hf_m3ua_li = -1;
+static int hf_version = -1;
+static int hf_reserved = -1;
+static int hf_message_class = -1;
+static int hf_v5_message_class = -1;
+static int hf_message_type = -1;
+static int hf_message_length = -1;
+static int hf_v5_parameter_tag = -1;
+static int hf_v6_parameter_tag = -1;
+static int hf_parameter_tag = -1;
+static int hf_parameter_length = -1;
+static int hf_parameter_value = -1;
+static int hf_parameter_padding = -1;
+static int hf_parameter_trailer = -1;
+static int hf_network_appearance = -1;
+static int hf_info_string = -1;
+static int hf_routing_context = -1;
+static int hf_diagnostic_information = -1;
+static int hf_heartbeat_data = -1;
+static int hf_v5_error_code = -1;
+static int hf_v6_error_code = -1;
+static int hf_error_code = -1;
+static int hf_status_type = -1;
+static int hf_status_info = -1;
+static int hf_asp_identifier = -1;
+static int hf_affected_point_code_mask = -1;
+static int hf_affected_point_code_pc = -1;
+static int hf_cause = -1;
+static int hf_user = -1;
+static int hf_reason = -1;
+static int hf_v5_traffic_mode_type = -1;
+static int hf_v6_traffic_mode_type = -1;
+static int hf_traffic_mode_type = -1;
+static int hf_congestion_reserved = -1;
+static int hf_congestion_level = -1;
+static int hf_concerned_dest_reserved = -1;
+static int hf_concerned_dest_pc = -1;
+static int hf_local_rk_identifier = -1;
+static int hf_dpc_mask = -1;
+static int hf_dpc_pc = -1;
+static int hf_si = -1;
+static int hf_ssn = -1;
+static int hf_opc_list_mask = -1;
+static int hf_opc_list_pc = -1;
+static int hf_cic_range_mask = -1;
+static int hf_cic_range_pc = -1;
+static int hf_cic_range_upper = -1;
+static int hf_cic_range_lower = -1;
+static int hf_protocol_data_opc = -1;
+static int hf_protocol_data_dpc = -1;
+static int hf_protocol_data_si = -1;
+static int hf_protocol_data_ni = -1;
+static int hf_protocol_data_mp = -1;
+static int hf_protocol_data_sls = -1;
+static int hf_correlation_identifier = -1;
+static int hf_registration_status = -1;
+static int hf_deregistration_status = -1;
+static int hf_registration_result_identifier = -1;
+static int hf_registration_result_status = -1;
+static int hf_registration_result_context = -1;
+static int hf_v6_deregistration_result_status = -1;
+static int hf_v6_deregistration_result_context = -1;
+static int hf_li = -1;
/* Initialize the subtree pointers */
static gint ett_m3ua = -1;
-static gint ett_m3ua_parameter = -1;
+static gint ett_parameter = -1;
static module_t *m3ua_module;
static dissector_handle_t mtp3_handle, data_handle;
-static dissector_table_t m3ua_si_dissector_table;
+static dissector_table_t si_dissector_table;
/* stuff for supporting multiple versions */
-#define M3UA_V6 1
-#define M3UA_V12 2
-static gint m3ua_version = M3UA_V12;
+typedef enum {
+ M3UA_V5,
+ M3UA_V6,
+ M3UA_RFC
+} Version_Type;
+
+static Version_Type version = M3UA_RFC;
static void
-dissect_m3ua_parameters(tvbuff_t *, packet_info *, proto_tree *, proto_tree *);
+dissect_parameters(tvbuff_t *, packet_info *, proto_tree *, proto_tree *);
-static guint
-nr_of_padding_bytes (guint length)
+static void
+dissect_v5_common_header(tvbuff_t *common_header_tvb, packet_info *pinfo, proto_tree *m3ua_tree)
{
- guint remainder;
+ guint8 message_class, message_type;
+
+ /* Extract the common header */
+ message_class = tvb_get_guint8(common_header_tvb, MESSAGE_CLASS_OFFSET);
+ message_type = tvb_get_guint8(common_header_tvb, MESSAGE_TYPE_OFFSET);
- remainder = length % 4;
+ if (check_col(pinfo->cinfo, COL_INFO)) {
+ col_append_str(pinfo->cinfo, COL_INFO, val_to_str(message_class * 256 + message_type, v5_message_class_type_acro_values, "reserved"));
+ col_append_str(pinfo->cinfo, COL_INFO, " ");
+ }
- if (remainder == 0)
- return 0;
- else
- return 4 - remainder;
+ if (m3ua_tree) {
+ /* add the components of the common header to the protocol tree */
+ proto_tree_add_item(m3ua_tree, hf_version, common_header_tvb, VERSION_OFFSET, VERSION_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(m3ua_tree, hf_reserved, common_header_tvb, RESERVED_OFFSET, RESERVED_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(m3ua_tree, hf_v5_message_class, common_header_tvb, MESSAGE_CLASS_OFFSET, MESSAGE_CLASS_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_uint_format(m3ua_tree, hf_message_type, common_header_tvb, MESSAGE_TYPE_OFFSET, MESSAGE_TYPE_LENGTH, message_type,
+ "Message type: %s (%u)", val_to_str(message_class * 256 + message_type, v5_message_class_type_values, "reserved"), message_type);
+ proto_tree_add_item(m3ua_tree, hf_message_length, common_header_tvb, MESSAGE_LENGTH_OFFSET, MESSAGE_LENGTH_LENGTH, NETWORK_BYTE_ORDER);
+ }
}
static void
-dissect_m3ua_common_header(tvbuff_t *common_header_tvb, packet_info *pinfo, proto_tree *m3ua_tree)
+dissect_common_header(tvbuff_t *common_header_tvb, packet_info *pinfo, proto_tree *m3ua_tree)
{
- guint8 version, reserved, message_class, message_type;
- guint32 message_length;
+ guint8 message_class, message_type;
/* Extract the common header */
- version = tvb_get_guint8(common_header_tvb, VERSION_OFFSET);
- reserved = tvb_get_guint8(common_header_tvb, RESERVED_OFFSET);
message_class = tvb_get_guint8(common_header_tvb, MESSAGE_CLASS_OFFSET);
message_type = tvb_get_guint8(common_header_tvb, MESSAGE_TYPE_OFFSET);
- message_length = tvb_get_ntohl (common_header_tvb, MESSAGE_LENGTH_OFFSET);
if (check_col(pinfo->cinfo, COL_INFO)) {
- col_append_str(pinfo->cinfo, COL_INFO, val_to_str(message_class * 256 + message_type, m3ua_message_class_type_acro_values, "reserved"));
+ col_append_str(pinfo->cinfo, COL_INFO, val_to_str(message_class * 256 + message_type, message_class_type_acro_values, "reserved"));
col_append_str(pinfo->cinfo, COL_INFO, " ");
}
if (m3ua_tree) {
/* add the components of the common header to the protocol tree */
- proto_tree_add_uint(m3ua_tree, hf_m3ua_version, common_header_tvb, VERSION_OFFSET, VERSION_LENGTH, version);
- proto_tree_add_uint(m3ua_tree, hf_m3ua_reserved, common_header_tvb, RESERVED_OFFSET, RESERVED_LENGTH, reserved);
- proto_tree_add_uint(m3ua_tree, hf_m3ua_message_class, common_header_tvb, MESSAGE_CLASS_OFFSET, MESSAGE_CLASS_LENGTH, message_class);
- proto_tree_add_uint_format(m3ua_tree, hf_m3ua_message_type, common_header_tvb, MESSAGE_TYPE_OFFSET, MESSAGE_TYPE_LENGTH, message_type,
- "Message type: %s (%u)",
- val_to_str(message_class * 256 + message_type, m3ua_message_class_type_values, "reserved"), message_type);
- proto_tree_add_uint(m3ua_tree, hf_m3ua_message_length, common_header_tvb, MESSAGE_LENGTH_OFFSET, MESSAGE_LENGTH_LENGTH, message_length);
+ proto_tree_add_item(m3ua_tree, hf_version, common_header_tvb, VERSION_OFFSET, VERSION_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(m3ua_tree, hf_reserved, common_header_tvb, RESERVED_OFFSET, RESERVED_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(m3ua_tree, hf_message_class, common_header_tvb, MESSAGE_CLASS_OFFSET, MESSAGE_CLASS_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_uint_format(m3ua_tree, hf_message_type, common_header_tvb, MESSAGE_TYPE_OFFSET, MESSAGE_TYPE_LENGTH, message_type,
+ "Message type: %s (%u)", val_to_str(message_class * 256 + message_type, message_class_type_values, "reserved"), message_type);
+ proto_tree_add_item(m3ua_tree, hf_message_length, common_header_tvb, MESSAGE_LENGTH_OFFSET, MESSAGE_LENGTH_LENGTH, NETWORK_BYTE_ORDER);
}
}
-#define INFO_STRING_OFFSET PARAMETER_VALUE_OFFSET
+#define NETWORK_APPEARANCE_LENGTH 4
+#define NETWORK_APPEARANCE_OFFSET PARAMETER_VALUE_OFFSET
+
+static void
+dissect_network_appearance_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+{
+ proto_tree_add_item(parameter_tree, hf_network_appearance, parameter_tvb, NETWORK_APPEARANCE_OFFSET, NETWORK_APPEARANCE_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%u)", tvb_get_ntohl(parameter_tvb, NETWORK_APPEARANCE_OFFSET));
+}
static void
-dissect_m3ua_info_string_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_v5_protocol_data_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_item *parameter_item)
{
- guint16 length, info_string_length;
- const char *info_string;
+ guint16 length, protocol_data_length;
+ tvbuff_t *payload_tvb;
length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
+ protocol_data_length = length - PARAMETER_HEADER_LENGTH;
+ payload_tvb = tvb_new_subset(parameter_tvb, PROTOCOL_DATA_OFFSET, protocol_data_length, protocol_data_length);
+ proto_item_append_text(parameter_item, " (SS7 message of %u byte%s)", protocol_data_length, plurality(protocol_data_length, "", "s"));
+ proto_item_set_len(parameter_item, PARAMETER_HEADER_LENGTH);
+ call_dissector(mtp3_handle, payload_tvb, pinfo, tree);
+}
+
+#define INFO_STRING_OFFSET PARAMETER_VALUE_OFFSET
+
+static void
+dissect_info_string_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+{
+ guint16 info_string_length;
+
+ info_string_length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET) - PARAMETER_HEADER_LENGTH;
+ proto_tree_add_item(parameter_tree, hf_info_string, parameter_tvb, INFO_STRING_OFFSET, info_string_length, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%.*s)", info_string_length,
+ (const char *)tvb_get_ptr(parameter_tvb, INFO_STRING_OFFSET, info_string_length));
+}
+
+#define AFFECTED_MASK_LENGTH 1
+#define AFFECTED_DPC_LENGTH 3
+#define AFFECTED_DESTINATION_LENGTH (AFFECTED_MASK_LENGTH + AFFECTED_DPC_LENGTH)
- info_string_length = length - PARAMETER_HEADER_LENGTH;
- info_string = (const char *)tvb_get_ptr(parameter_tvb, INFO_STRING_OFFSET, info_string_length);
- proto_tree_add_string(parameter_tree, hf_m3ua_info_string, parameter_tvb, INFO_STRING_OFFSET, info_string_length, info_string);
- proto_item_set_text(parameter_item, "Info String (%.*s)", info_string_length, info_string);
+#define AFFECTED_MASK_OFFSET 0
+#define AFFECTED_DPC_OFFSET 1
+
+static void
+dissect_affected_destinations_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+{
+ guint16 number_of_destinations, destination_number;
+ gint destination_offset;
+
+ number_of_destinations = (tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET) - PARAMETER_HEADER_LENGTH) >> 2;
+ destination_offset = PARAMETER_VALUE_OFFSET;
+ for(destination_number=1; destination_number <= number_of_destinations; destination_number++) {
+ proto_tree_add_item(parameter_tree, hf_affected_point_code_mask, parameter_tvb, destination_offset + AFFECTED_MASK_OFFSET, AFFECTED_MASK_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_affected_point_code_pc, parameter_tvb, destination_offset + AFFECTED_DPC_OFFSET, AFFECTED_DPC_LENGTH, NETWORK_BYTE_ORDER);
+ destination_offset += AFFECTED_DESTINATION_LENGTH;
+ }
+ proto_item_append_text(parameter_item, " (%u destination%s)", number_of_destinations, plurality(number_of_destinations, "", "s"));
}
#define ROUTING_CONTEXT_LENGTH 4
static void
-dissect_m3ua_routing_context_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_routing_context_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint16 length, number_of_contexts, context_number;
- guint32 context;
+ guint16 number_of_contexts, context_number, parameter_length;
gint context_offset;
- length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
- number_of_contexts = (length - PARAMETER_HEADER_LENGTH) / 4;
+ parameter_length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
+ number_of_contexts = (parameter_length - PARAMETER_HEADER_LENGTH) >> 4;
context_offset = PARAMETER_VALUE_OFFSET;
for(context_number=1; context_number <= number_of_contexts; context_number++) {
- context = tvb_get_ntohl(parameter_tvb, context_offset);
- proto_tree_add_uint(parameter_tree, hf_m3ua_routing_context, parameter_tvb, context_offset, ROUTING_CONTEXT_LENGTH, context);
+ proto_tree_add_item(parameter_tree, hf_routing_context, parameter_tvb, context_offset, ROUTING_CONTEXT_LENGTH, NETWORK_BYTE_ORDER);
context_offset += ROUTING_CONTEXT_LENGTH;
- }
- proto_item_set_text(parameter_item, "Routing context parameter (%u context%s)", number_of_contexts, plurality(number_of_contexts, "", "s"));
+ };
+ proto_item_append_text(parameter_item, " (%u context%s)", number_of_contexts, plurality(number_of_contexts, "", "s"));
}
+#define DIAGNOSTIC_INFO_OFFSET PARAMETER_VALUE_OFFSET
+
static void
-dissect_m3ua_diagnostic_information_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_diagnostic_information_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint16 length, diagnostic_info_length;
-
- length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
- diagnostic_info_length = length - PARAMETER_HEADER_LENGTH;
-
- proto_tree_add_bytes(parameter_tree, hf_m3ua_diagnostic_information, parameter_tvb, PARAMETER_VALUE_OFFSET, diagnostic_info_length,
- tvb_get_ptr(parameter_tvb, PARAMETER_VALUE_OFFSET, diagnostic_info_length));
+ guint16 diag_info_length;
- proto_item_set_text(parameter_item, "Diagnostic information (%u byte%s)", diagnostic_info_length, plurality(diagnostic_info_length, "", "s"));
+ diag_info_length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET) - PARAMETER_HEADER_LENGTH;
+ proto_tree_add_item(parameter_tree, hf_diagnostic_information, parameter_tvb, DIAGNOSTIC_INFO_OFFSET, diag_info_length, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%u byte%s)", diag_info_length, plurality(diag_info_length, "", "s"));
}
+#define HEARTBEAT_DATA_OFFSET PARAMETER_VALUE_OFFSET
+
static void
-dissect_m3ua_heartbeat_data_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_heartbeat_data_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint16 length, heartbeat_data_length;
+ guint16 heartbeat_data_length;
- length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
+ heartbeat_data_length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET) - PARAMETER_HEADER_LENGTH;
+ proto_tree_add_item(parameter_tree, hf_heartbeat_data, parameter_tvb, HEARTBEAT_DATA_OFFSET, heartbeat_data_length, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%u byte%s)", heartbeat_data_length, plurality(heartbeat_data_length, "", "s"));
+}
+
+#define UNKNOWN_UNAVAIL_CAUSE 0
+#define UNEQUIPPED_REMOTE_USER_UNAVAIL_CAUSE 1
+#define INACCESSABLE_REMOTE_USER_UNAVAIL_CAUSE 2
+
+static const value_string unavailability_cause_values[] = {
+ { UNKNOWN_UNAVAIL_CAUSE, "Unknown" },
+ { UNEQUIPPED_REMOTE_USER_UNAVAIL_CAUSE, "Unequipped remote user" },
+ { INACCESSABLE_REMOTE_USER_UNAVAIL_CAUSE, "Inaccessable remote user" },
+ {0, NULL } };
+
+#define RESERVED_0_USER_ID 0
+#define RESERVED_1_USER_ID 1
+#define RESERVED_2_USER_ID 2
+#define SCCP_USER_ID 3
+#define TUP_USER_ID 4
+#define ISUP_USER_ID 5
+#define RESERVED_6_USER_ID 6
+#define RESERVED_7_USER_ID 7
+#define RESERVED_8_USER_ID 8
+#define BROADBAND_ISUP_USER_ID 9
+#define SATELLITE_ISUP_USER_ID 10
+
+static const value_string user_identity_values[] = {
+ { RESERVED_0_USER_ID, "Reserved" },
+ { RESERVED_1_USER_ID, "Reserved" },
+ { RESERVED_2_USER_ID, "Reserved" },
+ { SCCP_USER_ID, "SCCP" },
+ { TUP_USER_ID, "TUP" },
+ { ISUP_USER_ID, "ISUP" },
+ { RESERVED_6_USER_ID, "Reserved" },
+ { RESERVED_7_USER_ID, "Reserved" },
+ { RESERVED_8_USER_ID, "Reserved" },
+ { BROADBAND_ISUP_USER_ID, "Broadband ISUP" },
+ { SATELLITE_ISUP_USER_ID, "Satellite ISUP" },
+ {0, NULL } };
- heartbeat_data_length = length - PARAMETER_HEADER_LENGTH;
+#define CAUSE_LENGTH 2
+#define USER_LENGTH 2
- proto_tree_add_bytes(parameter_tree, hf_m3ua_heartbeat_data, parameter_tvb, PARAMETER_VALUE_OFFSET, heartbeat_data_length,
- tvb_get_ptr(parameter_tvb, PARAMETER_VALUE_OFFSET, heartbeat_data_length));
+#define CAUSE_OFFSET PARAMETER_VALUE_OFFSET
+#define USER_OFFSET (CAUSE_OFFSET + CAUSE_LENGTH)
- proto_item_set_text(parameter_item, "Heartbeat data (%u byte%s)", heartbeat_data_length, plurality(heartbeat_data_length, "", "s"));
+static void
+dissect_user_cause_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+{
+ proto_tree_add_item(parameter_tree, hf_cause, parameter_tvb, CAUSE_OFFSET, CAUSE_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_user, parameter_tvb, USER_OFFSET, USER_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%s: %s)",
+ val_to_str(tvb_get_ntohs(parameter_tvb, USER_OFFSET), user_identity_values, "Unknown user"),
+ val_to_str(tvb_get_ntohs(parameter_tvb, CAUSE_OFFSET), unavailability_cause_values, "unknown cause"));
}
-#define OVER_RIDE_TYPE 1
-#define LOAD_SHARE_TYPE 2
-#define OVER_RIDE_STANDBY_TYPE 3
-#define LOAD_SHARE_STANDBY_TYPE 4
+#define UNSPECIFIED_REASON 0
+#define USER_UNAVAILABLE_REASON 1
+#define MANAGEMENT_BLOCKING_REASON 2
-static const value_string m3ua_v6_traffic_mode_type_values[] = {
- { OVER_RIDE_TYPE , "Over-ride" },
- { LOAD_SHARE_TYPE, "Load-share" },
- { OVER_RIDE_STANDBY_TYPE, "Over-ride (standby)" },
- { LOAD_SHARE_STANDBY_TYPE, "Load-share (standby)" },
+static const value_string reason_values[] = {
+ { UNSPECIFIED_REASON, "Unspecified" },
+ { USER_UNAVAILABLE_REASON, "User unavailable" },
+ { MANAGEMENT_BLOCKING_REASON, "Management blocking" },
{0, NULL } };
+#define REASON_LENGTH 4
+#define REASON_OFFSET PARAMETER_VALUE_OFFSET
+
static void
-dissect_m3ua_v6_traffic_mode_type_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_reason_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint32 traffic_mode_type;
+ proto_tree_add_item(parameter_tree, hf_reason, parameter_tvb, REASON_OFFSET, REASON_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%s)", val_to_str(tvb_get_ntohl(parameter_tvb, REASON_OFFSET), reason_values, "unknown"));
+}
- traffic_mode_type = tvb_get_ntohl(parameter_tvb, TRAFFIC_MODE_TYPE_OFFSET);
+static const value_string v5_traffic_mode_type_values[] = {
+ { 1, "Over-ride" },
+ { 2, "Load-share" },
+ { 3, "Over-ride (standby)" },
+ { 4, "Load-share (standby)" },
+ { 0, NULL } };
- proto_tree_add_uint_format(parameter_tree, hf_m3ua_traffic_mode_type, parameter_tvb, TRAFFIC_MODE_TYPE_OFFSET, TRAFFIC_MODE_TYPE_LENGTH, traffic_mode_type,
- "Traffic mode type: %u (%s)", traffic_mode_type, val_to_str(traffic_mode_type, m3ua_v6_traffic_mode_type_values, "unknown"));
- proto_item_set_text(parameter_item, "Traffic mode type parameter (%s)", val_to_str(traffic_mode_type, m3ua_v6_traffic_mode_type_values, "unknown"));
+static void
+dissect_v5_traffic_mode_type_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+{
+ proto_tree_add_item(parameter_tree, hf_v5_traffic_mode_type, parameter_tvb, TRAFFIC_MODE_TYPE_OFFSET, TRAFFIC_MODE_TYPE_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%s)", val_to_str(tvb_get_ntohl(parameter_tvb, TRAFFIC_MODE_TYPE_OFFSET), v5_traffic_mode_type_values, "unknown"));
}
-#define BROADCAST_TYPE 3
-
-static const value_string m3ua_v12_traffic_mode_type_values[] = {
- { OVER_RIDE_TYPE , "Over-ride" },
- { LOAD_SHARE_TYPE, "Load-share" },
- { BROADCAST_TYPE, "Broadcast" },
- {0, NULL } };
+static const value_string v6_traffic_mode_type_values[] = {
+ { 1, "Over-ride" },
+ { 2, "Load-share" },
+ { 3, "Over-ride (standby)" },
+ { 4, "Load-share (standby)" },
+ { 0, NULL } };
static void
-dissect_m3ua_v12_traffic_mode_type_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_v6_traffic_mode_type_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint32 traffic_mode_type;
+ proto_tree_add_item(parameter_tree, hf_v6_traffic_mode_type, parameter_tvb, TRAFFIC_MODE_TYPE_OFFSET, TRAFFIC_MODE_TYPE_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%s)", val_to_str(tvb_get_ntohl(parameter_tvb, TRAFFIC_MODE_TYPE_OFFSET), v6_traffic_mode_type_values, "unknown"));
+}
- traffic_mode_type = tvb_get_ntohl(parameter_tvb, TRAFFIC_MODE_TYPE_OFFSET);
+static const value_string traffic_mode_type_values[] = {
+ { 1, "Over-ride" },
+ { 2, "Load-share" },
+ { 3, "Broadcast" },
+ { 0, NULL } };
- proto_tree_add_uint_format(parameter_tree, hf_m3ua_traffic_mode_type,
- parameter_tvb, TRAFFIC_MODE_TYPE_OFFSET, TRAFFIC_MODE_TYPE_LENGTH,
- traffic_mode_type, "Traffic mode type: %u (%s)",
- traffic_mode_type, val_to_str(traffic_mode_type, m3ua_v12_traffic_mode_type_values, "unknown"));
- proto_item_set_text(parameter_item, "Traffic mode type parameter (%s)", val_to_str(traffic_mode_type, m3ua_v12_traffic_mode_type_values, "unknown"));
+static void
+dissect_traffic_mode_type_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+{
+ proto_tree_add_item(parameter_tree, hf_traffic_mode_type, parameter_tvb, TRAFFIC_MODE_TYPE_OFFSET, TRAFFIC_MODE_TYPE_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%s)", val_to_str(tvb_get_ntohl(parameter_tvb, TRAFFIC_MODE_TYPE_OFFSET), traffic_mode_type_values, "unknown"));
}
-#define V6_INVALID_VERSION_ERROR_CODE 1
-#define V6_INVALID_NETWORK_APPEARANCE_ERROR_CODE 2
-#define V6_UNSUPPORTED_MESSAGE_CLASS_ERROR_CODE 3
-#define V6_UNSUPPORTED_MESSAGE_TYPE_ERROR_CODE 4
-#define V6_INVALID_TRAFFIC_HANDLING_MODE_ERROR_CODE 5
-#define V6_UNEXPECTED_MESSAGE_ERROR_CODE 6
-#define V6_PROTOCOL_ERROR_ERROR_CODE 7
-#define V6_INVALID_ROUTING_CONTEXT_ERROR_CODE 8
-#define V6_INVALID_STREAM_IDENTIFIER_ERROR_CODE 9
-#define V6_INVALID_PARAMETER_VALUE_ERROR_CODE 10
-
-static const value_string m3ua_v6_error_code_values[] = {
- { V6_INVALID_VERSION_ERROR_CODE, "Invalid version" },
- { V6_INVALID_NETWORK_APPEARANCE_ERROR_CODE, "Invalid network appearance" },
- { V6_UNSUPPORTED_MESSAGE_CLASS_ERROR_CODE, "Unsupported message class" },
- { V6_UNSUPPORTED_MESSAGE_TYPE_ERROR_CODE, "Unsupported message type" },
- { V6_INVALID_TRAFFIC_HANDLING_MODE_ERROR_CODE, "Invalid traffic handling mode" },
- { V6_UNEXPECTED_MESSAGE_ERROR_CODE, "Unexpected message" },
- { V6_PROTOCOL_ERROR_ERROR_CODE, "Protocol error" },
- { V6_INVALID_ROUTING_CONTEXT_ERROR_CODE, "Invalid routing context" },
- { V6_INVALID_STREAM_IDENTIFIER_ERROR_CODE, "Invalid stream identifier" },
- { V6_INVALID_PARAMETER_VALUE_ERROR_CODE, "Invalid parameter value" },
- { 0, NULL } };
-
#define ERROR_CODE_LENGTH 4
#define ERROR_CODE_OFFSET PARAMETER_VALUE_OFFSET
+static const value_string v5_error_code_values[] = {
+ { 1, "Invalid version" },
+ { 2, "Invalid network appearance" },
+ { 3, "Unsupported message class" },
+ { 4, "Unsupported message type" },
+ { 5, "Invalid traffic handling mode" },
+ { 6, "Unexpected message" },
+ { 7, "Protocol error" },
+ { 8, "Invalid routing context" },
+ { 0, NULL } };
+
static void
-dissect_m3ua_v6_error_code_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_v5_error_code_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint32 error_code;
-
- error_code = tvb_get_ntohl(parameter_tvb, ERROR_CODE_OFFSET);
- proto_tree_add_uint_format(parameter_tree, hf_m3ua_error_code, parameter_tvb, ERROR_CODE_OFFSET, ERROR_CODE_LENGTH, error_code,
- "Error code: %u (%s)", error_code, val_to_str(error_code, m3ua_v6_error_code_values, "unknown"));
- proto_item_set_text(parameter_item, "Error code parameter (%s)", val_to_str(error_code, m3ua_v6_error_code_values, "unknown"));
+ proto_tree_add_item(parameter_tree, hf_v5_error_code, parameter_tvb, ERROR_CODE_OFFSET, ERROR_CODE_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%s)", val_to_str(tvb_get_ntohl(parameter_tvb, ERROR_CODE_OFFSET), v5_error_code_values, "unknown"));
}
+static const value_string v6_error_code_values[] = {
+ { 1, "Invalid version" },
+ { 2, "Invalid network appearance" },
+ { 3, "Unsupported message class" },
+ { 4, "Unsupported message type" },
+ { 5, "Invalid traffic handling mode" },
+ { 6, "Unexpected message" },
+ { 7, "Protocol error" },
+ { 8, "Invalid routing context" },
+ { 9, "Invalid stream identifier" },
+ { 10, "Invalid parameter value" },
+ { 0, NULL } };
-#define V12_INVALID_VERSION_ERROR_CODE 0x01
-#define V12_UNSUPPORTED_MESSAGE_CLASS_ERROR_CODE 0x03
-#define V12_UNSUPPORTED_MESSAGE_TYPE_ERROR_CODE 0x04
-#define V12_UNSUPPORTED_TRAFFIC_HANDLING_MODE_ERROR_CODE 0x05
-#define V12_UNEXPECTED_MESSAGE_ERROR_CODE 0x06
-#define V12_PROTOCOL_ERROR_ERROR_CODE 0x07
-#define V12_INVALID_STREAM_IDENTIFIER_ERROR_CODE 0x09
-#define V12_REFUSED_ERROR_CODE 0x0d
-#define V12_ASP_IDENTIFIER_REQUIRED_ERROR_CODE 0x0e
-#define V12_INVALID_ASP_IDENTIFIER_ERROR_CODE 0x0f
-#define V12_INVALID_PARAMETER_VALUE_ERROR_CODE 0x11
-#define V12_PARAMETER_FIELD_ERROR_CODE 0x12
-#define V12_UNEXPECTED_PARAMETER_ERROR_CODE 0x13
-#define V12_DESTINATION_STATUS_UNKNOWN_ERROR_CODE 0x14
-#define V12_INVALID_NETWORK_APPEARANCE_ERROR_CODE 0x15
-#define V12_MISSING_PARAMETER_ERROR_CODE 0x16
-#define V12_INVALID_ROUTING_CONTEXT_ERROR_CODE 0x19
-#define V12_NO_CONFIGURED_AS_FOR_ASP_ERROR_CODE 0x1a
-
-static const value_string m3ua_v12_error_code_values[] = {
- { V12_INVALID_VERSION_ERROR_CODE, "Invalid version" },
- { V12_UNSUPPORTED_MESSAGE_CLASS_ERROR_CODE, "Unsupported message class" },
- { V12_UNSUPPORTED_MESSAGE_TYPE_ERROR_CODE, "Unsupported message type" },
- { V12_UNSUPPORTED_TRAFFIC_HANDLING_MODE_ERROR_CODE, "Unsupported traffic handling mode" },
- { V12_UNEXPECTED_MESSAGE_ERROR_CODE, "Unexpected message" },
- { V12_PROTOCOL_ERROR_ERROR_CODE, "Protocol error" },
- { V12_INVALID_STREAM_IDENTIFIER_ERROR_CODE, "Invalid stream identifier" },
- { V12_REFUSED_ERROR_CODE, "Refused - management blocking" },
- { V12_ASP_IDENTIFIER_REQUIRED_ERROR_CODE, "ASP identifier required" },
- { V12_INVALID_ASP_IDENTIFIER_ERROR_CODE, "Invalid ASP identifier" },
- { V12_INVALID_PARAMETER_VALUE_ERROR_CODE, "Invalid parameter value" },
- { V12_PARAMETER_FIELD_ERROR_CODE, "Parameter field error" },
- { V12_UNEXPECTED_PARAMETER_ERROR_CODE, "Unexpected parameter" },
- { V12_DESTINATION_STATUS_UNKNOWN_ERROR_CODE, "Destination status unknown" },
- { V12_INVALID_NETWORK_APPEARANCE_ERROR_CODE, "Invalid network appearance" },
- { V12_MISSING_PARAMETER_ERROR_CODE, "Missing parameter" },
- { V12_INVALID_ROUTING_CONTEXT_ERROR_CODE, "Invalid routing context" },
- { V12_NO_CONFIGURED_AS_FOR_ASP_ERROR_CODE, "No configured AS for ASP" },
- { 0, NULL } };
static void
-dissect_m3ua_v12_error_code_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_v6_error_code_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint32 error_code;
+ proto_tree_add_item(parameter_tree, hf_v6_error_code, parameter_tvb, ERROR_CODE_OFFSET, ERROR_CODE_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%s)", val_to_str(tvb_get_ntohl(parameter_tvb, ERROR_CODE_OFFSET), v6_error_code_values, "unknown"));
+}
+
+static const value_string error_code_values[] = {
+ { 0x01, "Invalid version" },
+ { 0x03, "Unsupported message class" },
+ { 0x04, "Unsupported message type" },
+ { 0x05, "Unsupported traffic handling mode" },
+ { 0x06, "Unexpected message" },
+ { 0x07, "Protocol error" },
+ { 0x09, "Invalid stream identifier" },
+ { 0x0d, "Refused - management blocking" },
+ { 0x0e, "ASP identifier required" },
+ { 0x0f, "Invalid ASP identifier" },
+ { 0x11, "Invalid parameter value" },
+ { 0x12, "Parameter field error" },
+ { 0x13, "Unexpected parameter" },
+ { 0x14, "Destination status unknown" },
+ { 0x15, "Invalid network appearance" },
+ { 0x16, "Missing parameter" },
+ { 0x19, "Invalid routing context" },
+ { 0x1a, "No configured AS for ASP" },
+ { 0, NULL } };
- error_code = tvb_get_ntohl(parameter_tvb, ERROR_CODE_OFFSET);
- proto_tree_add_uint_format(parameter_tree, hf_m3ua_error_code, parameter_tvb, ERROR_CODE_OFFSET, ERROR_CODE_LENGTH, error_code,
- "Error code: %u (%s)",error_code, val_to_str(error_code, m3ua_v12_error_code_values, "unknown"));
- proto_item_set_text(parameter_item, "Error code parameter (%s)", val_to_str(error_code, m3ua_v12_error_code_values, "unknown"));
+static void
+dissect_error_code_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+{
+ proto_tree_add_item(parameter_tree, hf_error_code, parameter_tvb, ERROR_CODE_OFFSET, ERROR_CODE_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%s)", val_to_str(tvb_get_ntohl(parameter_tvb, ERROR_CODE_OFFSET), error_code_values, "unknown"));
}
#define AS_STATE_CHANGE_TYPE 1
#define OTHER_TYPE 2
-static const value_string m3ua_status_type_values[] = {
+static const value_string status_type_values[] = {
{ AS_STATE_CHANGE_TYPE, "Application server state change" },
{ OTHER_TYPE, "Other" },
{ 0, NULL } };
@@ -644,16 +673,16 @@ static const value_string m3ua_status_type_values[] = {
#define ALTERNATE_ASP_ACTIVE_INFO 2
#define ASP_FAILURE_INFO 3
-static const value_string m3ua_status_type_info_values[] = {
+static const value_string v56_status_type_info_values[] = {
{ AS_STATE_CHANGE_TYPE * 256 * 256 + RESERVED_INFO, "Reserved" },
{ AS_STATE_CHANGE_TYPE * 256 * 256 + AS_INACTIVE_INFO, "Application server inactive" },
{ AS_STATE_CHANGE_TYPE * 256 * 256 + AS_ACTIVE_INFO, "Application server active" },
{ AS_STATE_CHANGE_TYPE * 256 * 256 + AS_PENDING_INFO, "Application server pending" },
{ OTHER_TYPE * 256 * 256 + INSUFFICIENT_ASP_RES_INFO, "Insufficient ASP resources active in AS" },
{ OTHER_TYPE * 256 * 256 + ALTERNATE_ASP_ACTIVE_INFO, "Alternate ASP active" },
- { OTHER_TYPE * 256 * 256 + ASP_FAILURE_INFO, "ASP Failure" },
{0, NULL } };
+
#define STATUS_TYPE_LENGTH 2
#define STATUS_INFO_LENGTH 2
@@ -661,136 +690,78 @@ static const value_string m3ua_status_type_info_values[] = {
#define STATUS_INFO_OFFSET (STATUS_TYPE_OFFSET + STATUS_TYPE_LENGTH)
static void
-dissect_m3ua_status_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_v56_status_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
guint16 status_type, status_info;
status_type = tvb_get_ntohs(parameter_tvb, STATUS_TYPE_OFFSET);
status_info = tvb_get_ntohs(parameter_tvb, STATUS_INFO_OFFSET);
- proto_tree_add_uint(parameter_tree, hf_m3ua_status_type, parameter_tvb, STATUS_TYPE_OFFSET, STATUS_TYPE_LENGTH, status_type);
- proto_tree_add_uint_format(parameter_tree, hf_m3ua_status_info, parameter_tvb, STATUS_INFO_OFFSET, STATUS_INFO_LENGTH, status_info,
- "Status info: %s (%u)", val_to_str(status_type * 256 * 256 + status_info, m3ua_status_type_info_values, "unknown"), status_info);
+ proto_tree_add_item(parameter_tree, hf_status_type, parameter_tvb, STATUS_TYPE_OFFSET, STATUS_TYPE_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_uint_format(parameter_tree, hf_status_info, parameter_tvb, STATUS_INFO_OFFSET, STATUS_INFO_LENGTH, status_info,
+ "Status info: %s (%u)", val_to_str(status_type * 256 * 256 + status_info, v56_status_type_info_values, "unknown"), status_info);
- proto_item_set_text(parameter_item,
- "Status type / ID (%s)", val_to_str(status_type * 256 * 256 + status_info, m3ua_status_type_info_values, "unknown status information"));
+ proto_item_append_text(parameter_item, " (%s)", val_to_str(status_type * 256 * 256 + status_info, v56_status_type_info_values, "unknown status information"));
}
-#define ASP_IDENTIFIER_OFFSET PARAMETER_VALUE_OFFSET
-#define ASP_IDENTIFIER_LENGTH 4
+static const value_string status_type_info_values[] = {
+ { AS_STATE_CHANGE_TYPE * 256 * 256 + RESERVED_INFO, "Reserved" },
+ { AS_STATE_CHANGE_TYPE * 256 * 256 + AS_INACTIVE_INFO, "Application server inactive" },
+ { AS_STATE_CHANGE_TYPE * 256 * 256 + AS_ACTIVE_INFO, "Application server active" },
+ { AS_STATE_CHANGE_TYPE * 256 * 256 + AS_PENDING_INFO, "Application server pending" },
+ { OTHER_TYPE * 256 * 256 + INSUFFICIENT_ASP_RES_INFO, "Insufficient ASP resources active in AS" },
+ { OTHER_TYPE * 256 * 256 + ALTERNATE_ASP_ACTIVE_INFO, "Alternate ASP active" },
+ { OTHER_TYPE * 256 * 256 + ASP_FAILURE_INFO, "ASP Failure" },
+ {0, NULL } };
static void
-dissect_m3ua_asp_identifier_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_status_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint32 identifier;
-
- identifier = tvb_get_ntohl(parameter_tvb, ASP_IDENTIFIER_OFFSET);
- proto_tree_add_uint(parameter_tree, hf_m3ua_asp_identifier, parameter_tvb, ASP_IDENTIFIER_OFFSET, ASP_IDENTIFIER_LENGTH, identifier);
- proto_item_set_text(parameter_item, "ASP identifier (%u)", identifier);
-}
+ guint16 status_type, status_info;
-#define AFFECTED_MASK_LENGTH 1
-#define AFFECTED_PC_LENGTH 3
-#define AFFECTED_POINT_CODE_LENGTH (AFFECTED_MASK_LENGTH + AFFECTED_PC_LENGTH)
+ status_type = tvb_get_ntohs(parameter_tvb, STATUS_TYPE_OFFSET);
+ status_info = tvb_get_ntohs(parameter_tvb, STATUS_INFO_OFFSET);
-#define AFFECTED_MASK_OFFSET 0
-#define AFFECTED_PC_OFFSET (AFFECTED_MASK_OFFSET + AFFECTED_MASK_LENGTH)
+ proto_tree_add_item(parameter_tree, hf_status_type, parameter_tvb, STATUS_TYPE_OFFSET, STATUS_TYPE_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_uint_format(parameter_tree, hf_status_info, parameter_tvb, STATUS_INFO_OFFSET, STATUS_INFO_LENGTH, status_info,
+ "Status info: %s (%u)", val_to_str(status_type * 256 * 256 + status_info, status_type_info_values, "unknown"), status_info);
-static void
-dissect_m3ua_affected_point_code_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
-{
- guint8 mask;
- guint16 length, number_of_point_codes, point_code_number;
- guint32 pc;
- gint point_code_offset;
+ proto_item_append_text(parameter_item, " (%s)", val_to_str(status_type * 256 * 256 + status_info, status_type_info_values, "unknown status information"));
+}
- length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
- number_of_point_codes = (length - PARAMETER_HEADER_LENGTH) / AFFECTED_POINT_CODE_LENGTH;
+static const value_string congestion_level_values[] = {
+ { 0, "No congestion or undefined" },
+ { 1, "Congestion level 1" },
+ { 2, "Congestion level 2" },
+ { 3, "Congestion level 3" },
+ { 0, NULL } };
- point_code_offset = PARAMETER_VALUE_OFFSET;
- for(point_code_number=1; point_code_number <= number_of_point_codes; point_code_number++) {
- mask = tvb_get_guint8(parameter_tvb, point_code_offset + AFFECTED_MASK_OFFSET);
- pc = tvb_get_ntoh24(parameter_tvb, point_code_offset + AFFECTED_PC_OFFSET);
- proto_tree_add_uint(parameter_tree, hf_m3ua_affected_point_code_mask, parameter_tvb, point_code_offset + AFFECTED_MASK_OFFSET, AFFECTED_MASK_LENGTH, mask);
- proto_tree_add_uint(parameter_tree, hf_m3ua_affected_point_code_pc, parameter_tvb, point_code_offset + AFFECTED_PC_OFFSET, AFFECTED_PC_LENGTH, pc);
- point_code_offset += AFFECTED_POINT_CODE_LENGTH;
- };
- proto_item_set_text(parameter_item, "Affected point code parameter (%u point code%s)", number_of_point_codes, plurality(number_of_point_codes, "", "s"));
-
-}
+#define CONG_IND_RESERVED_LENGTH 3
+#define CONG_IND_LEVEL_LENGTH 1
-#define NETWORK_APPEARANCE_LENGTH 4
-#define NETWORK_APPEARANCE_OFFSET PARAMETER_VALUE_OFFSET
+#define CONG_IND_RESERVED_OFFSET PARAMETER_VALUE_OFFSET
+#define CONG_IND_LEVEL_OFFSET (CONG_IND_RESERVED_OFFSET + CONG_IND_RESERVED_LENGTH)
static void
-dissect_m3ua_network_appearance_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_congestion_indication_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint32 network_appearance;
-
- network_appearance = tvb_get_ntohl(parameter_tvb, NETWORK_APPEARANCE_OFFSET);
- proto_tree_add_uint(parameter_tree, hf_m3ua_network_appearance, parameter_tvb, NETWORK_APPEARANCE_OFFSET, NETWORK_APPEARANCE_LENGTH, network_appearance);
- proto_item_set_text(parameter_item, "Network appearance: %u", network_appearance);
+ proto_tree_add_item(parameter_tree, hf_congestion_reserved, parameter_tvb, CONG_IND_RESERVED_OFFSET, CONG_IND_RESERVED_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_congestion_level, parameter_tvb, CONG_IND_LEVEL_OFFSET, CONG_IND_LEVEL_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%s)", val_to_str(tvb_get_guint8(parameter_tvb, CONG_IND_LEVEL_OFFSET), congestion_level_values, "unknown"));
}
-#define UNKNOWN_UNAVAIL_CAUSE 0
-#define UNEQUIPPED_REMOTE_USER_UNAVAIL_CAUSE 1
-#define INACCESSABLE_REMOTE_USER_UNAVAIL_CAUSE 2
-
-static const value_string m3ua_unavailability_cause_values[] = {
- { UNKNOWN_UNAVAIL_CAUSE, "Unknown" },
- { UNEQUIPPED_REMOTE_USER_UNAVAIL_CAUSE, "Unequipped remote user" },
- { INACCESSABLE_REMOTE_USER_UNAVAIL_CAUSE, "Inaccessable remote user" },
- {0, NULL } };
-
-#define RESERVED_0_USER_ID 0
-#define RESERVED_1_USER_ID 1
-#define RESERVED_2_USER_ID 2
-#define SCCP_USER_ID 3
-#define TUP_USER_ID 4
-#define ISUP_USER_ID 5
-#define RESERVED_6_USER_ID 6
-#define RESERVED_7_USER_ID 7
-#define RESERVED_8_USER_ID 8
-#define BROADBAND_ISUP_USER_ID 9
-#define SATELLITE_ISUP_USER_ID 10
-
-static const value_string m3ua_user_identity_values[] = {
- { RESERVED_0_USER_ID, "Reserved" },
- { RESERVED_1_USER_ID, "Reserved" },
- { RESERVED_2_USER_ID, "Reserved" },
- { SCCP_USER_ID, "SCCP" },
- { TUP_USER_ID, "TUP" },
- { ISUP_USER_ID, "ISUP" },
- { RESERVED_6_USER_ID, "Reserved" },
- { RESERVED_7_USER_ID, "Reserved" },
- { RESERVED_8_USER_ID, "Reserved" },
- { BROADBAND_ISUP_USER_ID, "Broadband ISUP" },
- { SATELLITE_ISUP_USER_ID, "Satellite ISUP" },
- {0, NULL } };
-
-#define CAUSE_LENGTH 2
-#define USER_LENGTH 2
-
-#define CAUSE_OFFSET PARAMETER_VALUE_OFFSET
-#define USER_OFFSET (CAUSE_OFFSET + CAUSE_LENGTH)
+#define ASP_IDENTIFIER_OFFSET PARAMETER_VALUE_OFFSET
+#define ASP_IDENTIFIER_LENGTH 4
static void
-dissect_m3ua_user_cause_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_asp_identifier_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint16 cause, user;
-
- cause = tvb_get_ntohs(parameter_tvb, CAUSE_OFFSET);
- user = tvb_get_ntohs(parameter_tvb, USER_OFFSET);
-
- proto_tree_add_uint(parameter_tree, hf_m3ua_unavailability_cause, parameter_tvb, CAUSE_OFFSET, CAUSE_LENGTH, cause);
- proto_tree_add_uint(parameter_tree, hf_m3ua_user_identity, parameter_tvb, USER_OFFSET, USER_LENGTH, user);
- proto_item_set_text(parameter_item, "User / Cause parameter (%s: %s)",
- val_to_str(user, m3ua_user_identity_values, "Unknown user"),
- val_to_str(cause, m3ua_unavailability_cause_values, "unknown cause"));
+ proto_tree_add_item(parameter_tree, hf_asp_identifier, parameter_tvb, ASP_IDENTIFIER_OFFSET, ASP_IDENTIFIER_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%u)", tvb_get_ntohl(parameter_tvb, ASP_IDENTIFIER_OFFSET));
}
static void
-dissect_m3ua_protocol_data_1_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_item *parameter_item)
+dissect_protocol_data_1_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_item *parameter_item)
{
guint16 length, protocol_data_length;
tvbuff_t *payload_tvb;
@@ -798,7 +769,7 @@ dissect_m3ua_protocol_data_1_parameter(tvbuff_t *parameter_tvb, packet_info *pin
length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
protocol_data_length = length - PARAMETER_HEADER_LENGTH;
payload_tvb = tvb_new_subset(parameter_tvb, PROTOCOL_DATA_OFFSET, protocol_data_length, protocol_data_length);
- proto_item_set_text(parameter_item, "Protocol data (SS7 message of %u byte%s)", protocol_data_length, plurality(protocol_data_length, "", "s"));
+ proto_item_append_text(parameter_item, " (SS7 message of %u byte%s)", protocol_data_length, plurality(protocol_data_length, "", "s"));
proto_item_set_len(parameter_item, PARAMETER_HEADER_LENGTH);
call_dissector(mtp3_handle, payload_tvb, pinfo, tree);
@@ -808,7 +779,7 @@ dissect_m3ua_protocol_data_1_parameter(tvbuff_t *parameter_tvb, packet_info *pin
#define LI_OCTETT_OFFSET PARAMETER_VALUE_OFFSET
static void
-dissect_m3ua_protocol_data_2_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_protocol_data_2_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree, proto_item *parameter_item)
{
guint8 li;
guint16 length, protocol_data_length;
@@ -818,53 +789,13 @@ dissect_m3ua_protocol_data_2_parameter(tvbuff_t *parameter_tvb, packet_info *pin
li = tvb_get_guint8(parameter_tvb, LI_OCTETT_OFFSET);
protocol_data_length = length - PARAMETER_HEADER_LENGTH - LI_OCTETT_LENGTH;
payload_tvb = tvb_new_subset(parameter_tvb, PROTOCOL_DATA_OFFSET + LI_OCTETT_LENGTH, protocol_data_length, protocol_data_length);
- proto_tree_add_uint(parameter_tree, hf_m3ua_li, parameter_tvb, LI_OCTETT_OFFSET, LI_OCTETT_LENGTH, li);
- proto_item_set_text(parameter_item, "Protocol data (SS7 message of %u byte%s)", protocol_data_length, plurality(protocol_data_length, "", "s"));
+ proto_tree_add_uint(parameter_tree, hf_li, parameter_tvb, LI_OCTETT_OFFSET, LI_OCTETT_LENGTH, li);
+ proto_item_append_text(parameter_item, " (SS7 message of %u byte%s)", protocol_data_length, plurality(protocol_data_length, "", "s"));
proto_item_set_len(parameter_item, PARAMETER_HEADER_LENGTH + LI_OCTETT_LENGTH);
call_dissector(mtp3_handle, payload_tvb, pinfo, tree);
}
-static void
-dissect_m3ua_reason_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
-{
- guint32 reason;
-
- reason = tvb_get_ntohl(parameter_tvb, REASON_OFFSET);
-
- proto_tree_add_uint(parameter_tree, hf_m3ua_reason, parameter_tvb, REASON_OFFSET, REASON_LENGTH, reason);
- proto_item_set_text(parameter_item, "Reason parameter (%s)", val_to_str(reason, m3ua_reason_values, "unknown"));
-}
-
-#define NO_CONGESTION_LEVEL 0
-#define CONGESTION_LEVEL_1_LEVEL 1
-#define CONGESTION_LEVEL_2_LEVEL 2
-#define CONGESTION_LEVEL_3_LEVEL 3
-
-static const value_string m3ua_congestion_level_values[] = {
- { NO_CONGESTION_LEVEL, "No congestion or undefined" },
- { CONGESTION_LEVEL_1_LEVEL, "Congestion level 1" },
- { CONGESTION_LEVEL_2_LEVEL, "Congestion level 2" },
- { CONGESTION_LEVEL_3_LEVEL, "Congestion level 3" },
- {0, NULL } };
-
-#define CONG_IND_RESERVED_LENGTH 3
-#define CONG_IND_LEVEL_LENGTH 1
-
-#define CONG_IND_RESERVED_OFFSET PARAMETER_VALUE_OFFSET
-#define CONG_IND_LEVEL_OFFSET (CONG_IND_RESERVED_OFFSET + CONG_IND_RESERVED_LENGTH)
-
-static void
-dissect_m3ua_congestion_indication_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
-{
- guint8 level;
-
- level = tvb_get_guint8(parameter_tvb, CONG_IND_LEVEL_OFFSET);
- proto_tree_add_bytes(parameter_tree, hf_m3ua_congestion_reserved, parameter_tvb, CONG_IND_RESERVED_OFFSET, CONG_IND_RESERVED_LENGTH,
- tvb_get_ptr(parameter_tvb, CONG_IND_RESERVED_OFFSET, CONG_IND_RESERVED_LENGTH));
- proto_tree_add_uint(parameter_tree, hf_m3ua_congestion_level, parameter_tvb, CONG_IND_LEVEL_OFFSET, CONG_IND_LEVEL_LENGTH, level);
- proto_item_set_text(parameter_item, "Congestion indication(%s)", val_to_str(level, m3ua_congestion_level_values, "unknown"));
-}
#define CON_DEST_RESERVED_LENGTH 1
#define CON_DEST_PC_LENGTH 3
@@ -873,20 +804,15 @@ dissect_m3ua_congestion_indication_parameter(tvbuff_t *parameter_tvb, proto_tree
#define CON_DEST_PC_OFFSET (CON_DEST_RESERVED_OFFSET + CON_DEST_RESERVED_LENGTH)
static void
-dissect_m3ua_concerned_destination_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_concerned_destination_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint32 pc;
-
- pc = tvb_get_ntoh24(parameter_tvb, CON_DEST_PC_OFFSET);
-
- proto_tree_add_bytes(parameter_tree, hf_m3ua_concerned_dest_reserved, parameter_tvb, CON_DEST_RESERVED_OFFSET, CON_DEST_RESERVED_LENGTH,
- tvb_get_ptr(parameter_tvb, CON_DEST_RESERVED_OFFSET, CON_DEST_RESERVED_LENGTH));
- proto_tree_add_uint(parameter_tree, hf_m3ua_concerned_dest_pc, parameter_tvb, CON_DEST_PC_OFFSET, CON_DEST_PC_LENGTH, pc);
- proto_item_set_text(parameter_item, "Concerned destination (%u)", pc);
+ proto_tree_add_item(parameter_tree, hf_concerned_dest_reserved, parameter_tvb, CON_DEST_RESERVED_OFFSET, CON_DEST_RESERVED_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_concerned_dest_pc, parameter_tvb, CON_DEST_PC_OFFSET, CON_DEST_PC_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%u)", tvb_get_ntoh24(parameter_tvb, CON_DEST_PC_OFFSET));
}
static void
-dissect_m3ua_routing_key_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_routing_key_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree)
{
tvbuff_t *parameters_tvb;
guint16 length, parameters_length;
@@ -894,11 +820,10 @@ dissect_m3ua_routing_key_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo,
length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
parameters_length = length - PARAMETER_HEADER_LENGTH;
parameters_tvb = tvb_new_subset(parameter_tvb, PARAMETER_VALUE_OFFSET, parameters_length, parameters_length);
- dissect_m3ua_parameters(parameters_tvb, pinfo, tree, parameter_tree);
- proto_item_set_text(parameter_item, "Routing key");
+ dissect_parameters(parameters_tvb, pinfo, tree, parameter_tree);
}
-static const value_string m3ua_registration_result_status_values[] = {
+static const value_string registration_result_status_values[] = {
{ 0, "Successfully Registered" } ,
{ 1, "Error - Unknown" } ,
{ 2, "Error - Invalid DPC" } ,
@@ -919,22 +844,15 @@ static const value_string m3ua_registration_result_status_values[] = {
#define REG_RES_CONTEXT_OFFSET (REG_RES_STATUS_OFFSET + REG_RES_STATUS_LENGTH)
static void
-dissect_m3ua_v6_registration_result_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_v6_registration_result_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree)
{
- guint32 id, status, context;
-
- id = tvb_get_ntohl(parameter_tvb, REG_RES_IDENTIFIER_OFFSET);
- status = tvb_get_ntohl(parameter_tvb, REG_RES_STATUS_OFFSET);
- context = tvb_get_ntohl(parameter_tvb, REG_RES_CONTEXT_OFFSET);
-
- proto_tree_add_uint(parameter_tree, hf_m3ua_registration_result_identifier, parameter_tvb, REG_RES_IDENTIFIER_OFFSET, REG_RES_IDENTIFIER_LENGTH, id);
- proto_tree_add_uint(parameter_tree, hf_m3ua_registration_result_status, parameter_tvb, REG_RES_STATUS_OFFSET, REG_RES_STATUS_LENGTH, status);
- proto_tree_add_uint(parameter_tree, hf_m3ua_registration_result_context, parameter_tvb, REG_RES_CONTEXT_OFFSET, REG_RES_CONTEXT_LENGTH, context);
- proto_item_set_text(parameter_item, "Registration result");
+ proto_tree_add_item(parameter_tree, hf_registration_result_identifier, parameter_tvb, REG_RES_IDENTIFIER_OFFSET, REG_RES_IDENTIFIER_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_registration_result_status, parameter_tvb, REG_RES_STATUS_OFFSET, REG_RES_STATUS_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_registration_result_context, parameter_tvb, REG_RES_CONTEXT_OFFSET, REG_RES_CONTEXT_LENGTH, NETWORK_BYTE_ORDER);
}
static void
-dissect_m3ua_v12_registration_result_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_registration_result_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree)
{
tvbuff_t *parameters_tvb;
guint16 length, parameters_length;
@@ -942,17 +860,16 @@ dissect_m3ua_v12_registration_result_parameter(tvbuff_t *parameter_tvb, packet_i
length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
parameters_length = length - PARAMETER_HEADER_LENGTH;
parameters_tvb = tvb_new_subset(parameter_tvb, PARAMETER_VALUE_OFFSET, parameters_length, parameters_length);
- dissect_m3ua_parameters(parameters_tvb, pinfo, tree, parameter_tree);
- proto_item_set_text(parameter_item, "Registration result");
+ dissect_parameters(parameters_tvb, pinfo, tree, parameter_tree);
}
-static const value_string m3ua_deregistration_result_status_values[] = {
- { 0, "Successfully De-registered" } ,
- { 1, "Error - Unknown" } ,
- { 2, "Error - Invalid Routing context" } ,
- { 3, "Error - Permission Denied" } ,
- { 4, "Error - Not registered" } ,
- { 0, NULL } };
+static const value_string v6_deregistration_result_status_values[] = {
+ { 0, "Successfully De-registered" } ,
+ { 1, "Error - Unknown" } ,
+ { 2, "Error - Invalid Routing context" } ,
+ { 3, "Error - Permission Denied" } ,
+ { 4, "Error - Not registered" } ,
+ { 0, NULL } };
#define DEREG_RES_CONTEXT_LENGTH 4
#define DEREG_RES_STATUS_LENGTH 4
@@ -961,30 +878,22 @@ static const value_string m3ua_deregistration_result_status_values[] = {
#define DEREG_RES_STATUS_OFFSET (DEREG_RES_CONTEXT_OFFSET + DEREG_RES_CONTEXT_LENGTH)
static void
-dissect_m3ua_v6_deregistration_result_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_v6_deregistration_result_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree)
{
- guint32 status, context;
-
- context = tvb_get_ntohl(parameter_tvb, DEREG_RES_CONTEXT_OFFSET);
- status = tvb_get_ntohl(parameter_tvb, DEREG_RES_STATUS_OFFSET);
-
- proto_tree_add_uint(parameter_tree, hf_m3ua_deregistration_result_context, parameter_tvb, DEREG_RES_CONTEXT_OFFSET, DEREG_RES_CONTEXT_LENGTH, context);
- proto_tree_add_uint(parameter_tree, hf_m3ua_deregistration_result_status, parameter_tvb, DEREG_RES_STATUS_OFFSET, DEREG_RES_STATUS_LENGTH, status);
- proto_item_set_text(parameter_item, "De-registration result");
-
+ proto_tree_add_item(parameter_tree, hf_v6_deregistration_result_context, parameter_tvb, DEREG_RES_CONTEXT_OFFSET, DEREG_RES_CONTEXT_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_v6_deregistration_result_status, parameter_tvb, DEREG_RES_STATUS_OFFSET, DEREG_RES_STATUS_LENGTH, NETWORK_BYTE_ORDER);
}
static void
-dissect_m3ua_v12_deregistration_result_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_deregistration_result_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree)
{
tvbuff_t *parameters_tvb;
guint16 length, parameters_length;
- length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
+ length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
parameters_length = length - PARAMETER_HEADER_LENGTH;
- parameters_tvb = tvb_new_subset(parameter_tvb, PARAMETER_VALUE_OFFSET, parameters_length, parameters_length);
- dissect_m3ua_parameters(parameters_tvb, pinfo, tree, parameter_tree);
- proto_item_set_text(parameter_item, "Deregistration result");
+ parameters_tvb = tvb_new_subset(parameter_tvb, PARAMETER_VALUE_OFFSET, parameters_length, parameters_length);
+ dissect_parameters(parameters_tvb, pinfo, tree, parameter_tree);
}
@@ -992,13 +901,13 @@ dissect_m3ua_v12_deregistration_result_parameter(tvbuff_t *parameter_tvb, packet
#define LOCAL_RK_IDENTIFIER_LENGTH 4
static void
-dissect_m3ua_local_routing_key_identifier_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_local_routing_key_identifier_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
guint32 id;
id = tvb_get_ntohl(parameter_tvb, LOCAL_RK_IDENTIFIER_OFFSET);
- proto_tree_add_uint(parameter_tree, hf_m3ua_local_rk_identifier, parameter_tvb, LOCAL_RK_IDENTIFIER_OFFSET, LOCAL_RK_IDENTIFIER_LENGTH, id);
- proto_item_set_text(parameter_item, "Local routing key identifier (%u)", id);
+ proto_tree_add_item(parameter_tree, hf_local_rk_identifier, parameter_tvb, LOCAL_RK_IDENTIFIER_OFFSET, LOCAL_RK_IDENTIFIER_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%u)", tvb_get_ntohl(parameter_tvb, LOCAL_RK_IDENTIFIER_OFFSET));
}
#define DPC_MASK_LENGTH 1
@@ -1008,25 +917,18 @@ dissect_m3ua_local_routing_key_identifier_parameter(tvbuff_t *parameter_tvb, pro
#define DPC_PC_OFFSET (DPC_MASK_OFFSET + DPC_MASK_LENGTH)
static void
-dissect_m3ua_destination_point_code_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_destination_point_code_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint32 pc;
- guint8 mask;
-
- mask = tvb_get_guint8(parameter_tvb, DPC_MASK_OFFSET);
- pc = tvb_get_ntoh24(parameter_tvb, DPC_PC_OFFSET);
-
- proto_tree_add_uint(parameter_tree, hf_m3ua_dpc_mask, parameter_tvb, DPC_MASK_OFFSET, DPC_MASK_LENGTH, mask);
- proto_tree_add_uint(parameter_tree, hf_m3ua_dpc_pc, parameter_tvb, DPC_PC_OFFSET, DPC_PC_LENGTH, pc);
- proto_item_set_text(parameter_item, "Destination point code (%u)", pc);
+ proto_tree_add_item(parameter_tree, hf_dpc_mask, parameter_tvb, DPC_MASK_OFFSET, DPC_MASK_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_dpc_pc, parameter_tvb, DPC_PC_OFFSET, DPC_PC_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%u)", tvb_get_ntoh24(parameter_tvb, DPC_PC_OFFSET));
}
#define SI_LENGTH 1
static void
-dissect_m3ua_service_indicators_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_service_indicators_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint8 si;
guint16 length, number_of_sis, si_number;
gint si_offset;
@@ -1035,19 +937,17 @@ dissect_m3ua_service_indicators_parameter(tvbuff_t *parameter_tvb, proto_tree *p
si_offset = PARAMETER_VALUE_OFFSET;
for(si_number=1; si_number <= number_of_sis; si_number++) {
- si = tvb_get_guint8(parameter_tvb, si_offset);
- proto_tree_add_uint(parameter_tree, hf_m3ua_si, parameter_tvb, si_offset, SI_LENGTH, si);
+ proto_tree_add_item(parameter_tree, hf_si, parameter_tvb, si_offset, SI_LENGTH, NETWORK_BYTE_ORDER);
si_offset += SI_LENGTH;
};
- proto_item_set_text(parameter_item, "Service indicators (%u indicator%s)", number_of_sis, plurality(number_of_sis, "", "s"));
+ proto_item_append_text(parameter_item, " (%u indicator%s)", number_of_sis, plurality(number_of_sis, "", "s"));
}
#define SSN_LENGTH 1
static void
-dissect_m3ua_subsystem_numbers_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_subsystem_numbers_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint8 ssn;
guint16 length, number_of_ssns, ssn_number;
gint ssn_offset;
@@ -1056,11 +956,10 @@ dissect_m3ua_subsystem_numbers_parameter(tvbuff_t *parameter_tvb, proto_tree *pa
ssn_offset = PARAMETER_VALUE_OFFSET;
for(ssn_number=1; ssn_number <= number_of_ssns; ssn_number++) {
- ssn = tvb_get_guint8(parameter_tvb, ssn_offset);
- proto_tree_add_uint(parameter_tree, hf_m3ua_ssn, parameter_tvb, ssn_offset, SSN_LENGTH, ssn);
+ proto_tree_add_item(parameter_tree, hf_ssn, parameter_tvb, ssn_offset, SSN_LENGTH, NETWORK_BYTE_ORDER);
ssn_offset += SSN_LENGTH;
};
- proto_item_set_text(parameter_item, "Subsystem numbers (%u number%s)", number_of_ssns, plurality(number_of_ssns, "", "s"));
+ proto_item_append_text(parameter_item, " (%u number%s)", number_of_ssns, plurality(number_of_ssns, "", "s"));
}
@@ -1071,11 +970,9 @@ dissect_m3ua_subsystem_numbers_parameter(tvbuff_t *parameter_tvb, proto_tree *pa
#define OPC_PC_OFFSET (OPC_MASK_OFFSET + OPC_MASK_LENGTH)
static void
-dissect_m3ua_originating_point_code_list_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_originating_point_code_list_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint8 mask;
guint16 length, number_of_point_codes, point_code_number;
- guint32 pc;
gint point_code_offset;
length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
@@ -1083,13 +980,11 @@ dissect_m3ua_originating_point_code_list_parameter(tvbuff_t *parameter_tvb, prot
point_code_offset = PARAMETER_VALUE_OFFSET;
for(point_code_number=1; point_code_number <= number_of_point_codes; point_code_number++) {
- mask = tvb_get_guint8(parameter_tvb, point_code_offset + AFFECTED_MASK_OFFSET);
- pc = tvb_get_ntoh24(parameter_tvb, point_code_offset + AFFECTED_PC_OFFSET);
- proto_tree_add_uint(parameter_tree, hf_m3ua_opc_list_mask, parameter_tvb, point_code_offset + OPC_MASK_OFFSET, OPC_MASK_LENGTH, mask);
- proto_tree_add_uint(parameter_tree, hf_m3ua_opc_list_pc, parameter_tvb, point_code_offset + OPC_PC_OFFSET, OPC_PC_LENGTH, pc);
+ proto_tree_add_item(parameter_tree, hf_opc_list_mask, parameter_tvb, point_code_offset + OPC_MASK_OFFSET, OPC_MASK_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_opc_list_pc, parameter_tvb, point_code_offset + OPC_PC_OFFSET, OPC_PC_LENGTH, NETWORK_BYTE_ORDER);
point_code_offset += OPC_LENGTH;
};
- proto_item_set_text(parameter_item, "Originating point code list (%u point code%s)", number_of_point_codes, plurality(number_of_point_codes, "", "s"));
+ proto_item_append_text(parameter_item, " (%u point code%s)", number_of_point_codes, plurality(number_of_point_codes, "", "s"));
}
#define CIC_RANGE_MASK_LENGTH 1
@@ -1103,11 +998,9 @@ dissect_m3ua_originating_point_code_list_parameter(tvbuff_t *parameter_tvb, prot
#define CIC_RANGE_UPPER_OFFSET (CIC_RANGE_LOWER_OFFSET + CIC_RANGE_LOWER_LENGTH)
static void
-dissect_m3ua_circuit_range_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_circuit_range_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint8 mask;
- guint16 length, number_of_point_codes, point_code_number, lower, upper;
- guint32 pc;
+ guint16 length, number_of_point_codes, point_code_number;
gint point_code_offset;
length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
@@ -1115,18 +1008,13 @@ dissect_m3ua_circuit_range_parameter(tvbuff_t *parameter_tvb, proto_tree *parame
point_code_offset = PARAMETER_VALUE_OFFSET;
for(point_code_number = 1; point_code_number <= number_of_point_codes; point_code_number++) {
- mask = tvb_get_guint8(parameter_tvb, point_code_offset + CIC_RANGE_MASK_OFFSET);
- pc = tvb_get_ntoh24(parameter_tvb, point_code_offset + CIC_RANGE_PC_OFFSET);
- lower = tvb_get_ntohs(parameter_tvb, point_code_offset + CIC_RANGE_LOWER_OFFSET);
- upper = tvb_get_ntohs(parameter_tvb, point_code_offset + CIC_RANGE_UPPER_OFFSET);
-
- proto_tree_add_uint(parameter_tree, hf_m3ua_cic_range_mask, parameter_tvb, point_code_offset + CIC_RANGE_MASK_OFFSET, CIC_RANGE_MASK_LENGTH, mask);
- proto_tree_add_uint(parameter_tree, hf_m3ua_cic_range_pc, parameter_tvb, point_code_offset + CIC_RANGE_PC_OFFSET, CIC_RANGE_PC_LENGTH, pc);
- proto_tree_add_uint(parameter_tree, hf_m3ua_cic_range_lower, parameter_tvb, point_code_offset + CIC_RANGE_LOWER_OFFSET, CIC_RANGE_LOWER_LENGTH, lower);
- proto_tree_add_uint(parameter_tree, hf_m3ua_cic_range_upper, parameter_tvb, point_code_offset + CIC_RANGE_UPPER_OFFSET, CIC_RANGE_UPPER_LENGTH, upper);
+ proto_tree_add_item(parameter_tree, hf_cic_range_mask, parameter_tvb, point_code_offset + CIC_RANGE_MASK_OFFSET, CIC_RANGE_MASK_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_cic_range_pc, parameter_tvb, point_code_offset + CIC_RANGE_PC_OFFSET, CIC_RANGE_PC_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_cic_range_lower, parameter_tvb, point_code_offset + CIC_RANGE_LOWER_OFFSET, CIC_RANGE_LOWER_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_cic_range_upper, parameter_tvb, point_code_offset + CIC_RANGE_UPPER_OFFSET, CIC_RANGE_UPPER_LENGTH, NETWORK_BYTE_ORDER);
point_code_offset += CIC_RANGE_LENGTH;
};
- proto_item_set_text(parameter_item, "Circuit range (%u range%s)", number_of_point_codes, plurality(number_of_point_codes, "", "s"));
+ proto_item_append_text(parameter_item, " (%u range%s)", number_of_point_codes, plurality(number_of_point_codes, "", "s"));
}
#define DATA_OPC_LENGTH 4
@@ -1146,33 +1034,27 @@ dissect_m3ua_circuit_range_parameter(tvbuff_t *parameter_tvb, proto_tree *parame
#define DATA_ULP_OFFSET (DATA_SLS_OFFSET + DATA_SLS_LENGTH)
static void
-dissect_m3ua_protocol_data_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_protocol_data_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint32 opc, dpc;
guint16 length, ulp_length;
- guint8 si, ni, mp, sls;
+ guint8 si;
tvbuff_t *payload_tvb;
length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
ulp_length = length - PARAMETER_HEADER_LENGTH - DATA_HDR_LENGTH;
payload_tvb = tvb_new_subset(parameter_tvb, DATA_ULP_OFFSET, ulp_length, ulp_length);
- opc = tvb_get_ntohl(parameter_tvb, DATA_OPC_OFFSET);
- dpc = tvb_get_ntohl(parameter_tvb, DATA_DPC_OFFSET);
si = tvb_get_guint8(parameter_tvb, DATA_SI_OFFSET);
- ni = tvb_get_guint8(parameter_tvb, DATA_NI_OFFSET);
- mp = tvb_get_guint8(parameter_tvb, DATA_MP_OFFSET);
- sls = tvb_get_guint8(parameter_tvb, DATA_SLS_OFFSET);
- proto_tree_add_uint(parameter_tree, hf_m3ua_protocol_data_opc, parameter_tvb, DATA_OPC_OFFSET, DATA_OPC_LENGTH, opc);
- proto_tree_add_uint(parameter_tree, hf_m3ua_protocol_data_dpc, parameter_tvb, DATA_DPC_OFFSET, DATA_DPC_LENGTH, dpc);
- proto_tree_add_uint(parameter_tree, hf_m3ua_protocol_data_si, parameter_tvb, DATA_SI_OFFSET, DATA_SI_LENGTH, si);
- proto_tree_add_uint(parameter_tree, hf_m3ua_protocol_data_ni, parameter_tvb, DATA_NI_OFFSET, DATA_NI_LENGTH, ni);
- proto_tree_add_uint(parameter_tree, hf_m3ua_protocol_data_mp, parameter_tvb, DATA_MP_OFFSET, DATA_MP_LENGTH, mp);
- proto_tree_add_uint(parameter_tree, hf_m3ua_protocol_data_sls, parameter_tvb, DATA_SLS_OFFSET, DATA_SLS_LENGTH, sls);
-
- proto_item_set_text(parameter_item, "Protocol data (SS7 message of %u byte%s)", ulp_length, plurality(ulp_length, "", "s"));
+ proto_tree_add_item(parameter_tree, hf_protocol_data_opc, parameter_tvb, DATA_OPC_OFFSET, DATA_OPC_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_protocol_data_dpc, parameter_tvb, DATA_DPC_OFFSET, DATA_DPC_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_protocol_data_si, parameter_tvb, DATA_SI_OFFSET, DATA_SI_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_protocol_data_ni, parameter_tvb, DATA_NI_OFFSET, DATA_NI_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_protocol_data_mp, parameter_tvb, DATA_MP_OFFSET, DATA_MP_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_protocol_data_sls, parameter_tvb, DATA_SLS_OFFSET, DATA_SLS_LENGTH, NETWORK_BYTE_ORDER);
+
+ proto_item_append_text(parameter_item, " (SS7 message of %u byte%s)", ulp_length, plurality(ulp_length, "", "s"));
proto_item_set_len(parameter_item, PARAMETER_HEADER_LENGTH + DATA_HDR_LENGTH);
- if (!dissector_try_port(m3ua_si_dissector_table, si, payload_tvb, pinfo, tree)) {
+ if (!dissector_try_port(si_dissector_table, si, payload_tvb, pinfo, tree)) {
call_dissector(data_handle, payload_tvb, pinfo, tree);
}
}
@@ -1181,19 +1063,16 @@ dissect_m3ua_protocol_data_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo
#define CORR_ID_LENGTH 4
static void
-dissect_m3ua_correlation_identifier_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_correlation_identifier_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint32 id;
-
- id = tvb_get_ntohl(parameter_tvb, CORR_ID_OFFSET);
- proto_tree_add_uint(parameter_tree, hf_m3ua_correlation_identifier, parameter_tvb, CORR_ID_OFFSET, CORR_ID_LENGTH, id);
- proto_item_set_text(parameter_item, "Correlation Identifer (%u)", id);
+ proto_tree_add_item(parameter_tree, hf_correlation_identifier, parameter_tvb, CORR_ID_OFFSET, CORR_ID_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%u)", tvb_get_ntohl(parameter_tvb, CORR_ID_OFFSET));
}
#define REG_STATUS_LENGTH 4
#define REG_STATUS_OFFSET PARAMETER_VALUE_OFFSET
-static const value_string m3ua_registration_status_values[] = {
+static const value_string registration_status_values[] = {
{ 0, "Successfully Registered" },
{ 1, "Error - Unknown" },
{ 2, "Error - Invalid DPC" },
@@ -1208,19 +1087,16 @@ static const value_string m3ua_registration_status_values[] = {
{ 0, NULL } };
static void
-dissect_m3ua_registration_status_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_registration_status_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint32 status;
-
- status = tvb_get_ntohl(parameter_tvb, REG_STATUS_OFFSET);
- proto_tree_add_uint(parameter_tree, hf_m3ua_registration_status, parameter_tvb, REG_STATUS_OFFSET, REG_STATUS_LENGTH, status);
- proto_item_set_text(parameter_item, "Registration status (%s)", val_to_str(status, m3ua_registration_status_values, "unknown"));
+ proto_tree_add_item(parameter_tree, hf_registration_status, parameter_tvb, REG_STATUS_OFFSET, REG_STATUS_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%s)", val_to_str(tvb_get_ntohl(parameter_tvb, REG_STATUS_OFFSET), registration_status_values, "unknown"));
}
#define DEREG_STATUS_LENGTH 4
#define DEREG_STATUS_OFFSET PARAMETER_VALUE_OFFSET
-static const value_string m3ua_deregistration_status_values[] = {
+static const value_string deregistration_status_values[] = {
{ 0, "Successfully Deregistered" },
{ 1, "Error - Unknown" },
{ 2, "Error - Invalid Routing Context" },
@@ -1230,17 +1106,14 @@ static const value_string m3ua_deregistration_status_values[] = {
{ 0, NULL } };
static void
-dissect_m3ua_deregistration_status_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_deregistration_status_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint32 status;
-
- status = tvb_get_ntohl(parameter_tvb, DEREG_STATUS_OFFSET);
- proto_tree_add_uint(parameter_tree, hf_m3ua_deregistration_status, parameter_tvb, DEREG_STATUS_OFFSET, DEREG_STATUS_LENGTH, status);
- proto_item_set_text(parameter_item, "Deregistration status (%s)", val_to_str(status, m3ua_deregistration_status_values, "unknown"));
+ proto_tree_add_item(parameter_tree, hf_deregistration_status, parameter_tvb, DEREG_STATUS_OFFSET, DEREG_STATUS_LENGTH, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (%s)", val_to_str(tvb_get_ntohl(parameter_tvb, DEREG_STATUS_OFFSET), deregistration_status_values, "unknown"));
}
static void
-dissect_m3ua_registration_results_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_registration_results_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree)
{
tvbuff_t *parameters_tvb;
guint16 length, parameters_length;
@@ -1248,12 +1121,11 @@ dissect_m3ua_registration_results_parameter(tvbuff_t *parameter_tvb, packet_info
length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
parameters_length = length - PARAMETER_HEADER_LENGTH;
parameters_tvb = tvb_new_subset(parameter_tvb, PARAMETER_VALUE_OFFSET, parameters_length, parameters_length);
- dissect_m3ua_parameters(parameters_tvb, pinfo, tree, parameter_tree);
- proto_item_set_text(parameter_item, "Registration results");
+ dissect_parameters(parameters_tvb, pinfo, tree, parameter_tree);
}
static void
-dissect_m3ua_deregistration_results_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_deregistration_results_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *parameter_tree)
{
tvbuff_t *parameters_tvb;
guint16 length, parameters_length;
@@ -1261,271 +1133,463 @@ dissect_m3ua_deregistration_results_parameter(tvbuff_t *parameter_tvb, packet_in
length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
parameters_length = length - PARAMETER_HEADER_LENGTH;
parameters_tvb = tvb_new_subset(parameter_tvb, PARAMETER_VALUE_OFFSET, parameters_length, parameters_length);
- dissect_m3ua_parameters(parameters_tvb, pinfo, tree, parameter_tree);
- proto_item_set_text(parameter_item, "Deregistration results");
+ dissect_parameters(parameters_tvb, pinfo, tree, parameter_tree);
}
static void
-dissect_m3ua_unknown_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
+dissect_unknown_parameter(tvbuff_t *parameter_tvb, proto_tree *parameter_tree, proto_item *parameter_item)
{
- guint16 tag, length, parameter_value_length;
+ guint16 tag, parameter_value_length;
- tag = tvb_get_ntohs(parameter_tvb, PARAMETER_TAG_OFFSET);
- length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
+ tag = tvb_get_ntohs(parameter_tvb, PARAMETER_TAG_OFFSET);
+ parameter_value_length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET) - PARAMETER_HEADER_LENGTH;
+ proto_tree_add_item(parameter_tree, hf_parameter_value, parameter_tvb, PARAMETER_VALUE_OFFSET, parameter_value_length, NETWORK_BYTE_ORDER);
+ proto_item_append_text(parameter_item, " (tag %u and %u byte%s value)", tag, parameter_value_length, plurality(parameter_value_length, "", "s"));
+}
+
+#define V5_NETWORK_APPEARANCE_PARAMETER_TAG 1
+#define V5_PROTOCOL_DATA_PARAMETER_TAG 3
+#define V5_INFO_PARAMETER_TAG 4
+#define V5_AFFECTED_DESTINATIONS_PARAMETER_TAG 5
+#define V5_ROUTING_CONTEXT_PARAMETER_TAG 6
+#define V5_DIAGNOSTIC_INFORMATION_PARAMETER_TAG 7
+#define V5_HEARTBEAT_DATA_PARAMETER_TAG 8
+#define V5_USER_CAUSE_PARAMETER_TAG 9
+#define V5_REASON_PARAMETER_TAG 10
+#define V5_TRAFFIC_MODE_TYPE_PARAMETER_TAG 11
+#define V5_ERROR_CODE_PARAMETER_TAG 12
+#define V5_STATUS_PARAMETER_TAG 13
+#define V5_CONGESTION_INDICATION_PARAMETER_TAG 14
+
+static const value_string v5_parameter_tag_values[] = {
+ { V5_NETWORK_APPEARANCE_PARAMETER_TAG, "Network appearance" },
+ { V5_PROTOCOL_DATA_PARAMETER_TAG, "Protocol data" },
+ { V5_INFO_PARAMETER_TAG, "Info" },
+ { V5_AFFECTED_DESTINATIONS_PARAMETER_TAG, "Affected destinations" },
+ { V5_ROUTING_CONTEXT_PARAMETER_TAG, "Routing context" },
+ { V5_DIAGNOSTIC_INFORMATION_PARAMETER_TAG, "Diagnostic information" },
+ { V5_HEARTBEAT_DATA_PARAMETER_TAG, "Heartbeat data" },
+ { V5_USER_CAUSE_PARAMETER_TAG, "User / Cause" },
+ { V5_REASON_PARAMETER_TAG, "Reason" },
+ { V5_TRAFFIC_MODE_TYPE_PARAMETER_TAG, "Traffic mode type" },
+ { V5_ERROR_CODE_PARAMETER_TAG, "Error code" },
+ { V5_STATUS_PARAMETER_TAG, "Status" },
+ { V5_CONGESTION_INDICATION_PARAMETER_TAG, "Congestion indication" },
+ { 0, NULL } };
+
+static void
+dissect_v5_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *m3ua_tree)
+{
+ guint16 tag, length, padding_length;
+ proto_item *parameter_item;
+ proto_tree *parameter_tree;
- parameter_value_length = length - PARAMETER_HEADER_LENGTH;
+ /* extract tag and length from the parameter */
+ tag = tvb_get_ntohs(parameter_tvb, PARAMETER_TAG_OFFSET);
+ length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
+ padding_length = tvb_length(parameter_tvb) - length;
- proto_tree_add_bytes(parameter_tree, hf_m3ua_parameter_value, parameter_tvb, PARAMETER_VALUE_OFFSET, parameter_value_length,
- tvb_get_ptr(parameter_tvb, PARAMETER_VALUE_OFFSET, parameter_value_length));
+ /* create proto_tree stuff */
+ parameter_item = proto_tree_add_text(m3ua_tree, parameter_tvb, PARAMETER_HEADER_OFFSET, tvb_length(parameter_tvb), val_to_str(tag, v5_parameter_tag_values, "Unknown parameter"));
+ parameter_tree = proto_item_add_subtree(parameter_item, ett_parameter);
- proto_item_set_text(parameter_item, "Parameter with tag %u and %u byte%s value", tag, parameter_value_length, plurality(parameter_value_length, "", "s"));
+ /* add tag and length to the sua tree */
+ proto_tree_add_item(parameter_tree, hf_v5_parameter_tag, parameter_tvb, PARAMETER_TAG_OFFSET, PARAMETER_TAG_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_parameter_length, parameter_tvb, PARAMETER_LENGTH_OFFSET, PARAMETER_LENGTH_LENGTH, NETWORK_BYTE_ORDER);
+ switch(tag) {
+ case V5_NETWORK_APPEARANCE_PARAMETER_TAG:
+ dissect_network_appearance_parameter(parameter_tvb, parameter_tree, parameter_item);
+ break;
+ case V5_PROTOCOL_DATA_PARAMETER_TAG:
+ dissect_v5_protocol_data_parameter(parameter_tvb, pinfo, tree, parameter_item);
+ break;
+ case V5_INFO_PARAMETER_TAG:
+ dissect_info_string_parameter(parameter_tvb, parameter_tree, parameter_item);
+ break;
+ case V5_AFFECTED_DESTINATIONS_PARAMETER_TAG:
+ dissect_affected_destinations_parameter(parameter_tvb, parameter_tree, parameter_item);
+ break;
+ case V5_ROUTING_CONTEXT_PARAMETER_TAG:
+ dissect_routing_context_parameter(parameter_tvb, parameter_tree, parameter_item);
+ break;
+ case V5_DIAGNOSTIC_INFORMATION_PARAMETER_TAG:
+ dissect_diagnostic_information_parameter(parameter_tvb, parameter_tree, parameter_item);
+ break;
+ case V5_HEARTBEAT_DATA_PARAMETER_TAG:
+ dissect_heartbeat_data_parameter(parameter_tvb, parameter_tree, parameter_item);
+ break;
+ case V5_USER_CAUSE_PARAMETER_TAG:
+ dissect_user_cause_parameter(parameter_tvb, parameter_tree, parameter_item);
+ break;
+ case V5_REASON_PARAMETER_TAG:
+ dissect_reason_parameter(parameter_tvb, parameter_tree, parameter_item);
+ break;
+ case V5_TRAFFIC_MODE_TYPE_PARAMETER_TAG:
+ dissect_v5_traffic_mode_type_parameter(parameter_tvb, parameter_tree, parameter_item);
+ break;
+ case V5_ERROR_CODE_PARAMETER_TAG:
+ dissect_v5_error_code_parameter(parameter_tvb, parameter_tree, parameter_item);
+ break;
+ case V5_STATUS_PARAMETER_TAG:
+ dissect_v56_status_parameter(parameter_tvb, parameter_tree, parameter_item);
+ break;
+ case V5_CONGESTION_INDICATION_PARAMETER_TAG:
+ dissect_congestion_indication_parameter(parameter_tvb, parameter_tree, parameter_item);
+ break;
+ default:
+ dissect_unknown_parameter(parameter_tvb, parameter_tree, parameter_item);
+ break;
+ };
+ if (padding_length > 0)
+ proto_tree_add_item(parameter_tree, hf_parameter_padding, parameter_tvb, PARAMETER_HEADER_OFFSET + length, padding_length, NETWORK_BYTE_ORDER);
}
+#define V6_NETWORK_APPEARANCE_PARAMETER_TAG 1
+#define V6_PROTOCOL_DATA_1_PARAMETER_TAG 2
+#define V6_PROTOCOL_DATA_2_PARAMETER_TAG 3
+#define V6_INFO_PARAMETER_TAG 4
+#define V6_AFFECTED_DESTINATIONS_PARAMETER_TAG 5
+#define V6_ROUTING_CONTEXT_PARAMETER_TAG 6
+#define V6_DIAGNOSTIC_INFORMATION_PARAMETER_TAG 7
+#define V6_HEARTBEAT_DATA_PARAMETER_TAG 8
+#define V6_USER_CAUSE_PARAMETER_TAG 9
+#define V6_REASON_PARAMETER_TAG 10
+#define V6_TRAFFIC_MODE_TYPE_PARAMETER_TAG 11
+#define V6_ERROR_CODE_PARAMETER_TAG 12
+#define V6_STATUS_PARAMETER_TAG 13
+#define V6_CONGESTION_INDICATION_PARAMETER_TAG 14
+#define V6_CONCERNED_DESTINATION_PARAMETER_TAG 15
+#define V6_ROUTING_KEY_PARAMETER_TAG 16
+#define V6_REGISTRATION_RESULT_PARAMETER_TAG 17
+#define V6_DEREGISTRATION_RESULT_PARAMETER_TAG 18
+#define V6_LOCAL_ROUTING_KEY_IDENTIFIER_PARAMETER_TAG 19
+#define V6_DESTINATION_POINT_CODE_PARAMETER_TAG 20
+#define V6_SERVICE_INDICATORS_PARAMETER_TAG 21
+#define V6_SUBSYSTEM_NUMBERS_PARAMETER_TAG 22
+#define V6_ORIGINATING_POINT_CODE_LIST_PARAMETER_TAG 23
+#define V6_CIRCUIT_RANGE_PARAMETER_TAG 24
+#define V6_REGISTRATION_RESULTS_PARAMETER_TAG 25
+#define V6_DEREGISTRATION_RESULTS_PARAMETER_TAG 26
+
+static const value_string v6_parameter_tag_values[] = {
+ { V6_NETWORK_APPEARANCE_PARAMETER_TAG, "Network appearance" },
+ { V6_PROTOCOL_DATA_1_PARAMETER_TAG, "Protocol data 1" },
+ { V6_PROTOCOL_DATA_2_PARAMETER_TAG, "Protocol data 2" },
+ { V6_INFO_PARAMETER_TAG, "Info" },
+ { V6_AFFECTED_DESTINATIONS_PARAMETER_TAG, "Affected destinations" },
+ { V6_ROUTING_CONTEXT_PARAMETER_TAG, "Routing context" },
+ { V6_DIAGNOSTIC_INFORMATION_PARAMETER_TAG, "Diagnostic information" },
+ { V6_HEARTBEAT_DATA_PARAMETER_TAG, "Heartbeat data" },
+ { V6_USER_CAUSE_PARAMETER_TAG, "User / Cause" },
+ { V6_REASON_PARAMETER_TAG, "Reason" },
+ { V6_TRAFFIC_MODE_TYPE_PARAMETER_TAG, "Traffic mode type" },
+ { V6_ERROR_CODE_PARAMETER_TAG, "Error code" },
+ { V6_STATUS_PARAMETER_TAG, "Status" },
+ { V6_CONGESTION_INDICATION_PARAMETER_TAG, "Congestion indication" },
+ { V6_CONCERNED_DESTINATION_PARAMETER_TAG, "Concerned destination" },
+ { V6_ROUTING_KEY_PARAMETER_TAG, "Routing Key" },
+ { V6_REGISTRATION_RESULT_PARAMETER_TAG, "Registration result" },
+ { V6_DEREGISTRATION_RESULT_PARAMETER_TAG, "De-registration result" },
+ { V6_LOCAL_ROUTING_KEY_IDENTIFIER_PARAMETER_TAG, "Local routing key identifier" },
+ { V6_DESTINATION_POINT_CODE_PARAMETER_TAG, "Destination point code" },
+ { V6_SERVICE_INDICATORS_PARAMETER_TAG, "Service indicators" },
+ { V6_SUBSYSTEM_NUMBERS_PARAMETER_TAG, "Subsystem numbers" },
+ { V6_ORIGINATING_POINT_CODE_LIST_PARAMETER_TAG, "Originating point code list" },
+ { V6_CIRCUIT_RANGE_PARAMETER_TAG, "Circuit range" },
+ { V6_REGISTRATION_RESULTS_PARAMETER_TAG, "Registration results" },
+ { V6_DEREGISTRATION_RESULTS_PARAMETER_TAG, "De-registration results" },
+ { 0, NULL } };
static void
-dissect_m3ua_v6_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *m3ua_tree)
+dissect_v6_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *m3ua_tree)
{
- guint16 tag, length, padding_length, total_length;
+ guint16 tag, length, padding_length;
proto_item *parameter_item;
proto_tree *parameter_tree;
/* extract tag and length from the parameter */
tag = tvb_get_ntohs(parameter_tvb, PARAMETER_TAG_OFFSET);
length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
-
- /* calculate padding and total length */
padding_length = tvb_length(parameter_tvb) - length;
- total_length = length + padding_length;
/* create proto_tree stuff */
- parameter_item = proto_tree_add_text(m3ua_tree, parameter_tvb, PARAMETER_HEADER_OFFSET, total_length, "Incomplete parameter");
- parameter_tree = proto_item_add_subtree(parameter_item, ett_m3ua_parameter);
+ parameter_item = proto_tree_add_text(m3ua_tree, parameter_tvb, PARAMETER_HEADER_OFFSET, tvb_length(parameter_tvb), val_to_str(tag, v6_parameter_tag_values, "Unknown parameter"));
+ parameter_tree = proto_item_add_subtree(parameter_item, ett_parameter);
- /* add tag and length to the m3ua tree */
- proto_tree_add_uint_format(parameter_tree, hf_m3ua_parameter_tag, parameter_tvb, PARAMETER_TAG_OFFSET, PARAMETER_TAG_LENGTH, tag,
- "Parameter tag: %s (0x%x)", val_to_str(tag, m3ua_v6_parameter_tag_values, "unknown"), tag);
- proto_tree_add_uint(parameter_tree, hf_m3ua_parameter_length, parameter_tvb, PARAMETER_LENGTH_OFFSET, PARAMETER_LENGTH_LENGTH, length);
+ /* add tag and length to the sua tree */
+ proto_tree_add_item(parameter_tree, hf_v5_parameter_tag, parameter_tvb, PARAMETER_TAG_OFFSET, PARAMETER_TAG_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_parameter_length, parameter_tvb, PARAMETER_LENGTH_OFFSET, PARAMETER_LENGTH_LENGTH, NETWORK_BYTE_ORDER);
switch(tag) {
case V6_NETWORK_APPEARANCE_PARAMETER_TAG:
- dissect_m3ua_network_appearance_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_network_appearance_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_PROTOCOL_DATA_1_PARAMETER_TAG:
- dissect_m3ua_protocol_data_1_parameter(parameter_tvb, pinfo, tree, parameter_item);
+ dissect_protocol_data_1_parameter(parameter_tvb, pinfo, tree, parameter_item);
break;
case V6_PROTOCOL_DATA_2_PARAMETER_TAG:
- dissect_m3ua_protocol_data_2_parameter(parameter_tvb, pinfo, tree, parameter_tree, parameter_item);
+ dissect_protocol_data_2_parameter(parameter_tvb, pinfo, tree, parameter_tree, parameter_item);
break;
case V6_INFO_PARAMETER_TAG:
- dissect_m3ua_info_string_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_info_string_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_AFFECTED_DESTINATIONS_PARAMETER_TAG:
- dissect_m3ua_affected_point_code_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_affected_destinations_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_ROUTING_CONTEXT_PARAMETER_TAG:
- dissect_m3ua_routing_context_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_routing_context_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_DIAGNOSTIC_INFORMATION_PARAMETER_TAG:
- dissect_m3ua_diagnostic_information_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_diagnostic_information_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_HEARTBEAT_DATA_PARAMETER_TAG:
- dissect_m3ua_heartbeat_data_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_heartbeat_data_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_USER_CAUSE_PARAMETER_TAG:
- dissect_m3ua_user_cause_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_user_cause_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_REASON_PARAMETER_TAG:
- dissect_m3ua_reason_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_reason_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_TRAFFIC_MODE_TYPE_PARAMETER_TAG:
- dissect_m3ua_v6_traffic_mode_type_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_v6_traffic_mode_type_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_ERROR_CODE_PARAMETER_TAG:
- dissect_m3ua_v6_error_code_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_v6_error_code_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_STATUS_PARAMETER_TAG:
- dissect_m3ua_status_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_v56_status_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_CONGESTION_INDICATION_PARAMETER_TAG:
- dissect_m3ua_congestion_indication_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_congestion_indication_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_CONCERNED_DESTINATION_PARAMETER_TAG:
- dissect_m3ua_concerned_destination_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_concerned_destination_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_ROUTING_KEY_PARAMETER_TAG:
- dissect_m3ua_routing_key_parameter(parameter_tvb, pinfo, tree, parameter_tree, parameter_item);
+ dissect_routing_key_parameter(parameter_tvb, pinfo, tree, parameter_tree);
break;
case V6_REGISTRATION_RESULT_PARAMETER_TAG:
- dissect_m3ua_v6_registration_result_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_v6_registration_result_parameter(parameter_tvb, parameter_tree);
break;
case V6_DEREGISTRATION_RESULT_PARAMETER_TAG:
- dissect_m3ua_v6_deregistration_result_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_v6_deregistration_result_parameter(parameter_tvb, parameter_tree);
break;
case V6_LOCAL_ROUTING_KEY_IDENTIFIER_PARAMETER_TAG:
- dissect_m3ua_local_routing_key_identifier_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_local_routing_key_identifier_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_DESTINATION_POINT_CODE_PARAMETER_TAG:
- dissect_m3ua_destination_point_code_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_destination_point_code_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_SERVICE_INDICATORS_PARAMETER_TAG:
- dissect_m3ua_service_indicators_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_service_indicators_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_SUBSYSTEM_NUMBERS_PARAMETER_TAG:
- dissect_m3ua_subsystem_numbers_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_subsystem_numbers_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_ORIGINATING_POINT_CODE_LIST_PARAMETER_TAG:
- dissect_m3ua_originating_point_code_list_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_originating_point_code_list_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_CIRCUIT_RANGE_PARAMETER_TAG:
- dissect_m3ua_circuit_range_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_circuit_range_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
case V6_REGISTRATION_RESULTS_PARAMETER_TAG:
- dissect_m3ua_registration_results_parameter(parameter_tvb, pinfo, tree, parameter_tree, parameter_item);
+ dissect_registration_results_parameter(parameter_tvb, pinfo, tree, parameter_tree);
break;
case V6_DEREGISTRATION_RESULTS_PARAMETER_TAG:
- dissect_m3ua_deregistration_results_parameter(parameter_tvb, pinfo, tree, parameter_tree, parameter_item);
+ dissect_deregistration_results_parameter(parameter_tvb, pinfo, tree, parameter_tree);
break;
default:
- dissect_m3ua_unknown_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_unknown_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
};
if (padding_length > 0)
- proto_tree_add_bytes(parameter_tree, hf_m3ua_parameter_padding, parameter_tvb, PARAMETER_HEADER_OFFSET + length, padding_length,
- tvb_get_ptr(parameter_tvb, PARAMETER_HEADER_OFFSET + length, padding_length));
+ proto_tree_add_item(parameter_tree, hf_parameter_padding, parameter_tvb, PARAMETER_HEADER_OFFSET + length, padding_length, NETWORK_BYTE_ORDER);
}
+#define INFO_STRING_PARAMETER_TAG 0x0004
+#define ROUTING_CONTEXT_PARAMETER_TAG 0x0006
+#define DIAGNOSTIC_INFORMATION_PARAMETER_TAG 0x0007
+#define HEARTBEAT_DATA_PARAMETER_TAG 0x0009
+#define TRAFFIC_MODE_TYPE_PARAMETER_TAG 0x000b
+#define ERROR_CODE_PARAMETER_TAG 0x000c
+#define STATUS_PARAMETER_TAG 0x000d
+#define ASP_IDENTIFIER_PARAMETER_TAG 0x0011
+#define AFFECTED_POINT_CODE_PARAMETER_TAG 0x0012
+#define CORRELATION_IDENTIFIER_PARAMETER_TAG 0x0013
+
+#define NETWORK_APPEARANCE_PARAMETER_TAG 0x0200
+#define USER_CAUSE_PARAMETER_TAG 0x0204
+#define CONGESTION_INDICATIONS_PARAMETER_TAG 0x0205
+#define CONCERNED_DESTINATION_PARAMETER_TAG 0x0206
+#define ROUTING_KEY_PARAMETER_TAG 0x0207
+#define REGISTRATION_RESULT_PARAMETER_TAG 0x0208
+#define DEREGISTRATION_RESULT_PARAMETER_TAG 0x0209
+#define LOCAL_ROUTING_KEY_IDENTIFIER_PARAMETER_TAG 0x020a
+#define DESTINATION_POINT_CODE_PARAMETER_TAG 0x020b
+#define SERVICE_INDICATORS_PARAMETER_TAG 0x020c
+#define ORIGINATING_POINT_CODE_LIST_PARAMETER_TAG 0x020e
+#define CIRCUIT_RANGE_PARAMETER_TAG 0x020f
+#define PROTOCOL_DATA_PARAMETER_TAG 0x0210
+#define REGISTRATION_STATUS_PARAMETER_TAG 0x0212
+#define DEREGISTRATION_STATUS_PARAMETER_TAG 0x0213
+
+static const value_string parameter_tag_values[] = {
+ { INFO_STRING_PARAMETER_TAG, "Info string" } ,
+ { ROUTING_CONTEXT_PARAMETER_TAG, "Routing context" } ,
+ { DIAGNOSTIC_INFORMATION_PARAMETER_TAG, "Diagnostic Information" } ,
+ { HEARTBEAT_DATA_PARAMETER_TAG, "Heartbeat data" } ,
+ { TRAFFIC_MODE_TYPE_PARAMETER_TAG, "Traffic mode type" } ,
+ { ERROR_CODE_PARAMETER_TAG, "Error code" } ,
+ { STATUS_PARAMETER_TAG, "Status" } ,
+ { ASP_IDENTIFIER_PARAMETER_TAG, "ASP identifier" } ,
+ { AFFECTED_POINT_CODE_PARAMETER_TAG, "Affected point code" } ,
+ { CORRELATION_IDENTIFIER_PARAMETER_TAG, "Correlation identifier" } ,
+ { NETWORK_APPEARANCE_PARAMETER_TAG, "Network appearance" } ,
+ { USER_CAUSE_PARAMETER_TAG, "User / cause" } ,
+ { CONGESTION_INDICATIONS_PARAMETER_TAG, "Congestion indications" } ,
+ { CONCERNED_DESTINATION_PARAMETER_TAG, "Concerned destination" } ,
+ { ROUTING_KEY_PARAMETER_TAG, "Routing key" } ,
+ { REGISTRATION_RESULT_PARAMETER_TAG, "Registration result" } ,
+ { DEREGISTRATION_RESULT_PARAMETER_TAG, "Deregistration result" } ,
+ { LOCAL_ROUTING_KEY_IDENTIFIER_PARAMETER_TAG, "Local routing key identifier" } ,
+ { DESTINATION_POINT_CODE_PARAMETER_TAG, "Destination point code" } ,
+ { SERVICE_INDICATORS_PARAMETER_TAG, "Service indicators" } ,
+ { ORIGINATING_POINT_CODE_LIST_PARAMETER_TAG, "Originating point code list" } ,
+ { CIRCUIT_RANGE_PARAMETER_TAG, "Circuit range" } ,
+ { PROTOCOL_DATA_PARAMETER_TAG, "Protocol data" } ,
+ { REGISTRATION_STATUS_PARAMETER_TAG, "Registration status" } ,
+ { DEREGISTRATION_STATUS_PARAMETER_TAG, "Deregistration status" } ,
+ { 0, NULL } };
+
static void
-dissect_m3ua_v12_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *m3ua_tree)
+dissect_parameter(tvbuff_t *parameter_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *m3ua_tree)
{
- guint16 tag, length, padding_length, total_length;
+ guint16 tag, length, padding_length;
proto_item *parameter_item;
proto_tree *parameter_tree;
/* extract tag and length from the parameter */
tag = tvb_get_ntohs(parameter_tvb, PARAMETER_TAG_OFFSET);
length = tvb_get_ntohs(parameter_tvb, PARAMETER_LENGTH_OFFSET);
-
- /* calculate padding and total length */
padding_length = tvb_length(parameter_tvb) - length;
- total_length = length + padding_length;
/* create proto_tree stuff */
- parameter_item = proto_tree_add_text(m3ua_tree, parameter_tvb, PARAMETER_HEADER_OFFSET, total_length, "Incomplete parameter");
- parameter_tree = proto_item_add_subtree(parameter_item, ett_m3ua_parameter);
+ parameter_item = proto_tree_add_text(m3ua_tree, parameter_tvb, PARAMETER_HEADER_OFFSET, tvb_length(parameter_tvb), val_to_str(tag, parameter_tag_values, "Unknown parameter"));
+ parameter_tree = proto_item_add_subtree(parameter_item, ett_parameter);
- /* add tag and length to the m3ua tree */
- proto_tree_add_uint_format(parameter_tree, hf_m3ua_parameter_tag, parameter_tvb, PARAMETER_TAG_OFFSET, PARAMETER_TAG_LENGTH, tag,
- "Parameter tag: %s (0x%x)", val_to_str(tag, m3ua_v12_parameter_tag_values, "unknown"), tag);
- proto_tree_add_uint(parameter_tree, hf_m3ua_parameter_length, parameter_tvb, PARAMETER_LENGTH_OFFSET, PARAMETER_LENGTH_LENGTH, length);
+ /* add tag and length to the sua tree */
+ proto_tree_add_item(parameter_tree, hf_v5_parameter_tag, parameter_tvb, PARAMETER_TAG_OFFSET, PARAMETER_TAG_LENGTH, NETWORK_BYTE_ORDER);
+ proto_tree_add_item(parameter_tree, hf_parameter_length, parameter_tvb, PARAMETER_LENGTH_OFFSET, PARAMETER_LENGTH_LENGTH, NETWORK_BYTE_ORDER);
switch(tag) {
- case V12_INFO_STRING_PARAMETER_TAG:
- dissect_m3ua_info_string_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case INFO_STRING_PARAMETER_TAG:
+ dissect_info_string_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_ROUTING_CONTEXT_PARAMETER_TAG:
- dissect_m3ua_routing_context_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case ROUTING_CONTEXT_PARAMETER_TAG:
+ dissect_routing_context_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_DIAGNOSTIC_INFORMATION_PARAMETER_TAG:
- dissect_m3ua_diagnostic_information_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case DIAGNOSTIC_INFORMATION_PARAMETER_TAG:
+ dissect_diagnostic_information_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_HEARTBEAT_DATA_PARAMETER_TAG:
- dissect_m3ua_heartbeat_data_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case HEARTBEAT_DATA_PARAMETER_TAG:
+ dissect_heartbeat_data_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_TRAFFIC_MODE_TYPE_PARAMETER_TAG:
- dissect_m3ua_v12_traffic_mode_type_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case TRAFFIC_MODE_TYPE_PARAMETER_TAG:
+ dissect_traffic_mode_type_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_ERROR_CODE_PARAMETER_TAG:
- dissect_m3ua_v12_error_code_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case ERROR_CODE_PARAMETER_TAG:
+ dissect_error_code_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_STATUS_PARAMETER_TAG:
- dissect_m3ua_status_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case STATUS_PARAMETER_TAG:
+ dissect_status_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_ASP_IDENTIFIER_PARAMETER_TAG:
- dissect_m3ua_asp_identifier_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case ASP_IDENTIFIER_PARAMETER_TAG:
+ dissect_asp_identifier_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_AFFECTED_POINT_CODE_PARAMETER_TAG:
- dissect_m3ua_affected_point_code_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case AFFECTED_POINT_CODE_PARAMETER_TAG:
+ dissect_affected_destinations_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_NETWORK_APPEARANCE_PARAMETER_TAG:
- dissect_m3ua_network_appearance_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case NETWORK_APPEARANCE_PARAMETER_TAG:
+ dissect_network_appearance_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_USER_CAUSE_PARAMETER_TAG:
- dissect_m3ua_user_cause_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case USER_CAUSE_PARAMETER_TAG:
+ dissect_user_cause_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_CONGESTION_INDICATIONS_PARAMETER_TAG:
- dissect_m3ua_congestion_indication_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case CONGESTION_INDICATIONS_PARAMETER_TAG:
+ dissect_congestion_indication_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_CONCERNED_DESTINATION_PARAMETER_TAG:
- dissect_m3ua_concerned_destination_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case CONCERNED_DESTINATION_PARAMETER_TAG:
+ dissect_concerned_destination_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_ROUTING_KEY_PARAMETER_TAG:
- dissect_m3ua_routing_key_parameter(parameter_tvb, pinfo, tree, parameter_tree, parameter_item);
+ case ROUTING_KEY_PARAMETER_TAG:
+ dissect_routing_key_parameter(parameter_tvb, pinfo, tree, parameter_tree);
break;
- case V12_REGISTRATION_RESULT_PARAMETER_TAG:
- dissect_m3ua_v12_registration_result_parameter(parameter_tvb, pinfo, tree, parameter_tree, parameter_item);
+ case REGISTRATION_RESULT_PARAMETER_TAG:
+ dissect_registration_result_parameter(parameter_tvb, pinfo, tree, parameter_tree);
break;
- case V12_DEREGISTRATION_RESULT_PARAMETER_TAG:
- dissect_m3ua_v12_deregistration_result_parameter(parameter_tvb, pinfo, tree, parameter_tree, parameter_item);
+ case DEREGISTRATION_RESULT_PARAMETER_TAG:
+ dissect_deregistration_result_parameter(parameter_tvb, pinfo, tree, parameter_tree);
break;
- case V12_LOCAL_ROUTING_KEY_IDENTIFIER_PARAMETER_TAG:
- dissect_m3ua_local_routing_key_identifier_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case LOCAL_ROUTING_KEY_IDENTIFIER_PARAMETER_TAG:
+ dissect_local_routing_key_identifier_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_DESTINATION_POINT_CODE_PARAMETER_TAG:
- dissect_m3ua_destination_point_code_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case DESTINATION_POINT_CODE_PARAMETER_TAG:
+ dissect_destination_point_code_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_SERVICE_INDICATORS_PARAMETER_TAG:
- dissect_m3ua_service_indicators_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case SERVICE_INDICATORS_PARAMETER_TAG:
+ dissect_service_indicators_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_ORIGINATING_POINT_CODE_LIST_PARAMETER_TAG:
- dissect_m3ua_originating_point_code_list_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case ORIGINATING_POINT_CODE_LIST_PARAMETER_TAG:
+ dissect_originating_point_code_list_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_CIRCUIT_RANGE_PARAMETER_TAG:
- dissect_m3ua_circuit_range_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case CIRCUIT_RANGE_PARAMETER_TAG:
+ dissect_circuit_range_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_PROTOCOL_DATA_PARAMETER_TAG:
- dissect_m3ua_protocol_data_parameter(parameter_tvb, pinfo, tree, parameter_tree, parameter_item);
+ case PROTOCOL_DATA_PARAMETER_TAG:
+ dissect_protocol_data_parameter(parameter_tvb, pinfo, tree, parameter_tree, parameter_item);
break;
- case V12_CORRELATION_IDENTIFIER_PARAMETER_TAG:
- dissect_m3ua_correlation_identifier_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case CORRELATION_IDENTIFIER_PARAMETER_TAG:
+ dissect_correlation_identifier_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_REGISTRATION_STATUS_PARAMETER_TAG:
- dissect_m3ua_registration_status_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case REGISTRATION_STATUS_PARAMETER_TAG:
+ dissect_registration_status_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
- case V12_DEREGISTRATION_STATUS_PARAMETER_TAG:
- dissect_m3ua_deregistration_status_parameter(parameter_tvb, parameter_tree, parameter_item);
+ case DEREGISTRATION_STATUS_PARAMETER_TAG:
+ dissect_deregistration_status_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
default:
- dissect_m3ua_unknown_parameter(parameter_tvb, parameter_tree, parameter_item);
+ dissect_unknown_parameter(parameter_tvb, parameter_tree, parameter_item);
break;
};
if (padding_length > 0)
- proto_tree_add_bytes(parameter_tree, hf_m3ua_parameter_padding, parameter_tvb, PARAMETER_HEADER_OFFSET + length, padding_length,
- tvb_get_ptr(parameter_tvb, PARAMETER_HEADER_OFFSET + length, padding_length));
+ proto_tree_add_item(parameter_tree, hf_parameter_padding, parameter_tvb, PARAMETER_HEADER_OFFSET + length, padding_length, NETWORK_BYTE_ORDER);
}
static void
-dissect_m3ua_parameters(tvbuff_t *parameters_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *m3ua_tree)
+dissect_parameters(tvbuff_t *parameters_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *m3ua_tree)
{
- gint offset, length, padding_length, total_length, remaining_length;
+ gint offset, length, total_length, remaining_length;
tvbuff_t *parameter_tvb;
offset = 0;
- while((remaining_length = tvb_reported_length_remaining(parameters_tvb, offset))) {
- length = tvb_get_ntohs(parameters_tvb, offset + PARAMETER_LENGTH_OFFSET);
- padding_length = nr_of_padding_bytes(length);
+ while((remaining_length = tvb_length_remaining(parameters_tvb, offset))) {
+ length = tvb_get_ntohs(parameters_tvb, offset + PARAMETER_LENGTH_OFFSET);
+ total_length = ADD_PADDING(length);
if (remaining_length >= length)
- total_length = MIN(length + padding_length, remaining_length);
- else
- total_length = length + padding_length;
+ total_length = MIN(total_length, remaining_length);
/* create a tvb for the parameter including the padding bytes */
parameter_tvb = tvb_new_subset(parameters_tvb, offset, total_length, total_length);
- switch(m3ua_version) {
+ switch(version) {
+ case M3UA_V5:
+ dissect_v5_parameter(parameter_tvb, pinfo, tree, m3ua_tree);
+ break;
case M3UA_V6:
- dissect_m3ua_v6_parameter(parameter_tvb, pinfo, tree, m3ua_tree);
+ dissect_v6_parameter(parameter_tvb, pinfo, tree, m3ua_tree);
break;
- case M3UA_V12:
- dissect_m3ua_v12_parameter(parameter_tvb, pinfo, tree, m3ua_tree);
+ case M3UA_RFC:
+ dissect_parameter(parameter_tvb, pinfo, tree, m3ua_tree);
break;
}
/* get rid of the handled parameter */
@@ -1535,15 +1599,18 @@ dissect_m3ua_parameters(tvbuff_t *parameters_tvb, packet_info *pinfo, proto_tree
static void
-dissect_m3ua_message(tvbuff_t *message_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *m3ua_tree)
+dissect_message(tvbuff_t *message_tvb, packet_info *pinfo, proto_tree *tree, proto_tree *m3ua_tree)
{
tvbuff_t *common_header_tvb, *parameters_tvb;
common_header_tvb = tvb_new_subset(message_tvb, 0, COMMON_HEADER_LENGTH, COMMON_HEADER_LENGTH);
parameters_tvb = tvb_new_subset(message_tvb, COMMON_HEADER_LENGTH, -1, -1);
- dissect_m3ua_common_header(common_header_tvb, pinfo, m3ua_tree);
+ if (version == M3UA_V5)
+ dissect_v5_common_header(common_header_tvb, pinfo, m3ua_tree);
+ else
+ dissect_common_header(common_header_tvb, pinfo, m3ua_tree);
if (m3ua_tree)
- dissect_m3ua_parameters(parameters_tvb, pinfo, tree, m3ua_tree);
+ dissect_parameters(parameters_tvb, pinfo, tree, m3ua_tree);
}
static void
@@ -1566,7 +1633,7 @@ dissect_m3ua(tvbuff_t *message_tvb, packet_info *pinfo, proto_tree *tree)
m3ua_tree = NULL;
};
/* dissect the message */
- dissect_m3ua_message(message_tvb, pinfo, tree, m3ua_tree);
+ dissect_message(message_tvb, pinfo, tree, m3ua_tree);
}
/* Register the protocol with Ethereal */
@@ -1576,301 +1643,93 @@ proto_register_m3ua(void)
/* Setup list of header fields */
static hf_register_info hf[] = {
- { &hf_m3ua_version,
- { "Version", "m3ua.version",
- FT_UINT8, BASE_DEC, VALS(m3ua_protocol_version_values), 0x0,
- "", HFILL }
- },
- { &hf_m3ua_reserved,
- { "Reserved", "m3ua.reserved",
- FT_UINT8, BASE_HEX, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_message_class,
- { "Message class", "m3ua.message_class",
- FT_UINT8, BASE_DEC, VALS(m3ua_message_class_values), 0x0,
- "", HFILL }
- },
- { &hf_m3ua_message_type,
- { "Message Type", "m3ua.message_type",
- FT_UINT8, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_message_length,
- { "Message length", "m3ua.message_length",
- FT_UINT32, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_parameter_tag,
- { "Parameter Tag", "m3ua.parameter_tag",
- FT_UINT16, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_parameter_length,
- { "Parameter length", "m3ua.parameter_length",
- FT_UINT16, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_parameter_value,
- { "Parameter value", "m3ua.parameter_value",
- FT_BYTES, BASE_NONE, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_parameter_padding,
- { "Padding", "m3ua.parameter_padding",
- FT_BYTES, BASE_NONE, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_info_string,
- { "Info string", "m3ua.info_string",
- FT_STRING, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_routing_context,
- { "Routing context", "m3ua.routing_context",
- FT_UINT32, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_diagnostic_information,
- { "Diagnostic information", "m3ua.diagnostic_information",
- FT_BYTES, BASE_NONE, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_heartbeat_data,
- { "Heartbeat data", "m3ua.heartbeat_data",
- FT_BYTES, BASE_NONE, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_error_code,
- { "Error code", "m3ua.error_code",
- FT_UINT32, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_status_type,
- { "Status type", "m3ua.status_type",
- FT_UINT16, BASE_DEC, VALS(m3ua_status_type_values), 0x0,
- "", HFILL }
- },
- { &hf_m3ua_status_info,
- { "Status info", "m3ua.status_info",
- FT_UINT16, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_asp_identifier,
- { "ASP identifier", "m3ua.asp_identifier",
- FT_UINT32, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_affected_point_code_mask,
- { "Mask", "m3ua.affected_point_code_mask",
- FT_UINT8, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_affected_point_code_pc,
- { "Affected point code", "m3ua.affected_point_code_pc",
- FT_UINT24, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_network_appearance,
- { "Network appearance", "m3ua.network_appearance",
- FT_UINT32, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_unavailability_cause,
- { "Unavailability cause", "m3ua.unavailability_cause",
- FT_UINT16, BASE_DEC, VALS(m3ua_unavailability_cause_values), 0x0,
- "", HFILL }
- },
- { &hf_m3ua_user_identity,
- { "User Identity", "m3ua.user_identity",
- FT_UINT16, BASE_DEC, VALS(m3ua_user_identity_values), 0x0,
- "", HFILL }
- },
- { &hf_m3ua_congestion_reserved,
- { "Reserved", "m3ua.congestion_reserved",
- FT_BYTES, BASE_NONE, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_congestion_level,
- { "Congestion level", "m3ua.congestion_level",
- FT_UINT8, BASE_DEC, VALS(m3ua_congestion_level_values), 0x0,
- "", HFILL }
- },
- { &hf_m3ua_concerned_dest_reserved,
- { "Reserved", "m3ua.concerned_reserved",
- FT_BYTES, BASE_NONE, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_concerned_dest_pc,
- { "Concerned DPC", "m3ua.concerned_dpc",
- FT_UINT24, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_dpc_mask,
- { "Mask", "m3ua.dpc_mask",
- FT_UINT8, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_dpc_pc,
- { "Destination point code", "m3ua.dpc_pc",
- FT_UINT24, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_si,
- { "Service indicator", "m3ua_si",
- FT_UINT8, BASE_DEC, VALS(m3ua_user_identity_values), 0x0,
- "", HFILL }
- },
- { &hf_m3ua_ssn,
- { "Subsystem number", "m3ua_ssn",
- FT_UINT8, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_opc_list_mask,
- { "Mask", "m3ua.opc_list_mask",
- FT_UINT8, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_opc_list_pc,
- { "Originating point code", "m3ua.opc_list_pc",
- FT_UINT24, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_cic_range_mask,
- { "Mask", "m3ua.cic_range_mask",
- FT_UINT8, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_cic_range_pc,
- { "Originating point code", "m3ua.cic_range_pc",
- FT_UINT24, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_cic_range_lower,
- { "Lower CIC value", "m3ua.cic_range_lower",
- FT_UINT16, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_cic_range_upper,
- { "Upper CIC value", "m3ua.cic_range_upper",
- FT_UINT16, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_local_rk_identifier,
- { "Local routing key identifier", "m3ua.local_rk_identifier",
- FT_UINT32, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_li,
- { "Length indicator", "m3ua.protocol_data_2_li",
- FT_UINT8, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_protocol_data_opc,
- { "OPC", "m3ua.protocol_data_opc",
- FT_UINT32, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_protocol_data_dpc,
- { "DPC", "m3ua.protocol_data_dpc",
- FT_UINT32, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_protocol_data_si,
- { "SI", "m3ua.protocol_data_si",
- FT_UINT8, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_protocol_data_ni,
- { "NI", "m3ua.protocol_data_ni",
- FT_UINT8, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_protocol_data_mp,
- { "MP", "m3ua.protocol_data_mp",
- FT_UINT8, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_protocol_data_sls,
- { "SLS", "m3ua.protocol_data_sls",
- FT_UINT8, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_correlation_identifier,
- { "Correlation Identifier", "m3ua.correlation_identifier",
- FT_UINT32, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_registration_status,
- { "Registration status", "m3ua.registration_status",
- FT_UINT32, BASE_DEC, VALS(m3ua_registration_status_values), 0x0,
- "", HFILL }
- },
- { &hf_m3ua_deregistration_status,
- { "Deregistration status", "m3ua.deregistration_status",
- FT_UINT32, BASE_DEC, VALS(m3ua_deregistration_status_values), 0x0,
- "", HFILL }
- },
- { &hf_m3ua_reason,
- { "Reason", "m3ua_reason",
- FT_UINT32, BASE_DEC, VALS(m3ua_reason_values), 0x0,
- "", HFILL }
- },
- { &hf_m3ua_traffic_mode_type,
- { "Traffic mode Type", "m3ua.traffic_mode_type",
- FT_UINT32, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_registration_result_identifier,
- { "Local RK-identifier value", "m3ua.registration_result_identifier",
- FT_UINT32, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_registration_result_status,
- { "Registration status", "m3ua.registration_results_status",
- FT_UINT32, BASE_DEC, VALS(m3ua_registration_result_status_values), 0x0,
- "", HFILL }
- },
- { &hf_m3ua_registration_result_context,
- { "Routing context", "m3ua.registration_result_routing_context",
- FT_UINT32, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
- { &hf_m3ua_deregistration_result_status,
- { "De-Registration status", "m3ua.deregistration_results_status",
- FT_UINT32, BASE_DEC, VALS(m3ua_deregistration_result_status_values), 0x0,
- "", HFILL }
- },
- { &hf_m3ua_deregistration_result_context,
- { "Routing context", "m3ua.deregistration_result_routing_context",
- FT_UINT32, BASE_DEC, NULL, 0x0,
- "", HFILL }
- },
+ { &hf_version, { "Version", "m3ua.version", FT_UINT8, BASE_DEC, VALS(protocol_version_values), 0x0, "", HFILL } },
+ { &hf_reserved, { "Reserved", "m3ua.reserved", FT_UINT8, BASE_HEX, NULL, 0x0, "", HFILL } },
+ { &hf_v5_message_class, { "Message class", "m3ua.message_class", FT_UINT8, BASE_DEC, VALS(v5_message_class_values), 0x0, "", HFILL } },
+ { &hf_message_class, { "Message class", "m3ua.message_class", FT_UINT8, BASE_DEC, VALS(message_class_values), 0x0, "", HFILL } },
+ { &hf_message_type, { "Message Type", "m3ua.message_type", FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_message_length, { "Message length", "m3ua.message_length", FT_UINT32, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_v5_parameter_tag, { "Parameter Tag", "m3ua.parameter_tag", FT_UINT16, BASE_DEC, VALS(v5_parameter_tag_values), 0x0, "", HFILL } },
+ { &hf_v6_parameter_tag, { "Parameter Tag", "m3ua.parameter_tag", FT_UINT16, BASE_DEC, VALS(v6_parameter_tag_values), 0x0, "", HFILL } },
+ { &hf_parameter_tag, { "Parameter Tag", "m3ua.parameter_tag", FT_UINT16, BASE_DEC, VALS(parameter_tag_values), 0x0, "", HFILL } },
+ { &hf_parameter_length, { "Parameter length", "m3ua.parameter_length", FT_UINT16, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_parameter_value, { "Parameter value", "m3ua.parameter_value", FT_BYTES, BASE_NONE, NULL, 0x0, "", HFILL } },
+ { &hf_parameter_padding, { "Padding", "m3ua.parameter_padding", FT_BYTES, BASE_NONE, NULL, 0x0, "", HFILL } },
+ { &hf_parameter_trailer, { "Trailer", "m3ua.paramter_trailer", FT_BYTES, BASE_NONE, NULL, 0x0, "", HFILL } },
+ { &hf_network_appearance, { "Network appearance", "m3ua.network_appearance", FT_UINT32, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_info_string, { "Info string", "m3ua.info_string", FT_STRING, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_routing_context, { "Routing context", "m3ua.routing_context", FT_UINT32, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_diagnostic_information, { "Diagnostic information", "m3ua.diagnostic_information", FT_BYTES, BASE_NONE, NULL, 0x0, "", HFILL } },
+ { &hf_heartbeat_data, { "Heartbeat data", "m3ua.heartbeat_data", FT_BYTES, BASE_NONE, NULL, 0x0, "", HFILL } },
+ { &hf_v5_error_code, { "Error code", "m3ua.error_code", FT_UINT32, BASE_DEC, VALS(v5_error_code_values), 0x0, "", HFILL } },
+ { &hf_v6_error_code, { "Error code", "m3ua.error_code", FT_UINT32, BASE_DEC, VALS(v6_error_code_values), 0x0, "", HFILL } },
+ { &hf_error_code, { "Error code", "m3ua.error_code", FT_UINT32, BASE_DEC, VALS(error_code_values), 0x0, "", HFILL } },
+ { &hf_status_type, { "Status type", "m3ua.status_type", FT_UINT16, BASE_DEC, VALS(status_type_values), 0x0, "", HFILL } },
+ { &hf_status_info, { "Status info", "m3ua.status_info", FT_UINT16, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_asp_identifier, { "ASP identifier", "m3ua.asp_identifier", FT_UINT32, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_affected_point_code_mask, { "Mask", "m3ua.affected_point_code_mask", FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_affected_point_code_pc, { "Affected point code", "m3ua.affected_point_code_pc", FT_UINT24, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_cause, { "Unavailability cause", "m3ua.unavailability_cause", FT_UINT16, BASE_DEC, VALS(unavailability_cause_values), 0x0, "", HFILL } },
+ { &hf_user, { "User Identity", "m3ua.user_identity", FT_UINT16, BASE_DEC, VALS(user_identity_values), 0x0, "", HFILL } },
+ { &hf_reason, { "Reason", "m3ua.reason", FT_UINT32, BASE_DEC, VALS(reason_values), 0x0, "", HFILL } },
+ { &hf_v5_traffic_mode_type, { "Traffic mode Type", "m3ua.traffic_mode_type", FT_UINT32, BASE_DEC, VALS(v5_traffic_mode_type_values), 0x0, "", HFILL } },
+ { &hf_v6_traffic_mode_type, { "Traffic mode Type", "m3ua.traffic_mode_type", FT_UINT32, BASE_DEC, VALS(v6_traffic_mode_type_values), 0x0, "", HFILL } },
+ { &hf_traffic_mode_type, { "Traffic mode Type", "m3ua.traffic_mode_type", FT_UINT32, BASE_DEC, VALS(traffic_mode_type_values), 0x0, "", HFILL } },
+ { &hf_congestion_reserved, { "Reserved", "m3ua.congestion_reserved", FT_BYTES, BASE_NONE, NULL, 0x0, "", HFILL } },
+ { &hf_congestion_level, { "Congestion level", "m3ua.congestion_level", FT_UINT8, BASE_DEC, VALS(congestion_level_values), 0x0, "", HFILL } },
+ { &hf_concerned_dest_reserved, { "Reserved", "m3ua.concerned_reserved", FT_BYTES, BASE_NONE, NULL, 0x0, "", HFILL } },
+ { &hf_concerned_dest_pc, { "Concerned DPC", "m3ua.concerned_dpc", FT_UINT24, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_local_rk_identifier, { "Local routing key identifier", "m3ua.local_rk_identifier", FT_UINT32, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_dpc_mask, { "Mask", "m3ua.dpc_mask", FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_dpc_pc, { "Destination point code", "m3ua.dpc_pc", FT_UINT24, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_si, { "Service indicator", "m3ua.si", FT_UINT8, BASE_DEC, VALS(user_identity_values), 0x0, "", HFILL } },
+ { &hf_ssn, { "Subsystem number", "m3ua.ssn", FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_opc_list_mask, { "Mask", "m3ua.opc_list_mask", FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_opc_list_pc, { "Originating point code", "m3ua.opc_list_pc", FT_UINT24, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_cic_range_mask, { "Mask", "m3ua.cic_range_mask", FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_cic_range_pc, { "Originating point code", "m3ua.cic_range_pc", FT_UINT24, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_cic_range_lower, { "Lower CIC value", "m3ua.cic_range_lower", FT_UINT16, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_cic_range_upper, { "Upper CIC value", "m3ua.cic_range_upper", FT_UINT16, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_li, { "Length indicator", "m3ua.protocol_data_2_li", FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_protocol_data_opc, { "OPC", "m3ua.protocol_data_opc", FT_UINT32, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_protocol_data_dpc, { "DPC", "m3ua.protocol_data_dpc", FT_UINT32, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_protocol_data_si, { "SI", "m3ua.protocol_data_si", FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_protocol_data_ni, { "NI", "m3ua.protocol_data_ni", FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_protocol_data_mp, { "MP", "m3ua.protocol_data_mp", FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_protocol_data_sls, { "SLS", "m3ua.protocol_data_sls", FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_correlation_identifier, { "Correlation Identifier", "m3ua.correlation_identifier", FT_UINT32, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_registration_status, { "Registration status", "m3ua.registration_status", FT_UINT32, BASE_DEC, VALS(registration_status_values), 0x0, "", HFILL } },
+ { &hf_deregistration_status, { "Deregistration status", "m3ua.deregistration_status", FT_UINT32, BASE_DEC, VALS(deregistration_status_values), 0x0, "", HFILL } },
+ { &hf_traffic_mode_type, { "Traffic mode Type", "m3ua.traffic_mode_type", FT_UINT32, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_registration_result_identifier, { "Local RK-identifier value", "m3ua.registration_result_identifier", FT_UINT32, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_registration_result_status, { "Registration status", "m3ua.registration_results_status", FT_UINT32, BASE_DEC, VALS(registration_result_status_values), 0x0, "", HFILL } },
+ { &hf_registration_result_context, { "Routing context", "m3ua.registration_result_routing_context", FT_UINT32, BASE_DEC, NULL, 0x0, "", HFILL } },
+ { &hf_v6_deregistration_result_status, { "De-Registration status", "m3ua.deregistration_results_status", FT_UINT32, BASE_DEC, VALS(v6_deregistration_result_status_values), 0x0, "", HFILL } },
+ { &hf_v6_deregistration_result_context, { "Routing context", "m3ua.deregistration_result_routing_context", FT_UINT32, BASE_DEC, NULL, 0x0, "", HFILL } },
};
/* Setup protocol subtree array */
static gint *ett[] = {
&ett_m3ua,
- &ett_m3ua_parameter,
+ &ett_parameter,
};
- static enum_val_t m3ua_options[] = {
- { "Internet Draft version 6", M3UA_V6 },
- { "Internet Draft version 12", M3UA_V12 },
+ static enum_val_t options[] = {
+ { "Internet Draft version 5", M3UA_V5 },
+ { "Internet Draft version 6", M3UA_V6 },
+ { "RFC 3332", M3UA_RFC },
{ NULL, 0 }
};
/* Register the protocol name and description */
proto_m3ua = proto_register_protocol("MTP 3 User Adaptation Layer", "M3UA", "m3ua");
m3ua_module = prefs_register_protocol(proto_m3ua, NULL);
- prefs_register_enum_preference(m3ua_module,
- "version", "M3UA Version", "Internet Draft version used by Ethereal",
- &m3ua_version, m3ua_options, FALSE);
+ prefs_register_enum_preference(m3ua_module, "version", "M3UA Version", "Version used by Ethereal", (gint *)&version, options, FALSE);
/* Required function calls to register the header fields and subtrees used */
proto_register_field_array(proto_m3ua, hf, array_length(hf));
proto_register_subtree_array(ett, array_length(ett));
- m3ua_si_dissector_table = register_dissector_table("m3ua.protocol_data_si", "MTP3 Service indicator", FT_UINT8, BASE_HEX);
+ si_dissector_table = register_dissector_table("m3ua.protocol_data_si", "MTP3 Service indicator", FT_UINT8, BASE_HEX);
};