summaryrefslogtreecommitdiffstats
path: root/epan/dissectors/packet-ndp.c
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-10 20:34:10 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-10 20:34:10 +0000
commite4ba6dbc3f1e76890b22773807ea37fe8fa2b1bc (patch)
tree68cb5ef9081156392f1dd62a00c6ccc1451b93df /epan/dissectors/packet-ndp.c
parentInitial commit. (diff)
downloadwireshark-e4ba6dbc3f1e76890b22773807ea37fe8fa2b1bc.tar.xz
wireshark-e4ba6dbc3f1e76890b22773807ea37fe8fa2b1bc.zip
Adding upstream version 4.2.2.upstream/4.2.2
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'epan/dissectors/packet-ndp.c')
-rw-r--r--epan/dissectors/packet-ndp.c380
1 files changed, 380 insertions, 0 deletions
diff --git a/epan/dissectors/packet-ndp.c b/epan/dissectors/packet-ndp.c
new file mode 100644
index 00000000..dff04c41
--- /dev/null
+++ b/epan/dissectors/packet-ndp.c
@@ -0,0 +1,380 @@
+/* packet-ndp.c
+ * Routines for the disassembly of the Nortel Discovery Protocol, formerly
+ * the SynOptics Network Management Protocol (SONMP).
+ * (c) Copyright Giles Scott <giles.scott1 [AT] arubanetworks.com>
+ *
+ * Wireshark - Network traffic analyzer
+ * By Gerald Combs <gerald@wireshark.org>
+ * Copyright 1998 Gerald Combs
+ *
+ * SPDX-License-Identifier: GPL-2.0-or-later
+ *
+ * This protocol has gone by many names over the years:
+ *
+ * Bay Discovery Protocol (BDP), Bay Topology Protocol, Bay Network Management
+ * Protocol (BNMP), Nortel Management MIB (NMM), Nortel Topology Discovery
+ * Protocol (NTDP), SynOptics Network Management Protocol (SONMP).
+ * (source: Wikipedia article on "Nortel Discovery Protocol")
+ *
+ */
+
+#include "config.h"
+
+#include <epan/packet.h>
+
+void proto_register_ndp(void);
+void proto_reg_handoff_ndp(void);
+
+/* Although this protocol is proprietary it is documented in the SynOptics MIB's
+ * So I'm not giving anything away :-)
+ * The only thing I have not done is decode the segment identifier;
+ * This changes so much depending on whether the chassis supports
+ * multi-segment autotopology. As the 5000 is now EOL don't see much point.
+ *
+ * MIB's s5emt104.mib, s5tcs112.mib, synro199.mib these should be available via
+ * http://www.nortelnetworks.com
+ */
+
+
+/* chassis types */
+/* Last updated from version 229 ("200609010000Z") of SnpxChassisType in SYNOPTICS-ROOT-MIB.mib */
+static const value_string ndp_chassis_val[] =
+{
+ { 1, "other"},
+ { 2, "3000"},
+ { 3, "3030"},
+ { 4, "2310"},
+ { 5, "2810"},
+ { 6, "2912"},
+ { 7, "2914"},
+ { 8, "271x"},
+ { 9, "2813"},
+ { 10, "2814"},
+ { 11, "2915"},
+ { 12, "5000"},
+ { 13, "2813SA"},
+ { 14, "2814SA"},
+ { 15, "810M"},
+ { 16, "Ethercell"},
+ { 17, "5005"},
+ { 18, "Alcatel Ethernet workgroup conc."},
+
+ { 20, "2715SA"},
+ { 21, "2486"},
+ { 22, "28000 series"},
+ { 23, "23000 series"},
+ { 24, "5DN00x series"},
+ { 25, "BayStack Ethernet"},
+ { 26, "23100 series"},
+ { 27, "100Base-T Hub"},
+ { 28, "3000 Fast Ethernet"},
+ { 29, "Orion switch"},
+ /* 30 is "not used" */
+ { 31, "DDS"},
+ { 32, "Centillion (6 slot)"},
+ { 33, "Centillion (12 slot)"},
+ { 34, "Centillion (1 slot)"},
+ { 35, "BayStack 301"},
+ { 36, "BayStack TokenRing Hub"},
+ { 37, "FVC Multimedia Switch"},
+ { 38, "Switch Node"},
+ { 39, "BayStack 302 Switch"},
+ { 40, "BayStack 350 Switch"},
+ { 41, "BayStack 150 Ethernet Hub"},
+ { 42, "Centillion 50N switch"},
+ { 43, "Centillion 50T switch"},
+ { 44, "BayStack 303 and 304 Switches"},
+ { 45, "BayStack 200 Ethernet Hub"},
+ { 46, "BayStack 250 10/100 Ethernet Hub"},
+ /*{ 47, "StackProbe"}, XXX - No longer listed */
+ { 48, "BayStack 450 10/100/1000 Switches"},
+ { 49, "BayStack 410 10/100 Switches"},
+ { 50, "Passport 1200 L3 Switch"},
+ { 51, "Passport 1250 L3 Switch"},
+ { 52, "Passport 1100 L3 Switch"},
+ { 53, "Passport 1150 L3 Switch"},
+ { 54, "Passport 1050 L3 Switch"},
+ { 55, "Passport 1051 L3 Switch"},
+ { 56, "Passport 8610 L3 Switch"},
+ { 57, "Passport 8606 L3 Switch"},
+ { 58, "Passport 8010"},
+ { 59, "Passport 8006"},
+ { 60, "BayStack 670 wireless access point"},
+ { 61, "Passport 740"},
+ { 62, "Passport 750"},
+ { 63, "Passport 790"},
+ { 64, "Business Policy Switch 2000 10/100 Switches"},
+ { 65, "Passport 8110 L2 Switch"},
+ { 66, "Passport 8106 L2 Switch"},
+ { 67, "BayStack 3580 Gig Switch"},
+ { 68, "BayStack 10 Power Supply Unit"},
+ { 69, "BayStack 420 10/100 Switch"},
+ { 70, "OPTera Metro 1200 Ethernet Service Module"},
+ { 71, "OPTera 8010co"},
+ { 72, "OPTera 8610co L3 switch"},
+ { 73, "OPTera 8110co L2 switch"},
+ { 74, "OPTera 8003"},
+ { 75, "OPTera 8603 L3 switch"},
+ { 76, "OPTera 8103 L2 switch"},
+ { 77, "BayStack 380 10/100/1000 Switch"},
+ { 78, "Ethernet Switch 470-48T"},
+ { 79, "OPTera Metro 1450 Ethernet Service Module"},
+ { 80, "OPTera Metro 1400 Ethernet Service Module"},
+ { 81, "Alteon Switch Family"},
+ { 82, "Ethernet Switch 460-24T-PWR"},
+ { 83, "OPTera Metro 8010 OPM L2 Switch"},
+ { 84, "OPTera Metro 8010co OPM L2 Switch"},
+ { 85, "OPTera Metro 8006 OPM L2 Switch"},
+ { 86, "OPTera Metro 8003 OPM L2 Switch"},
+ { 87, "Alteon 180e"},
+ { 88, "Alteon AD3"},
+ { 89, "Alteon 184"},
+ { 90, "Alteon AD4"},
+ { 91, "Passport 1424 L3 switch"},
+ { 92, "Passport 1648 L3 switch"},
+ { 93, "Passport 1612 L3 switch"},
+ { 94, "Passport 1624 L3 switch"},
+ { 95, "BayStack 380-24F Fiber 1000 Switch"},
+ { 96, "Ethernet Routing Switch 5510-24T"},
+ { 97, "Ethernet Routing Switch 5510-48T"},
+ { 98, "Ethernet Switch 470-24T"},
+ { 99, "Nortel Networks Wireless LAN Access Point 2220"},
+ {100, "Passport RBS 2402 L3 switch"},
+ {101, "Alteon Application Switch 2424"},
+ {102, "Alteon Application Switch 2224"},
+ {103, "Alteon Application Switch 2208"},
+ {104, "Alteon Application Switch 2216"},
+ {105, "Alteon Application Switch 3408"},
+ {106, "Alteon Application Switch 3416"},
+ {107, "Nortel Networks Wireless LAN SecuritySwitch 2250"},
+ {108, "Ethernet Switch 425-48T"},
+ {109, "Ethernet Switch 425-24T"},
+ {110, "Nortel Networks Wireless LAN Access Point 2221"},
+ {111, "Nortel Metro Ethernet Service Unit 24-T SPF switch"},
+ {112, " Nortel Metro Ethernet Service Unit 24-T LX DC switch"},
+ {113, "Passport 8300 10-slot chassis"},
+ {114, "Passport 8300 6-slot chassis"},
+ {115, "Ethernet Routing Switch 5520-24T-PWR"},
+ {116, "Ethernet Routing Switch 5520-48T-PWR"},
+ {117, "Nortel Networks VPN Gateway 3050"},
+ {118, "Alteon SSL 310 10/100"},
+ {119, "Alteon SSL 310 10/100 Fiber"},
+ {120, "Alteon SSL 310 10/100 FIPS"},
+ {121, "Alteon SSL 410 10/100/1000"},
+ {122, "Alteon SSL 410 10/100/1000 Fiber"},
+ {123, "Alteon Application Switch 2424-SSL"},
+ {124, "Ethernet Switch 325-24T"},
+ {125, "Ethernet Switch 325-24G"},
+ {126, "Nortel Networks Wireless LAN Access Point 2225"},
+ {127, "Nortel Networks Wireless LAN SecuritySwitch 2270"},
+ {128, "24-port Ethernet Switch 470-24T-PWR"},
+ {129, "48-port Ethernet Switch 470-48T-PWR"},
+ {130, "Ethernet Routing Switch 5530-24TFD"},
+ {131, "Ethernet Switch 3510-24T"},
+ {132, "Nortel Metro Ethernet Service Unit 12G AC L3 switch"},
+ {133, "Nortel Metro Ethernet Service Unit 12G DC L3 switch"},
+ {134, "Nortel Secure Access Switch"},
+ {135, "Nortel Networks VPN Gateway 3070"},
+ {136, "OPTera Metro 3500"},
+ {137, "SMB BES 1010 24T"},
+ {138, "SMB BES 1010 48T"},
+ {139, "SMB BES 1020 24T PWR"},
+ {140, "SMB BES 1020 48T PWR"},
+ {141, "SMB BES 2010 24T"},
+ {142, "SMB BES 2010 48T"},
+ {143, "SMB BES 2020 24T PWR"},
+ {144, "SMB BES 2020 48T PWR"},
+ {145, "SMB BES 110 24T"},
+ {146, "SMB BES 110 48T"},
+ {147, "SMB BES 120 24T PWR"},
+ {148, "SMB BES 120 48T PWR"},
+ {149, "SMB BES 210 24T"},
+ {150, "SMB BES 210 48T"},
+ {151, "SMB BES 220 24T PWR"},
+ {152, "SMB BES 220 48T PWR"},
+ {153, "OME 6500"},
+ {154, "Ethernet Routing Switch 4548GT"},
+ {155, "Ethernet Routing Switch 4548GT-PWR"},
+ {156, "Ethernet Routing Switch 4550T"},
+ {157, "Ethernet Routing Switch 4550T-PWR"},
+ {158, "Ethernet Routing Switch 4526FX"},
+ {159, "Ethernet Routing Switch 2500-26T"},
+ {160, "Ethernet Routing Switch 2500-26T-PWR"},
+ {161, "Ethernet Routing Switch 2500-50T"},
+ {162, "Ethernet Routing Switch 2500-50T-PWR"},
+ {213, "Virtual Services Platform 8284XSQ"},
+ {0, NULL}
+};
+static value_string_ext ndp_chassis_val_ext = VALUE_STRING_EXT_INIT(ndp_chassis_val);
+
+/* from synro179.mib - SnpxBackplaneType */
+static const value_string ndp_backplane_val[] =
+{
+ { 1, "Other"},
+ { 2, "Ethernet"},
+ { 3, "Ethernet and Tokenring"},
+ { 4, "Ethernet and FDDI"},
+ { 5, "Ethernet, Tokenring and FDDI"},
+ { 6, "Ethernet and Tokenring with redundant power"},
+ { 7, "Ethernet, Tokenring, FDDI with redundant power"},
+ { 8, "Token Ring"},
+ { 9, "Ethernet, Tokenring and Fast Ethernet"},
+ {10, "Ethernet and Fast Ethernet"},
+ {11, "Ethernet, Tokenring, Fast Ethernet with redundant power"},
+ {12, "Ethernet, Fast Ethernet and Gigabit Ethernet"},
+ {0, NULL}
+};
+static value_string_ext ndp_backplane_val_ext = VALUE_STRING_EXT_INIT(ndp_backplane_val);
+
+static const value_string ndp_state_val[] =
+{
+ {1, "Topology Change"},
+ {2, "Heartbeat"},
+ {3, "New"},
+ {0, NULL}
+};
+
+
+/* Offsets in NDP Hello structure. */
+#define NDP_IP_ADDRESS 0
+#define NDP_SEGMENT_IDENTIFIER 4
+#define NDP_CHASSIS_TYPE 7
+#define NDP_BACKPLANE_TYPE 8
+#define NDP_STATE 9
+#define NDP_NUMBER_OF_LINKS 10
+
+static int proto_ndp = -1;
+static int hf_ndp_ip_address = -1;
+static int hf_ndp_segment_identifier = -1;
+static int hf_ndp_chassis_type = -1;
+static int hf_ndp_backplane_type = -1;
+static int hf_ndp_state = -1;
+static int hf_ndp_number_of_links = -1;
+
+static gint ett_ndp = -1;
+
+static dissector_handle_t ndp_handle;
+
+static int
+dissect_ndp(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data _U_)
+{
+ const char *hello_type;
+ proto_tree *ndp_tree = NULL;
+ proto_item *ti;
+
+ col_set_str(pinfo->cinfo, COL_PROTOCOL, "NDP");
+
+ hello_type = "";
+ if (pinfo->dl_dst.type == AT_ETHER) {
+ const guint8 *dstmac = (const guint8 *)pinfo->dl_dst.data;
+
+ switch (dstmac[5]) {
+
+ case 0:
+ hello_type = "Segment ";
+ break;
+
+ case 1:
+ hello_type = "FlatNet ";
+ break;
+ }
+ }
+ col_add_fstr(pinfo->cinfo, COL_INFO, "%sHello", hello_type);
+
+ if (tree) {
+ ti = proto_tree_add_protocol_format(tree, proto_ndp, tvb, 0, 11,
+ "Nortel Discovery Protocol");
+
+ ndp_tree = proto_item_add_subtree(ti, ett_ndp);
+
+ proto_tree_add_item(ndp_tree, hf_ndp_ip_address, tvb,
+ NDP_IP_ADDRESS, 4, ENC_BIG_ENDIAN);
+
+
+ proto_tree_add_item(ndp_tree, hf_ndp_segment_identifier, tvb,
+ NDP_SEGMENT_IDENTIFIER, 3, ENC_BIG_ENDIAN);
+
+
+ proto_tree_add_item(ndp_tree, hf_ndp_chassis_type, tvb,
+ NDP_CHASSIS_TYPE, 1, ENC_BIG_ENDIAN);
+
+ proto_tree_add_item(ndp_tree, hf_ndp_backplane_type, tvb,
+ NDP_BACKPLANE_TYPE, 1, ENC_BIG_ENDIAN);
+
+
+ proto_tree_add_item(ndp_tree, hf_ndp_state, tvb,
+ NDP_STATE, 1, ENC_BIG_ENDIAN);
+
+ proto_tree_add_item(ndp_tree, hf_ndp_number_of_links, tvb,
+ NDP_NUMBER_OF_LINKS, 1, ENC_BIG_ENDIAN);
+ }
+
+ return tvb_captured_length(tvb);
+}
+
+
+
+void
+proto_register_ndp(void)
+{
+ static hf_register_info hf[] = {
+ { &hf_ndp_ip_address,
+ { "IP address", "ndp.ipaddress", FT_IPv4, BASE_NONE, NULL, 0x0,
+ "IP address of the Network Management Module (NMM)", HFILL }},
+
+ { &hf_ndp_segment_identifier,
+ { "Segment Identifier", "ndp.segmentident", FT_UINT24, BASE_HEX, NULL, 0x0,
+ "Segment id of the segment from which the agent is sending the topology message", HFILL }},
+
+ { &hf_ndp_chassis_type,
+ { "Chassis type", "ndp.chassis", FT_UINT8, BASE_DEC|BASE_EXT_STRING,
+ &ndp_chassis_val_ext, 0x0,
+ "Chassis type of the agent sending the topology message", HFILL }},
+
+ { &hf_ndp_backplane_type,
+ { "Backplane type", "ndp.backplane", FT_UINT8, BASE_DEC|BASE_EXT_STRING,
+ &ndp_backplane_val_ext, 0x0,
+ "Backplane type of the agent sending the topology message", HFILL }},
+
+ { &hf_ndp_state,
+ { "State", "ndp.state", FT_UINT8, BASE_DEC,
+ VALS(ndp_state_val), 0x0,
+ "Current state of this Network Management Module (NMM)", HFILL }},
+
+ { &hf_ndp_number_of_links,
+ { "Number of links", "ndp.numberoflinks", FT_UINT8, BASE_DEC, NULL, 0x0,
+ "Number of interconnect ports", HFILL }},
+ };
+
+ static gint *ett[] = {
+ &ett_ndp,
+ };
+ proto_ndp = proto_register_protocol("Nortel Discovery Protocol", "NDP", "ndp");
+ proto_register_field_array(proto_ndp, hf, array_length(hf));
+ proto_register_subtree_array(ett, array_length(ett));
+
+ ndp_handle = register_dissector("ndp", dissect_ndp, proto_ndp);
+}
+
+void
+proto_reg_handoff_ndp(void)
+{
+ dissector_add_uint("llc.nortel_pid", 0x01a1, ndp_handle); /* flatnet hello */
+ dissector_add_uint("llc.nortel_pid", 0x01a2, ndp_handle); /* Segment hello */
+ /* not got round to adding this but it's really old, so I'm not sure people will see it */
+ /* it uses a different packet format */
+ /* dissector_add_uint("llc.nortel_pid", 0x01a3, ndp_handle); */ /* Bridge hello */
+}
+
+/*
+ * Editor modelines - https://www.wireshark.org/tools/modelines.html
+ *
+ * Local variables:
+ * c-basic-offset: 8
+ * tab-width: 8
+ * indent-tabs-mode: t
+ * End:
+ *
+ * vi: set shiftwidth=8 tabstop=8 noexpandtab:
+ * :indentSize=8:tabSize=8:noTabs=false:
+ */