aboutsummaryrefslogtreecommitdiffstats
path: root/wireshark/0005-rsl-hsl.patch
diff options
context:
space:
mode:
Diffstat (limited to 'wireshark/0005-rsl-hsl.patch')
-rw-r--r--wireshark/0005-rsl-hsl.patch272
1 files changed, 0 insertions, 272 deletions
diff --git a/wireshark/0005-rsl-hsl.patch b/wireshark/0005-rsl-hsl.patch
deleted file mode 100644
index 4ffaccd69..000000000
--- a/wireshark/0005-rsl-hsl.patch
+++ /dev/null
@@ -1,272 +0,0 @@
-Index: wireshark/epan/dissectors/packet-rsl.c
-===================================================================
---- wireshark.orig/epan/dissectors/packet-rsl.c 2011-09-06 13:57:15.000000000 +0200
-+++ wireshark/epan/dissectors/packet-rsl.c 2011-09-06 14:11:09.000000000 +0200
-@@ -2,6 +2,7 @@
- * Routines for Radio Signalling Link (RSL) dissection.
- *
- * Copyright 2007, 2011, Anders Broman <anders.broman@ericsson.com>
-+ * Copyright 2009-2011, Harald Welte <laforge@gnumonks.org>
- *
- * $Id: packet-rsl.c 38413 2011-08-08 17:59:32Z wmeier $
- *
-@@ -136,7 +137,14 @@
- static int hf_rsl_cstat_lost_pkts = -1;
- static int hf_rsl_cstat_ia_jitter = -1;
- static int hf_rsl_cstat_avg_tx_dly = -1;
--
-+/* HSL */
-+static int hf_rsl_hsl_bts_serno = -1;
-+static int hf_rsl_hsl_bts_ver = -1;
-+static int hf_rsl_hsl_dsp_ver = -1;
-+static int hf_rsl_hsl_fpga_ver = -1;
-+static int hf_rsl_hsl_trau_remote_port = -1;
-+static int hf_rsl_hsl_trau_remote_ip = -1;
-+static int hf_rsl_hsl_tx_power = -1;
-
- /* Initialize the subtree pointers */
- static int ett_rsl = -1;
-@@ -207,6 +215,7 @@
- static proto_tree *top_tree;
- static dissector_handle_t gsm_a_ccch_handle;
- static dissector_handle_t gsm_a_dtap_handle;
-+static dissector_handle_t bssgp_handle;
-
- static gboolean is_si2q = FALSE;
-
-@@ -243,9 +252,11 @@
- { 0x08, "TRX Management messages" },
- { 0x16, "Location Services messages" },
- { 0x3f, "ip.access Vendor Specific messages" },
-+ { 0x80, "HSL Vendor Specific messages" },
- { 0, NULL }
- };
- #define RSL_MSGDISC_IPACCESS 0x3f
-+#define RSL_MSGDISC_HSL 0x40
- /*
- * 9.2 MESSAGE TYPE
- */
-@@ -357,6 +368,22 @@
- #define RSL_IE_IPAC_RTP_MPLEX 0xfd
- #define RSL_IE_IPAC_RTP_MPLEX_ID 0xfe
-
-+/* Vendor-Specific messages of HSL femtocell. There is no public documentation
-+ * about those extensions, all information in this dissector is based on lawful
-+ * protocol reverse enginering by Harald Welte <laforge@gnumonks.org> */
-+#define RSL_MSG_TYPE_HSL_IDENTIFY 0x80
-+#define RSL_MSG_TYPE_HSL_CONN_TRAU 0x81
-+#define RSL_MSG_TYPE_HSL_BSSGP 0x82
-+#define RSL_MSG_TYPE_HSL_GPRS_TS_ALLOC 0x83
-+#define RSL_MSG_TYPE_HSL_L1_PRIM 0x8a
-+
-+#define RSL_IE_HSL_BTS_SERNO 0xc0
-+#define RSL_IE_HSL_TRAU_PARAMS 0xc1
-+#define RSL_IE_HSL_TX_POWER 0xc4
-+#define RSL_IE_HSL_BTS_VERSION 0xc5
-+#define RSL_IE_HSL_DSP_VERSION 0xc6
-+#define RSL_IE_HSL_FPGA_VERSION 0xc7
-+
- static const value_string rsl_msg_type_vals[] = {
- /* 0 0 0 0 - - - - Radio Link Layer Management messages: */
- { 0x01, "DATA REQuest" }, /* 8.3.1 */
-@@ -438,6 +465,12 @@
- { 0x77, "ip.access DLCX" },
- { 0x78, "ip.access DLCX ACK" },
- { 0x79, "ip.access DLCX NACK" },
-+ /* HSL */
-+ { 0x80, "HSL IDENTIFY" },
-+ { 0x81, "HSL CONNECT TRAU" },
-+ { 0x82, "HSL BSSGP" },
-+ { 0x83, "HSL GPRS TS ALLOC" },
-+ { 0x8a, "HSL TX SET POWER" },
- { 0, NULL }
- };
-
-@@ -578,6 +611,7 @@
- Not used
-
- */
-+ /* ip.access */
- { 0xe0, "SRTP Configuration" },
- { 0xe1, "BSC Proxy UDP Port" },
- { 0xe2, "BSC Multiplex Timeout" },
-@@ -596,6 +630,13 @@
- { 0xfc, "RTP Payload Type 2" },
- { 0xfd, "RTP Multiplex" },
- { 0xfe, "RTP Multiplex Identifier" },
-+ /* HSL */
-+ { 0xc0, "HSL Serial Number" },
-+ { 0xc1, "HSL TRAU Parameters" },
-+ { 0xc4, "HSL TX Power (dBm)" },
-+ { 0xc5, "HSL BTS SW Version" },
-+ { 0xc6, "HSL DSP SW Version" },
-+ { 0xc7, "HSL FPGA SW Version" },
- { 0, NULL }
- };
-
-@@ -3062,9 +3103,10 @@
- guint8 msg_type;
- guint32 local_addr = 0;
- guint16 local_port = 0;
-+ int old_visited;
- address src_addr;
-
-- msg_type = tvb_get_guint8(tvb, offset)&0x7f;
-+ msg_type = tvb_get_guint8(tvb, offset)&0xff;
- offset++;
-
- #if 0
-@@ -3203,20 +3245,62 @@
- proto_tree_add_item(ie_tree, hf_rsl_cstat_avg_tx_dly, tvb,
- offset+24, 4, FALSE);
- break;
-+ /* HSL */
-+ case RSL_IE_HSL_BTS_SERNO:
-+ proto_tree_add_item(ie_tree, hf_rsl_hsl_bts_serno, tvb,
-+ offset, len, FALSE);
-+ col_append_fstr(pinfo->cinfo, COL_INFO, "SerNo %s ",
-+ tvb_get_string(tvb, offset, len));
-+ break;
-+ case RSL_IE_HSL_TRAU_PARAMS:
-+ proto_tree_add_item(tree, hf_rsl_hsl_trau_remote_port, tvb,
-+ offset+2, 2, TRUE);
-+ local_port = tvb_get_letohs(tvb, offset+2);
-+ proto_tree_add_item(tree, hf_rsl_hsl_trau_remote_ip, tvb,
-+ offset+4, 4, FALSE);
-+ local_addr = tvb_get_ipv4(tvb, offset+4);
-+ break;
-+ case RSL_IE_HSL_TX_POWER:
-+ proto_tree_add_item(ie_tree, hf_rsl_hsl_tx_power, tvb,
-+ offset, len, FALSE);
-+ break;
-+ case RSL_IE_HSL_BTS_VERSION:
-+ proto_tree_add_item(ie_tree, hf_rsl_hsl_bts_ver, tvb,
-+ offset, len, FALSE);
-+ break;
-+ case RSL_IE_HSL_DSP_VERSION:
-+ proto_tree_add_item(ie_tree, hf_rsl_hsl_dsp_ver, tvb,
-+ offset, len, FALSE);
-+ break;
-+ case RSL_IE_HSL_FPGA_VERSION:
-+ proto_tree_add_item(ie_tree, hf_rsl_hsl_fpga_ver, tvb,
-+ offset, len, FALSE);
-+ break;
-+ case RSL_IE_L3_INF:
-+ if (msg_type == RSL_MSG_TYPE_HSL_BSSGP) {
-+ tvbuff_t *next_tvb;
-+ next_tvb = tvb_new_subset(tvb, offset, -1, len);
-+ call_dissector(bssgp_handle, next_tvb, pinfo, tree);
-+ }
-+ break;
- }
- offset += len;
- }
-
- switch (msg_type) {
- case RSL_MSG_TYPE_IPAC_CRCX_ACK:
-+ case RSL_MSG_TYPE_HSL_CONN_TRAU:
- /* Notify the RTP and RTCP dissectors about a new RTP stream */
- src_addr.type = AT_IPv4;
- src_addr.len = 4;
- src_addr.data = (guint8 *)&local_addr;
-+ old_visited = pinfo->fd->flags.visited;
-+ pinfo->fd->flags.visited = 0;
- rtp_add_address(pinfo, &src_addr, local_port, 0,
- "GSM A-bis/IP", pinfo->fd->num, 0, NULL);
- rtcp_add_address(pinfo, &src_addr, local_port+1, 0,
- "GSM A-bis/IP", pinfo->fd->num);
-+ pinfo->fd->flags.visited = old_visited;
- break;
- }
- return offset;
-@@ -3228,10 +3312,12 @@
- guint8 msg_disc, msg_type;
-
- msg_disc = tvb_get_guint8(tvb, offset++) >> 1;
-- msg_type = tvb_get_guint8(tvb,offset)&0x7f;
-+ msg_type = tvb_get_guint8(tvb,offset);
- proto_tree_add_item(tree, hf_rsl_msg_type, tvb, offset, 1, ENC_BIG_ENDIAN);
-
-- if (msg_disc == RSL_MSGDISC_IPACCESS) {
-+ switch (msg_disc) {
-+ case RSL_MSGDISC_HSL:
-+ case RSL_MSGDISC_IPACCESS:
- offset = dissct_rsl_ipaccess_msg(tvb, pinfo, tree, offset);
- return offset;
- }
-@@ -3868,7 +3954,7 @@
- col_set_str(pinfo->cinfo, COL_PROTOCOL, "RSL");
- col_clear(pinfo->cinfo, COL_INFO);
-
-- msg_type = tvb_get_guint8(tvb,offset+1)&0x7f;
-+ msg_type = tvb_get_guint8(tvb,offset+1);
-
- col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",val_to_str(msg_type, rsl_msg_type_vals,"unknown %u"));
-
-@@ -3905,6 +3991,7 @@
-
- gsm_a_ccch_handle = find_dissector("gsm_a_ccch");
- gsm_a_dtap_handle = find_dissector("gsm_a_dtap");
-+ bssgp_handle = find_dissector("bssgp");
- }
-
- /* Register the protocol with Wireshark */
-@@ -3925,7 +4012,7 @@
- },
- { &hf_rsl_msg_type,
- { "Message type", "rsl.msg_type",
-- FT_UINT8, BASE_HEX_DEC, VALS(rsl_msg_type_vals), 0x7f,
-+ FT_UINT8, BASE_HEX_DEC, VALS(rsl_msg_type_vals), 0xff,
- NULL, HFILL }
- },
- { &hf_rsl_ie_id,
-@@ -4342,6 +4429,35 @@
- { "Average Tx Delay", "rsl.ipacc.cstat.avg_tx_delay",
- FT_UINT32, BASE_DEC, NULL, 0, NULL, HFILL }
- },
-+ /* HSL */
-+ { &hf_rsl_hsl_bts_serno,
-+ { "BTS Serial Number", "rsl.hsl.bts_serno",
-+ FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL }
-+ },
-+ { &hf_rsl_hsl_tx_power,
-+ { "Transmit Power", "rsl.hsl.tx_power",
-+ FT_UINT8, BASE_DEC, NULL, 0, NULL, HFILL }
-+ },
-+ { &hf_rsl_hsl_bts_ver,
-+ { "BTS Version Number", "rsl.hsl.bts_ver",
-+ FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL }
-+ },
-+ { &hf_rsl_hsl_dsp_ver,
-+ { "DSP Version Number", "rsl.hsl.dsp_ver",
-+ FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL }
-+ },
-+ { &hf_rsl_hsl_fpga_ver,
-+ { "FPGA Version Number", "rsl.hsl.fpga_ver",
-+ FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL }
-+ },
-+ { &hf_rsl_hsl_trau_remote_port,
-+ { "HSL TRAU Remote RTP Port", "rsl.hsl.trau.remote_port",
-+ FT_UINT16, BASE_DEC, NULL, 0x0, NULL, HFILL },
-+ },
-+ { &hf_rsl_hsl_trau_remote_ip,
-+ { "HSL TRAU Remote IP Address", "rsl.hsl.trau.remote_ip",
-+ FT_IPv4, BASE_NONE, NULL, 0x0, NULL, HFILL },
-+ },
- };
- static gint *ett[] = {
- &ett_rsl,
-@@ -4481,6 +4597,13 @@
- RSL_ATT_TLVDEF(RSL_IE_IPAC_SPEECH_MODE, TLV_TYPE_TV, 0);
- RSL_ATT_TLVDEF(RSL_IE_IPAC_CONN_ID, TLV_TYPE_FIXED, 2);
- RSL_ATT_TLVDEF(RSL_IE_IPAC_RTP_PAYLOAD2,TLV_TYPE_TV, 0);
-+ /* HSL */
-+ RSL_ATT_TLVDEF(RSL_IE_HSL_BTS_SERNO, TLV_TYPE_TLV, 0);
-+ RSL_ATT_TLVDEF(RSL_IE_HSL_TRAU_PARAMS, TLV_TYPE_TLV, 0);
-+ RSL_ATT_TLVDEF(RSL_IE_HSL_TX_POWER, TLV_TYPE_TV, 0);
-+ RSL_ATT_TLVDEF(RSL_IE_HSL_BTS_VERSION, TLV_TYPE_TLV, 0);
-+ RSL_ATT_TLVDEF(RSL_IE_HSL_DSP_VERSION, TLV_TYPE_TLV, 0);
-+ RSL_ATT_TLVDEF(RSL_IE_HSL_FPGA_VERSION, TLV_TYPE_TLV, 0);
-
- /* Register the protocol name and description */
- proto_rsl = proto_register_protocol("Radio Signalling Link (RSL)",