blob: c54575355002df476a2f54a281c1ea00357445f2 [file] [log] [blame]
Holger Hans Peter Freyther8d66dfb2010-05-23 03:46:46 +08001From 61a4d5540a7860e7eddc67b3db0f2f80357f1da0 Mon Sep 17 00:00:00 2001
Holger Hans Peter Freyther2fb7ccf2010-04-21 20:37:53 +08002From: Holger Hans Peter Freyther <zecke@selfish.org>
3Date: Mon, 19 Apr 2010 13:23:51 +0800
4Subject: [PATCH 1/2] Add the Abis OML patch.
5
6---
7 epan/dissectors/Makefile.common | 1 +
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +08008 epan/dissectors/packet-gsm_abis_oml.c | 1402 +++++++++++++++++++++++++++++++++
9 epan/dissectors/packet-gsm_abis_oml.h | 798 +++++++++++++++++++
10 3 files changed, 2201 insertions(+), 0 deletions(-)
Holger Hans Peter Freyther2fb7ccf2010-04-21 20:37:53 +080011 create mode 100644 epan/dissectors/packet-gsm_abis_oml.c
12 create mode 100644 epan/dissectors/packet-gsm_abis_oml.h
13
14diff --git a/epan/dissectors/Makefile.common b/epan/dissectors/Makefile.common
Holger Hans Peter Freyther8d66dfb2010-05-23 03:46:46 +080015index 4973c3b..65e6d01 100644
Holger Hans Peter Freyther2fb7ccf2010-04-21 20:37:53 +080016--- a/epan/dissectors/Makefile.common
17+++ b/epan/dissectors/Makefile.common
Holger Hans Peter Freyther8d66dfb2010-05-23 03:46:46 +080018@@ -483,6 +483,7 @@ DISSECTOR_SRC = \
Harald Welte4e8c98a2009-08-20 00:59:11 +090019 packet-gsm_a_gm.c \
Harald Welteb16004c2009-07-11 19:44:53 +020020 packet-gsm_a_rp.c \
21 packet-gsm_a_rr.c \
Harald Welte63aba292009-07-04 04:11:21 +020022+ packet-gsm_abis_oml.c \
Harald Welte4e8c98a2009-08-20 00:59:11 +090023 packet-gsm_ipa.c \
Harald Welteb16004c2009-07-11 19:44:53 +020024 packet-gsm_bsslap.c \
25 packet-gsm_bssmap_le.c \
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +010026diff --git a/epan/dissectors/packet-gsm_abis_oml.c b/epan/dissectors/packet-gsm_abis_oml.c
27new file mode 100644
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +080028index 0000000..dc53496
Harald Welte31b03472009-12-21 19:04:47 +010029--- /dev/null
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +010030+++ b/epan/dissectors/packet-gsm_abis_oml.c
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +080031@@ -0,0 +1,1402 @@
Harald Welte6900c162009-06-25 20:50:57 +020032+/* packet-abis_oml.c
33+ * Routines for packet dissection of GSM A-bis over IP (3GPP TS 12.21)
34+ * Copyright 2009 by Harald Welte <laforge@gnumonks.org>
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +010035+ * Copyright 2009 by Holger Hans Peter Freyther <zecke@selfish.org>
Harald Welte6900c162009-06-25 20:50:57 +020036+ * based on A-bis OML code in OpenBSC
37+ *
38+ * $Id$
39+ *
40+ * Wireshark - Network traffic analyzer
41+ * By Gerald Combs <gerald@wireshark.org>
42+ * Copyright 1998 Gerald Combs
43+ *
44+ * This program is free software; you can redistribute it and/or
45+ * modify it under the terms of the GNU General Public License
46+ * as published by the Free Software Foundation; either version 2
47+ * of the License, or (at your option) any later version.
48+ *
49+ * This program is distributed in the hope that it will be useful,
50+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
51+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
52+ * GNU General Public License for more details.
53+ *
54+ * You should have received a copy of the GNU General Public License
55+ * along with this program; if not, write to the Free Software
56+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
57+ */
58+
59+#ifdef HAVE_CONFIG_H
60+# include "config.h"
61+#endif
62+
63+#include <glib.h>
64+
65+#include <epan/packet.h>
66+#include <epan/emem.h>
Harald Welte4e8c98a2009-08-20 00:59:11 +090067+#include <epan/lapd_sapi.h>
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +010068+#include <epan/prefs.h>
Harald Welte6900c162009-06-25 20:50:57 +020069+
Harald Welte63aba292009-07-04 04:11:21 +020070+#include "packet-gsm_abis_oml.h"
Harald Welte1cc3fa82009-07-01 17:40:50 +020071+#include "packet-gsm_a_common.h"
Harald Welte6900c162009-06-25 20:50:57 +020072+
73+/* initialize the protocol and registered fields */
74+static int proto_abis_oml = -1;
75+
76+/* OML header */
77+static int hf_oml_msg_disc = -1;
78+static int hf_oml_placement = -1;
79+static int hf_oml_sequence = -1;
80+static int hf_oml_length = -1;
81+/* FOM header */
82+static int hf_oml_fom_msgtype = -1;
83+static int hf_oml_fom_objclass = -1;
84+static int hf_oml_fom_inst_bts = -1;
85+static int hf_oml_fom_inst_trx = -1;
86+static int hf_oml_fom_inst_ts = -1;
87+static int hf_oml_fom_attr_tag = -1;
88+static int hf_oml_fom_attr_len = -1;
89+static int hf_oml_fom_attr_val = -1;
90+/* FOM attributes */
91+static int hf_attr_adm_state = -1;
Harald Welte2c544c82009-07-11 16:41:15 +020092+static int hf_attr_arfcn = -1;
Harald Welte6900c162009-06-25 20:50:57 +020093+static int hf_attr_oper_state = -1;
94+static int hf_attr_avail_state = -1;
95+static int hf_attr_event_type = -1;
96+static int hf_attr_severity = -1;
Harald Welte1cc3fa82009-07-01 17:40:50 +020097+static int hf_attr_bcch_arfcn = -1;
98+static int hf_attr_bsic = -1;
99+static int hf_attr_test_no = -1;
100+static int hf_attr_tsc = -1;
101+static int hf_attr_tei = -1;
102+static int hf_attr_ach_btsp = -1;
103+static int hf_attr_ach_tslot = -1;
104+static int hf_attr_ach_sslot = -1;
105+static int hf_attr_gsm_time = -1;
106+static int hf_attr_chan_comb = -1;
107+/* Ipaccess */
108+static int hf_oml_ipa_tres_attr_tag = -1;
109+static int hf_oml_ipa_tres_attr_len = -1;
110+static int hf_attr_ipa_test_res = -1;
111+static int hf_attr_ipa_tr_rxlev = -1;
Harald Welte450129f2009-07-03 12:46:47 +0200112+static int hf_attr_ipa_tr_b_rxlev = -1;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200113+static int hf_attr_ipa_tr_arfcn = -1;
114+static int hf_attr_ipa_tr_f_qual = -1;
115+static int hf_attr_ipa_tr_f_err = -1;
116+static int hf_attr_ipa_tr_rxqual = -1;
117+static int hf_attr_ipa_tr_frame_offs = -1;
118+static int hf_attr_ipa_tr_framenr_offs = -1;
119+static int hf_attr_ipa_tr_bsic = -1;
120+static int hf_attr_ipa_tr_cell_id = -1;
Harald Welte450129f2009-07-03 12:46:47 +0200121+static int hf_attr_ipa_tr_si2 = -1;
122+static int hf_attr_ipa_tr_si2bis = -1;
123+static int hf_attr_ipa_tr_si2ter = -1;
124+static int hf_attr_ipa_tr_chan_desc = -1;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200125+static int hf_attr_ipa_rsl_ip = -1;
126+static int hf_attr_ipa_rsl_port = -1;
Harald Welte450129f2009-07-03 12:46:47 +0200127+static int hf_attr_ipa_prim_oml_ip = -1;
128+static int hf_attr_ipa_prim_oml_port = -1;
129+static int hf_attr_ipa_location_name = -1;
130+static int hf_attr_ipa_unit_id = -1;
131+static int hf_attr_ipa_unit_name = -1;
132+static int hf_attr_ipa_nv_flags = -1;
133+static int hf_attr_ipa_nv_mask = -1;
Harald Weltec9b484f2009-07-12 20:46:43 +0200134+static int hf_attr_ipa_nsl_sport = -1;
135+static int hf_attr_ipa_nsl_daddr = -1;
136+static int hf_attr_ipa_nsl_dport = -1;
137+static int hf_attr_ipa_nsei = -1;
138+static int hf_attr_ipa_nsvci = -1;
139+static int hf_attr_ipa_bvci = -1;
140+static int hf_attr_ipa_rac = -1;
Harald Welte6900c162009-06-25 20:50:57 +0200141+
142+/* initialize the subtree pointers */
143+static int ett_oml = -1;
144+static int ett_oml_fom = -1;
145+static int ett_oml_fom_att = -1;
146+
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +0100147+/* Decode things as nanoBTS traces */
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +0800148+static gboolean global_oml_use_nano_bts = TRUE;
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +0100149+
Harald Welte6900c162009-06-25 20:50:57 +0200150+static proto_tree *top_tree;
151+
152+/* TS 12.21 Chapter 8.1 / TS 08.59 */
153+static const value_string oml_msg_disc_vals[] = {
154+ { ABIS_OM_MDISC_FOM, "Formatted O&M" },
155+ { ABIS_OM_MDISC_MMI, "MMI Transfer" },
156+ { ABIS_OM_MDISC_TRAU, "TRAU O&M" },
157+ { ABIS_OM_MDISC_MANUF, "Manufacturer specific" },
158+};
159+
160+/* TS 12.21 Chapter 8.1.1 */
161+static const value_string oml_placement_vals[] = {
162+ { ABIS_OM_PLACEMENT_ONLY, "Only" },
163+ { ABIS_OM_PLACEMENT_FIRST, "First" },
164+ { ABIS_OM_PLACEMENT_MIDDLE, "Middle" },
165+ { ABIS_OM_PLACEMENT_LAST, "Last" },
166+};
167+
168+/* TS 12.21 Chapter 9.2 */
169+static const value_string oml_fom_msgtype_vals[] = {
170+ { NM_MT_LOAD_INIT, "Software Load Init" },
171+ { NM_MT_LOAD_INIT_ACK, "Software Load Init ACK" },
172+ { NM_MT_LOAD_INIT_NACK, "Software Load Init NACK" },
173+ { NM_MT_LOAD_SEG, "Software Load Segment" },
174+ { NM_MT_LOAD_SEG_ACK, "Software Load Segment ACK" },
175+ { NM_MT_LOAD_END, "Software Load End" },
176+ { NM_MT_LOAD_END_ACK, "Software Load End ACK" },
177+ { NM_MT_LOAD_END_NACK, "Software Load End NACK" },
178+ { NM_MT_SW_ACT_REQ, "Software Activate Request" },
179+ { NM_MT_SW_ACT_REQ_ACK, "Software Activate Request ACK" },
180+ { NM_MT_SW_ACT_REQ_NACK, "Software Activate Request NACK" },
181+ { NM_MT_ACTIVATE_SW, "Activate Software" },
182+ { NM_MT_ACTIVATE_SW_ACK, "Activate Software ACK" },
183+ { NM_MT_ACTIVATE_SW_NACK, "Activate Software NACK" },
184+ { NM_MT_SW_ACTIVATED_REP, "Software Activated Report" },
185+ { NM_MT_ESTABLISH_TEI, "Establish TEI" },
186+ { NM_MT_ESTABLISH_TEI_ACK, "Establish TEI ACK" },
187+ { NM_MT_ESTABLISH_TEI_NACK, "Establish TEI NACK" },
188+ { NM_MT_CONN_TERR_SIGN, "Connect Terrestrial Signalling" },
189+ { NM_MT_CONN_TERR_SIGN_ACK, "Connect Terrestrial Signalling ACK" },
190+ { NM_MT_CONN_TERR_SIGN_NACK, "Connect Terrestrial Signalling NACK" },
191+ { NM_MT_DISC_TERR_SIGN, "Disconnect Terrestrial Signalling" },
192+ { NM_MT_DISC_TERR_SIGN_ACK, "Disconnect Terrestrial Signalling ACK" },
193+ { NM_MT_DISC_TERR_SIGN_NACK, "Disconnect Terrestrial Signalling NACK" },
194+ { NM_MT_CONN_TERR_TRAF, "Connect Terrestrial Traffic" },
195+ { NM_MT_CONN_TERR_TRAF_ACK, "Connect Terrestrial Traffic ACK" },
196+ { NM_MT_CONN_TERR_TRAF_NACK, "Connect Terrestrial Traffic NACK" },
197+ { NM_MT_DISC_TERR_TRAF, "Disconnect Terrestrial Traffic" },
198+ { NM_MT_DISC_TERR_TRAF_ACK, "Disconnect Terrestrial Traffic ACK" },
199+ { NM_MT_DISC_TERR_TRAF_NACK, "Disconnect Terrestrial Traffic NACK" },
200+ { NM_MT_CONN_MDROP_LINK, "Connect Multi-Drop Link" },
201+ { NM_MT_CONN_MDROP_LINK_ACK, "Connect Multi-Drop Link ACK" },
202+ { NM_MT_CONN_MDROP_LINK_NACK, "Connect Multi-Drop Link NACK" },
203+ { NM_MT_DISC_MDROP_LINK, "Disconnect Multi-Drop Link" },
204+ { NM_MT_DISC_MDROP_LINK_ACK, "Disconnect Multi-Drop Link ACK" },
205+ { NM_MT_DISC_MDROP_LINK_NACK, "Disconnect Multi-Drop Link NACK" },
206+ { NM_MT_SET_BTS_ATTR, "Set BTS Attributes" },
207+ { NM_MT_SET_BTS_ATTR_ACK, "Set BTS Attributes ACK" },
208+ { NM_MT_SET_BTS_ATTR_NACK, "Set BTS Attributes NACK" },
209+ { NM_MT_SET_RADIO_ATTR, "Set Radio Carrier Attributes" },
210+ { NM_MT_SET_RADIO_ATTR_ACK, "Set Radio Carrier Attributes ACK" },
211+ { NM_MT_SET_RADIO_ATTR_NACK, "Set Radio Carrier Attributes NACK" },
212+ { NM_MT_SET_CHAN_ATTR, "Set Channel Attributes" },
213+ { NM_MT_SET_CHAN_ATTR_ACK, "Set Channel Attributes ACK" },
214+ { NM_MT_SET_CHAN_ATTR_NACK, "Set Channel Attributes NACK" },
215+ { NM_MT_PERF_TEST, "Perform Test" },
216+ { NM_MT_PERF_TEST_ACK, "Perform Test ACK" },
217+ { NM_MT_PERF_TEST_NACK, "Perform Test NACK" },
218+ { NM_MT_TEST_REP, "Test Report" },
219+ { NM_MT_SEND_TEST_REP, "Send Test Report" },
220+ { NM_MT_SEND_TEST_REP_ACK, "Send Test Report ACK" },
221+ { NM_MT_SEND_TEST_REP_NACK, "Send Test Report NACK" },
222+ { NM_MT_STOP_TEST, "Stop Test" },
223+ { NM_MT_STOP_TEST_ACK, "Stop Test ACK" },
224+ { NM_MT_STOP_TEST_NACK, "Stop Test NACK" },
225+ { NM_MT_STATECHG_EVENT_REP, "State Changed Event Report" },
226+ { NM_MT_FAILURE_EVENT_REP, "Failure Event Report" },
227+ { NM_MT_STOP_EVENT_REP, "Stop Sending Event Reports" },
228+ { NM_MT_STOP_EVENT_REP_ACK, "Stop Sending Event Reports ACK" },
229+ { NM_MT_STOP_EVENT_REP_NACK, "Stop Sending Event Reports NACK" },
230+ { NM_MT_REST_EVENT_REP, "Restart Sending Event Reports" },
231+ { NM_MT_REST_EVENT_REP_ACK, "Restart Sending Event Reports ACK" },
232+ { NM_MT_REST_EVENT_REP_NACK, "Restart Sending Event Reports NACK" },
233+ { NM_MT_CHG_ADM_STATE, "Change Administrative State" },
234+ { NM_MT_CHG_ADM_STATE_ACK, "Change Administrative State ACK" },
235+ { NM_MT_CHG_ADM_STATE_NACK, "Change Administrative State NACK" },
236+ { NM_MT_CHG_ADM_STATE_REQ, "Change Administrative State Request" },
237+ { NM_MT_CHG_ADM_STATE_REQ_ACK, "Change Administrative State Request ACK" },
238+ { NM_MT_CHG_ADM_STATE_REQ_NACK, "Change Administrative State Request NACK" },
239+ { NM_MT_REP_OUTST_ALARMS, "Report Outstanding Alarms" },
240+ { NM_MT_REP_OUTST_ALARMS_ACK, "Report Outstanding Alarms ACK" },
241+ { NM_MT_REP_OUTST_ALARMS_NACK, "Report Outstanding Alarms NACK" },
242+ { NM_MT_CHANGEOVER, "Changeover" },
243+ { NM_MT_CHANGEOVER_ACK, "Changeover ACK" },
244+ { NM_MT_CHANGEOVER_NACK, "Changeover NACK" },
245+ { NM_MT_OPSTART, "Opstart" },
246+ { NM_MT_OPSTART_ACK, "Opstart ACK" },
247+ { NM_MT_OPSTART_NACK, "Opstart NACK" },
248+ { NM_MT_REINIT, "Reinitialize" },
249+ { NM_MT_REINIT_ACK, "Reinitialize ACK" },
250+ { NM_MT_REINIT_NACK, "Reinitialize NACK" },
251+ { NM_MT_SET_SITE_OUT, "Set Site Outputs" },
252+ { NM_MT_SET_SITE_OUT_ACK, "Set Site Outputs ACK" },
253+ { NM_MT_SET_SITE_OUT_NACK, "Set Site Outputs NACK" },
254+ { NM_MT_CHG_HW_CONF, "Change HW Configuration" },
255+ { NM_MT_CHG_HW_CONF_ACK, "Change HW Configuration ACK" },
256+ { NM_MT_CHG_HW_CONF_NACK, "Change HW Configuration NACK" },
257+ { NM_MT_MEAS_RES_REQ, "Measurement Result Request" },
258+ { NM_MT_MEAS_RES_RESP, "Measurement Result Response" },
259+ { NM_MT_STOP_MEAS, "Stop Measurement" },
260+ { NM_MT_START_MEAS, "Start Measurement" },
261+ { NM_MT_GET_ATTR, "Get Attributes" },
262+ { NM_MT_GET_ATTR_RESP, "Get Attributes Response" },
263+ { NM_MT_GET_ATTR_NACK, "Get Attributes NACK" },
264+ { NM_MT_SET_ALARM_THRES, "Set Alarm Threshold" },
265+ { NM_MT_SET_ALARM_THRES_ACK, "Set Alarm Threshold ACK" },
266+ { NM_MT_SET_ALARM_THRES_NACK, "Set Alarm Threshold NACK" },
267+ /* proprietary, not in the standard */
268+ { NM_MT_IPACC_RESTART, "IPA Restart" },
269+ { NM_MT_IPACC_RESTART_ACK, "IPA Restart ACK" },
270+ { NM_MT_IPACC_RSL_CONNECT, "IPA RSL Connect" },
271+ { NM_MT_IPACC_RSL_CONNECT_ACK, "IPA RSL Connect ACK" },
272+ { NM_MT_IPACC_RSL_CONNECT_NACK, "IPA RSL Connect NACK" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200273+ { NM_MT_IPACC_RSL_DISCONNECT, "IPA RSL Disconnect" },
274+ { NM_MT_IPACC_RSL_DISCONNECT_ACK, "IPA RSL Disconnect ACK" },
275+ { NM_MT_IPACC_RSL_DISCONNECT_NACK, "IPA RSL Disconnect NACK" },
276+ { NM_MT_IPACC_CONN_TRAF, "IPA Connect Traffic" },
277+ { NM_MT_IPACC_CONN_TRAF_ACK, "IPA Connect Traffic ACK" },
278+ { NM_MT_IPACC_CONN_TRAF_NACK, "IPA Connect Traffic NACK" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200279+ { NM_MT_IPACC_DISC_TRAF, "IPA Disconnect Traffic" },
280+ { NM_MT_IPACC_DISC_TRAF_ACK, "IPA Disconnect Traffic ACK" },
281+ { NM_MT_IPACC_DISC_TRAF_NACK, "IPA Disconnect Traffic NACK" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200282+ { NM_MT_IPACC_DEF_BOOT_SW, "IPA Default Boot Software" },
283+ { NM_MT_IPACC_DEF_BOOT_SW_ACK, "IPA Default Boot Software ACK" },
284+ { NM_MT_IPACC_DEF_BOOT_SW_NACK, "IPA Default Boot Software NACK" },
Harald Welte6900c162009-06-25 20:50:57 +0200285+ { NM_MT_IPACC_SET_NVATTR, "IPA Set NVRAM Attributes" },
286+ { NM_MT_IPACC_SET_NVATTR_ACK, "IPA Set NVRAM Attributes ACK" },
287+ { NM_MT_IPACC_SET_NVATTR_NACK, "IPA Set NVRAM Attributes NACK" },
288+ { NM_MT_IPACC_GET_NVATTR, "IPA Get NVRAM Attributes" },
289+ { NM_MT_IPACC_GET_NVATTR_ACK, "IPA Get NVRAM Attributes ACK" },
290+ { NM_MT_IPACC_GET_NVATTR_NACK, "IPA Get NVRAM Attributes NACK" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200291+ { NM_MT_IPACC_SET_ATTR, "IPA Set Attributes" },
292+ { NM_MT_IPACC_SET_ATTR_ACK, "IPA Set Attributes ACK" },
293+ { NM_MT_IPACC_SET_ATTR_NACK, "IPA Set Attributes NACK" },
294+ { NM_MT_IPACC_ATTR_CHG_EVT, "IPA Attribute Change Event" },
295+ { NM_MT_IPACC_SW_DEACT, "IPA Software Deactivate" },
296+ { NM_MT_IPACC_SW_DEACT_ACK, "IPA Software Deactivate ACK" },
297+ { NM_MT_IPACC_SW_DEACT_NACK, "IPA Software Deactivate NACK" },
298+ { NM_MT_IPACC_MEAS_RES_REQ_NACK,"IPA Measurement Result Request NACK" },
299+ { NM_MT_IPACC_START_MEAS_NACK, "IPA Start Measurement NACK" },
300+ { NM_MT_IPACC_STOP_MEAS_NACK, "IPA Stop Measurement NACK" },
Harald Welte6900c162009-06-25 20:50:57 +0200301+ { NM_MT_BS11_RESET_RESOURCE, "SIE Reset Resource" },
302+ { NM_MT_BS11_BEGIN_DB_TX, "SIE Begin Database Transmission" },
303+ { NM_MT_BS11_BEGIN_DB_TX_ACK, "SIE Begin Database Transmission ACK" },
304+ { NM_MT_BS11_BEGIN_DB_TX_NACK, "SIE Begin Database Transmission NACK" },
305+ { NM_MT_BS11_END_DB_TX, "SIE End Database Transmission" },
306+ { NM_MT_BS11_END_DB_TX_ACK, "SIE End Database Transmission ACK" },
307+ { NM_MT_BS11_END_DB_TX_NACK, "SIE End Database Transmission NACK" },
308+ { NM_MT_BS11_CREATE_OBJ, "SIE Create Object" },
309+ { NM_MT_BS11_CREATE_OBJ_ACK, "SIE Create Object ACK" },
310+ { NM_MT_BS11_CREATE_OBJ_NACK, "SIE Create Object NACK" },
311+ { NM_MT_BS11_DELETE_OBJ, "SIE Delete Object" },
312+ { NM_MT_BS11_DELETE_OBJ_ACK, "SIE Delete Object ACK" },
313+ { NM_MT_BS11_DELETE_OBJ_NACK, "SIE Delete Object NACK" },
314+ { NM_MT_BS11_GET_STATE, "SIE Get State" },
315+ { NM_MT_BS11_GET_STATE_ACK, "SIE Get State ACK" },
316+ { NM_MT_BS11_LMT_LOGON, "SIE LMT Logon" },
317+ { NM_MT_BS11_LMT_LOGON_ACK, "SIE LMT Logon ACK" },
318+ { NM_MT_BS11_RESTART, "SIE Restart" },
319+ { NM_MT_BS11_RESTART_ACK, "SIE Restart ACK" },
320+ { NM_MT_BS11_DISCONNECT, "SIE Disconnect BTS" },
321+ { NM_MT_BS11_DISCONNECT_ACK, "SIE Disconnect BTS ACK" },
322+ { NM_MT_BS11_LMT_LOGOFF, "SIE LMT Logoff" },
323+ { NM_MT_BS11_LMT_LOGOFF_ACK, "SIE LMT Logoff ACK" },
324+ { NM_MT_BS11_RECONNECT, "SIE Reconnect BTS" },
325+ { NM_MT_BS11_RECONNECT_ACK, "SIE Reconnect BTS ACK" },
326+};
327+
328+/* TS 12.21 Section 9.2: Object Class */
329+static const value_string oml_fom_objclass_vals[] = {
330+ { NM_OC_SITE_MANAGER, "BTS Site Manager" },
331+ { NM_OC_BTS, "BTS" },
332+ { NM_OC_RADIO_CARRIER, "Radio Carrier" },
333+ { NM_OC_CHANNEL, "Radio Channel" },
334+ { NM_OC_BASEB_TRANSC, "Baseband Transceiver" },
335+ /* proprietary, vendor specific */
336+ { NM_OC_BS11_ADJC, "SIE Adjacend Channel" },
337+ { NM_OC_BS11_HANDOVER, "SIE Handover" },
338+ { NM_OC_BS11_PWR_CTRL, "SIE Power Control" },
339+ { NM_OC_BS11_BTSE, "SIE BTSE" },
340+ { NM_OC_BS11_RACK, "SIE Rack" },
341+ { NM_OC_BS11, "SIE SiemensHW" },
342+ { NM_OC_BS11_TEST, "SIE Test" },
343+ { NM_OC_BS11_ENVABTSE, "SIE EnvaBTSE" },
344+ { NM_OC_BS11_BPORT, "SIE BPort" },
345+ { NM_OC_GPRS_NSE, "GPRS NSE" },
346+ { NM_OC_GPRS_CELL, "GPRS Cell" },
347+ { NM_OC_GPRS_NSVC0, "GPRS NSVC0" },
348+ { NM_OC_GPRS_NSVC1, "GPRS NSVC1" },
349+ { NM_OC_NULL, "NULL" },
350+};
351+
352+/* TS 12.21 Section 9.4: Attributes */
353+static const value_string oml_fom_attr_vals[] = {
354+ { NM_ATT_ABIS_CHANNEL, "A-bis Channel" },
355+ { NM_ATT_ADD_INFO, "Additional Information" },
356+ { NM_ATT_ADD_TEXT, "Additional Text" },
357+ { NM_ATT_ADM_STATE, "Administrative State" },
358+ { NM_ATT_ARFCN_LIST, "ARFCN List" },
359+ { NM_ATT_AUTON_REPORT, "Autonomously Report" },
360+ { NM_ATT_AVAIL_STATUS, "Availability Status" },
361+ { NM_ATT_BCCH_ARFCN, "BCCH ARFCN" },
362+ { NM_ATT_BSIC, "BSIC" },
363+ { NM_ATT_BTS_AIR_TIMER, "BTS Air Timer" },
364+ { NM_ATT_CCCH_L_I_P, "CCCH Load Indication Period" },
365+ { NM_ATT_CCCH_L_T, "CCCH Load Threshold" },
366+ { NM_ATT_CHAN_COMB, "Channel Combination" },
367+ { NM_ATT_CONN_FAIL_CRIT, "Connection Fail Criterion" },
368+ { NM_ATT_DEST, "Destination" },
369+ { NM_ATT_EVENT_TYPE, "Event Type" },
370+ { NM_ATT_FILE_ID, "File ID" },
371+ { NM_ATT_FILE_VERSION, "File Version" },
372+ { NM_ATT_GSM_TIME, "GSM Time" },
373+ { NM_ATT_HSN, "HSN" },
374+ { NM_ATT_HW_CONFIG, "HW Configuration" },
375+ { NM_ATT_HW_DESC, "HW Description" },
376+ { NM_ATT_INTAVE_PARAM, "Intave Parameter" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200377+ { NM_ATT_INTERF_BOUND, "Interference Boundaries" },
Harald Welte6900c162009-06-25 20:50:57 +0200378+ { NM_ATT_LIST_REQ_ATTR, "List of required Attributes" },
379+ { NM_ATT_MAIO, "MAIO" },
380+ { NM_ATT_MANUF_STATE, "Manufacturer Dependent State" },
381+ { NM_ATT_MANUF_THRESH, "Manufacturer Dependent Thresholds" },
382+ { NM_ATT_MANUF_ID, "Manufacturer Id" },
383+ { NM_ATT_MAX_TA, "Maximum Timing Advance" },
384+ { NM_ATT_MDROP_LINK, "Multi-drop BSC Link" },
385+ { NM_ATT_MDROP_NEXT, "Multi-drop next BTS Link" },
386+ { NM_ATT_NACK_CAUSES, "NACK Causes" },
387+ { NM_ATT_NY1, "Ny1" },
388+ { NM_ATT_OPER_STATE, "Operational State" },
389+ { NM_ATT_OVERL_PERIOD, "Overload Period" },
390+ { NM_ATT_PHYS_CONF, "Physical Config" },
391+ { NM_ATT_POWER_CLASS, "Power Class" },
392+ { NM_ATT_POWER_THRESH, "Power Output Thresholds" },
393+ { NM_ATT_PROB_CAUSE, "Probable Cause" },
394+ { NM_ATT_RACH_B_THRESH, "RACH Busy Threshold" },
395+ { NM_ATT_LDAVG_SLOTS, "RACH Load Averaging Slots" },
396+ { NM_ATT_RAD_SUBC, "Radio Sub Channel" },
397+ { NM_ATT_RF_MAXPOWR_R, "RF Max Power Reduction" },
398+ { NM_ATT_SITE_INPUTS, "Site Inputs" },
399+ { NM_ATT_SITE_OUTPUTS, "Site Outputs" },
400+ { NM_ATT_SOURCE, "Source" },
401+ { NM_ATT_SPEC_PROB, "Specific Problems" },
402+ { NM_ATT_START_TIME, "Starting Time" },
403+ { NM_ATT_T200, "T200" },
404+ { NM_ATT_TEI, "TEI" },
405+ { NM_ATT_TEST_DUR, "Test Duration" },
406+ { NM_ATT_TEST_NO, "Test No" },
407+ { NM_ATT_TEST_REPORT, "Test Report Info" },
408+ { NM_ATT_VSWR_THRESH, "VSWR Thresholds " },
409+ { NM_ATT_WINDOW_SIZE, "Window Size" },
410+ { NM_ATT_BS11_RSSI_OFFS, "SIE RSSI Offset" },
411+ { NM_ATT_BS11_TXPWR, "SIE TX Power" },
412+ { NM_ATT_BS11_DIVERSITY, "SIE Diversity" },
413+ { NM_ATT_TSC, "Training Sequence Code" },
414+ { NM_ATT_SW_CONFIG, "SW Configuration" },
415+ { NM_ATT_SW_DESCR, "SW Description" },
416+ { NM_ATT_SEVERITY, "Perceived Severity" },
417+ { NM_ATT_GET_ARI, "Get ARI" },
418+ { NM_ATT_HW_CONF_CHG, "HW Configuration Change" },
419+ { NM_ATT_OUTST_ALARM, "Outstanding Alarm" },
420+ { NM_ATT_FILE_DATA, "File Data" },
421+ { NM_ATT_MEAS_RES, "Measurement Result" },
422+ { NM_ATT_MEAS_TYPE, "Measurement Type" },
423+ { NM_ATT_BS11_ESN_FW_CODE_NO, "SIE ESN FW Code Number" },
424+ { NM_ATT_BS11_ESN_HW_CODE_NO, "SIE ESN HW Code Number" },
425+ { NM_ATT_BS11_ESN_PCB_SERIAL, "SIE ESN PCB Serial Number" },
426+ { NM_ATT_BS11_EXCESSIVE_DISTANCE, "SIE Excessive Distance" },
427+ { NM_ATT_BS11_ALL_TEST_CATG, "SIE All Test Categories" },
428+ { NM_ATT_BS11_BTSLS_HOPPING, "SIE BTS LS Hopping" },
429+ { NM_ATT_BS11_CELL_ALLOC_NR, "SIE Cell Allocation Number" },
430+ { NM_ATT_BS11_CELL_GLOBAL_ID, "SIE Cell Global ID" },
431+ { NM_ATT_BS11_ENA_INTERF_CLASS, "SIE Enable Interference Class" },
432+ /* FIXME */
433+ { NM_ATT_BS11_ENA_MS_PWR_CTRL, "SIE Enable MS Power Control" },
434+ { NM_ATT_BS11_ENA_PWR_BDGT_HO, "SIE Enable Power Budget HO" },
435+ { NM_ATT_BS11_ENA_RXLEV_HO, "SIE Enable RxLevel HO" },
436+ { NM_ATT_BS11_ENA_RXQUAL_HO, "SIE Enable RxQual HO" },
437+ { NM_ATT_BS11_FACCH_QUAL, "SIE FACCH Quality" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200438+ { NM_ATT_IPACC_DST_IP, "IPA Destination IP Address" },
439+ { NM_ATT_IPACC_DST_IP_PORT, "IPA Destionation IP Port" },
440+ { NM_ATT_IPACC_SSRC, "IPA RTP SSRC" },
441+ { NM_ATT_IPACC_RTP_PAYLD_TYPE, "IPA RTP Payload Type" },
442+ { NM_ATT_IPACC_BASEB_ID, "IPA Baseband Identifier" },
443+ { NM_ATT_IPACC_STREAM_ID, "IPA Stream Identifier" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200444+ { NM_ATT_IPACC_NV_FLAGS, "IPA NVRAM Flags" },
445+ { NM_ATT_IPACC_FREQ_CTRL, "IPA Frequency Control" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200446+ { NM_ATT_IPACC_PRIM_OML_CFG, "IPA Primary OML Config" },
447+ { NM_ATT_IPACC_SEC_OML_CFG, "IPA Secondary OML Config" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200448+ { NM_ATT_IPACC_IP_IF_CFG, "IPA IP Interface Config" },
449+ { NM_ATT_IPACC_IP_GW_CFG, "IPA IP Gateway Config" },
450+ { NM_ATT_IPACC_IN_SERV_TIME, "IPA In Service Time" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200451+ { NM_ATT_IPACC_TRX_BTS_ASS, "IPA TRX BTS Assignment" },
452+ { NM_ATT_IPACC_LOCATION, "IPA BTS Location Name" },
453+ { NM_ATT_IPACC_PAGING_CFG, "IPA Paging Configuration" },
454+ { NM_ATT_IPACC_FILE_DATA, "IPA File Data" },
Harald Welte6900c162009-06-25 20:50:57 +0200455+ { NM_ATT_IPACC_UNIT_ID, "IPA Unit ID" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200456+ { NM_ATT_IPACC_PARENT_UNIT_ID, "IPA Parent Unit ID" },
Harald Welte6900c162009-06-25 20:50:57 +0200457+ { NM_ATT_IPACC_UNIT_NAME, "IPA Unit Name" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200458+ { NM_ATT_IPACC_SNMP_CFG, "IPA SNMP Config" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200459+ { NM_ATT_IPACC_PRIM_OML_CFG_LIST, "IPA Primary OML Config List" },
460+ { NM_ATT_IPACC_PRIM_OML_FB_TOUT,"IPA Primary OML Fallback Timeout" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200461+ { NM_ATT_IPACC_CUR_SW_CFG, "IPA Current Software Config" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200462+ { NM_ATT_IPACC_TIMING_BUS, "IPA Timing Bus" },
463+ { NM_ATT_IPACC_CGI, "IPA CGI" },
464+ { NM_ATT_IPACC_RAC, "IPA RAC" },
465+ { NM_ATT_IPACC_OBJ_VERSION, "IPA Object Version" },
466+ { NM_ATT_IPACC_GPRS_PAGING_CFG, "IPA GPRS Paging Configuration" },
467+ { NM_ATT_IPACC_NSEI, "IPA NSEI" },
468+ { NM_ATT_IPACC_BVCI, "IPA BVCI" },
469+ { NM_ATT_IPACC_NSVCI, "IPA NSVCI" },
470+ { NM_ATT_IPACC_NS_CFG, "IPA NS Configuration" },
471+ { NM_ATT_IPACC_BSSGP_CFG, "IPA BSSGP Configuration" },
472+ { NM_ATT_IPACC_NS_LINK_CFG, "IPA NS Link Configuration" },
473+ { NM_ATT_IPACC_RLC_CFG, "IPA RLC Configuration" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200474+ { NM_ATT_IPACC_ALM_THRESH_LIST, "IPA Alarm Threshold List" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200475+ { NM_ATT_IPACC_MONIT_VAL_LIST, "IPA Monitored Value List" },
476+ { NM_ATT_IPACC_TIB_CONTROL, "IPA Timing Interface Bus Control" },
477+ { NM_ATT_IPACC_SUPP_FEATURES, "IPA Supported Features" },
478+ { NM_ATT_IPACC_CODING_SCHEMES, "IPA Coding Schemes" },
479+ { NM_ATT_IPACC_RLC_CFG_2, "IPA RLC Configuration 2" },
480+ { NM_ATT_IPACC_HEARTB_TOUT, "IPA Heartbeat Timeout" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200481+ { NM_ATT_IPACC_UPTIME, "IPA Uptime" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200482+ { NM_ATT_IPACC_RLC_CFG_3, "IPA RLC Configuration 3" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200483+ { NM_ATT_IPACC_SSL_CFG, "IPA SSL Configuration" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200484+ { NM_ATT_IPACC_SEC_POSSIBLE, "IPA Security Possible" },
485+ { NM_ATT_IPACC_IML_SSL_STATE, "IPA IML SSL State" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200486+ { NM_ATT_IPACC_REVOC_DATE, "IPA Revocation Date" },
Harald Welte6900c162009-06-25 20:50:57 +0200487+ /* FIXME: More SIE */
488+};
489+
490+/* Section 9.4.4: Administrative State */
491+static const value_string oml_adm_state_vals[] = {
492+ { NM_STATE_LOCKED, "Locked" },
493+ { NM_STATE_UNLOCKED, "Unlocked" },
494+ { NM_STATE_SHUTDOWN, "Shutdown" },
495+ { NM_STATE_NULL, "Null" },
496+};
497+
498+static const value_string oml_oper_state_vals[] = {
499+ { 1, "Disabled" },
500+ { 2, "Enabled" },
501+ { 0xff, "NULL" },
502+};
503+
504+/* Section 9.4.7 Availability Status */
505+static const value_string oml_avail_state_vals[] = {
506+ { 0, "In test" },
507+ { 1, "Failed" },
508+ { 2, "Power off" },
509+ { 3, "Off line" },
510+ { 5, "Dependency" },
511+ { 6, "Degraded" },
512+ { 7, "Not installed" },
513+ { 0xff, "OK" },
514+};
515+
516+/* Section 9.4.13: Channel Combination */
517+static const value_string oml_chan_comb_vals[] = {
518+ { NM_CHANC_TCHFull, "TCH/F" },
519+ { NM_CHANC_TCHHalf, "TCH/H" },
520+ { NM_CHANC_TCHHalf2, "TCH/H 2" },
521+ { NM_CHANC_SDCCH, "SDCCH" },
522+ { NM_CHANC_mainBCCH, "Main BCCH" },
523+ { NM_CHANC_BCCHComb, "Combined BCCH" },
524+ { NM_CHANC_BCCH, "BCCH" },
525+ { NM_CHANC_BCCH_CBCH, "BCCH+CBCH" },
526+ { NM_CHANC_SDCCH_CBCH, "SDCCH+CBCH" },
527+};
528+
529+/* Section 9.4.16: Event Type */
530+static const value_string oml_event_type_vals[] = {
531+ { NM_EVT_COMM_FAIL, "Communication Failure" },
532+ { NM_EVT_QOS_FAIL, "QoS Failure" },
533+ { NM_EVT_PROC_FAIL, "Processor Failure" },
534+ { NM_EVT_EQUIP_FAIL, "Equipment Failure" },
535+ { NM_EVT_ENV_FAIL, "Environment Failure" },
536+};
537+
538+/* Section 9.4.63: Perceived Severity */
539+static const value_string oml_severity_vals[] = {
540+ { NM_SEVER_CEASED, "Ceased" },
541+ { NM_SEVER_CRITICAL, "Critical" },
542+ { NM_SEVER_MAJOR, "Major" },
543+ { NM_SEVER_MINOR, "Minor" },
544+ { NM_SEVER_WARNING, "Warning" },
545+ { NM_SEVER_INDETERMINATE, "Indeterminate" },
546+};
547+
548+/* Section 9.4.36: NACK Causes */
549+static const value_string oml_nack_cause[] = {
550+ { NM_NACK_INCORR_STRUCT, "Incorrect message structure" },
551+ { NM_NACK_MSGTYPE_INVAL, "Invalid message type value" },
552+ { NM_NACK_OBJCLASS_INVAL, "Invalid Object class value" },
553+ { NM_NACK_OBJCLASS_NOTSUPP, "Object Class not supported" },
554+ { NM_NACK_BTSNR_UNKN, "BTS Number unknown" },
555+ { NM_NACK_TRXNR_UNKN, "TRX Number unknown" },
556+ { NM_NACK_OBJINST_UNKN, "Object Instance unknown" },
557+ { NM_NACK_ATTRID_INVAL, "Invalid Attribute ID value" },
558+ { NM_NACK_ATTRID_NOTSUPP, "Attribute ID not supported" },
559+ { NM_NACK_PARAM_RANGE, "Parameter value out of range" },
560+ { NM_NACK_ATTRLIST_INCONSISTENT, "Inconsistency in Attribute list" },
561+ { NM_NACK_SPEC_IMPL_NOTSUPP, "Specified Implementation not supported" },
562+ { NM_NACK_CANT_PERFORM, "Message cannot be performed" },
563+ { NM_NACK_RES_NOTIMPL, "Resource not implemented" },
564+ { NM_NACK_RES_NOTAVAIL, "Resource not available" },
565+ { NM_NACK_FREQ_NOTAVAIL, "Frequency not available" },
566+ { NM_NACK_TEST_NOTSUPP, "Test not supported" },
567+ { NM_NACK_CAPACITY_RESTR, "Capacity restrictions" },
568+ { NM_NACK_PHYSCFG_NOTPERFORM, "Phys config cannot be performed" },
569+ { NM_NACK_TEST_NOTINIT, "Test not initiated" },
570+ { NM_NACK_PHYSCFG_NOTRESTORE, "Phys config cannot be restored" },
571+ { NM_NACK_TEST_NOSUCH, "No such Test" },
572+ { NM_NACK_TEST_NOSTOP, "Test cannot be stopped" },
573+ { NM_NACK_MSGINCONSIST_PHYSCFG, "Message inconsisten with physical config" },
574+ { NM_NACK_FILE_INCOMPLETE, "Complete file not received" },
575+ { NM_NACK_FILE_NOTAVAIL, "File not available at destination" },
576+ { NM_NACK_FILE_NOTACTIVATE, "File cannot be activated" },
577+ { NM_NACK_REQ_NOT_GRANT, "Request not granted" },
578+ { NM_NACK_WAIT, "Wait" },
579+ { NM_NACK_NOTH_REPORT_EXIST, "Nothing reportable existing" },
580+ { NM_NACK_MEAS_NOTSUPP, "Measurement not supported" },
581+ { NM_NACK_MEAS_NOTSTART, "Measurement not started" },
582+ { 0xff, "NULL" },
583+};
584+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200585+static const value_string oml_test_no_vals[] = {
Harald Weltec9b484f2009-07-12 20:46:43 +0200586+ { NM_IPACC_TESTNO_RLOOP_ANT, "Radio Loop test via antenna" },
587+ { NM_IPACC_TESTNO_RLOOP_XCVR, "Radio Loop test via transceiver" },
588+ { NM_IPACC_TESTNO_FUNC_OBJ, "BTS Functional object self test" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200589+ { NM_IPACC_TESTNO_CHAN_USAGE, "Channel Usage" },
590+ { NM_IPACC_TESTNO_BCCH_CHAN_USAGE, "BCCH Channel Usage" },
591+ { NM_IPACC_TESTNO_FREQ_SYNC, "Frequency Synchronization" },
592+ { NM_IPACC_TESTNO_BCCH_INFO, "BCCH Information" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200593+ { NM_IPACC_TESTNO_TX_BEACON, "Transmit Beacon" },
594+ { NM_IPACC_TESTNO_SYSINFO_MONITOR, "SysInfo Monitor" },
595+ { NM_IPACC_TESTNO_BCCCH_MONITOR, "BCCH & CCCH Monitor" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200596+};
597+
598+static const value_string ipacc_test_res_vals[] = {
599+ { NM_IPACC_TESTRES_SUCCESS, "Success" },
600+ { NM_IPACC_TESTRES_TIMEOUT, "Timeout" },
601+ { NM_IPACC_TESTRES_NO_CHANS, "No suitable channels available" },
602+ { NM_IPACC_TESTRES_PARTIAL, "Partial" },
603+ { NM_IPACC_TESTRES_STOPPED, "Stopped" },
604+};
605+
606+static const value_string ipacc_testres_ie_vals[] = {
607+ { NM_IPACC_TR_IE_FREQ_ERR_LIST, "Frequency Error List" },
608+ { NM_IPACC_TR_IE_CHAN_USAGE, "Channel Usage" },
609+ { NM_IPACC_TR_IE_BCCH_INFO, "BCCH Information" },
610+ { NM_IPACC_TR_IE_RESULT_DETAILS,"Result Details" },
611+ { NM_IPACC_TR_IE_FREQ_ERR, "Frequency Error" },
612+};
613+
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +0800614+static const struct tlv_def *
615+find_tlv_tag(guint8 tag)
616+{
617+ const struct tlv_def *specific;
618+
619+ if (global_oml_use_nano_bts)
620+ specific = &nm_att_tlvdef_ipa.def[tag];
621+ else
622+ specific = &nm_att_tlvdev_bs11.def[tag];
623+
624+ if (specific->type != TLV_TYPE_FIXED)
625+ return specific;
626+
627+ return &nm_att_tlvdef_base.def[tag];
628+}
629+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200630+/* Parse the ip.access specific BCCH Information IE embedded into the Test
631+ * Report IE */
632+static gint
633+ipacc_tr_ie_bcch(tvbuff_t *tvb, proto_tree *att_tree, int offset)
634+{
Harald Welte450129f2009-07-03 12:46:47 +0200635+ guint16 binfo_type, tmp;
636+
637+ binfo_type = tvb_get_ntohs(tvb, offset);
638+ offset += 2;
639+
640+ tmp = tvb_get_ntohs(tvb, offset);
Harald Welte1cc3fa82009-07-01 17:40:50 +0200641+
642+ /* FIXME: there are still some bugs remaining here */
643+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_arfcn,
644+ tvb, offset, 2, TRUE);
Harald Welte450129f2009-07-03 12:46:47 +0200645+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200646+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_f_qual,
647+ tvb, offset, 2, TRUE);
648+ offset += 2;
Harald Welte450129f2009-07-03 12:46:47 +0200649+
650+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_b_rxlev,
Harald Welte1cc3fa82009-07-01 17:40:50 +0200651+ tvb, offset++, 1, TRUE);
Harald Welte450129f2009-07-03 12:46:47 +0200652+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200653+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_rxqual,
654+ tvb, offset++, 1, TRUE);
Harald Welte450129f2009-07-03 12:46:47 +0200655+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200656+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_f_err,
657+ tvb, offset, 2, TRUE);
658+ offset += 2;
Harald Welte450129f2009-07-03 12:46:47 +0200659+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200660+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_frame_offs,
661+ tvb, offset, 2, TRUE);
662+ offset += 2;
663+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_framenr_offs,
664+ tvb, offset, 4, TRUE);
665+ offset += 4;
Harald Welte450129f2009-07-03 12:46:47 +0200666+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200667+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_bsic,
668+ tvb, offset++, 1, TRUE);
Harald Welte450129f2009-07-03 12:46:47 +0200669+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200670+ de_lai(tvb, att_tree, offset, 5, NULL, 0);
671+ offset += 5;
Harald Welte450129f2009-07-03 12:46:47 +0200672+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200673+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_cell_id,
674+ tvb, offset, 2, TRUE);
675+ offset += 2;
Harald Welte450129f2009-07-03 12:46:47 +0200676+
677+ if (binfo_type & 0x8000) {
678+ /* System Information 2 */
679+ /* FIXME: Parse 04.18 Neighbour Cell Description */
680+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_si2,
681+ tvb, offset, 16, TRUE);
682+ offset += 16;
683+ }
684+ if (binfo_type & 0x0001) {
685+ /* System Information 2bis */
686+ /* FIXME: Parse 04.18 Neighbour Cell Description */
687+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_si2bis,
688+ tvb, offset, 16, TRUE);
689+ offset += 16;
690+ }
691+ if (binfo_type & 0x0002) {
692+ /* System Information 2ter */
693+ /* FIXME: Parse 04.18 Neighbour Cell Description */
694+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_si2ter,
695+ tvb, offset, 16, TRUE);
696+ offset += 16;
697+ }
698+ if (binfo_type & 0x0004) {
699+ /* FIXME: Parse 04.18 Cell Channel Description */
700+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_chan_desc,
701+ tvb, offset, 16, TRUE);
702+ offset += 16;
703+ }
Harald Welte1cc3fa82009-07-01 17:40:50 +0200704+
705+ return offset;
706+}
707+
708+/* Parse the ip.access specific Channel Usage IE embedded into the Test
709+ * Report IE */
710+static gint
711+ipacc_tr_ie_chan_usage(tvbuff_t *tvb, proto_tree *att_tree, int offset)
712+{
713+ while (tvb_reported_length_remaining(tvb, offset) != 0) {
Holger Hans Peter Freyther8d66dfb2010-05-23 03:46:46 +0800714+ guint16 result;
715+
716+ result = tvb_get_ntohs(tvb, offset);
Harald Welte1cc3fa82009-07-01 17:40:50 +0200717+ proto_tree_add_uint(att_tree, hf_attr_ipa_tr_arfcn,
718+ tvb, offset, 2, result);
719+ proto_tree_add_uint(att_tree, hf_attr_ipa_tr_rxlev,
720+ tvb, offset, 2, result);
721+ offset += 2;
722+ }
723+ return offset;
724+}
725+
726+/* Parse the ip.access specific format of the standard test report IE */
727+static gint
728+dissect_ipacc_test_rep(proto_tree *tree, tvbuff_t *tvb)
729+{
730+ gint offset = 0;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200731+
732+ proto_tree_add_item(tree, hf_attr_ipa_test_res, tvb, offset++,
733+ 1, FALSE);
734+
735+ while (tvb_reported_length_remaining(tvb, offset) != 0) {
Holger Hans Peter Freyther8d66dfb2010-05-23 03:46:46 +0800736+ guint8 ie;
737+ guint16 len;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200738+ proto_item *ti;
739+ proto_tree *att_tree;
740+
Holger Hans Peter Freyther8d66dfb2010-05-23 03:46:46 +0800741+ ie = tvb_get_guint8(tvb, offset);
742+ len = tvb_get_ntohs(tvb, offset+1);
Harald Welte1cc3fa82009-07-01 17:40:50 +0200743+ ti = proto_tree_add_item(tree, hf_oml_ipa_tres_attr_tag, tvb,
744+ offset++, 1, FALSE);
745+ att_tree = proto_item_add_subtree(ti, ett_oml_fom_att);
746+ proto_tree_add_uint(att_tree, hf_oml_ipa_tres_attr_len, tvb,
747+ offset, 2, len);
748+ offset += 2;
749+
750+ switch (ie) {
751+ case NM_IPACC_TR_IE_CHAN_USAGE:
752+ offset = ipacc_tr_ie_chan_usage(tvb,
753+ att_tree, offset);
754+ break;
755+ case NM_IPACC_TR_IE_BCCH_INFO:
756+ offset = ipacc_tr_ie_bcch(tvb,
757+ att_tree, offset);
758+ break;
759+ default:
760+ break;
761+ }
762+ }
Harald Welteb16004c2009-07-11 19:44:53 +0200763+ return offset;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200764+}
765+
766+/* Dissect OML FOM Attributes after OML + FOM header */
Harald Welte6900c162009-06-25 20:50:57 +0200767+static gint
768+dissect_oml_attrs(tvbuff_t *tvb, int base_offs, packet_info *pinfo,
769+ proto_tree *tree)
770+{
771+ int offset = base_offs;
772+
773+ while (tvb_reported_length_remaining(tvb, offset) != 0) {
Harald Welte2c544c82009-07-11 16:41:15 +0200774+ guint i;
Harald Welte6900c162009-06-25 20:50:57 +0200775+ guint8 tag, val8;
Harald Welte2c544c82009-07-11 16:41:15 +0200776+ guint16 val16;
777+ guint32 val32;
Harald Welte6900c162009-06-25 20:50:57 +0200778+ unsigned int len, len_len, hlen;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200779+ const struct tlv_def *tdef;
Harald Welte6900c162009-06-25 20:50:57 +0200780+ proto_item *ti;
781+ proto_tree *att_tree;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200782+ tvbuff_t *sub_tvb;
Harald Welte6900c162009-06-25 20:50:57 +0200783+
784+ tag = tvb_get_guint8(tvb, offset);
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +0800785+ tdef = find_tlv_tag(tag);
Harald Welte6900c162009-06-25 20:50:57 +0200786+
787+ switch (tdef->type) {
788+ case TLV_TYPE_FIXED:
789+ hlen = 1;
790+ len_len = 0;
791+ len = tdef->fixed_len;
792+ break;
793+ case TLV_TYPE_T:
794+ hlen = 1;
795+ len_len = 0;
796+ len = 0;
797+ break;
798+ case TLV_TYPE_TV:
799+ hlen = 1;
800+ len_len = 0;
801+ len = 1;
802+ break;
803+ case TLV_TYPE_TLV:
804+ hlen = 2;
805+ len_len = 1;
806+ len = tvb_get_guint8(tvb, offset+1);
807+ break;
808+ case TLV_TYPE_TL16V:
809+ hlen = 3;
810+ len_len = 2;
811+ len = tvb_get_guint8(tvb, offset+1) << 8 |
812+ tvb_get_guint8(tvb, offset+2);
813+ break;
Harald Welteb16004c2009-07-11 19:44:53 +0200814+ default:
815+ hlen = len_len = len = 0;
816+ DISSECTOR_ASSERT_NOT_REACHED();
817+ break;
Harald Welte6900c162009-06-25 20:50:57 +0200818+ }
819+
820+ ti = proto_tree_add_item(tree, hf_oml_fom_attr_tag, tvb,
821+ offset, 1, FALSE);
822+ att_tree = proto_item_add_subtree(ti, ett_oml_fom_att);
823+ proto_tree_add_uint(att_tree, hf_oml_fom_attr_len, tvb,
824+ offset+1, len_len, len);
825+ offset += hlen;
826+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200827+ sub_tvb = tvb_new_subset(tvb, offset, len, len);
828+
Harald Welte6900c162009-06-25 20:50:57 +0200829+ switch (tag) {
830+ /* parse only the most common IE for now */
831+ case NM_ATT_ABIS_CHANNEL:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200832+ proto_tree_add_item(att_tree, hf_attr_ach_btsp, tvb,
833+ offset, 1, TRUE);
834+ proto_tree_add_item(att_tree, hf_attr_ach_tslot, tvb,
835+ offset+1, 1, TRUE);
836+ proto_tree_add_item(att_tree, hf_attr_ach_sslot, tvb,
837+ offset+2, 1, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200838+ break;
839+ case NM_ATT_ADM_STATE:
840+ proto_tree_add_item(att_tree, hf_attr_adm_state, tvb,
841+ offset, len, FALSE);
Harald Welte2c544c82009-07-11 16:41:15 +0200842+ val8 = tvb_get_guint8(tvb, offset);
843+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
844+ val_to_str(val8, oml_adm_state_vals,
845+ "%02x"));
Harald Welte6900c162009-06-25 20:50:57 +0200846+ break;
847+ case NM_ATT_ARFCN_LIST:
Harald Welte2c544c82009-07-11 16:41:15 +0200848+ for (i = 0; i < len; i += 2) {
849+ val16 = tvb_get_ntohs(tvb, offset + i);
850+ proto_tree_add_uint(att_tree, hf_attr_arfcn,
851+ tvb, offset + i, 2, val16);
852+ }
Harald Welte6900c162009-06-25 20:50:57 +0200853+ break;
854+ case NM_ATT_AVAIL_STATUS:
Harald Welte2c544c82009-07-11 16:41:15 +0200855+ /* Availability status can have length 0 */
856+ if (len) {
857+ val8 = tvb_get_guint8(tvb, offset);
858+ proto_tree_add_item(att_tree,
859+ hf_attr_avail_state, tvb,
860+ offset, len, FALSE);
861+ } else
862+ val8 = 0xff;
863+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
864+ val_to_str(val8, oml_avail_state_vals,
865+ "%02x"));
Harald Welte6900c162009-06-25 20:50:57 +0200866+ break;
867+ case NM_ATT_BCCH_ARFCN:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200868+ proto_tree_add_item(att_tree, hf_attr_bcch_arfcn, tvb,
869+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200870+ break;
871+ case NM_ATT_BSIC:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200872+ proto_tree_add_item(att_tree, hf_attr_bsic, tvb,
873+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200874+ break;
875+ case NM_ATT_CHAN_COMB:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200876+ proto_tree_add_item(att_tree, hf_attr_chan_comb, tvb,
877+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200878+ break;
879+ case NM_ATT_EVENT_TYPE:
880+ proto_tree_add_item(att_tree, hf_attr_event_type, tvb,
Harald Welte1cc3fa82009-07-01 17:40:50 +0200881+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200882+ break;
883+ case NM_ATT_GSM_TIME:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200884+ proto_tree_add_item(att_tree, hf_attr_gsm_time, tvb,
885+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200886+ break;
887+ case NM_ATT_OPER_STATE:
888+ proto_tree_add_item(att_tree, hf_attr_oper_state, tvb,
889+ offset, len, FALSE);
Harald Welte2c544c82009-07-11 16:41:15 +0200890+ val8 = tvb_get_guint8(tvb, offset);
891+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
892+ val_to_str(val8, oml_oper_state_vals,
893+ "%02x"));
Harald Welte6900c162009-06-25 20:50:57 +0200894+ break;
895+ case NM_ATT_TEI:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200896+ proto_tree_add_item(att_tree, hf_attr_tei, tvb,
897+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200898+ break;
899+ case NM_ATT_TSC:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200900+ proto_tree_add_item(att_tree, hf_attr_tsc, tvb,
901+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200902+ break;
903+ case NM_ATT_SEVERITY:
904+ proto_tree_add_item(att_tree, hf_attr_severity, tvb,
Harald Welte1cc3fa82009-07-01 17:40:50 +0200905+ offset, len, TRUE);
906+ break;
907+ case NM_ATT_TEST_REPORT:
908+ dissect_ipacc_test_rep(att_tree, sub_tvb);
909+ break;
910+ case NM_ATT_TEST_NO:
911+ proto_tree_add_item(att_tree, hf_attr_test_no, tvb,
912+ offset, len, TRUE);
Harald Welte2c544c82009-07-11 16:41:15 +0200913+ val8 = tvb_get_guint8(tvb, offset);
914+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
915+ val_to_str(val8, oml_test_no_vals,
916+ "%02x"));
Harald Welte6900c162009-06-25 20:50:57 +0200917+ break;
918+
919+ /* proprietary ip.access extensions */
Harald Weltec9b484f2009-07-12 20:46:43 +0200920+ case NM_ATT_IPACC_DST_IP:
Harald Welte2c544c82009-07-11 16:41:15 +0200921+ val32 = tvb_get_ntohl(tvb, offset);
922+ proto_tree_add_ipv4(att_tree, hf_attr_ipa_rsl_ip, tvb,
923+ offset, len, val32);
Harald Welte6900c162009-06-25 20:50:57 +0200924+ break;
Harald Weltec9b484f2009-07-12 20:46:43 +0200925+ case NM_ATT_IPACC_DST_IP_PORT:
Harald Welte2c544c82009-07-11 16:41:15 +0200926+ val16 = tvb_get_ntohs(tvb, offset);
927+ proto_tree_add_uint(att_tree, hf_attr_ipa_rsl_port, tvb,
928+ offset, len, val16);
Harald Welte6900c162009-06-25 20:50:57 +0200929+ break;
930+ case NM_ATT_IPACC_LOCATION:
Harald Welte450129f2009-07-03 12:46:47 +0200931+ proto_tree_add_item(att_tree, hf_attr_ipa_location_name,
932+ tvb, offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200933+ break;
934+ case NM_ATT_IPACC_UNIT_ID:
Harald Welte450129f2009-07-03 12:46:47 +0200935+ proto_tree_add_item(att_tree, hf_attr_ipa_unit_id,
936+ tvb, offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200937+ break;
938+ case NM_ATT_IPACC_UNIT_NAME:
Harald Welte450129f2009-07-03 12:46:47 +0200939+ proto_tree_add_item(att_tree, hf_attr_ipa_unit_name,
940+ tvb, offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200941+ break;
Harald Weltec9b484f2009-07-12 20:46:43 +0200942+ case NM_ATT_IPACC_PRIM_OML_CFG_LIST:
Harald Welte450129f2009-07-03 12:46:47 +0200943+ proto_tree_add_item(att_tree, hf_attr_ipa_prim_oml_ip,
944+ tvb, offset+1, 4, TRUE);
945+ proto_tree_add_item(att_tree, hf_attr_ipa_prim_oml_port,
946+ tvb, offset+1+4, 2, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200947+ break;
Harald Welte450129f2009-07-03 12:46:47 +0200948+ case NM_ATT_IPACC_NV_FLAGS:
949+ {
950+ guint flags, mask;
951+ flags = tvb_get_guint8(tvb, offset);
952+ mask = tvb_get_guint8(tvb, offset+1);
953+ flags |= tvb_get_guint8(tvb, offset+2) << 8;
954+ mask |= tvb_get_guint8(tvb, offset+3) << 8;
955+ proto_tree_add_uint(att_tree, hf_attr_ipa_nv_flags,
956+ tvb, offset, 3, flags);
957+ proto_tree_add_uint(att_tree, hf_attr_ipa_nv_mask,
958+ tvb, offset+1, 3, mask);
959+ }
Harald Welte6900c162009-06-25 20:50:57 +0200960+ break;
Harald Weltec9b484f2009-07-12 20:46:43 +0200961+ case NM_ATT_IPACC_RAC:
962+ proto_tree_add_item(att_tree, hf_attr_ipa_rac,
963+ tvb, offset, 1, TRUE);
964+ break;
965+ case NM_ATT_IPACC_NSEI:
966+ val16 = tvb_get_ntohs(tvb, offset);
967+ proto_tree_add_uint(att_tree, hf_attr_ipa_nsei,
968+ tvb, offset, 2, val16);
969+ break;
970+ case NM_ATT_IPACC_NSVCI:
971+ val16 = tvb_get_ntohs(tvb, offset);
972+ proto_tree_add_uint(att_tree, hf_attr_ipa_nsvci,
973+ tvb, offset, 2, val16);
974+ break;
975+ case NM_ATT_IPACC_BVCI:
976+ val16 = tvb_get_ntohs(tvb, offset);
977+ proto_tree_add_uint(att_tree, hf_attr_ipa_bvci,
978+ tvb, offset, 2, val16);
979+ break;
980+ case NM_ATT_IPACC_NS_LINK_CFG:
981+ val16 = tvb_get_ntohs(tvb, offset);
982+ proto_tree_add_uint(att_tree, hf_attr_ipa_nsl_sport,
983+ tvb, offset, 2, val16);
984+ val32 = tvb_get_ipv4(tvb, offset+2);
985+ proto_tree_add_ipv4(att_tree, hf_attr_ipa_nsl_daddr,
986+ tvb, offset+2, 4, val32);
987+ val16 = tvb_get_ntohs(tvb, offset+6);
988+ proto_tree_add_uint(att_tree, hf_attr_ipa_nsl_dport,
989+ tvb, offset+6, 2, val16);
990+ break;
Harald Welte6900c162009-06-25 20:50:57 +0200991+ default:
992+ proto_tree_add_item(att_tree, hf_oml_fom_attr_val, tvb,
993+ offset, len, FALSE);
994+ }
995+ offset += len;
996+ }
997+ return offset;
998+}
999+
1000+static int
Harald Welte2c544c82009-07-11 16:41:15 +02001001+dissect_oml_fom(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
1002+ int offset, proto_item *top_ti)
Harald Welte6900c162009-06-25 20:50:57 +02001003+{
1004+ guint8 msg_type, obj_class, bts_nr, trx_nr, ts_nr;
1005+ proto_item *ti;
1006+ proto_tree *fom_tree;
1007+
1008+ msg_type = tvb_get_guint8(tvb, offset);
1009+ obj_class = tvb_get_guint8(tvb, offset+1);
1010+ bts_nr = tvb_get_guint8(tvb, offset+2);
1011+ trx_nr = tvb_get_guint8(tvb, offset+3);
1012+ ts_nr = tvb_get_guint8(tvb, offset+4);
Harald Welte2c544c82009-07-11 16:41:15 +02001013+ proto_item_append_text(top_ti, ", %s(%02x,%02x,%02x) %s ",
1014+ val_to_str(obj_class, oml_fom_objclass_vals, "%02x"),
1015+ bts_nr, trx_nr, ts_nr,
1016+ val_to_str(msg_type, oml_fom_msgtype_vals,
1017+ "unknown 0x%x"));
1018+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s(%02x,%02x,%02x) %s ",
1019+ val_to_str(obj_class, oml_fom_objclass_vals, "%02x"),
1020+ bts_nr, trx_nr, ts_nr,
1021+ val_to_str(msg_type, oml_fom_msgtype_vals,
1022+ "unknown 0x%x"));
Harald Welte6900c162009-06-25 20:50:57 +02001023+ ti = proto_tree_add_item(tree, hf_oml_fom_msgtype, tvb, offset++, 1, FALSE);
1024+ fom_tree = proto_item_add_subtree(ti, ett_oml_fom);
1025+ proto_tree_add_item(fom_tree, hf_oml_fom_objclass, tvb, offset++, 1, FALSE);
1026+ proto_tree_add_item(fom_tree, hf_oml_fom_inst_bts, tvb, offset++, 1, FALSE);
1027+ proto_tree_add_item(fom_tree, hf_oml_fom_inst_trx, tvb, offset++, 1, FALSE);
1028+ proto_tree_add_item(fom_tree, hf_oml_fom_inst_ts, tvb, offset++, 1, FALSE);
1029+
1030+
1031+ /* dissect the TLV objects in the message body */
1032+ offset = dissect_oml_attrs(tvb, offset, pinfo, fom_tree);
1033+
1034+ return offset;
1035+}
1036+
Harald Welte1cc3fa82009-07-01 17:40:50 +02001037+static const guint8 ipaccess_magic[] = "com.ipaccess";
1038+
1039+static int
Harald Welte2c544c82009-07-11 16:41:15 +02001040+dissect_oml_manuf(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
1041+ int offset, proto_item *top_ti)
Harald Welte1cc3fa82009-07-01 17:40:50 +02001042+{
1043+ if (tvb_get_guint8(tvb, offset) != 0x0d ||
1044+ tvb_memeql(tvb, offset+1, ipaccess_magic, sizeof(ipaccess_magic)))
1045+ return offset;
1046+
1047+ offset += sizeof(ipaccess_magic) + 1;
1048+
Harald Welte2c544c82009-07-11 16:41:15 +02001049+ return dissect_oml_fom(tvb, pinfo, tree, offset, top_ti);
Harald Welte1cc3fa82009-07-01 17:40:50 +02001050+}
Harald Welte6900c162009-06-25 20:50:57 +02001051+
1052+static void
1053+dissect_abis_oml(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
1054+{
1055+ proto_item *ti;
1056+ proto_tree *oml_tree;
Harald Welte6900c162009-06-25 20:50:57 +02001057+
1058+ int offset = 0;
1059+
Harald Welte2c544c82009-07-11 16:41:15 +02001060+ col_set_str(pinfo->cinfo, COL_PROTOCOL, "OML");
Harald Welte6900c162009-06-25 20:50:57 +02001061+
1062+ top_tree = tree;
1063+ if (tree) {
1064+ u_int8_t msg_disc = tvb_get_guint8(tvb, offset);
1065+
1066+ ti = proto_tree_add_item(tree, proto_abis_oml, tvb, 0, -1, FALSE);
1067+ oml_tree = proto_item_add_subtree(ti, ett_oml);
1068+
Harald Welte1cc3fa82009-07-01 17:40:50 +02001069+ proto_tree_add_item(oml_tree, hf_oml_msg_disc, tvb, offset++,
1070+ 1, TRUE);
1071+ proto_tree_add_item(oml_tree, hf_oml_placement, tvb, offset++,
1072+ 1, TRUE);
1073+ proto_tree_add_item(oml_tree, hf_oml_sequence, tvb, offset++,
1074+ 1, TRUE);
1075+ proto_tree_add_item(oml_tree, hf_oml_length, tvb, offset++,
1076+ 1, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +02001077+
1078+ switch (msg_disc) {
1079+ case ABIS_OM_MDISC_FOM:
Harald Welte2c544c82009-07-11 16:41:15 +02001080+ offset = dissect_oml_fom(tvb, pinfo, oml_tree,
1081+ offset, ti);
Harald Welte6900c162009-06-25 20:50:57 +02001082+ break;
Harald Welte1cc3fa82009-07-01 17:40:50 +02001083+ case ABIS_OM_MDISC_MANUF:
Harald Welte2c544c82009-07-11 16:41:15 +02001084+ offset = dissect_oml_manuf(tvb, pinfo, oml_tree, offset, ti);
Harald Welte1cc3fa82009-07-01 17:40:50 +02001085+ break;
Harald Welte6900c162009-06-25 20:50:57 +02001086+ case ABIS_OM_MDISC_MMI:
1087+ case ABIS_OM_MDISC_TRAU:
Harald Welte6900c162009-06-25 20:50:57 +02001088+ default:
1089+ break;
1090+ }
1091+ }
1092+}
1093+
1094+void
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +01001095+proto_reg_handoff_abis_oml(void);
1096+
1097+void
Harald Welte6900c162009-06-25 20:50:57 +02001098+proto_register_abis_oml(void)
1099+{
1100+ static hf_register_info hf[] = {
1101+ { &hf_oml_msg_disc,
1102+ { "Message Discriminator", "oml.msg_dsc",
1103+ FT_UINT8, BASE_HEX, VALS(oml_msg_disc_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001104+ "GSM 12.21 Message Discriminator", HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001105+ },
1106+ { &hf_oml_placement,
1107+ { "Placement Indicator", "oml.placement",
1108+ FT_UINT8, BASE_HEX, VALS(oml_placement_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001109+ "GSM 12.21 Placement Indicator", HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001110+ },
1111+ { &hf_oml_sequence,
1112+ { "Sequence Number", "oml.sequence",
1113+ FT_UINT8, BASE_HEX, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001114+ "Sequence Number (if multi-part msg)", HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001115+ },
1116+ { &hf_oml_length,
1117+ { "Length Indicator", "oml.length",
1118+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001119+ "Total length of payload", HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001120+ },
1121+ { &hf_oml_fom_msgtype,
1122+ { "FOM Message Type", "oml.fom.msg_type",
1123+ FT_UINT8, BASE_HEX, VALS(oml_fom_msgtype_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001124+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001125+ },
1126+ { &hf_oml_fom_objclass,
1127+ { "FOM Object Class", "oml.fom.obj_class",
1128+ FT_UINT8, BASE_HEX, VALS(oml_fom_objclass_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001129+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001130+ },
1131+ { &hf_oml_fom_inst_bts,
1132+ { "FOM Object Instance BTS", "oml.fom.obj_inst.bts",
1133+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001134+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001135+ },
1136+ { &hf_oml_fom_inst_trx,
1137+ { "FOM Object Instance TRX", "oml.fom.obj_inst.trx",
1138+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001139+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001140+ },
1141+ { &hf_oml_fom_inst_ts,
1142+ { "FOM Object Instance TS", "oml.fom.obj_inst.ts",
1143+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001144+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001145+ },
1146+ { &hf_oml_fom_attr_tag,
1147+ { "FOM Attribute ID", "oml.fom.attr_id",
1148+ FT_UINT8, BASE_HEX, VALS(oml_fom_attr_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001149+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001150+ },
1151+ { &hf_oml_fom_attr_len,
1152+ { "FOM Attribute Length", "oml.fom.attr_len",
1153+ FT_UINT16, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001154+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001155+ },
1156+ { &hf_oml_fom_attr_val,
1157+ { "FOM Attribute Value", "oml.fom.attr_val",
Harald Weltea165a422009-10-22 10:09:21 +02001158+ FT_BYTES, BASE_NONE, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001159+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001160+ },
1161+
1162+
1163+
1164+ /* OML Attributes */
1165+ { &hf_attr_adm_state,
1166+ { "Administrative State", "oml.fom.attr.adm_state",
1167+ FT_UINT8, BASE_HEX, VALS(oml_adm_state_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001168+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001169+ },
Harald Welte2c544c82009-07-11 16:41:15 +02001170+ { &hf_attr_arfcn,
1171+ { "ARFCN", "oml.fom.attr.arfcn",
1172+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1173+ },
Harald Welte6900c162009-06-25 20:50:57 +02001174+ { &hf_attr_oper_state,
1175+ { "Operational State", "oml.fom.attr.oper_state",
1176+ FT_UINT8, BASE_HEX, VALS(oml_oper_state_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001177+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001178+ },
1179+ { &hf_attr_avail_state,
1180+ { "Availability Status", "oml.fom.attr.avail_state",
1181+ FT_UINT8, BASE_HEX, VALS(oml_avail_state_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001182+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001183+ },
1184+ { &hf_attr_event_type,
1185+ { "Event Type", "oml.fom.attr.event_type",
1186+ FT_UINT8, BASE_HEX, VALS(oml_event_type_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001187+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001188+ },
1189+ { &hf_attr_severity,
1190+ { "Severity", "oml.fom.attr.severity",
1191+ FT_UINT8, BASE_HEX, VALS(oml_severity_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001192+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001193+ },
Harald Welte1cc3fa82009-07-01 17:40:50 +02001194+ { &hf_attr_bcch_arfcn,
1195+ { "BCCH ARFCN", "oml.fom.attr.bcch_arfcn",
1196+ FT_UINT16, BASE_DEC, NULL, 0,
1197+ "ARFCN of the BCCH", HFILL }
1198+ },
1199+ { &hf_attr_bsic,
1200+ { "BSIC", "oml.fom.attr.bsic",
1201+ FT_UINT16, BASE_HEX, NULL, 0,
1202+ "Base Station Identity Cdoe", HFILL }
1203+ },
1204+ { &hf_attr_test_no,
1205+ { "Test Number", "oml.fom.attr.test_no",
1206+ FT_UINT8, BASE_HEX, VALS(oml_test_no_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001207+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001208+ },
1209+ { &hf_attr_tsc,
1210+ { "TSC", "oml.fom.attr.tsc",
1211+ FT_UINT8, BASE_HEX, NULL, 0,
1212+ "Training Sequence Code", HFILL }
1213+ },
1214+ { &hf_attr_tei,
1215+ { "TEI", "oml.fom.attr.tei",
1216+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001217+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001218+ },
1219+ { &hf_attr_ach_btsp,
Harald Welte450129f2009-07-03 12:46:47 +02001220+ { "BTS E1 Port", "oml.fom.attr.abis_ch.bts_port",
Harald Welte1cc3fa82009-07-01 17:40:50 +02001221+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001222+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001223+ },
1224+ { &hf_attr_ach_tslot,
Harald Welte450129f2009-07-03 12:46:47 +02001225+ { "E1 Timeslot", "oml.fom.attr.abis_ch.timeslot",
Harald Welte1cc3fa82009-07-01 17:40:50 +02001226+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001227+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001228+ },
1229+ { &hf_attr_ach_sslot,
Harald Welte450129f2009-07-03 12:46:47 +02001230+ { "E1 Subslot", "oml.fom.attr.abis_ch.subslot",
Harald Welte1cc3fa82009-07-01 17:40:50 +02001231+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001232+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001233+ },
1234+ { &hf_attr_gsm_time,
1235+ { "GSM Time", "oml.fom.attr.gsm_time",
1236+ FT_UINT16, BASE_DEC, NULL, 0,
1237+ "GSM Time", HFILL }
1238+ },
1239+ { &hf_attr_chan_comb,
1240+ { "Channel Combination", "oml.fom.attr.chan_comb",
1241+ FT_UINT8, BASE_HEX, VALS(oml_chan_comb_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001242+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001243+ },
1244+ /* IP Access */
1245+ { &hf_oml_ipa_tres_attr_tag,
1246+ { "IPA Test Result Embedded IE",
1247+ "oml.fom.testrep.ipa_tag",
1248+ FT_UINT8, BASE_HEX, VALS(ipacc_testres_ie_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001249+ "Information Element embedded into the Test Result "
1250+ "of ip.access BTS", HFILL },
Harald Welte1cc3fa82009-07-01 17:40:50 +02001251+ },
1252+ { &hf_oml_ipa_tres_attr_len,
1253+ { "IPA Test Result Embedded IE Length",
1254+ "oml.fom.testrep.ipa_len",
1255+ FT_UINT16, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001256+ "Length of ip.access Test Result Embedded IE", HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001257+ },
1258+ { &hf_attr_ipa_test_res,
1259+ { "IPA Test Result", "oml.fom.testrep.result",
1260+ FT_UINT8, BASE_DEC, VALS(ipacc_test_res_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001261+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001262+ },
1263+ { &hf_attr_ipa_tr_rxlev,
1264+ { "Rx Level", "oml.fom.testrep.ipa_rxlev",
Harald Welte450129f2009-07-03 12:46:47 +02001265+ FT_UINT16, BASE_DEC, NULL, 0xfc00, NULL, HFILL }
1266+ },
1267+ { &hf_attr_ipa_tr_b_rxlev,
1268+ { "Rx Level", "oml.fom.testrep.ipa_rxlev_b",
1269+ FT_UINT8, BASE_DEC, NULL, 0, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001270+ },
1271+ { &hf_attr_ipa_tr_arfcn,
1272+ { "ARFCN", "oml.fom.testrep.ipa_arfcn",
Harald Welte450129f2009-07-03 12:46:47 +02001273+ FT_UINT16, BASE_DEC, NULL, 0x03ff, "ARFCN", HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001274+ },
1275+ { &hf_attr_ipa_tr_f_qual,
1276+ { "Frequency Quality", "oml.fom.testrep.ipa.freq_qual",
Harald Welte450129f2009-07-03 12:46:47 +02001277+ FT_UINT8, BASE_DEC, NULL, 0xfc, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001278+ },
1279+ { &hf_attr_ipa_tr_f_err,
1280+ { "Frequency Error", "oml.fom.testrep.ipa.freq_err",
Harald Welte450129f2009-07-03 12:46:47 +02001281+ FT_INT16, BASE_DEC, NULL, 0, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001282+ },
1283+ { &hf_attr_ipa_tr_rxqual,
1284+ { "Rx Quality", "oml.fom.testrep.ipa.rx_qual",
Harald Welte450129f2009-07-03 12:46:47 +02001285+ FT_UINT8, BASE_DEC, NULL, 0x7, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001286+ },
1287+ { &hf_attr_ipa_tr_frame_offs,
1288+ { "Frame Offset", "oml.fom.testrep.ipa.frame_offset",
Harald Welte450129f2009-07-03 12:46:47 +02001289+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001290+ },
1291+ { &hf_attr_ipa_tr_framenr_offs,
Harald Welte450129f2009-07-03 12:46:47 +02001292+ { "Frame Number Offset",
1293+ "oml.fom.testrep.ipa.framenr_offset",
1294+ FT_UINT32, BASE_DEC, NULL, 0, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001295+ },
1296+ { &hf_attr_ipa_tr_bsic,
1297+ { "BSIC", "oml.fom.testrep.ipa.bsic",
1298+ FT_UINT8, BASE_DEC, NULL, 0x3f,
1299+ "Base Station Identity Code", HFILL }
1300+ },
1301+ { &hf_attr_ipa_tr_cell_id,
1302+ { "Cell ID", "oml.fom.testrep.ipa.cell_id",
Harald Welte450129f2009-07-03 12:46:47 +02001303+ FT_UINT16, BASE_HEX, NULL, 0, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001304+ },
1305+ { &hf_attr_ipa_rsl_ip,
1306+ { "BSC RSL IP Address", "oml.fom.attr.ipa.rsl_ip",
1307+ FT_IPv4, BASE_NONE, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001308+ "IP Address to which the BTS establishes "
1309+ "the RSL link", HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001310+ },
1311+ { &hf_attr_ipa_rsl_port,
1312+ { "BSC RSL TCP Port", "oml.fom.attr.ipa.rsl_port",
1313+ FT_UINT16, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001314+ "Port number to which the BST establishes "
1315+ "the RSL link", HFILL }
1316+ },
1317+ { &hf_attr_ipa_prim_oml_ip,
1318+ { "Primary OML IP Address",
1319+ "oml.fom.attr.ipa.prim_oml_ip",
1320+ FT_IPv4, BASE_NONE, NULL, 0,
1321+ "IP Address of the BSC for the primary OML link",
1322+ HFILL }
1323+ },
1324+ { &hf_attr_ipa_prim_oml_port,
1325+ { "Primary OML TCP Port",
1326+ "oml.fom.attr.ipa.prim_oml_port",
1327+ FT_UINT16, BASE_DEC, NULL, 0,
1328+ "TCP Port of the BSC for the primarly OML link",
1329+ HFILL }
1330+ },
1331+ { &hf_attr_ipa_location_name,
1332+ { "Location Name", "oml.fom.attr.ipa.loc_name",
1333+ FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL }
1334+ },
1335+ { &hf_attr_ipa_unit_name,
1336+ { "Unit Name", "oml.fom.attr.ipa.unit_name",
1337+ FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL }
1338+ },
1339+ { &hf_attr_ipa_unit_id,
1340+ { "Unit ID", "oml.fom.attr.ipa.unit_id",
1341+ FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL }
1342+ },
1343+ { &hf_attr_ipa_nv_flags,
1344+ { "NVRAM Config Flags", "oml.fom.attr.ipa.nv_flags",
1345+ FT_UINT16, BASE_HEX, NULL, 0xffff, NULL, HFILL }
1346+ },
1347+ { &hf_attr_ipa_nv_mask,
1348+ { "NVRAM Config Mask", "oml.fom.attr.ipa.nv_mask",
1349+ FT_UINT16, BASE_HEX, NULL, 0xffff, NULL, HFILL }
1350+ },
1351+ { &hf_attr_ipa_tr_si2,
1352+ { "System Information 2", "oml.fom.attr.ipa.si2",
Harald Weltea165a422009-10-22 10:09:21 +02001353+ FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL }
Harald Welte450129f2009-07-03 12:46:47 +02001354+ },
1355+ { &hf_attr_ipa_tr_si2bis,
1356+ { "System Information 2bis", "oml.fom.attr.ipa.si2bis",
Harald Weltea165a422009-10-22 10:09:21 +02001357+ FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL }
Harald Welte450129f2009-07-03 12:46:47 +02001358+ },
1359+ { &hf_attr_ipa_tr_si2ter,
1360+ { "System Information 2ter", "oml.fom.attr.ipa.si2ter",
Harald Weltea165a422009-10-22 10:09:21 +02001361+ FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL }
Harald Welte450129f2009-07-03 12:46:47 +02001362+ },
1363+ { &hf_attr_ipa_tr_chan_desc,
1364+ { "Cell Channel Description",
1365+ "oml.fom.attr.ipa.chan_desc",
Harald Weltea165a422009-10-22 10:09:21 +02001366+ FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001367+ },
Harald Weltec9b484f2009-07-12 20:46:43 +02001368+ { &hf_attr_ipa_nsl_sport,
1369+ { "NS Link IP Source Port",
1370+ "oml.fom.attr.ipa.nsl_sport",
1371+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1372+ },
1373+ { &hf_attr_ipa_nsl_daddr,
1374+ { "NS Link IP Destination Addr",
1375+ "oml.fom.attr.ipa.nsl_daddr",
1376+ FT_IPv4, BASE_NONE, NULL, 0, NULL, HFILL }
1377+ },
1378+ { &hf_attr_ipa_nsl_dport,
1379+ { "NS Link IP Destination Port",
1380+ "oml.fom.attr.ipa.nsl_dport",
1381+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1382+ },
1383+ { &hf_attr_ipa_nsei,
1384+ { "NSEI", "oml.fom.attr.ipa.nsei",
1385+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1386+ },
1387+ { &hf_attr_ipa_nsvci,
1388+ { "NSVCI", "oml.fom.attr.ipa.nsvci",
1389+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1390+ },
1391+ { &hf_attr_ipa_bvci,
1392+ { "BVCI", "oml.fom.attr.ipa.bvci",
1393+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1394+ },
1395+ { &hf_attr_ipa_rac,
1396+ { "RAC", "oml.fom.attr.ipa.rac",
1397+ FT_UINT8, BASE_HEX, NULL, 0,
1398+ "Routing Area Code", HFILL }
1399+ },
Harald Welte6900c162009-06-25 20:50:57 +02001400+ };
1401+ static gint *ett[] = {
1402+ &ett_oml,
1403+ &ett_oml_fom,
1404+ &ett_oml_fom_att,
1405+ };
1406+
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +01001407+ module_t *oml_module;
1408+
Harald Welte6900c162009-06-25 20:50:57 +02001409+ proto_abis_oml = proto_register_protocol("GSM A-bis OML", "OML",
1410+ "gsm_abis_oml");
1411+
1412+ proto_register_field_array(proto_abis_oml, hf, array_length(hf));
1413+
1414+ proto_register_subtree_array(ett, array_length(ett));
1415+
1416+ register_dissector("gsm_abis_oml", dissect_abis_oml, proto_abis_oml);
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +01001417+
1418+
1419+ oml_module = prefs_register_protocol(proto_abis_oml, proto_reg_handoff_abis_oml);
1420+ prefs_register_bool_preference(oml_module, "use_ipaccess_oml",
1421+ "Use nanoBTS definitions",
1422+ "Use ipaccess nanoBTS specific definitions for OML",
1423+ &global_oml_use_nano_bts);
Harald Welte6900c162009-06-25 20:50:57 +02001424+}
1425+
1426+void
1427+proto_reg_handoff_abis_oml(void)
1428+{
1429+ dissector_handle_t abis_oml_handle;
1430+
Harald Welte31b03472009-12-21 19:04:47 +01001431+ abis_oml_handle = create_dissector_handle(dissect_abis_oml, proto_abis_oml);
Harald Welte4e8c98a2009-08-20 00:59:11 +09001432+ dissector_add("lapd.gsm.sapi", LAPD_GSM_SAPI_OM_PROC, abis_oml_handle);
Harald Welte6900c162009-06-25 20:50:57 +02001433+}
Holger Hans Peter Freyther2fb7ccf2010-04-21 20:37:53 +08001434diff --git a/epan/dissectors/packet-gsm_abis_oml.h b/epan/dissectors/packet-gsm_abis_oml.h
1435new file mode 100644
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +08001436index 0000000..98aeb24
Harald Welte31b03472009-12-21 19:04:47 +01001437--- /dev/null
Holger Hans Peter Freyther2fb7ccf2010-04-21 20:37:53 +08001438+++ b/epan/dissectors/packet-gsm_abis_oml.h
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +08001439@@ -0,0 +1,798 @@
Harald Welte6900c162009-06-25 20:50:57 +02001440+/* GSM Network Management messages on the A-bis interface
1441+ * 3GPP TS 12.21 version 8.0.0 Release 1999 / ETSI TS 100 623 V8.0.0 */
1442+
1443+/* (C) 2008-2009 by Harald Welte <laforge@gnumonks.org>
1444+ * All Rights Reserved
1445+ *
1446+ * This program is free software; you can redistribute it and/or modify
1447+ * it under the terms of the GNU General Public License as published by
1448+ * the Free Software Foundation; either version 2 of the License, or
1449+ * (at your option) any later version.
1450+ *
1451+ * This program is distributed in the hope that it will be useful,
1452+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
1453+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1454+ * GNU General Public License for more details.
1455+ *
1456+ * You should have received a copy of the GNU General Public License along
1457+ * with this program; if not, write to the Free Software Foundation, Inc.,
1458+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
1459+ *
1460+ */
1461+
1462+#ifndef __PACKET_ABIS_OML_H__
1463+#define __PACKET_ABIS_OML_H__
1464+
1465+#include <sys/types.h>
1466+
1467+/* From openbsc/include/openbsc/abis_nm.h */
1468+
1469+/* generic header in front of every OML message according to TS 08.59 */
1470+struct abis_om_hdr {
1471+ guint8 mdisc;
1472+ guint8 placement;
1473+ guint8 sequence;
1474+ guint8 length;
1475+ guint8 data[0];
1476+} __attribute__ ((packed));
1477+
1478+#define ABIS_OM_MDISC_FOM 0x80
1479+#define ABIS_OM_MDISC_MMI 0x40
1480+#define ABIS_OM_MDISC_TRAU 0x20
1481+#define ABIS_OM_MDISC_MANUF 0x10
1482+#define ABIS_OM_PLACEMENT_ONLY 0x80
1483+#define ABIS_OM_PLACEMENT_FIRST 0x40
1484+#define ABIS_OM_PLACEMENT_MIDDLE 0x20
1485+#define ABIS_OM_PLACEMENT_LAST 0x10
1486+
1487+struct abis_om_obj_inst {
1488+ guint8 bts_nr;
1489+ guint8 trx_nr;
1490+ guint8 ts_nr;
1491+} __attribute__ ((packed));
1492+
1493+struct abis_om_fom_hdr {
1494+ guint8 msg_type;
1495+ guint8 obj_class;
1496+ struct abis_om_obj_inst obj_inst;
1497+ guint8 data[0];
1498+} __attribute__ ((packed));
1499+
1500+#define ABIS_OM_FOM_HDR_SIZE (sizeof(struct abis_om_hdr) + sizeof(struct abis_om_fom_hdr))
1501+
1502+/* Section 9.1: Message Types */
1503+enum abis_nm_msgtype {
1504+ /* SW Download Management Messages */
1505+ NM_MT_LOAD_INIT = 0x01,
1506+ NM_MT_LOAD_INIT_ACK,
1507+ NM_MT_LOAD_INIT_NACK,
1508+ NM_MT_LOAD_SEG,
1509+ NM_MT_LOAD_SEG_ACK,
1510+ NM_MT_LOAD_ABORT,
1511+ NM_MT_LOAD_END,
1512+ NM_MT_LOAD_END_ACK,
1513+ NM_MT_LOAD_END_NACK,
1514+ NM_MT_SW_ACT_REQ, /* BTS->BSC */
1515+ NM_MT_SW_ACT_REQ_ACK,
1516+ NM_MT_SW_ACT_REQ_NACK,
1517+ NM_MT_ACTIVATE_SW, /* BSC->BTS */
1518+ NM_MT_ACTIVATE_SW_ACK,
1519+ NM_MT_ACTIVATE_SW_NACK,
1520+ NM_MT_SW_ACTIVATED_REP, /* 0x10 */
1521+ /* A-bis Interface Management Messages */
1522+ NM_MT_ESTABLISH_TEI = 0x21,
1523+ NM_MT_ESTABLISH_TEI_ACK,
1524+ NM_MT_ESTABLISH_TEI_NACK,
1525+ NM_MT_CONN_TERR_SIGN,
1526+ NM_MT_CONN_TERR_SIGN_ACK,
1527+ NM_MT_CONN_TERR_SIGN_NACK,
1528+ NM_MT_DISC_TERR_SIGN,
1529+ NM_MT_DISC_TERR_SIGN_ACK,
1530+ NM_MT_DISC_TERR_SIGN_NACK,
1531+ NM_MT_CONN_TERR_TRAF,
1532+ NM_MT_CONN_TERR_TRAF_ACK,
1533+ NM_MT_CONN_TERR_TRAF_NACK,
1534+ NM_MT_DISC_TERR_TRAF,
1535+ NM_MT_DISC_TERR_TRAF_ACK,
1536+ NM_MT_DISC_TERR_TRAF_NACK,
1537+ /* Transmission Management Messages */
1538+ NM_MT_CONN_MDROP_LINK = 0x31,
1539+ NM_MT_CONN_MDROP_LINK_ACK,
1540+ NM_MT_CONN_MDROP_LINK_NACK,
1541+ NM_MT_DISC_MDROP_LINK,
1542+ NM_MT_DISC_MDROP_LINK_ACK,
1543+ NM_MT_DISC_MDROP_LINK_NACK,
1544+ /* Air Interface Management Messages */
1545+ NM_MT_SET_BTS_ATTR = 0x41,
1546+ NM_MT_SET_BTS_ATTR_ACK,
1547+ NM_MT_SET_BTS_ATTR_NACK,
1548+ NM_MT_SET_RADIO_ATTR,
1549+ NM_MT_SET_RADIO_ATTR_ACK,
1550+ NM_MT_SET_RADIO_ATTR_NACK,
1551+ NM_MT_SET_CHAN_ATTR,
1552+ NM_MT_SET_CHAN_ATTR_ACK,
1553+ NM_MT_SET_CHAN_ATTR_NACK,
1554+ /* Test Management Messages */
1555+ NM_MT_PERF_TEST = 0x51,
1556+ NM_MT_PERF_TEST_ACK,
1557+ NM_MT_PERF_TEST_NACK,
1558+ NM_MT_TEST_REP,
1559+ NM_MT_SEND_TEST_REP,
1560+ NM_MT_SEND_TEST_REP_ACK,
1561+ NM_MT_SEND_TEST_REP_NACK,
1562+ NM_MT_STOP_TEST,
1563+ NM_MT_STOP_TEST_ACK,
1564+ NM_MT_STOP_TEST_NACK,
1565+ /* State Management and Event Report Messages */
1566+ NM_MT_STATECHG_EVENT_REP = 0x61,
1567+ NM_MT_FAILURE_EVENT_REP,
1568+ NM_MT_STOP_EVENT_REP,
1569+ NM_MT_STOP_EVENT_REP_ACK,
1570+ NM_MT_STOP_EVENT_REP_NACK,
1571+ NM_MT_REST_EVENT_REP,
1572+ NM_MT_REST_EVENT_REP_ACK,
1573+ NM_MT_REST_EVENT_REP_NACK,
1574+ NM_MT_CHG_ADM_STATE,
1575+ NM_MT_CHG_ADM_STATE_ACK,
1576+ NM_MT_CHG_ADM_STATE_NACK,
1577+ NM_MT_CHG_ADM_STATE_REQ,
1578+ NM_MT_CHG_ADM_STATE_REQ_ACK,
1579+ NM_MT_CHG_ADM_STATE_REQ_NACK,
1580+ NM_MT_REP_OUTST_ALARMS = 0x93,
1581+ NM_MT_REP_OUTST_ALARMS_ACK,
1582+ NM_MT_REP_OUTST_ALARMS_NACK,
1583+ /* Equipment Management Messages */
1584+ NM_MT_CHANGEOVER = 0x71,
1585+ NM_MT_CHANGEOVER_ACK,
1586+ NM_MT_CHANGEOVER_NACK,
1587+ NM_MT_OPSTART,
1588+ NM_MT_OPSTART_ACK,
1589+ NM_MT_OPSTART_NACK,
1590+ NM_MT_REINIT,
1591+ NM_MT_REINIT_ACK,
1592+ NM_MT_REINIT_NACK,
1593+ NM_MT_SET_SITE_OUT, /* BS11: get alarm ?!? */
1594+ NM_MT_SET_SITE_OUT_ACK,
1595+ NM_MT_SET_SITE_OUT_NACK,
1596+ NM_MT_CHG_HW_CONF = 0x90,
1597+ NM_MT_CHG_HW_CONF_ACK,
1598+ NM_MT_CHG_HW_CONF_NACK,
1599+ /* Measurement Management Messages */
1600+ NM_MT_MEAS_RES_REQ = 0x8a,
1601+ NM_MT_MEAS_RES_RESP,
1602+ NM_MT_STOP_MEAS,
1603+ NM_MT_START_MEAS,
1604+ /* Other Messages */
1605+ NM_MT_GET_ATTR = 0x81,
1606+ NM_MT_GET_ATTR_RESP,
1607+ NM_MT_GET_ATTR_NACK,
1608+ NM_MT_SET_ALARM_THRES,
1609+ NM_MT_SET_ALARM_THRES_ACK,
1610+ NM_MT_SET_ALARM_THRES_NACK,
1611+
1612+ NM_MT_IPACC_RESTART = 0x87,
1613+ NM_MT_IPACC_RESTART_ACK,
1614+};
1615+
1616+enum abis_nm_msgtype_bs11 {
1617+ NM_MT_BS11_RESET_RESOURCE = 0x74,
1618+
1619+ NM_MT_BS11_BEGIN_DB_TX = 0xa3,
1620+ NM_MT_BS11_BEGIN_DB_TX_ACK,
1621+ NM_MT_BS11_BEGIN_DB_TX_NACK,
1622+ NM_MT_BS11_END_DB_TX = 0xa6,
1623+ NM_MT_BS11_END_DB_TX_ACK,
1624+ NM_MT_BS11_END_DB_TX_NACK,
1625+ NM_MT_BS11_CREATE_OBJ = 0xa9,
1626+ NM_MT_BS11_CREATE_OBJ_ACK,
1627+ NM_MT_BS11_CREATE_OBJ_NACK,
1628+ NM_MT_BS11_DELETE_OBJ = 0xac,
1629+ NM_MT_BS11_DELETE_OBJ_ACK,
1630+ NM_MT_BS11_DELETE_OBJ_NACK,
1631+
1632+ NM_MT_BS11_SET_ATTR = 0xd0,
1633+ NM_MT_BS11_SET_ATTR_ACK,
1634+ NM_MT_BS11_SET_ATTR_NACK,
1635+ NM_MT_BS11_LMT_SESSION = 0xdc,
1636+
1637+ NM_MT_BS11_GET_STATE = 0xe3,
1638+ NM_MT_BS11_GET_STATE_ACK,
1639+ NM_MT_BS11_LMT_LOGON = 0xe5,
1640+ NM_MT_BS11_LMT_LOGON_ACK,
1641+ NM_MT_BS11_RESTART = 0xe7,
1642+ NM_MT_BS11_RESTART_ACK,
1643+ NM_MT_BS11_DISCONNECT = 0xe9,
1644+ NM_MT_BS11_DISCONNECT_ACK,
1645+ NM_MT_BS11_LMT_LOGOFF = 0xec,
1646+ NM_MT_BS11_LMT_LOGOFF_ACK,
1647+ NM_MT_BS11_RECONNECT = 0xf1,
1648+ NM_MT_BS11_RECONNECT_ACK,
1649+};
1650+
1651+enum abis_nm_msgtype_ipacc {
1652+ NM_MT_IPACC_RSL_CONNECT = 0xe0,
1653+ NM_MT_IPACC_RSL_CONNECT_ACK,
1654+ NM_MT_IPACC_RSL_CONNECT_NACK,
Harald Welte1cc3fa82009-07-01 17:40:50 +02001655+ NM_MT_IPACC_RSL_DISCONNECT = 0xe3,
1656+ NM_MT_IPACC_RSL_DISCONNECT_ACK,
1657+ NM_MT_IPACC_RSL_DISCONNECT_NACK,
1658+ NM_MT_IPACC_CONN_TRAF = 0xe6,
1659+ NM_MT_IPACC_CONN_TRAF_ACK,
1660+ NM_MT_IPACC_CONN_TRAF_NACK,
Harald Weltec9b484f2009-07-12 20:46:43 +02001661+ NM_MT_IPACC_DISC_TRAF = 0xe9,
1662+ NM_MT_IPACC_DISC_TRAF_ACK,
1663+ NM_MT_IPACC_DISC_TRAF_NACK,
Harald Welte1cc3fa82009-07-01 17:40:50 +02001664+ NM_MT_IPACC_DEF_BOOT_SW = 0xec,
1665+ NM_MT_IPACC_DEF_BOOT_SW_ACK,
1666+ NM_MT_IPACC_DEF_BOOT_SW_NACK,
Harald Welte6900c162009-06-25 20:50:57 +02001667+ NM_MT_IPACC_SET_NVATTR = 0xef,
1668+ NM_MT_IPACC_SET_NVATTR_ACK,
1669+ NM_MT_IPACC_SET_NVATTR_NACK,
1670+ NM_MT_IPACC_GET_NVATTR = 0xf2,
1671+ NM_MT_IPACC_GET_NVATTR_ACK,
1672+ NM_MT_IPACC_GET_NVATTR_NACK,
Harald Weltec9b484f2009-07-12 20:46:43 +02001673+ NM_MT_IPACC_SET_ATTR = 0xf5,
1674+ NM_MT_IPACC_SET_ATTR_ACK,
1675+ NM_MT_IPACC_SET_ATTR_NACK,
1676+ NM_MT_IPACC_ATTR_CHG_EVT = 0xf8,
1677+ NM_MT_IPACC_SW_DEACT = 0xf9,
1678+ NM_MT_IPACC_SW_DEACT_ACK,
1679+ NM_MT_IPACC_SW_DEACT_NACK,
1680+ NM_MT_IPACC_MEAS_RES_REQ_NACK = 0xfc,
1681+ NM_MT_IPACC_START_MEAS_NACK,
1682+ NM_MT_IPACC_STOP_MEAS_NACK,
Harald Welte6900c162009-06-25 20:50:57 +02001683+};
1684+
1685+enum abis_nm_bs11_cell_alloc {
1686+ NM_BS11_CANR_GSM = 0x00,
1687+ NM_BS11_CANR_DCS1800 = 0x01,
1688+};
1689+
1690+/* Section 9.2: Object Class */
1691+enum abis_nm_obj_class {
1692+ NM_OC_SITE_MANAGER = 0x00,
1693+ NM_OC_BTS,
1694+ NM_OC_RADIO_CARRIER,
1695+ NM_OC_CHANNEL,
1696+ NM_OC_BASEB_TRANSC,
1697+ /* RFU: 05-FE */
1698+ NM_OC_BS11_ADJC = 0xa0,
1699+ NM_OC_BS11_HANDOVER = 0xa1,
1700+ NM_OC_BS11_PWR_CTRL = 0xa2,
1701+ NM_OC_BS11_BTSE = 0xa3, /* LMT? */
1702+ NM_OC_BS11_RACK = 0xa4,
1703+ NM_OC_BS11 = 0xa5, /* 01: ALCO */
1704+ NM_OC_BS11_TEST = 0xa6,
1705+ NM_OC_BS11_ENVABTSE = 0xa8,
1706+ NM_OC_BS11_BPORT = 0xa9,
1707+
1708+ NM_OC_GPRS_NSE = 0xf0,
1709+ NM_OC_GPRS_CELL = 0xf1,
1710+ NM_OC_GPRS_NSVC0 = 0xf2,
1711+ NM_OC_GPRS_NSVC1 = 0xf3,
1712+
1713+ NM_OC_NULL = 0xff,
1714+};
1715+
1716+/* Section 9.4: Attributes */
1717+enum abis_nm_attr {
1718+ NM_ATT_ABIS_CHANNEL = 0x01,
1719+ NM_ATT_ADD_INFO,
1720+ NM_ATT_ADD_TEXT,
1721+ NM_ATT_ADM_STATE,
1722+ NM_ATT_ARFCN_LIST,
1723+ NM_ATT_AUTON_REPORT,
1724+ NM_ATT_AVAIL_STATUS,
1725+ NM_ATT_BCCH_ARFCN,
1726+ NM_ATT_BSIC,
1727+ NM_ATT_BTS_AIR_TIMER,
1728+ NM_ATT_CCCH_L_I_P,
1729+ NM_ATT_CCCH_L_T,
1730+ NM_ATT_CHAN_COMB,
1731+ NM_ATT_CONN_FAIL_CRIT,
1732+ NM_ATT_DEST,
1733+ /* res */
1734+ NM_ATT_EVENT_TYPE = 0x11, /* BS11: file data ?!? */
1735+ NM_ATT_FILE_ID,
1736+ NM_ATT_FILE_VERSION,
1737+ NM_ATT_GSM_TIME,
1738+ NM_ATT_HSN,
1739+ NM_ATT_HW_CONFIG,
1740+ NM_ATT_HW_DESC,
1741+ NM_ATT_INTAVE_PARAM,
1742+ NM_ATT_INTERF_BOUND,
1743+ NM_ATT_LIST_REQ_ATTR,
1744+ NM_ATT_MAIO,
1745+ NM_ATT_MANUF_STATE,
1746+ NM_ATT_MANUF_THRESH,
1747+ NM_ATT_MANUF_ID,
1748+ NM_ATT_MAX_TA,
1749+ NM_ATT_MDROP_LINK, /* 0x20 */
1750+ NM_ATT_MDROP_NEXT,
1751+ NM_ATT_NACK_CAUSES,
1752+ NM_ATT_NY1,
1753+ NM_ATT_OPER_STATE,
1754+ NM_ATT_OVERL_PERIOD,
1755+ NM_ATT_PHYS_CONF,
1756+ NM_ATT_POWER_CLASS,
1757+ NM_ATT_POWER_THRESH,
1758+ NM_ATT_PROB_CAUSE,
1759+ NM_ATT_RACH_B_THRESH,
1760+ NM_ATT_LDAVG_SLOTS,
1761+ NM_ATT_RAD_SUBC,
1762+ NM_ATT_RF_MAXPOWR_R,
1763+ NM_ATT_SITE_INPUTS,
1764+ NM_ATT_SITE_OUTPUTS,
1765+ NM_ATT_SOURCE, /* 0x30 */
1766+ NM_ATT_SPEC_PROB,
1767+ NM_ATT_START_TIME,
1768+ NM_ATT_T200,
1769+ NM_ATT_TEI,
1770+ NM_ATT_TEST_DUR,
1771+ NM_ATT_TEST_NO,
1772+ NM_ATT_TEST_REPORT,
1773+ NM_ATT_VSWR_THRESH,
1774+ NM_ATT_WINDOW_SIZE,
1775+ /* Res */
1776+ NM_ATT_BS11_RSSI_OFFS = 0x3d,
1777+ NM_ATT_BS11_TXPWR = 0x3e,
1778+ NM_ATT_BS11_DIVERSITY = 0x3f,
1779+ /* Res */
1780+ NM_ATT_TSC = 0x40,
1781+ NM_ATT_SW_CONFIG,
1782+ NM_ATT_SW_DESCR,
1783+ NM_ATT_SEVERITY,
1784+ NM_ATT_GET_ARI,
1785+ NM_ATT_HW_CONF_CHG,
1786+ NM_ATT_OUTST_ALARM,
1787+ NM_ATT_FILE_DATA,
1788+ NM_ATT_MEAS_RES,
1789+ NM_ATT_MEAS_TYPE,
1790+
1791+ NM_ATT_BS11_ESN_FW_CODE_NO = 0x4c,
1792+ NM_ATT_BS11_ESN_HW_CODE_NO = 0x4f,
1793+
1794+ NM_ATT_BS11_ESN_PCB_SERIAL = 0x55,
1795+ NM_ATT_BS11_EXCESSIVE_DISTANCE = 0x58,
1796+
1797+ NM_ATT_BS11_ALL_TEST_CATG = 0x60,
1798+ NM_ATT_BS11_BTSLS_HOPPING,
1799+ NM_ATT_BS11_CELL_ALLOC_NR,
1800+ NM_ATT_BS11_CELL_GLOBAL_ID,
1801+ NM_ATT_BS11_ENA_INTERF_CLASS = 0x66,
1802+ NM_ATT_BS11_ENA_INT_INTEC_HANDO = 0x67,
1803+ NM_ATT_BS11_ENA_INT_INTRC_HANDO = 0x68,
1804+ NM_ATT_BS11_ENA_MS_PWR_CTRL = 0x69,
1805+ NM_ATT_BS11_ENA_PWR_BDGT_HO = 0x6a,
1806+ NM_ATT_BS11_ENA_PWR_CTRL_RLFW = 0x6b,
1807+ NM_ATT_BS11_ENA_RXLEV_HO = 0x6c,
1808+ NM_ATT_BS11_ENA_RXQUAL_HO = 0x6d,
1809+ NM_ATT_BS11_FACCH_QUAL = 0x6e,
1810+
Harald Weltec9b484f2009-07-12 20:46:43 +02001811+ NM_ATT_IPACC_DST_IP = 0x80,
1812+ NM_ATT_IPACC_DST_IP_PORT = 0x81,
1813+ NM_ATT_IPACC_SSRC = 0x82, /* RTP Sync Source */
1814+ NM_ATT_IPACC_RTP_PAYLD_TYPE = 0x83,
1815+ NM_ATT_IPACC_BASEB_ID = 0x84,
1816+ NM_ATT_IPACC_STREAM_ID = 0x85,
Harald Welte1cc3fa82009-07-01 17:40:50 +02001817+ NM_ATT_IPACC_NV_FLAGS = 0x86,
1818+ NM_ATT_IPACC_FREQ_CTRL = 0x87,
Harald Weltec9b484f2009-07-12 20:46:43 +02001819+ NM_ATT_IPACC_PRIM_OML_CFG = 0x88,
Harald Welte450129f2009-07-03 12:46:47 +02001820+ NM_ATT_IPACC_SEC_OML_CFG = 0x89,
Harald Welte1cc3fa82009-07-01 17:40:50 +02001821+ NM_ATT_IPACC_IP_IF_CFG = 0x8a, /* IP interface */
1822+ NM_ATT_IPACC_IP_GW_CFG = 0x8b, /* IP gateway */
1823+ NM_ATT_IPACC_IN_SERV_TIME = 0x8c,
Harald Weltec9b484f2009-07-12 20:46:43 +02001824+ NM_ATT_IPACC_TRX_BTS_ASS = 0x8d,
Harald Welte6900c162009-06-25 20:50:57 +02001825+ NM_ATT_IPACC_LOCATION = 0x8e, /* string describing location */
Harald Weltec9b484f2009-07-12 20:46:43 +02001826+ NM_ATT_IPACC_PAGING_CFG = 0x8f,
1827+ NM_ATT_IPACC_FILE_DATA = 0x90,
Harald Welte6900c162009-06-25 20:50:57 +02001828+ NM_ATT_IPACC_UNIT_ID = 0x91, /* Site/BTS/TRX */
Harald Weltec9b484f2009-07-12 20:46:43 +02001829+ NM_ATT_IPACC_PARENT_UNIT_ID = 0x92,
Harald Welte6900c162009-06-25 20:50:57 +02001830+ NM_ATT_IPACC_UNIT_NAME = 0x93, /* default: nbts-<mac-as-string> */
Harald Welte1cc3fa82009-07-01 17:40:50 +02001831+ NM_ATT_IPACC_SNMP_CFG = 0x94,
Harald Weltec9b484f2009-07-12 20:46:43 +02001832+ NM_ATT_IPACC_PRIM_OML_CFG_LIST = 0x95,
1833+ NM_ATT_IPACC_PRIM_OML_FB_TOUT = 0x96, /* fallback timeout */
Harald Welte1cc3fa82009-07-01 17:40:50 +02001834+ NM_ATT_IPACC_CUR_SW_CFG = 0x97,
Harald Weltec9b484f2009-07-12 20:46:43 +02001835+ NM_ATT_IPACC_TIMING_BUS = 0x98,
1836+ NM_ATT_IPACC_CGI = 0x99, /* Cell Global ID */
1837+ NM_ATT_IPACC_RAC = 0x9a,
1838+ NM_ATT_IPACC_OBJ_VERSION = 0x9b,
1839+ NM_ATT_IPACC_GPRS_PAGING_CFG = 0x9c,
1840+ NM_ATT_IPACC_NSEI = 0x9d,
1841+ NM_ATT_IPACC_BVCI = 0x9e,
1842+ NM_ATT_IPACC_NSVCI = 0x9f,
1843+ NM_ATT_IPACC_NS_CFG = 0xa0,
1844+ NM_ATT_IPACC_BSSGP_CFG = 0xa1,
1845+ NM_ATT_IPACC_NS_LINK_CFG = 0xa2,
1846+ NM_ATT_IPACC_RLC_CFG = 0xa3,
Harald Welte1cc3fa82009-07-01 17:40:50 +02001847+ NM_ATT_IPACC_ALM_THRESH_LIST = 0xa4,
Harald Weltec9b484f2009-07-12 20:46:43 +02001848+ NM_ATT_IPACC_MONIT_VAL_LIST = 0xa5,
1849+ NM_ATT_IPACC_TIB_CONTROL = 0xa6,
1850+ NM_ATT_IPACC_SUPP_FEATURES = 0xa7,
1851+ NM_ATT_IPACC_CODING_SCHEMES = 0xa8,
1852+ NM_ATT_IPACC_RLC_CFG_2 = 0xa9,
1853+ NM_ATT_IPACC_HEARTB_TOUT = 0xaa,
Harald Welte1cc3fa82009-07-01 17:40:50 +02001854+ NM_ATT_IPACC_UPTIME = 0xab,
Harald Weltec9b484f2009-07-12 20:46:43 +02001855+ NM_ATT_IPACC_RLC_CFG_3 = 0xac,
Harald Welte1cc3fa82009-07-01 17:40:50 +02001856+ NM_ATT_IPACC_SSL_CFG = 0xad,
1857+ NM_ATT_IPACC_SEC_POSSIBLE = 0xae,
Harald Weltec9b484f2009-07-12 20:46:43 +02001858+ NM_ATT_IPACC_IML_SSL_STATE = 0xaf,
Harald Welte1cc3fa82009-07-01 17:40:50 +02001859+ NM_ATT_IPACC_REVOC_DATE = 0xb0,
1860+
Harald Welte6900c162009-06-25 20:50:57 +02001861+
1862+ NM_ATT_BS11_RF_RES_IND_PER = 0x8f,
1863+
1864+ NM_ATT_BS11_RX_LEV_MIN_CELL = 0x90,
1865+ NM_ATT_BS11_ABIS_EXT_TIME = 0x91,
1866+ NM_ATT_BS11_TIMER_HO_REQUEST = 0x92,
1867+ NM_ATT_BS11_TIMER_NCELL = 0x93,
1868+ NM_ATT_BS11_TSYNC = 0x94,
1869+ NM_ATT_BS11_TTRAU = 0x95,
1870+ NM_ATT_BS11_EMRG_CFG_MEMBER = 0x9b,
1871+ NM_ATT_BS11_TRX_AREA = 0x9f,
1872+
1873+ NM_ATT_BS11_BCCH_RECONF = 0xd7,
1874+ NM_ATT_BS11_BIT_ERR_THESH = 0xa0,
1875+ NM_ATT_BS11_BOOT_SW_VERS = 0xa1,
1876+ NM_ATT_BS11_CCLK_ACCURACY = 0xa3,
1877+ NM_ATT_BS11_CCLK_TYPE = 0xa4,
1878+ NM_ATT_BS11_INP_IMPEDANCE = 0xaa,
1879+ NM_ATT_BS11_L1_PROT_TYPE = 0xab,
1880+ NM_ATT_BS11_LINE_CFG = 0xac,
1881+ NM_ATT_BS11_LI_PORT_1 = 0xad,
1882+ NM_ATT_BS11_LI_PORT_2 = 0xae,
1883+
1884+ NM_ATT_BS11_L1_REM_ALM_TYPE = 0xb0,
1885+ NM_ATT_BS11_SW_LOAD_INTENDED = 0xbb,
1886+ NM_ATT_BS11_SW_LOAD_SAFETY = 0xbc,
1887+ NM_ATT_BS11_SW_LOAD_STORED = 0xbd,
1888+
1889+ NM_ATT_BS11_VENDOR_NAME = 0xc1,
1890+ NM_ATT_BS11_HOPPING_MODE = 0xc5,
1891+ NM_ATT_BS11_LMT_LOGON_SESSION = 0xc6,
1892+ NM_ATT_BS11_LMT_LOGIN_TIME = 0xc7,
1893+ NM_ATT_BS11_LMT_USER_ACC_LEV = 0xc8,
1894+ NM_ATT_BS11_LMT_USER_NAME = 0xc9,
1895+
1896+ NM_ATT_BS11_L1_CONTROL_TS = 0xd8,
1897+ NM_ATT_BS11_RADIO_MEAS_GRAN = 0xdc, /* in SACCH multiframes */
1898+ NM_ATT_BS11_RADIO_MEAS_REP = 0xdd,
1899+
1900+ NM_ATT_BS11_SH_LAPD_INT_TIMER = 0xe8,
1901+
1902+ NM_ATT_BS11_BTS_STATE = 0xf0,
1903+ NM_ATT_BS11_E1_STATE = 0xf1,
1904+ NM_ATT_BS11_PLL = 0xf2,
1905+ NM_ATT_BS11_RX_OFFSET = 0xf3,
1906+ NM_ATT_BS11_ANT_TYPE = 0xf4,
1907+ NM_ATT_BS11_PLL_MODE = 0xfc,
1908+ NM_ATT_BS11_PASSWORD = 0xfd,
1909+};
1910+#define NM_ATT_BS11_FILE_DATA NM_ATT_EVENT_TYPE
1911+
1912+/* Section 9.4.4: Administrative State */
1913+enum abis_nm_adm_state {
1914+ NM_STATE_LOCKED = 0x01,
1915+ NM_STATE_UNLOCKED = 0x02,
1916+ NM_STATE_SHUTDOWN = 0x03,
1917+ NM_STATE_NULL = 0xff,
1918+};
1919+
1920+/* Section 9.4.13: Channel Combination */
1921+enum abis_nm_chan_comb {
1922+ NM_CHANC_TCHFull = 0x00,
1923+ NM_CHANC_TCHHalf = 0x01,
1924+ NM_CHANC_TCHHalf2 = 0x02,
1925+ NM_CHANC_SDCCH = 0x03,
1926+ NM_CHANC_mainBCCH = 0x04,
1927+ NM_CHANC_BCCHComb = 0x05,
1928+ NM_CHANC_BCCH = 0x06,
1929+ NM_CHANC_BCCH_CBCH = 0x07,
1930+ NM_CHANC_SDCCH_CBCH = 0x08,
1931+};
1932+
1933+/* Section 9.4.16: Event Type */
1934+enum abis_nm_event_type {
1935+ NM_EVT_COMM_FAIL = 0x00,
1936+ NM_EVT_QOS_FAIL = 0x01,
1937+ NM_EVT_PROC_FAIL = 0x02,
1938+ NM_EVT_EQUIP_FAIL = 0x03,
1939+ NM_EVT_ENV_FAIL = 0x04,
1940+};
1941+
1942+/* Section: 9.4.63: Perceived Severity */
1943+enum abis_nm_severity {
1944+ NM_SEVER_CEASED = 0x00,
1945+ NM_SEVER_CRITICAL = 0x01,
1946+ NM_SEVER_MAJOR = 0x02,
1947+ NM_SEVER_MINOR = 0x03,
1948+ NM_SEVER_WARNING = 0x04,
1949+ NM_SEVER_INDETERMINATE = 0x05,
1950+};
1951+
1952+/* Section 9.4.43: Probable Cause Type */
1953+enum abis_nm_pcause_type {
1954+ NM_PCAUSE_T_X721 = 0x01,
1955+ NM_PCAUSE_T_GSM = 0x02,
1956+ NM_PCAUSE_T_MANUF = 0x03,
1957+};
1958+
1959+/* Section 9.4.36: NACK Causes */
1960+enum abis_nm_nack_cause {
1961+ /* General Nack Causes */
1962+ NM_NACK_INCORR_STRUCT = 0x01,
1963+ NM_NACK_MSGTYPE_INVAL = 0x02,
1964+ NM_NACK_OBJCLASS_INVAL = 0x05,
1965+ NM_NACK_OBJCLASS_NOTSUPP = 0x06,
1966+ NM_NACK_BTSNR_UNKN = 0x07,
1967+ NM_NACK_TRXNR_UNKN = 0x08,
1968+ NM_NACK_OBJINST_UNKN = 0x09,
1969+ NM_NACK_ATTRID_INVAL = 0x0c,
1970+ NM_NACK_ATTRID_NOTSUPP = 0x0d,
1971+ NM_NACK_PARAM_RANGE = 0x0e,
1972+ NM_NACK_ATTRLIST_INCONSISTENT = 0x0f,
1973+ NM_NACK_SPEC_IMPL_NOTSUPP = 0x10,
1974+ NM_NACK_CANT_PERFORM = 0x11,
1975+ /* Specific Nack Causes */
1976+ NM_NACK_RES_NOTIMPL = 0x19,
1977+ NM_NACK_RES_NOTAVAIL = 0x1a,
1978+ NM_NACK_FREQ_NOTAVAIL = 0x1b,
1979+ NM_NACK_TEST_NOTSUPP = 0x1c,
1980+ NM_NACK_CAPACITY_RESTR = 0x1d,
1981+ NM_NACK_PHYSCFG_NOTPERFORM = 0x1e,
1982+ NM_NACK_TEST_NOTINIT = 0x1f,
1983+ NM_NACK_PHYSCFG_NOTRESTORE = 0x20,
1984+ NM_NACK_TEST_NOSUCH = 0x21,
1985+ NM_NACK_TEST_NOSTOP = 0x22,
1986+ NM_NACK_MSGINCONSIST_PHYSCFG = 0x23,
1987+ NM_NACK_FILE_INCOMPLETE = 0x25,
1988+ NM_NACK_FILE_NOTAVAIL = 0x26,
1989+ NM_NACK_FILE_NOTACTIVATE = 0x27,
1990+ NM_NACK_REQ_NOT_GRANT = 0x28,
1991+ NM_NACK_WAIT = 0x29,
1992+ NM_NACK_NOTH_REPORT_EXIST = 0x2a,
1993+ NM_NACK_MEAS_NOTSUPP = 0x2b,
1994+ NM_NACK_MEAS_NOTSTART = 0x2c,
1995+};
1996+
1997+/* Section 9.4.1 */
1998+struct abis_nm_channel {
1999+ guint8 attrib;
2000+ guint8 bts_port;
2001+ guint8 timeslot;
2002+ guint8 subslot;
2003+} __attribute__ ((packed));
2004+
2005+/* Siemens BS-11 specific objects in the SienemsHW (0xA5) object class */
2006+enum abis_bs11_objtype {
2007+ BS11_OBJ_ALCO = 0x01,
2008+ BS11_OBJ_BBSIG = 0x02, /* obj_class: 0,1 */
2009+ BS11_OBJ_TRX1 = 0x03, /* only DEACTIVATE TRX1 */
2010+ BS11_OBJ_CCLK = 0x04,
2011+ BS11_OBJ_GPSU = 0x06,
2012+ BS11_OBJ_LI = 0x07,
2013+ BS11_OBJ_PA = 0x09, /* obj_class: 0, 1*/
2014+};
2015+
2016+enum abis_bs11_trx_power {
2017+ BS11_TRX_POWER_GSM_2W = 0x06,
2018+ BS11_TRX_POWER_GSM_250mW= 0x07,
2019+ BS11_TRX_POWER_GSM_80mW = 0x08,
2020+ BS11_TRX_POWER_GSM_30mW = 0x09,
2021+ BS11_TRX_POWER_DCS_3W = 0x0a,
2022+ BS11_TRX_POWER_DCS_1W6 = 0x0b,
2023+ BS11_TRX_POWER_DCS_500mW= 0x0c,
2024+ BS11_TRX_POWER_DCS_160mW= 0x0d,
2025+};
2026+
2027+enum abis_bs11_li_pll_mode {
2028+ BS11_LI_PLL_LOCKED = 2,
2029+ BS11_LI_PLL_STANDALONE = 3,
2030+};
2031+
2032+enum abis_bs11_phase {
2033+ BS11_STATE_SOFTWARE_RQD = 0x01,
2034+ BS11_STATE_LOAD_SMU_INTENDED = 0x11,
2035+ BS11_STATE_LOAD_SMU_SAFETY = 0x21,
2036+ BS11_STATE_LOAD_FAILED = 0x31,
2037+ BS11_STATE_LOAD_DIAGNOSTIC = 0x41,
2038+ BS11_STATE_WARM_UP = 0x51,
2039+ BS11_STATE_WARM_UP_2 = 0x52,
2040+ BS11_STATE_WAIT_MIN_CFG = 0x62,
2041+ BS11_STATE_MAINTENANCE = 0x72,
2042+ BS11_STATE_LOAD_MBCCU = 0x92,
2043+ BS11_STATE_WAIT_MIN_CFG_2 = 0xA2,
2044+ BS11_STATE_NORMAL = 0x03,
2045+ BS11_STATE_ABIS_LOAD = 0x13,
2046+};
2047+
2048+/* From openbsc/include/openbsc/tlv.h */
2049+enum tlv_type {
2050+ TLV_TYPE_FIXED,
2051+ TLV_TYPE_T,
2052+ TLV_TYPE_TV,
2053+ TLV_TYPE_TLV,
2054+ TLV_TYPE_TL16V,
2055+};
2056+
2057+struct tlv_def {
2058+ enum tlv_type type;
2059+ u_int8_t fixed_len;
2060+};
2061+
2062+struct tlv_definition {
2063+ struct tlv_def def[0xff];
2064+};
2065+
Harald Welte1cc3fa82009-07-01 17:40:50 +02002066+enum abis_nm_ipacc_test_no {
Harald Weltec9b484f2009-07-12 20:46:43 +02002067+ NM_IPACC_TESTNO_RLOOP_ANT = 0x01,
2068+ NM_IPACC_TESTNO_RLOOP_XCVR = 0x02,
2069+ NM_IPACC_TESTNO_FUNC_OBJ = 0x03,
Harald Welte1cc3fa82009-07-01 17:40:50 +02002070+ NM_IPACC_TESTNO_CHAN_USAGE = 0x40,
2071+ NM_IPACC_TESTNO_BCCH_CHAN_USAGE = 0x41,
2072+ NM_IPACC_TESTNO_FREQ_SYNC = 0x42,
2073+ NM_IPACC_TESTNO_BCCH_INFO = 0x43,
2074+ NM_IPACC_TESTNO_TX_BEACON = 0x44,
Harald Weltec9b484f2009-07-12 20:46:43 +02002075+ NM_IPACC_TESTNO_SYSINFO_MONITOR = 0x45,
2076+ NM_IPACC_TESTNO_BCCCH_MONITOR = 0x46,
Harald Welte1cc3fa82009-07-01 17:40:50 +02002077+};
2078+
2079+/* first byte after length inside NM_ATT_TEST_REPORT */
2080+enum abis_nm_ipacc_test_res {
2081+ NM_IPACC_TESTRES_SUCCESS = 0,
2082+ NM_IPACC_TESTRES_TIMEOUT = 1,
2083+ NM_IPACC_TESTRES_NO_CHANS = 2,
2084+ NM_IPACC_TESTRES_PARTIAL = 3,
2085+ NM_IPACC_TESTRES_STOPPED = 4,
2086+};
2087+
2088+/* internal IE inside NM_ATT_TEST_REPORT */
2089+enum abis_nm_ipacc_testres_ie {
2090+ NM_IPACC_TR_IE_FREQ_ERR_LIST = 3,
2091+ NM_IPACC_TR_IE_CHAN_USAGE = 4,
2092+ NM_IPACC_TR_IE_BCCH_INFO = 6,
2093+ NM_IPACC_TR_IE_RESULT_DETAILS = 8,
2094+ NM_IPACC_TR_IE_FREQ_ERR = 18,
2095+};
Harald Welte6900c162009-06-25 20:50:57 +02002096+
2097+/* From openbsc/src/abis_nm.c */
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +08002098+static const struct tlv_definition nm_att_tlvdef_base = {
Harald Welte6900c162009-06-25 20:50:57 +02002099+ .def = {
2100+ [NM_ATT_ABIS_CHANNEL] = { TLV_TYPE_FIXED, 3 },
2101+ [NM_ATT_ADD_INFO] = { TLV_TYPE_TL16V, 0 },
Harald Welteb16004c2009-07-11 19:44:53 +02002102+ [NM_ATT_ADD_TEXT] = { TLV_TYPE_TL16V, 0 },
2103+ [NM_ATT_ADM_STATE] = { TLV_TYPE_TV, 0 },
2104+ [NM_ATT_ARFCN_LIST]= { TLV_TYPE_TL16V, 0 },
2105+ [NM_ATT_AUTON_REPORT] = { TLV_TYPE_TV, 0 },
2106+ [NM_ATT_AVAIL_STATUS] = { TLV_TYPE_TL16V, 0 },
Harald Welte6900c162009-06-25 20:50:57 +02002107+ [NM_ATT_BCCH_ARFCN] = { TLV_TYPE_FIXED, 2 },
Harald Welteb16004c2009-07-11 19:44:53 +02002108+ [NM_ATT_BSIC] = { TLV_TYPE_TV, 0 },
2109+ [NM_ATT_BTS_AIR_TIMER] = { TLV_TYPE_TV, 0 },
2110+ [NM_ATT_CCCH_L_I_P] = { TLV_TYPE_TV, 0 },
2111+ [NM_ATT_CCCH_L_T] = { TLV_TYPE_TV, 0 },
2112+ [NM_ATT_CHAN_COMB] = { TLV_TYPE_TV, 0 },
2113+ [NM_ATT_CONN_FAIL_CRIT] = { TLV_TYPE_TL16V, 0 },
2114+ [NM_ATT_DEST] = { TLV_TYPE_TL16V, 0 },
2115+ [NM_ATT_EVENT_TYPE] = { TLV_TYPE_TV, 0 },
2116+ [NM_ATT_FILE_ID] = { TLV_TYPE_TL16V, 0 },
2117+ [NM_ATT_FILE_VERSION] = { TLV_TYPE_TL16V, 0 },
Harald Welte6900c162009-06-25 20:50:57 +02002118+ [NM_ATT_GSM_TIME] = { TLV_TYPE_FIXED, 2 },
Harald Welteb16004c2009-07-11 19:44:53 +02002119+ [NM_ATT_HSN] = { TLV_TYPE_TV, 0 },
2120+ [NM_ATT_HW_CONFIG] = { TLV_TYPE_TL16V, 0 },
Harald Welteb16004c2009-07-11 19:44:53 +02002121+ [NM_ATT_HW_DESC] = { TLV_TYPE_TLV, 0 },
2122+ [NM_ATT_INTAVE_PARAM] = { TLV_TYPE_TV, 0 },
Harald Welte6900c162009-06-25 20:50:57 +02002123+ [NM_ATT_INTERF_BOUND] = { TLV_TYPE_FIXED, 6 },
Harald Welteb16004c2009-07-11 19:44:53 +02002124+ [NM_ATT_LIST_REQ_ATTR] = { TLV_TYPE_TL16V, 0 },
2125+ [NM_ATT_MAIO] = { TLV_TYPE_TV, 0 },
2126+ [NM_ATT_MANUF_STATE] = { TLV_TYPE_TV, 0 },
2127+ [NM_ATT_MANUF_THRESH] = { TLV_TYPE_TL16V, 0 },
2128+ [NM_ATT_MANUF_ID] = { TLV_TYPE_TL16V, 0 },
2129+ [NM_ATT_MAX_TA] = { TLV_TYPE_TV, 0 },
Harald Welte6900c162009-06-25 20:50:57 +02002130+ [NM_ATT_MDROP_LINK] = { TLV_TYPE_FIXED, 2 },
2131+ [NM_ATT_MDROP_NEXT] = { TLV_TYPE_FIXED, 2 },
Harald Welteb16004c2009-07-11 19:44:53 +02002132+ [NM_ATT_NACK_CAUSES] = { TLV_TYPE_TV, 0 },
2133+ [NM_ATT_NY1] = { TLV_TYPE_TV, 0 },
2134+ [NM_ATT_OPER_STATE] = { TLV_TYPE_TV, 0 },
2135+ [NM_ATT_OVERL_PERIOD] = { TLV_TYPE_TL16V, 0 },
2136+ [NM_ATT_PHYS_CONF] = { TLV_TYPE_TL16V, 0 },
2137+ [NM_ATT_POWER_CLASS] = { TLV_TYPE_TV, 0 },
Harald Welte6900c162009-06-25 20:50:57 +02002138+ [NM_ATT_POWER_THRESH] = { TLV_TYPE_FIXED, 3 },
2139+ [NM_ATT_PROB_CAUSE] = { TLV_TYPE_FIXED, 3 },
Harald Welteb16004c2009-07-11 19:44:53 +02002140+ [NM_ATT_RACH_B_THRESH] = { TLV_TYPE_TV, 0 },
Harald Welte6900c162009-06-25 20:50:57 +02002141+ [NM_ATT_LDAVG_SLOTS] = { TLV_TYPE_FIXED, 2 },
Harald Welteb16004c2009-07-11 19:44:53 +02002142+ [NM_ATT_RAD_SUBC] = { TLV_TYPE_TV, 0 },
2143+ [NM_ATT_RF_MAXPOWR_R] = { TLV_TYPE_TV, 0 },
2144+ [NM_ATT_SITE_INPUTS] = { TLV_TYPE_TL16V, 0 },
2145+ [NM_ATT_SITE_OUTPUTS] = { TLV_TYPE_TL16V, 0 },
2146+ [NM_ATT_SOURCE] = { TLV_TYPE_TL16V, 0 },
2147+ [NM_ATT_SPEC_PROB] = { TLV_TYPE_TV, 0 },
Harald Welte6900c162009-06-25 20:50:57 +02002148+ [NM_ATT_START_TIME] = { TLV_TYPE_FIXED, 2 },
2149+ [NM_ATT_T200] = { TLV_TYPE_FIXED, 7 },
Harald Welteb16004c2009-07-11 19:44:53 +02002150+ [NM_ATT_TEI] = { TLV_TYPE_TV, 0 },
Harald Welte6900c162009-06-25 20:50:57 +02002151+ [NM_ATT_TEST_DUR] = { TLV_TYPE_FIXED, 2 },
Harald Welteb16004c2009-07-11 19:44:53 +02002152+ [NM_ATT_TEST_NO] = { TLV_TYPE_TV, 0 },
2153+ [NM_ATT_TEST_REPORT] = { TLV_TYPE_TL16V, 0 },
Harald Welte6900c162009-06-25 20:50:57 +02002154+ [NM_ATT_VSWR_THRESH] = { TLV_TYPE_FIXED, 2 },
Harald Welteb16004c2009-07-11 19:44:53 +02002155+ [NM_ATT_WINDOW_SIZE] = { TLV_TYPE_TV, 0 },
2156+ [NM_ATT_TSC] = { TLV_TYPE_TV, 0 },
2157+ [NM_ATT_SW_CONFIG] = { TLV_TYPE_TL16V, 0 },
2158+ [NM_ATT_SEVERITY] = { TLV_TYPE_TV, 0 },
2159+ [NM_ATT_GET_ARI] = { TLV_TYPE_TL16V, 0 },
2160+ [NM_ATT_HW_CONF_CHG] = { TLV_TYPE_TL16V, 0 },
2161+ [NM_ATT_OUTST_ALARM] = { TLV_TYPE_TV, 0 },
2162+ [NM_ATT_FILE_DATA] = { TLV_TYPE_TL16V, 0 },
2163+ [NM_ATT_MEAS_RES] = { TLV_TYPE_TL16V, 0 },
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +08002164+
2165+ },
2166+};
2167+
2168+/* BS11 specifics */
2169+static const struct tlv_definition nm_att_tlvdev_bs11 = {
2170+ .def = {
2171+ /* a difference.. */
2172+ [NM_ATT_HW_DESC] = { TLV_TYPE_TL16V, 0 },
Harald Welteb16004c2009-07-11 19:44:53 +02002173+ [NM_ATT_BS11_ESN_FW_CODE_NO] = { TLV_TYPE_TLV, 0 },
2174+ [NM_ATT_BS11_ESN_HW_CODE_NO] = { TLV_TYPE_TLV, 0 },
2175+ [NM_ATT_BS11_ESN_PCB_SERIAL] = { TLV_TYPE_TLV, 0 },
2176+ [NM_ATT_BS11_BOOT_SW_VERS] = { TLV_TYPE_TLV, 0 },
2177+ [0xd5] = { TLV_TYPE_TLV, 0 },
2178+ [0xa8] = { TLV_TYPE_TLV, 0 },
2179+ [NM_ATT_BS11_PASSWORD] = { TLV_TYPE_TLV, 0 },
2180+ [NM_ATT_BS11_TXPWR] = { TLV_TYPE_TLV, 0 },
2181+ [NM_ATT_BS11_RSSI_OFFS] = { TLV_TYPE_TLV, 0 },
2182+ [NM_ATT_BS11_LINE_CFG] = { TLV_TYPE_TV, 0 },
2183+ [NM_ATT_BS11_L1_PROT_TYPE] = { TLV_TYPE_TV, 0 },
Harald Welte6900c162009-06-25 20:50:57 +02002184+ [NM_ATT_BS11_BIT_ERR_THESH] = { TLV_TYPE_FIXED, 2 },
Harald Welteb16004c2009-07-11 19:44:53 +02002185+ [NM_ATT_BS11_DIVERSITY] = { TLV_TYPE_TLV, 0 },
2186+ [NM_ATT_BS11_LMT_LOGON_SESSION]={ TLV_TYPE_TLV, 0 },
2187+ [NM_ATT_BS11_LMT_LOGIN_TIME] = { TLV_TYPE_TLV, 0 },
2188+ [NM_ATT_BS11_LMT_USER_ACC_LEV] ={ TLV_TYPE_TLV, 0 },
2189+ [NM_ATT_BS11_LMT_USER_NAME] = { TLV_TYPE_TLV, 0 },
2190+ [NM_ATT_BS11_BTS_STATE] = { TLV_TYPE_TLV, 0 },
2191+ [NM_ATT_BS11_E1_STATE] = { TLV_TYPE_TLV, 0 },
2192+ [NM_ATT_BS11_PLL_MODE] = { TLV_TYPE_TLV, 0 },
2193+ [NM_ATT_BS11_PLL] = { TLV_TYPE_TLV, 0 },
2194+ [NM_ATT_BS11_CCLK_ACCURACY] = { TLV_TYPE_TV, 0 },
2195+ [NM_ATT_BS11_CCLK_TYPE] = { TLV_TYPE_TV, 0 },
Harald Welte2c544c82009-07-11 16:41:15 +02002196+ [0x95] = { TLV_TYPE_FIXED, 2 },
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +08002197+ },
2198+};
2199+
2200+/* ip.access specifics */
2201+static const struct tlv_definition nm_att_tlvdef_ipa = {
2202+ .def = {
Harald Weltec9b484f2009-07-12 20:46:43 +02002203+ [NM_ATT_IPACC_DST_IP] = { TLV_TYPE_FIXED, 4 },
2204+ [NM_ATT_IPACC_DST_IP_PORT] = { TLV_TYPE_FIXED, 2 },
2205+ [NM_ATT_IPACC_PRIM_OML_CFG] = { TLV_TYPE_TL16V, 0 },
Harald Welteb16004c2009-07-11 19:44:53 +02002206+ [NM_ATT_IPACC_NV_FLAGS] = { TLV_TYPE_TL16V, 0 },
Harald Welte450129f2009-07-03 12:46:47 +02002207+ [NM_ATT_IPACC_FREQ_CTRL] = { TLV_TYPE_FIXED, 2 },
Harald Welte450129f2009-07-03 12:46:47 +02002208+ [NM_ATT_IPACC_SEC_OML_CFG] = { TLV_TYPE_FIXED, 6 },
2209+ [NM_ATT_IPACC_IP_IF_CFG] = { TLV_TYPE_FIXED, 8 },
2210+ [NM_ATT_IPACC_IP_GW_CFG] = { TLV_TYPE_FIXED, 12 },
Harald Welteb16004c2009-07-11 19:44:53 +02002211+ [NM_ATT_IPACC_LOCATION] = { TLV_TYPE_TL16V, 0 },
2212+ [NM_ATT_IPACC_UNIT_ID] = { TLV_TYPE_TL16V, 0 },
2213+ [NM_ATT_IPACC_UNIT_NAME] = { TLV_TYPE_TL16V, 0 },
2214+ [NM_ATT_IPACC_SNMP_CFG] = { TLV_TYPE_TL16V, 0 },
2215+ [NM_ATT_IPACC_ALM_THRESH_LIST]= { TLV_TYPE_TL16V, 0 },
2216+ [NM_ATT_IPACC_CUR_SW_CFG] = { TLV_TYPE_TL16V, 0 },
Harald Weltec9b484f2009-07-12 20:46:43 +02002217+ [NM_ATT_IPACC_STREAM_ID] = { TLV_TYPE_TV, 0 },
2218+ [NM_ATT_IPACC_RAC] = { TLV_TYPE_TL16V, 0 },
2219+ [NM_ATT_IPACC_OBJ_VERSION] = { TLV_TYPE_TL16V, 0 },
2220+ [NM_ATT_IPACC_GPRS_PAGING_CFG] ={ TLV_TYPE_TL16V, 0 },
2221+ [NM_ATT_IPACC_NSEI] = { TLV_TYPE_TL16V, 0 },
2222+ [NM_ATT_IPACC_BVCI] = { TLV_TYPE_TL16V, 0 },
2223+ [NM_ATT_IPACC_NSVCI] = { TLV_TYPE_TL16V, 0 },
2224+ [NM_ATT_IPACC_NS_CFG] = { TLV_TYPE_TL16V, 0 },
2225+ [NM_ATT_IPACC_BSSGP_CFG] = { TLV_TYPE_TL16V, 0 },
2226+ [NM_ATT_IPACC_NS_LINK_CFG] = { TLV_TYPE_TL16V, 0 },
2227+ [NM_ATT_IPACC_RLC_CFG] = { TLV_TYPE_TL16V, 0 },
2228+ [NM_ATT_IPACC_SUPP_FEATURES] = { TLV_TYPE_TL16V, 0 },
2229+ [NM_ATT_IPACC_CODING_SCHEMES] = { TLV_TYPE_TL16V, 0 },
2230+ [NM_ATT_IPACC_RLC_CFG_2] = { TLV_TYPE_TL16V, 0 },
2231+ [NM_ATT_IPACC_RLC_CFG_3] = { TLV_TYPE_TL16V, 0 },
Holger Hans Peter Freyther304db152009-12-29 04:16:37 +01002232+ [NM_ATT_IPACC_FILE_DATA] = { TLV_TYPE_TL16V, 0 },
Holger Hans Peter Freyther5af5e322010-05-23 05:46:21 +08002233+ [NM_ATT_IPACC_CGI] = { TLV_TYPE_TL16V, 0 },
Harald Welte6900c162009-06-25 20:50:57 +02002234+ },
2235+};
2236+
2237+#endif /* _NM_H */
Holger Hans Peter Freyther2fb7ccf2010-04-21 20:37:53 +08002238--
22391.7.0.1
2240