aboutsummaryrefslogtreecommitdiffstats
path: root/epan/dissectors/packet-cisco-sm.c
diff options
context:
space:
mode:
authorPascal Quantin <pascal.quantin@gmail.com>2012-12-13 09:59:20 +0000
committerPascal Quantin <pascal.quantin@gmail.com>2012-12-13 09:59:20 +0000
commit548313e65673ba1eb58c0124887ef7e30cff490d (patch)
tree4161d187dfef4055e35a0813c485376261ba107c /epan/dissectors/packet-cisco-sm.c
parent252c23c744eda814573f54134818887a36e72ca3 (diff)
From Ojab via https://bugs.wireshark.org/bugzilla/show_bug.cgi?id=8082 :
cisco-sm dissector enhancement svn path=/trunk/; revision=46525
Diffstat (limited to 'epan/dissectors/packet-cisco-sm.c')
-rw-r--r--epan/dissectors/packet-cisco-sm.c293
1 files changed, 261 insertions, 32 deletions
diff --git a/epan/dissectors/packet-cisco-sm.c b/epan/dissectors/packet-cisco-sm.c
index 1e4671a781..5cfc0d8ec5 100644
--- a/epan/dissectors/packet-cisco-sm.c
+++ b/epan/dissectors/packet-cisco-sm.c
@@ -25,18 +25,16 @@
/*
* This is basically a glue dissector for the Cisco SM protocol. It sits
- * between the RUDP and MTP3 layers in conversations on port 7000 between
- * SLTs and MGCs. A link to an overview of the technology :
+ * between the RUDP and MTP3 layers between SLTs and MGCs.
*
+ * A link to an overview of the technology :
* http://www.cisco.com/en/US/products/sw/netmgtsw/ps4883/products_installation_and_configuration_guide_chapter09186a008010950a.html
- *
* Link showing debugs of the protocol:
* http://www.cisco.com/univercd/cc/td/doc/product/access/sc/rel7/omts/omts_apb.htm#30052
- *
- * I'm unable to get local debugs of this protocol, as the SLT's are
- * slow cpu cisco 2600's, and they tend to drop the signalling links
- * if you turn any debugging on! But there's not much interesting
- * here, its just glue to get the ISUP/MTP3 data nicely.
+ * Scroll down to Backhaul Debug Event/Cause/Reason Codes:
+ * http://www.cisco.com/en/US/docs/ios-xml/ios/debug/command/s1/db-s2.html#GUID-83B6671D-B86F-4B41-819C-85D14F4AACAE
+ * Free/Opensource implementation:
+ * http://yate.null.ro/websvn/filedetails.php?repname=yate&path=%2Ftrunk%2Fmodules%2Fserver%2Fciscosm.cpp
*/
#include "config.h"
@@ -69,37 +67,160 @@ static const value_string sm_message_type_value[] = {
{ MESSAGE_TYPE_Q_RESET_INVOKE, "Q_RESET Invoke Message" },
{ MESSAGE_TYPE_Q_RESET_RESPONSE, "Q_RESET Response Message" },
{ MESSAGE_TYPE_PDU, "PDU Message" },
- { 0, NULL }
+ { 0, NULL }
};
static const value_string sm_message_type_value_info[] = {
- { MESSAGE_TYPE_START, "Start" },
- { MESSAGE_TYPE_STOP, "Stop" },
- { MESSAGE_TYPE_ACTIVE, "Active" },
- { MESSAGE_TYPE_STANDBY, "Standby" },
- { MESSAGE_TYPE_Q_HOLD_INVOKE, "Q_HOLD Invoke" },
- { MESSAGE_TYPE_Q_HOLD_RESPONSE, "Q_HOLD Response" },
- { MESSAGE_TYPE_Q_RESUME_INVOKE, "Q_RESUME Invoke" },
- { MESSAGE_TYPE_Q_RESUME_RESPONSE, "Q_RESUME Response" },
- { MESSAGE_TYPE_Q_RESET_INVOKE, "Q_RESET Invoke" },
- { MESSAGE_TYPE_Q_RESET_RESPONSE, "Q_RESET Response" },
- { MESSAGE_TYPE_PDU, "PDU" },
- { 0, NULL }
+ { MESSAGE_TYPE_START, "Start" },
+ { MESSAGE_TYPE_STOP, "Stop" },
+ { MESSAGE_TYPE_ACTIVE, "Active" },
+ { MESSAGE_TYPE_STANDBY, "Standby" },
+ { MESSAGE_TYPE_Q_HOLD_INVOKE, "Q_HOLD Invoke" },
+ { MESSAGE_TYPE_Q_HOLD_RESPONSE, "Q_HOLD Response" },
+ { MESSAGE_TYPE_Q_RESUME_INVOKE, "Q_RESUME Invoke" },
+ { MESSAGE_TYPE_Q_RESUME_RESPONSE, "Q_RESUME Response" },
+ { MESSAGE_TYPE_Q_RESET_INVOKE, "Q_RESET Invoke" },
+ { MESSAGE_TYPE_Q_RESET_RESPONSE, "Q_RESET Response" },
+ { MESSAGE_TYPE_PDU, "PDU" },
+ { 0, NULL }
+};
+
+static const value_string sm_alignment_type[] = {
+ { 0x00, "Unknown (probably linkset was already up)"},
+ { 0x03, "Emergency alignment"},
+ { 0x04, "Normal alignment"},
+ { 0x05, "Power On MTP2"},
+ { 0x06, "Start MTP2"},
+ { 0, NULL}
+};
+
+static const value_string sm_backhaul_reason_code[] = {
+ { 0x00, "Layer management request"},
+ { 0x01, "SUERM (Signal Unit Error Monitor) failure"},
+ { 0x02, "Excessively long alignment period"},
+ { 0x03, "T7 timer expired"},
+ { 0x04, "Physical interface failure"},
+ { 0x05, "Two or three invalid BSNs"},
+ { 0x06, "Two or three invalid FIBs"},
+ { 0x07, "LSSU (Link Status Signal Unit) condition"},
+ { 0x13, "SIOs (Service Information Octets) received "
+ "in Link State Control (LSC)"},
+ { 0x14, "Timer T2 expired waiting for SIO"},
+ { 0x15, "Timer T3 expired waiting for SIE/SIN "},
+ { 0x16, "SIO received in initial alignment control (IAC)"},
+ { 0x17, "Proving period failure"},
+ { 0x18, "Timer T1 expired waiting for FISU (Fill-In Signal Unit)"},
+ { 0x19, "SIN received in the in-service state"},
+ { 0x20, "CTS lost"},
+ { 0x25, "No resources"},
+ { 0, NULL}
+};
+
+static const value_string sm_backhaul_event_code[] = {
+ { 0x00, "Local processor outage"},
+ { 0x01, "Local processor outage recovered"},
+ { 0x02, "Entered a congested state"},
+ { 0x03, "Exited a congested state"},
+ { 0x04, "Physical layer up"},
+ { 0x05, "Physical layer down"},
+ { 0x06, "Protocol error"},
+ { 0x07, "Link is aligned"},
+ { 0x08, "Link alignment lost"},
+ { 0x09, "Retransmit buffer full"},
+ { 0x0a, "Retransmit buffer no longer full"},
+ { 0x0b, "Negative acknowledgment"},
+ { 0x0c, "Remote entered congestion"},
+ { 0x0d, "Remote exited congestion"},
+ { 0x0e, "Remote entered processor outage"},
+ { 0x0f, "Remote exited processor outage"},
+ { 0, NULL}
+};
+
+static const value_string sm_backhaul_cause_code[] = {
+ { 0x00, "Unknown (default)"},
+ { 0x01, "Management initiated"},
+ { 0x02, "Abnormal BSN (backward sequence number)"},
+ { 0x03, "Abnormal FIB (Forward Indicator Bit)"},
+ { 0x04, "Congestion discard"},
+ { 0, NULL}
+};
+
+static const value_string sm_linkdown_cause_code[] = {
+ { 0x00, "Unknown (default)"},
+ { 0x01, "Management initiated"},
+ { 0x03, "Congestion ended"},
+ { 0, NULL}
+};
+
+static const value_string sm_retrieval_type[] = {
+ { 0x01, "Request for BSN"},
+ { 0x02, "Request for MSUs"},
+ { 0x03, "Request to drop MSUs"},
+ { 0, NULL}
};
+static const value_string sm_lsc_state_type[] = {
+ { 0x00, "Set LPO"},
+ { 0x01, "Clear LPO"},
+ { 0x02, "Set Emergency"},
+ { 0x03, "Clear Emergency"},
+ { 0x04, "Clear Buffers"},
+ { 0x05, "Clear Transmit Buffer"},
+ { 0x06, "Clear ReTransmission Buffer"},
+ { 0x07, "Clear Receive Buffer"},
+ { 0x08, "Continue"},
+ { 0x09, "Power On"},
+ { 0x0a, "Start"},
+ { 0x0b, "Stop"},
+ { 0, NULL}
+};
+
+static const value_string sm_stat_request_type[] = {
+ { 0x00, "Reset"},
+ { 0x01, "Send & Reset"},
+ { 0x02, "Send"},
+ { 0, NULL}
+};
+#define PDU_CONNECT_REQUEST 0x06
+#define PDU_CONNECT_CONFIRM 0x07
+#define PDU_DISCONNECT_CONFIRM 0x0b
+#define PDU_DISCONNECT_INDICATION 0x0c
#define PDU_MTP3_TO_SLT 0x10
#define PDU_MTP3_FROM_SLT 0x11
-
-#define PDU_SET_STATE 0x44
-#define PDU_RETURN_STATE 0x45
+#define PDU_RETRIEVAL_REQUEST 0x12
+#define PDU_RETRIEVAL_CONFIRM 0x13
+#define PDU_LSC_REQUEST 0x20
+#define PDU_LSC_CONFIRM 0x21
+#define PDU_LSC_INDICATION 0x22
+#define PDU_STAT_REQUEST 0x44
static const value_string sm_pdu_type_value[] = {
- { PDU_MTP3_TO_SLT, "mtp3 to SLT"},
- { PDU_MTP3_FROM_SLT, "mtp3 from SLT"},
- { PDU_SET_STATE, "set session state"},
- { PDU_RETURN_STATE, "return session state"},
- { 0, NULL }
+ { PDU_CONNECT_REQUEST, "Connect Request"},
+ { PDU_CONNECT_CONFIRM, "Connect Confirm"},
+ { 0x0a, "Disconnect Request"},
+ { PDU_DISCONNECT_CONFIRM, "Disconnect Confirm"},
+ { PDU_DISCONNECT_INDICATION, "Disconnect Indication Message"},
+ { PDU_MTP3_TO_SLT, "MSU Request (message to MTP2 link)"},
+ { PDU_MTP3_FROM_SLT, "MSU Indication (message from MTP2 link)"},
+ { PDU_RETRIEVAL_REQUEST, "Retrieval Request"},
+ { PDU_RETRIEVAL_CONFIRM, "Retrieval Confirm"},
+ { 0x14, "Retrieval Indication"},
+ { 0x15, "Retrieval Message"},
+ { PDU_LSC_REQUEST, "Link State Controller Request"},
+ { PDU_LSC_CONFIRM, "Link State Controller Confirm"},
+ { PDU_LSC_INDICATION, "Link State Controller Indication"},
+ { 0x40, "Configuration Request"},
+ { 0x41, "Configuration Confirm"},
+ { 0x42, "Status Request"},
+ { 0x43, "Status Confirm"},
+ { PDU_STAT_REQUEST, "Statistic Request"},
+ { 0x45, "Statistic Confirm"},
+ { 0x46, "Control Request"},
+ { 0x47, "Control Confirm"},
+ { 0x50, "Flow Control Request"},
+ { 0x51, "Flow Control Indication"},
+ { 0, NULL }
};
/* TODO: Change to useful name once known */
@@ -125,6 +246,15 @@ static int hf_sm_ip_addr = -1;
static int hf_sm_context = -1;
static int hf_sm_eisup_msg_id = -1;
static int hf_sm_tag = -1;
+static int hf_sm_alignment_type = -1;
+static int hf_sm_backhaul_reason_code = -1;
+static int hf_sm_backhaul_event_code = -1;
+static int hf_sm_backhaul_cause_code = -1;
+static int hf_sm_linkdown_cause_code = -1;
+static int hf_sm_retrieval_type = -1;
+static int hf_sm_lsc_state_type = -1;
+static int hf_sm_stat_request_type = -1;
+static int hf_sm_bsn_num = -1;
/* Initialize the subtree pointers */
static gint ett_sm = -1;
@@ -142,6 +272,8 @@ dissect_sm(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
proto_tree *sm_tree;
tvbuff_t *next_tvb = NULL;
guint32 sm_message_type;
+ guint32 bsn_num = 0;
+ guint32 bh_event_code = 0;
guint16 protocol;
guint16 msg_type = 0;
guint16 length;
@@ -308,15 +440,53 @@ dissect_sm(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
if (length > 0) {
next_tvb = tvb_new_subset(tvb, offset, length, length);
- if ((msg_type == PDU_MTP3_TO_SLT || msg_type == PDU_MTP3_FROM_SLT)) {
+ switch (msg_type) {
+ case PDU_MTP3_TO_SLT:
+ case PDU_MTP3_FROM_SLT:
call_dissector(mtp3_handle, next_tvb, pinfo, tree);
- } else {
+ break;
+ case PDU_CONNECT_REQUEST:
+ case PDU_CONNECT_CONFIRM:
+ proto_tree_add_item(sm_tree, hf_sm_alignment_type, tvb, offset, 4, ENC_BIG_ENDIAN);
+ break;
+ case PDU_DISCONNECT_CONFIRM:
+ case PDU_DISCONNECT_INDICATION:
+ proto_tree_add_item(sm_tree, hf_sm_backhaul_reason_code, tvb, offset, 4, ENC_BIG_ENDIAN);
+ break;
+ case PDU_RETRIEVAL_REQUEST:
+ case PDU_RETRIEVAL_CONFIRM:
+ proto_tree_add_item(sm_tree, hf_sm_retrieval_type, tvb, offset, 4, ENC_BIG_ENDIAN);
+ if (msg_type == PDU_RETRIEVAL_CONFIRM && tvb_get_ntohl(tvb,offset) == 0x01) {
+ offset += 4;
+ bsn_num = tvb_get_ntohl(tvb,offset);
+ proto_tree_add_uint_format(sm_tree, hf_sm_bsn_num, tvb, offset, 4,
+ bsn_num, "BSN: %d", bsn_num);
+ }
+ break;
+ case PDU_LSC_REQUEST:
+ case PDU_LSC_CONFIRM:
+ proto_tree_add_item(sm_tree, hf_sm_lsc_state_type, tvb, offset, 4, ENC_BIG_ENDIAN);
+ break;
+ case PDU_LSC_INDICATION:
+ proto_tree_add_item(sm_tree, hf_sm_backhaul_event_code, tvb, offset, 4, ENC_BIG_ENDIAN);
+ bh_event_code = tvb_get_ntohl(tvb,offset);
+ if (bh_event_code == 0x02 || bh_event_code == 0x04) {
+ offset += 4;
+ proto_tree_add_item(sm_tree, hf_sm_linkdown_cause_code, tvb, offset, 4, ENC_BIG_ENDIAN);
+ } else if (bh_event_code == 0x06) {
+ offset += 4;
+ proto_tree_add_item(sm_tree, hf_sm_backhaul_cause_code, tvb, offset, 4, ENC_BIG_ENDIAN);
+ }
+ break;
+ case PDU_STAT_REQUEST:
+ proto_tree_add_item(sm_tree, hf_sm_stat_request_type, tvb, offset, 4, ENC_BIG_ENDIAN);
+ break;
+ default:
call_dissector(data_handle, next_tvb, pinfo, tree);
}
}
}
}
-
}
void
@@ -378,6 +548,53 @@ proto_register_sm(void)
FT_UINT16, BASE_DEC, NULL, 0x0,
"Tag(guesswork!)", HFILL }
},
+ { &hf_sm_alignment_type,
+ { "Alignment type","sm.connect_type",
+ FT_UINT32, BASE_HEX, VALS(sm_alignment_type), 0x0,
+ NULL, HFILL }
+ },
+ { &hf_sm_backhaul_reason_code,
+ { "Backhaul reason code","sm.backhaul_reason",
+ FT_UINT32, BASE_HEX, VALS(sm_backhaul_reason_code), 0x0,
+ NULL, HFILL }
+ },
+ { &hf_sm_backhaul_event_code,
+ { "Backhaul event code","sm.backhaul_event",
+ FT_UINT32, BASE_HEX, VALS(sm_backhaul_event_code), 0x0,
+ NULL, HFILL }
+ },
+ { &hf_sm_backhaul_cause_code,
+ { "Backhaul cause code","sm.backhaul_cause",
+ FT_UINT32, BASE_HEX, VALS(sm_backhaul_cause_code), 0x0,
+ NULL, HFILL }
+ },
+ { &hf_sm_linkdown_cause_code,
+ { "Link down cause","sm.linkdown_reason",
+ FT_UINT32, BASE_HEX, VALS(sm_linkdown_cause_code), 0x0,
+ NULL, HFILL }
+ },
+
+ { &hf_sm_retrieval_type,
+ { "Retrieval type","sm.retrieval_type",
+ FT_UINT32, BASE_HEX, VALS(sm_retrieval_type), 0x0,
+ NULL, HFILL }
+ },
+ { &hf_sm_lsc_state_type,
+ { "LSC Request type","sm.lsc_state_type",
+ FT_UINT32, BASE_HEX, VALS(sm_lsc_state_type), 0x0,
+ NULL, HFILL }
+ },
+ { &hf_sm_stat_request_type,
+ { "Statistic request type","sm.stat_request_type",
+ FT_UINT32, BASE_HEX, VALS(sm_stat_request_type), 0x0,
+ NULL, HFILL }
+ },
+ { &hf_sm_bsn_num,
+ { "BSN Number","sm.bsn_num",
+ FT_UINT32, BASE_HEX, NULL, 0x0,
+ NULL, HFILL }
+ },
+
};
/* Setup protocol subtree array */
@@ -405,3 +622,15 @@ proto_reg_handoff_sm(void)
data_handle = find_dissector("data");
}
+/*
+ * Editor modelines - http://www.wireshark.org/tools/modelines.html
+ *
+ * Local variables:
+ * c-basic-offset: 4
+ * tab-width: 4
+ * indent-tabs-mode: t
+ * End:
+ *
+ * vi: set shiftwidth=4 tabstop=8 expandtab:
+ * :indentSize=4:tabSize=8:noTabs=false:
+ */