blob: 25254918e4c8bc5c9c1904674f4167512d98d37e [file] [log] [blame]
Holger Hans Peter Freyther9b5f1d72011-01-11 16:33:52 +01001From c6c10dab54b9a667308004ab5c72dd08f52e4fc1 Mon Sep 17 00:00:00 2001
Holger Hans Peter Freyther2fb7ccf2010-04-21 20:37:53 +08002From: Holger Hans Peter Freyther <zecke@selfish.org>
Holger Hans Peter Freyther9b5f1d72011-01-11 16:33:52 +01003Date: Tue, 11 Jan 2011 15:08:42 +0100
4Subject: [PATCH 1/4] abis_oml
Holger Hans Peter Freyther2fb7ccf2010-04-21 20:37:53 +08005
Holger Hans Peter Freyther9b5f1d72011-01-11 16:33:52 +01006Add the GSM ABIS OML dissector from OpenBSC
Holger Hans Peter Freyther2fb7ccf2010-04-21 20:37:53 +08007---
Holger Hans Peter Freyther9b5f1d72011-01-11 16:33:52 +01008 epan/CMakeLists.txt | 1 +
Holger Hans Peter Freyther2fb7ccf2010-04-21 20:37:53 +08009 epan/dissectors/Makefile.common | 1 +
Holger Hans Peter Freyther9b5f1d72011-01-11 16:33:52 +010010 epan/dissectors/packet-gsm_abis_oml.c | 1608 +++++++++++++++++++++++++++++++++
11 epan/dissectors/packet-gsm_abis_oml.h | 830 +++++++++++++++++
12 4 files changed, 2440 insertions(+), 0 deletions(-)
Holger Hans Peter Freyther2fb7ccf2010-04-21 20:37:53 +080013 create mode 100644 epan/dissectors/packet-gsm_abis_oml.c
14 create mode 100644 epan/dissectors/packet-gsm_abis_oml.h
15
Pablo Neira Ayuso4fcd3572011-03-06 16:47:28 +010016Index: wireshark/epan/CMakeLists.txt
17===================================================================
18--- wireshark.orig/epan/CMakeLists.txt 2011-03-03 14:01:07.000000000 +0100
19+++ wireshark/epan/CMakeLists.txt 2011-03-03 14:01:20.000000000 +0100
20@@ -589,6 +589,7 @@ set(DISSECTOR_SRC
Holger Hans Peter Freyther9b5f1d72011-01-11 16:33:52 +010021 dissectors/packet-gsm_a_gm.c
22 dissectors/packet-gsm_a_rp.c
23 dissectors/packet-gsm_a_rr.c
24+ dissectors/packet-gsm_abis_oml.c
25 dissectors/packet-gsm_ipa.c
26 dissectors/packet-gsm_bsslap.c
27 dissectors/packet-gsm_bssmap_le.c
Pablo Neira Ayuso4fcd3572011-03-06 16:47:28 +010028Index: wireshark/epan/dissectors/Makefile.common
29===================================================================
30--- wireshark.orig/epan/dissectors/Makefile.common 2011-03-03 14:01:07.000000000 +0100
31+++ wireshark/epan/dissectors/Makefile.common 2011-03-03 14:01:20.000000000 +0100
32@@ -501,6 +501,7 @@ DISSECTOR_SRC = \
Harald Welte6d42dbe2010-12-01 00:04:09 +010033 packet-gsm_a_gm.c \
34 packet-gsm_a_rp.c \
Harald Welteb16004c2009-07-11 19:44:53 +020035 packet-gsm_a_rr.c \
Harald Welte63aba292009-07-04 04:11:21 +020036+ packet-gsm_abis_oml.c \
Harald Welte6d42dbe2010-12-01 00:04:09 +010037 packet-gsm_bsslap.c \
Harald Welteb16004c2009-07-11 19:44:53 +020038 packet-gsm_bssmap_le.c \
Holger Hans Peter Freyther9b5f1d72011-01-11 16:33:52 +010039 packet-gsm_ipa.c \
Pablo Neira Ayuso4fcd3572011-03-06 16:47:28 +010040Index: wireshark/epan/dissectors/packet-gsm_abis_oml.c
41===================================================================
42--- /dev/null 1970-01-01 00:00:00.000000000 +0000
43+++ wireshark/epan/dissectors/packet-gsm_abis_oml.c 2011-03-06 13:12:30.000000000 +0100
44@@ -0,0 +1,1776 @@
Harald Welte6900c162009-06-25 20:50:57 +020045+/* packet-abis_oml.c
46+ * Routines for packet dissection of GSM A-bis over IP (3GPP TS 12.21)
Harald Welteb88b6d32010-06-19 13:52:54 +020047+ * Copyright 2009-2010 by Harald Welte <laforge@gnumonks.org>
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +010048+ * Copyright 2009 by Holger Hans Peter Freyther <zecke@selfish.org>
Harald Welte6900c162009-06-25 20:50:57 +020049+ * based on A-bis OML code in OpenBSC
50+ *
51+ * $Id$
52+ *
53+ * Wireshark - Network traffic analyzer
54+ * By Gerald Combs <gerald@wireshark.org>
55+ * Copyright 1998 Gerald Combs
56+ *
57+ * This program is free software; you can redistribute it and/or
58+ * modify it under the terms of the GNU General Public License
59+ * as published by the Free Software Foundation; either version 2
60+ * of the License, or (at your option) any later version.
61+ *
62+ * This program is distributed in the hope that it will be useful,
63+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
64+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
65+ * GNU General Public License for more details.
66+ *
67+ * You should have received a copy of the GNU General Public License
68+ * along with this program; if not, write to the Free Software
69+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
70+ */
71+
72+#ifdef HAVE_CONFIG_H
73+# include "config.h"
74+#endif
75+
76+#include <glib.h>
77+
78+#include <epan/packet.h>
79+#include <epan/emem.h>
Harald Welte4e8c98a2009-08-20 00:59:11 +090080+#include <epan/lapd_sapi.h>
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +010081+#include <epan/prefs.h>
Harald Welte6900c162009-06-25 20:50:57 +020082+
Harald Welte63aba292009-07-04 04:11:21 +020083+#include "packet-gsm_abis_oml.h"
Harald Welte1cc3fa82009-07-01 17:40:50 +020084+#include "packet-gsm_a_common.h"
Harald Welte6900c162009-06-25 20:50:57 +020085+
Holger Hans Peter Freytherbdcf45c2010-06-06 21:33:52 +080086+#include <stdio.h>
87+
Harald Welte6900c162009-06-25 20:50:57 +020088+/* initialize the protocol and registered fields */
89+static int proto_abis_oml = -1;
90+
91+/* OML header */
92+static int hf_oml_msg_disc = -1;
93+static int hf_oml_placement = -1;
94+static int hf_oml_sequence = -1;
95+static int hf_oml_length = -1;
96+/* FOM header */
97+static int hf_oml_fom_msgtype = -1;
98+static int hf_oml_fom_objclass = -1;
99+static int hf_oml_fom_inst_bts = -1;
100+static int hf_oml_fom_inst_trx = -1;
101+static int hf_oml_fom_inst_ts = -1;
102+static int hf_oml_fom_attr_tag = -1;
103+static int hf_oml_fom_attr_len = -1;
104+static int hf_oml_fom_attr_val = -1;
105+/* FOM attributes */
106+static int hf_attr_adm_state = -1;
Harald Welte2c544c82009-07-11 16:41:15 +0200107+static int hf_attr_arfcn = -1;
Harald Welte6900c162009-06-25 20:50:57 +0200108+static int hf_attr_oper_state = -1;
109+static int hf_attr_avail_state = -1;
110+static int hf_attr_event_type = -1;
111+static int hf_attr_severity = -1;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200112+static int hf_attr_bcch_arfcn = -1;
113+static int hf_attr_bsic = -1;
114+static int hf_attr_test_no = -1;
115+static int hf_attr_tsc = -1;
116+static int hf_attr_tei = -1;
117+static int hf_attr_ach_btsp = -1;
118+static int hf_attr_ach_tslot = -1;
119+static int hf_attr_ach_sslot = -1;
120+static int hf_attr_gsm_time = -1;
121+static int hf_attr_chan_comb = -1;
Harald Welteb88b6d32010-06-19 13:52:54 +0200122+static int hf_attr_hsn = -1;
123+static int hf_attr_maio = -1;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200124+/* Ipaccess */
125+static int hf_oml_ipa_tres_attr_tag = -1;
126+static int hf_oml_ipa_tres_attr_len = -1;
127+static int hf_attr_ipa_test_res = -1;
128+static int hf_attr_ipa_tr_rxlev = -1;
Harald Welte450129f2009-07-03 12:46:47 +0200129+static int hf_attr_ipa_tr_b_rxlev = -1;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200130+static int hf_attr_ipa_tr_arfcn = -1;
131+static int hf_attr_ipa_tr_f_qual = -1;
132+static int hf_attr_ipa_tr_f_err = -1;
133+static int hf_attr_ipa_tr_rxqual = -1;
134+static int hf_attr_ipa_tr_frame_offs = -1;
135+static int hf_attr_ipa_tr_framenr_offs = -1;
136+static int hf_attr_ipa_tr_bsic = -1;
137+static int hf_attr_ipa_tr_cell_id = -1;
Harald Welte450129f2009-07-03 12:46:47 +0200138+static int hf_attr_ipa_tr_si2 = -1;
139+static int hf_attr_ipa_tr_si2bis = -1;
140+static int hf_attr_ipa_tr_si2ter = -1;
141+static int hf_attr_ipa_tr_chan_desc = -1;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200142+static int hf_attr_ipa_rsl_ip = -1;
143+static int hf_attr_ipa_rsl_port = -1;
Harald Welte450129f2009-07-03 12:46:47 +0200144+static int hf_attr_ipa_prim_oml_ip = -1;
145+static int hf_attr_ipa_prim_oml_port = -1;
146+static int hf_attr_ipa_location_name = -1;
147+static int hf_attr_ipa_unit_id = -1;
148+static int hf_attr_ipa_unit_name = -1;
149+static int hf_attr_ipa_nv_flags = -1;
150+static int hf_attr_ipa_nv_mask = -1;
Harald Weltec9b484f2009-07-12 20:46:43 +0200151+static int hf_attr_ipa_nsl_sport = -1;
152+static int hf_attr_ipa_nsl_daddr = -1;
153+static int hf_attr_ipa_nsl_dport = -1;
154+static int hf_attr_ipa_nsei = -1;
155+static int hf_attr_ipa_nsvci = -1;
156+static int hf_attr_ipa_bvci = -1;
157+static int hf_attr_ipa_rac = -1;
Harald Welte6900c162009-06-25 20:50:57 +0200158+
159+/* initialize the subtree pointers */
160+static int ett_oml = -1;
161+static int ett_oml_fom = -1;
162+static int ett_oml_fom_att = -1;
163+
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +0100164+/* Decode things as nanoBTS traces */
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +0800165+static gboolean global_oml_use_nano_bts = TRUE;
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +0100166+
Harald Welte6900c162009-06-25 20:50:57 +0200167+static proto_tree *top_tree;
168+
169+/* TS 12.21 Chapter 8.1 / TS 08.59 */
170+static const value_string oml_msg_disc_vals[] = {
171+ { ABIS_OM_MDISC_FOM, "Formatted O&M" },
172+ { ABIS_OM_MDISC_MMI, "MMI Transfer" },
173+ { ABIS_OM_MDISC_TRAU, "TRAU O&M" },
174+ { ABIS_OM_MDISC_MANUF, "Manufacturer specific" },
175+};
176+
177+/* TS 12.21 Chapter 8.1.1 */
178+static const value_string oml_placement_vals[] = {
179+ { ABIS_OM_PLACEMENT_ONLY, "Only" },
180+ { ABIS_OM_PLACEMENT_FIRST, "First" },
181+ { ABIS_OM_PLACEMENT_MIDDLE, "Middle" },
182+ { ABIS_OM_PLACEMENT_LAST, "Last" },
183+};
184+
Harald Welteb88b6d32010-06-19 13:52:54 +0200185+/* Standard Message Types as per TS 12.21 Chapter 9.2 */
186+static const value_string _oml_fom_msgtype_vals[] = {
Harald Welte6900c162009-06-25 20:50:57 +0200187+ { NM_MT_LOAD_INIT, "Software Load Init" },
188+ { NM_MT_LOAD_INIT_ACK, "Software Load Init ACK" },
189+ { NM_MT_LOAD_INIT_NACK, "Software Load Init NACK" },
190+ { NM_MT_LOAD_SEG, "Software Load Segment" },
191+ { NM_MT_LOAD_SEG_ACK, "Software Load Segment ACK" },
192+ { NM_MT_LOAD_END, "Software Load End" },
193+ { NM_MT_LOAD_END_ACK, "Software Load End ACK" },
194+ { NM_MT_LOAD_END_NACK, "Software Load End NACK" },
195+ { NM_MT_SW_ACT_REQ, "Software Activate Request" },
196+ { NM_MT_SW_ACT_REQ_ACK, "Software Activate Request ACK" },
197+ { NM_MT_SW_ACT_REQ_NACK, "Software Activate Request NACK" },
198+ { NM_MT_ACTIVATE_SW, "Activate Software" },
199+ { NM_MT_ACTIVATE_SW_ACK, "Activate Software ACK" },
200+ { NM_MT_ACTIVATE_SW_NACK, "Activate Software NACK" },
201+ { NM_MT_SW_ACTIVATED_REP, "Software Activated Report" },
202+ { NM_MT_ESTABLISH_TEI, "Establish TEI" },
203+ { NM_MT_ESTABLISH_TEI_ACK, "Establish TEI ACK" },
204+ { NM_MT_ESTABLISH_TEI_NACK, "Establish TEI NACK" },
205+ { NM_MT_CONN_TERR_SIGN, "Connect Terrestrial Signalling" },
206+ { NM_MT_CONN_TERR_SIGN_ACK, "Connect Terrestrial Signalling ACK" },
207+ { NM_MT_CONN_TERR_SIGN_NACK, "Connect Terrestrial Signalling NACK" },
208+ { NM_MT_DISC_TERR_SIGN, "Disconnect Terrestrial Signalling" },
209+ { NM_MT_DISC_TERR_SIGN_ACK, "Disconnect Terrestrial Signalling ACK" },
210+ { NM_MT_DISC_TERR_SIGN_NACK, "Disconnect Terrestrial Signalling NACK" },
211+ { NM_MT_CONN_TERR_TRAF, "Connect Terrestrial Traffic" },
212+ { NM_MT_CONN_TERR_TRAF_ACK, "Connect Terrestrial Traffic ACK" },
213+ { NM_MT_CONN_TERR_TRAF_NACK, "Connect Terrestrial Traffic NACK" },
214+ { NM_MT_DISC_TERR_TRAF, "Disconnect Terrestrial Traffic" },
215+ { NM_MT_DISC_TERR_TRAF_ACK, "Disconnect Terrestrial Traffic ACK" },
216+ { NM_MT_DISC_TERR_TRAF_NACK, "Disconnect Terrestrial Traffic NACK" },
217+ { NM_MT_CONN_MDROP_LINK, "Connect Multi-Drop Link" },
218+ { NM_MT_CONN_MDROP_LINK_ACK, "Connect Multi-Drop Link ACK" },
219+ { NM_MT_CONN_MDROP_LINK_NACK, "Connect Multi-Drop Link NACK" },
220+ { NM_MT_DISC_MDROP_LINK, "Disconnect Multi-Drop Link" },
221+ { NM_MT_DISC_MDROP_LINK_ACK, "Disconnect Multi-Drop Link ACK" },
222+ { NM_MT_DISC_MDROP_LINK_NACK, "Disconnect Multi-Drop Link NACK" },
223+ { NM_MT_SET_BTS_ATTR, "Set BTS Attributes" },
224+ { NM_MT_SET_BTS_ATTR_ACK, "Set BTS Attributes ACK" },
225+ { NM_MT_SET_BTS_ATTR_NACK, "Set BTS Attributes NACK" },
226+ { NM_MT_SET_RADIO_ATTR, "Set Radio Carrier Attributes" },
227+ { NM_MT_SET_RADIO_ATTR_ACK, "Set Radio Carrier Attributes ACK" },
228+ { NM_MT_SET_RADIO_ATTR_NACK, "Set Radio Carrier Attributes NACK" },
229+ { NM_MT_SET_CHAN_ATTR, "Set Channel Attributes" },
230+ { NM_MT_SET_CHAN_ATTR_ACK, "Set Channel Attributes ACK" },
231+ { NM_MT_SET_CHAN_ATTR_NACK, "Set Channel Attributes NACK" },
232+ { NM_MT_PERF_TEST, "Perform Test" },
233+ { NM_MT_PERF_TEST_ACK, "Perform Test ACK" },
234+ { NM_MT_PERF_TEST_NACK, "Perform Test NACK" },
235+ { NM_MT_TEST_REP, "Test Report" },
236+ { NM_MT_SEND_TEST_REP, "Send Test Report" },
237+ { NM_MT_SEND_TEST_REP_ACK, "Send Test Report ACK" },
238+ { NM_MT_SEND_TEST_REP_NACK, "Send Test Report NACK" },
239+ { NM_MT_STOP_TEST, "Stop Test" },
240+ { NM_MT_STOP_TEST_ACK, "Stop Test ACK" },
241+ { NM_MT_STOP_TEST_NACK, "Stop Test NACK" },
242+ { NM_MT_STATECHG_EVENT_REP, "State Changed Event Report" },
243+ { NM_MT_FAILURE_EVENT_REP, "Failure Event Report" },
244+ { NM_MT_STOP_EVENT_REP, "Stop Sending Event Reports" },
245+ { NM_MT_STOP_EVENT_REP_ACK, "Stop Sending Event Reports ACK" },
246+ { NM_MT_STOP_EVENT_REP_NACK, "Stop Sending Event Reports NACK" },
247+ { NM_MT_REST_EVENT_REP, "Restart Sending Event Reports" },
248+ { NM_MT_REST_EVENT_REP_ACK, "Restart Sending Event Reports ACK" },
249+ { NM_MT_REST_EVENT_REP_NACK, "Restart Sending Event Reports NACK" },
250+ { NM_MT_CHG_ADM_STATE, "Change Administrative State" },
251+ { NM_MT_CHG_ADM_STATE_ACK, "Change Administrative State ACK" },
252+ { NM_MT_CHG_ADM_STATE_NACK, "Change Administrative State NACK" },
253+ { NM_MT_CHG_ADM_STATE_REQ, "Change Administrative State Request" },
254+ { NM_MT_CHG_ADM_STATE_REQ_ACK, "Change Administrative State Request ACK" },
255+ { NM_MT_CHG_ADM_STATE_REQ_NACK, "Change Administrative State Request NACK" },
256+ { NM_MT_REP_OUTST_ALARMS, "Report Outstanding Alarms" },
257+ { NM_MT_REP_OUTST_ALARMS_ACK, "Report Outstanding Alarms ACK" },
258+ { NM_MT_REP_OUTST_ALARMS_NACK, "Report Outstanding Alarms NACK" },
259+ { NM_MT_CHANGEOVER, "Changeover" },
260+ { NM_MT_CHANGEOVER_ACK, "Changeover ACK" },
261+ { NM_MT_CHANGEOVER_NACK, "Changeover NACK" },
262+ { NM_MT_OPSTART, "Opstart" },
263+ { NM_MT_OPSTART_ACK, "Opstart ACK" },
264+ { NM_MT_OPSTART_NACK, "Opstart NACK" },
265+ { NM_MT_REINIT, "Reinitialize" },
266+ { NM_MT_REINIT_ACK, "Reinitialize ACK" },
267+ { NM_MT_REINIT_NACK, "Reinitialize NACK" },
268+ { NM_MT_SET_SITE_OUT, "Set Site Outputs" },
269+ { NM_MT_SET_SITE_OUT_ACK, "Set Site Outputs ACK" },
270+ { NM_MT_SET_SITE_OUT_NACK, "Set Site Outputs NACK" },
271+ { NM_MT_CHG_HW_CONF, "Change HW Configuration" },
272+ { NM_MT_CHG_HW_CONF_ACK, "Change HW Configuration ACK" },
273+ { NM_MT_CHG_HW_CONF_NACK, "Change HW Configuration NACK" },
274+ { NM_MT_MEAS_RES_REQ, "Measurement Result Request" },
275+ { NM_MT_MEAS_RES_RESP, "Measurement Result Response" },
276+ { NM_MT_STOP_MEAS, "Stop Measurement" },
277+ { NM_MT_START_MEAS, "Start Measurement" },
278+ { NM_MT_GET_ATTR, "Get Attributes" },
279+ { NM_MT_GET_ATTR_RESP, "Get Attributes Response" },
280+ { NM_MT_GET_ATTR_NACK, "Get Attributes NACK" },
281+ { NM_MT_SET_ALARM_THRES, "Set Alarm Threshold" },
282+ { NM_MT_SET_ALARM_THRES_ACK, "Set Alarm Threshold ACK" },
283+ { NM_MT_SET_ALARM_THRES_NACK, "Set Alarm Threshold NACK" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200284+ { 0, NULL }
285+};
286+
287+/* proprietary ip.access message types, not in the standard */
288+static const value_string _oml_fom_msgtype_vals_ipa[] = {
Harald Welte6900c162009-06-25 20:50:57 +0200289+ { NM_MT_IPACC_RESTART, "IPA Restart" },
290+ { NM_MT_IPACC_RESTART_ACK, "IPA Restart ACK" },
291+ { NM_MT_IPACC_RSL_CONNECT, "IPA RSL Connect" },
292+ { NM_MT_IPACC_RSL_CONNECT_ACK, "IPA RSL Connect ACK" },
293+ { NM_MT_IPACC_RSL_CONNECT_NACK, "IPA RSL Connect NACK" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200294+ { NM_MT_IPACC_RSL_DISCONNECT, "IPA RSL Disconnect" },
295+ { NM_MT_IPACC_RSL_DISCONNECT_ACK, "IPA RSL Disconnect ACK" },
296+ { NM_MT_IPACC_RSL_DISCONNECT_NACK, "IPA RSL Disconnect NACK" },
297+ { NM_MT_IPACC_CONN_TRAF, "IPA Connect Traffic" },
298+ { NM_MT_IPACC_CONN_TRAF_ACK, "IPA Connect Traffic ACK" },
299+ { NM_MT_IPACC_CONN_TRAF_NACK, "IPA Connect Traffic NACK" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200300+ { NM_MT_IPACC_DISC_TRAF, "IPA Disconnect Traffic" },
301+ { NM_MT_IPACC_DISC_TRAF_ACK, "IPA Disconnect Traffic ACK" },
302+ { NM_MT_IPACC_DISC_TRAF_NACK, "IPA Disconnect Traffic NACK" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200303+ { NM_MT_IPACC_DEF_BOOT_SW, "IPA Default Boot Software" },
304+ { NM_MT_IPACC_DEF_BOOT_SW_ACK, "IPA Default Boot Software ACK" },
305+ { NM_MT_IPACC_DEF_BOOT_SW_NACK, "IPA Default Boot Software NACK" },
Harald Welte6900c162009-06-25 20:50:57 +0200306+ { NM_MT_IPACC_SET_NVATTR, "IPA Set NVRAM Attributes" },
307+ { NM_MT_IPACC_SET_NVATTR_ACK, "IPA Set NVRAM Attributes ACK" },
308+ { NM_MT_IPACC_SET_NVATTR_NACK, "IPA Set NVRAM Attributes NACK" },
309+ { NM_MT_IPACC_GET_NVATTR, "IPA Get NVRAM Attributes" },
310+ { NM_MT_IPACC_GET_NVATTR_ACK, "IPA Get NVRAM Attributes ACK" },
311+ { NM_MT_IPACC_GET_NVATTR_NACK, "IPA Get NVRAM Attributes NACK" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200312+ { NM_MT_IPACC_SET_ATTR, "IPA Set Attributes" },
313+ { NM_MT_IPACC_SET_ATTR_ACK, "IPA Set Attributes ACK" },
314+ { NM_MT_IPACC_SET_ATTR_NACK, "IPA Set Attributes NACK" },
315+ { NM_MT_IPACC_ATTR_CHG_EVT, "IPA Attribute Change Event" },
316+ { NM_MT_IPACC_SW_DEACT, "IPA Software Deactivate" },
317+ { NM_MT_IPACC_SW_DEACT_ACK, "IPA Software Deactivate ACK" },
318+ { NM_MT_IPACC_SW_DEACT_NACK, "IPA Software Deactivate NACK" },
319+ { NM_MT_IPACC_MEAS_RES_REQ_NACK,"IPA Measurement Result Request NACK" },
320+ { NM_MT_IPACC_START_MEAS_NACK, "IPA Start Measurement NACK" },
321+ { NM_MT_IPACC_STOP_MEAS_NACK, "IPA Stop Measurement NACK" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200322+ { 0, NULL }
323+};
324+
325+/* proprietary Siemens message types, not in the standard */
326+static const value_string _oml_fom_msgtype_vals_bs11[] = {
Harald Welte6900c162009-06-25 20:50:57 +0200327+ { NM_MT_BS11_RESET_RESOURCE, "SIE Reset Resource" },
328+ { NM_MT_BS11_BEGIN_DB_TX, "SIE Begin Database Transmission" },
329+ { NM_MT_BS11_BEGIN_DB_TX_ACK, "SIE Begin Database Transmission ACK" },
330+ { NM_MT_BS11_BEGIN_DB_TX_NACK, "SIE Begin Database Transmission NACK" },
331+ { NM_MT_BS11_END_DB_TX, "SIE End Database Transmission" },
332+ { NM_MT_BS11_END_DB_TX_ACK, "SIE End Database Transmission ACK" },
333+ { NM_MT_BS11_END_DB_TX_NACK, "SIE End Database Transmission NACK" },
334+ { NM_MT_BS11_CREATE_OBJ, "SIE Create Object" },
335+ { NM_MT_BS11_CREATE_OBJ_ACK, "SIE Create Object ACK" },
336+ { NM_MT_BS11_CREATE_OBJ_NACK, "SIE Create Object NACK" },
337+ { NM_MT_BS11_DELETE_OBJ, "SIE Delete Object" },
338+ { NM_MT_BS11_DELETE_OBJ_ACK, "SIE Delete Object ACK" },
339+ { NM_MT_BS11_DELETE_OBJ_NACK, "SIE Delete Object NACK" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200340+ { NM_MT_BS11_SET_ATTR, "SIE Set Attribute" },
341+ { NM_MT_BS11_SET_ATTR_ACK, "SIE Set Attribute ACK" },
342+ { NM_MT_BS11_SET_ATTR_NACK, "SIE Set Attribute NACK" },
Harald Welte6900c162009-06-25 20:50:57 +0200343+ { NM_MT_BS11_GET_STATE, "SIE Get State" },
344+ { NM_MT_BS11_GET_STATE_ACK, "SIE Get State ACK" },
345+ { NM_MT_BS11_LMT_LOGON, "SIE LMT Logon" },
346+ { NM_MT_BS11_LMT_LOGON_ACK, "SIE LMT Logon ACK" },
347+ { NM_MT_BS11_RESTART, "SIE Restart" },
348+ { NM_MT_BS11_RESTART_ACK, "SIE Restart ACK" },
349+ { NM_MT_BS11_DISCONNECT, "SIE Disconnect BTS" },
350+ { NM_MT_BS11_DISCONNECT_ACK, "SIE Disconnect BTS ACK" },
351+ { NM_MT_BS11_LMT_LOGOFF, "SIE LMT Logoff" },
352+ { NM_MT_BS11_LMT_LOGOFF_ACK, "SIE LMT Logoff ACK" },
353+ { NM_MT_BS11_RECONNECT, "SIE Reconnect BTS" },
354+ { NM_MT_BS11_RECONNECT_ACK, "SIE Reconnect BTS ACK" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200355+ { 0, NULL }
Harald Welte6900c162009-06-25 20:50:57 +0200356+};
357+
Harald Welteb88b6d32010-06-19 13:52:54 +0200358+/* initialize with the standard message types only */
359+static value_string_ext oml_fom_msgtype_vse = VALUE_STRING_EXT_INIT(_oml_fom_msgtype_vals);
360+
Harald Welte6900c162009-06-25 20:50:57 +0200361+/* TS 12.21 Section 9.2: Object Class */
362+static const value_string oml_fom_objclass_vals[] = {
363+ { NM_OC_SITE_MANAGER, "BTS Site Manager" },
364+ { NM_OC_BTS, "BTS" },
365+ { NM_OC_RADIO_CARRIER, "Radio Carrier" },
366+ { NM_OC_CHANNEL, "Radio Channel" },
367+ { NM_OC_BASEB_TRANSC, "Baseband Transceiver" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200368+
Harald Welte6900c162009-06-25 20:50:57 +0200369+ /* proprietary, vendor specific */
370+ { NM_OC_BS11_ADJC, "SIE Adjacend Channel" },
371+ { NM_OC_BS11_HANDOVER, "SIE Handover" },
372+ { NM_OC_BS11_PWR_CTRL, "SIE Power Control" },
373+ { NM_OC_BS11_BTSE, "SIE BTSE" },
374+ { NM_OC_BS11_RACK, "SIE Rack" },
375+ { NM_OC_BS11, "SIE SiemensHW" },
376+ { NM_OC_BS11_TEST, "SIE Test" },
377+ { NM_OC_BS11_ENVABTSE, "SIE EnvaBTSE" },
378+ { NM_OC_BS11_BPORT, "SIE BPort" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200379+
Harald Welte6900c162009-06-25 20:50:57 +0200380+ { NM_OC_GPRS_NSE, "GPRS NSE" },
381+ { NM_OC_GPRS_CELL, "GPRS Cell" },
382+ { NM_OC_GPRS_NSVC0, "GPRS NSVC0" },
383+ { NM_OC_GPRS_NSVC1, "GPRS NSVC1" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200384+
Harald Welte6900c162009-06-25 20:50:57 +0200385+ { NM_OC_NULL, "NULL" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200386+ { 0, NULL }
Harald Welte6900c162009-06-25 20:50:57 +0200387+};
388+
389+/* TS 12.21 Section 9.4: Attributes */
Harald Welteb88b6d32010-06-19 13:52:54 +0200390+static const value_string _oml_fom_attr_vals[] = {
Harald Welte6900c162009-06-25 20:50:57 +0200391+ { NM_ATT_ABIS_CHANNEL, "A-bis Channel" },
392+ { NM_ATT_ADD_INFO, "Additional Information" },
393+ { NM_ATT_ADD_TEXT, "Additional Text" },
394+ { NM_ATT_ADM_STATE, "Administrative State" },
395+ { NM_ATT_ARFCN_LIST, "ARFCN List" },
396+ { NM_ATT_AUTON_REPORT, "Autonomously Report" },
397+ { NM_ATT_AVAIL_STATUS, "Availability Status" },
398+ { NM_ATT_BCCH_ARFCN, "BCCH ARFCN" },
399+ { NM_ATT_BSIC, "BSIC" },
400+ { NM_ATT_BTS_AIR_TIMER, "BTS Air Timer" },
401+ { NM_ATT_CCCH_L_I_P, "CCCH Load Indication Period" },
402+ { NM_ATT_CCCH_L_T, "CCCH Load Threshold" },
403+ { NM_ATT_CHAN_COMB, "Channel Combination" },
404+ { NM_ATT_CONN_FAIL_CRIT, "Connection Fail Criterion" },
405+ { NM_ATT_DEST, "Destination" },
406+ { NM_ATT_EVENT_TYPE, "Event Type" },
407+ { NM_ATT_FILE_ID, "File ID" },
408+ { NM_ATT_FILE_VERSION, "File Version" },
409+ { NM_ATT_GSM_TIME, "GSM Time" },
410+ { NM_ATT_HSN, "HSN" },
411+ { NM_ATT_HW_CONFIG, "HW Configuration" },
412+ { NM_ATT_HW_DESC, "HW Description" },
413+ { NM_ATT_INTAVE_PARAM, "Intave Parameter" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200414+ { NM_ATT_INTERF_BOUND, "Interference Boundaries" },
Harald Welte6900c162009-06-25 20:50:57 +0200415+ { NM_ATT_LIST_REQ_ATTR, "List of required Attributes" },
416+ { NM_ATT_MAIO, "MAIO" },
417+ { NM_ATT_MANUF_STATE, "Manufacturer Dependent State" },
418+ { NM_ATT_MANUF_THRESH, "Manufacturer Dependent Thresholds" },
419+ { NM_ATT_MANUF_ID, "Manufacturer Id" },
420+ { NM_ATT_MAX_TA, "Maximum Timing Advance" },
421+ { NM_ATT_MDROP_LINK, "Multi-drop BSC Link" },
422+ { NM_ATT_MDROP_NEXT, "Multi-drop next BTS Link" },
423+ { NM_ATT_NACK_CAUSES, "NACK Causes" },
424+ { NM_ATT_NY1, "Ny1" },
425+ { NM_ATT_OPER_STATE, "Operational State" },
426+ { NM_ATT_OVERL_PERIOD, "Overload Period" },
427+ { NM_ATT_PHYS_CONF, "Physical Config" },
428+ { NM_ATT_POWER_CLASS, "Power Class" },
429+ { NM_ATT_POWER_THRESH, "Power Output Thresholds" },
430+ { NM_ATT_PROB_CAUSE, "Probable Cause" },
431+ { NM_ATT_RACH_B_THRESH, "RACH Busy Threshold" },
432+ { NM_ATT_LDAVG_SLOTS, "RACH Load Averaging Slots" },
433+ { NM_ATT_RAD_SUBC, "Radio Sub Channel" },
434+ { NM_ATT_RF_MAXPOWR_R, "RF Max Power Reduction" },
435+ { NM_ATT_SITE_INPUTS, "Site Inputs" },
436+ { NM_ATT_SITE_OUTPUTS, "Site Outputs" },
437+ { NM_ATT_SOURCE, "Source" },
438+ { NM_ATT_SPEC_PROB, "Specific Problems" },
439+ { NM_ATT_START_TIME, "Starting Time" },
440+ { NM_ATT_T200, "T200" },
441+ { NM_ATT_TEI, "TEI" },
442+ { NM_ATT_TEST_DUR, "Test Duration" },
443+ { NM_ATT_TEST_NO, "Test No" },
444+ { NM_ATT_TEST_REPORT, "Test Report Info" },
445+ { NM_ATT_VSWR_THRESH, "VSWR Thresholds " },
446+ { NM_ATT_WINDOW_SIZE, "Window Size" },
447+ { NM_ATT_BS11_RSSI_OFFS, "SIE RSSI Offset" },
448+ { NM_ATT_BS11_TXPWR, "SIE TX Power" },
449+ { NM_ATT_BS11_DIVERSITY, "SIE Diversity" },
450+ { NM_ATT_TSC, "Training Sequence Code" },
451+ { NM_ATT_SW_CONFIG, "SW Configuration" },
452+ { NM_ATT_SW_DESCR, "SW Description" },
453+ { NM_ATT_SEVERITY, "Perceived Severity" },
454+ { NM_ATT_GET_ARI, "Get ARI" },
455+ { NM_ATT_HW_CONF_CHG, "HW Configuration Change" },
456+ { NM_ATT_OUTST_ALARM, "Outstanding Alarm" },
457+ { NM_ATT_FILE_DATA, "File Data" },
458+ { NM_ATT_MEAS_RES, "Measurement Result" },
459+ { NM_ATT_MEAS_TYPE, "Measurement Type" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200460+ { 0, NULL }
461+};
462+
463+static value_string_ext oml_fom_attr_vse = VALUE_STRING_EXT_INIT(_oml_fom_attr_vals);
464+
465+/* proprietary Siemens attributes, not in the standard */
466+static const value_string oml_fom_attr_vals_bs11[] = {
467+ { NM_ATT_BS11_OM_LAPD_REL_TIMER,"SIE OML LAPD Release Timer" },
468+ { NM_ATT_BS11_RF_RES_IND_PER, "SIE RF Resource Indication Period" },
469+ { NM_ATT_BS11_RX_LEV_MIN_CELL, "SIE RxLevel Min Cell" },
470+ { NM_ATT_BS11_ABIS_EXT_TIME, "SIE A-bis external time" },
471+ { NM_ATT_BS11_TIMER_HO_REQUEST, "SIE Timer Handover Request" },
472+ { NM_ATT_BS11_TIMER_NCELL, "SIE Timer nCell" },
473+ { NM_ATT_BS11_TSYNC, "SIE Timer Tsync" },
474+ { NM_ATT_BS11_TTRAU, "SIE Timer Ttrau" },
475+ { NM_ATT_BS11_EMRG_CFG_MEMBER, "SIE Emergency Config Member" },
476+ { NM_ATT_BS11_TRX_AREA, "SIE TRX Area" },
477+ { NM_ATT_BS11_BCCH_RECONF, "SIE BCCH Reconfiguration" },
478+ { NM_ATT_BS11_BIT_ERR_THESH, "SIE Bit Error Threshold" },
479+ { NM_ATT_BS11_BOOT_SW_VERS, "SIE Boot Software Version" },
480+ { NM_ATT_BS11_CCLK_ACCURACY, "SIE CCLK Accuracy" },
481+ { NM_ATT_BS11_CCLK_TYPE, "SIE CCLK Type" },
482+ { NM_ATT_BS11_INP_IMPEDANCE, "SIE Input Impedance" },
483+ { NM_ATT_BS11_L1_PROT_TYPE, "SIE L1 Protocol Type" },
484+ { NM_ATT_BS11_LINE_CFG, "SIE Line Configuration" },
485+ { NM_ATT_BS11_LI_PORT_1, "SIE Line Interface Port 1" },
486+ { NM_ATT_BS11_LI_PORT_2, "SIE Line Interface Port 2" },
487+ { NM_ATT_BS11_L1_REM_ALM_TYPE, "SIE L1 Remote Alarm Type" },
488+ { NM_ATT_BS11_SW_LOAD_INTENDED, "SIE Software Load Intended" },
489+ { NM_ATT_BS11_SW_LOAD_SAFETY, "SIE Software Load Safety" },
490+ { NM_ATT_BS11_SW_LOAD_STORED, "SIE Software Load Stored" },
491+ { NM_ATT_BS11_VENDOR_NAME, "SIE Vendor Name" },
492+ { NM_ATT_BS11_HOPPING_MODE, "SIE Hopping Mode" },
493+ { NM_ATT_BS11_LMT_LOGON_SESSION,"SIE LMT Logon Session" },
494+ { NM_ATT_BS11_LMT_LOGIN_TIME, "SIE LMT Login Time" },
495+ { NM_ATT_BS11_LMT_USER_ACC_LEV, "SIE LMT User Account Level" },
496+ { NM_ATT_BS11_LMT_USER_NAME, "SIE LMT User Account Name" },
497+ { NM_ATT_BS11_L1_CONTROL_TS, "SIE L1 Control TS" },
498+ { NM_ATT_BS11_RADIO_MEAS_GRAN, "SIE Radio Measurement Granularity" },
499+ { NM_ATT_BS11_RADIO_MEAS_REP, "SIE Rdadio Measurement Report" },
500+ { NM_ATT_BS11_SH_LAPD_INT_TIMER,"SIE LAPD Internal Timer" },
501+ { NM_ATT_BS11_BTS_STATE, "SIE BTS State" },
502+ { NM_ATT_BS11_E1_STATE, "SIE E1 State" },
503+ { NM_ATT_BS11_PLL, "SIE PLL" },
504+ { NM_ATT_BS11_RX_OFFSET, "SIE Rx Offset" },
505+ { NM_ATT_BS11_ANT_TYPE, "SIE Antenna Type" },
506+ { NM_ATT_BS11_PLL_MODE, "SIE PLL Mode" },
507+ { NM_ATT_BS11_PASSWORD, "SIE Password" },
Harald Welte6900c162009-06-25 20:50:57 +0200508+ { NM_ATT_BS11_ESN_FW_CODE_NO, "SIE ESN FW Code Number" },
509+ { NM_ATT_BS11_ESN_HW_CODE_NO, "SIE ESN HW Code Number" },
510+ { NM_ATT_BS11_ESN_PCB_SERIAL, "SIE ESN PCB Serial Number" },
511+ { NM_ATT_BS11_EXCESSIVE_DISTANCE, "SIE Excessive Distance" },
512+ { NM_ATT_BS11_ALL_TEST_CATG, "SIE All Test Categories" },
513+ { NM_ATT_BS11_BTSLS_HOPPING, "SIE BTS LS Hopping" },
514+ { NM_ATT_BS11_CELL_ALLOC_NR, "SIE Cell Allocation Number" },
515+ { NM_ATT_BS11_CELL_GLOBAL_ID, "SIE Cell Global ID" },
516+ { NM_ATT_BS11_ENA_INTERF_CLASS, "SIE Enable Interference Class" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200517+ { NM_ATT_BS11_ENA_INT_INTEC_HANDO, "SIE Enable Int Intec Handover" },
518+ { NM_ATT_BS11_ENA_INT_INTRC_HANDO, "SIE Enable Int Intrc Handover" },
Harald Welte6900c162009-06-25 20:50:57 +0200519+ { NM_ATT_BS11_ENA_MS_PWR_CTRL, "SIE Enable MS Power Control" },
520+ { NM_ATT_BS11_ENA_PWR_BDGT_HO, "SIE Enable Power Budget HO" },
521+ { NM_ATT_BS11_ENA_RXLEV_HO, "SIE Enable RxLevel HO" },
522+ { NM_ATT_BS11_ENA_RXQUAL_HO, "SIE Enable RxQual HO" },
523+ { NM_ATT_BS11_FACCH_QUAL, "SIE FACCH Quality" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200524+ { 0, NULL }
525+};
526+
527+/* proprietary ip.access attributes, not in the standard */
528+static const value_string oml_fom_attr_vals_ipa[] = {
Harald Weltec9b484f2009-07-12 20:46:43 +0200529+ { NM_ATT_IPACC_DST_IP, "IPA Destination IP Address" },
530+ { NM_ATT_IPACC_DST_IP_PORT, "IPA Destionation IP Port" },
531+ { NM_ATT_IPACC_SSRC, "IPA RTP SSRC" },
532+ { NM_ATT_IPACC_RTP_PAYLD_TYPE, "IPA RTP Payload Type" },
533+ { NM_ATT_IPACC_BASEB_ID, "IPA Baseband Identifier" },
534+ { NM_ATT_IPACC_STREAM_ID, "IPA Stream Identifier" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200535+ { NM_ATT_IPACC_NV_FLAGS, "IPA NVRAM Flags" },
536+ { NM_ATT_IPACC_FREQ_CTRL, "IPA Frequency Control" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200537+ { NM_ATT_IPACC_PRIM_OML_CFG, "IPA Primary OML Config" },
538+ { NM_ATT_IPACC_SEC_OML_CFG, "IPA Secondary OML Config" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200539+ { NM_ATT_IPACC_IP_IF_CFG, "IPA IP Interface Config" },
540+ { NM_ATT_IPACC_IP_GW_CFG, "IPA IP Gateway Config" },
541+ { NM_ATT_IPACC_IN_SERV_TIME, "IPA In Service Time" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200542+ { NM_ATT_IPACC_TRX_BTS_ASS, "IPA TRX BTS Assignment" },
543+ { NM_ATT_IPACC_LOCATION, "IPA BTS Location Name" },
544+ { NM_ATT_IPACC_PAGING_CFG, "IPA Paging Configuration" },
545+ { NM_ATT_IPACC_FILE_DATA, "IPA File Data" },
Harald Welte6900c162009-06-25 20:50:57 +0200546+ { NM_ATT_IPACC_UNIT_ID, "IPA Unit ID" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200547+ { NM_ATT_IPACC_PARENT_UNIT_ID, "IPA Parent Unit ID" },
Harald Welte6900c162009-06-25 20:50:57 +0200548+ { NM_ATT_IPACC_UNIT_NAME, "IPA Unit Name" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200549+ { NM_ATT_IPACC_SNMP_CFG, "IPA SNMP Config" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200550+ { NM_ATT_IPACC_PRIM_OML_CFG_LIST, "IPA Primary OML Config List" },
551+ { NM_ATT_IPACC_PRIM_OML_FB_TOUT,"IPA Primary OML Fallback Timeout" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200552+ { NM_ATT_IPACC_CUR_SW_CFG, "IPA Current Software Config" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200553+ { NM_ATT_IPACC_TIMING_BUS, "IPA Timing Bus" },
554+ { NM_ATT_IPACC_CGI, "IPA CGI" },
555+ { NM_ATT_IPACC_RAC, "IPA RAC" },
556+ { NM_ATT_IPACC_OBJ_VERSION, "IPA Object Version" },
557+ { NM_ATT_IPACC_GPRS_PAGING_CFG, "IPA GPRS Paging Configuration" },
558+ { NM_ATT_IPACC_NSEI, "IPA NSEI" },
559+ { NM_ATT_IPACC_BVCI, "IPA BVCI" },
560+ { NM_ATT_IPACC_NSVCI, "IPA NSVCI" },
561+ { NM_ATT_IPACC_NS_CFG, "IPA NS Configuration" },
562+ { NM_ATT_IPACC_BSSGP_CFG, "IPA BSSGP Configuration" },
563+ { NM_ATT_IPACC_NS_LINK_CFG, "IPA NS Link Configuration" },
564+ { NM_ATT_IPACC_RLC_CFG, "IPA RLC Configuration" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200565+ { NM_ATT_IPACC_ALM_THRESH_LIST, "IPA Alarm Threshold List" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200566+ { NM_ATT_IPACC_MONIT_VAL_LIST, "IPA Monitored Value List" },
567+ { NM_ATT_IPACC_TIB_CONTROL, "IPA Timing Interface Bus Control" },
568+ { NM_ATT_IPACC_SUPP_FEATURES, "IPA Supported Features" },
569+ { NM_ATT_IPACC_CODING_SCHEMES, "IPA Coding Schemes" },
570+ { NM_ATT_IPACC_RLC_CFG_2, "IPA RLC Configuration 2" },
571+ { NM_ATT_IPACC_HEARTB_TOUT, "IPA Heartbeat Timeout" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200572+ { NM_ATT_IPACC_UPTIME, "IPA Uptime" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200573+ { NM_ATT_IPACC_RLC_CFG_3, "IPA RLC Configuration 3" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200574+ { NM_ATT_IPACC_SSL_CFG, "IPA SSL Configuration" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200575+ { NM_ATT_IPACC_SEC_POSSIBLE, "IPA Security Possible" },
576+ { NM_ATT_IPACC_IML_SSL_STATE, "IPA IML SSL State" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200577+ { NM_ATT_IPACC_REVOC_DATE, "IPA Revocation Date" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200578+ { 0, NULL }
Harald Welte6900c162009-06-25 20:50:57 +0200579+};
580+
Harald Welteb88b6d32010-06-19 13:52:54 +0200581+#if 0
582+static gint merge_value_strings(value_string **dst, const value_string *base, const value_string delta)
583+{
584+ const value_string *cur;
585+ guint num_base, num_delta, num_max, num_out;
586+
587+ for (cur = base; cur->value || cur->strptr; cur++)
588+ num_base++;
589+ for (cur = delta; cur->value || cur->strptr; cur++)
590+ num_delta++;
591+ num_max = num_base + num_delta + 1; /* terminating entry */
592+
593+ *dst = g_malloc(sizeof(value_string) * num_max);
594+ if (!*dst)
595+ return -ENOMEM;
596+ /* zero-initialize the entire array so we always are zero-
597+ * terminated */
598+ memset(*dst, 0, sizeof(value_string * num_max));
599+
600+ /* initialize with the 'base' */
601+ memcpy(*dst, base, sizeof(value_string)*num_base);
602+ num_out = num_base;
603+
604+ /* patch/append the delta */
605+ for (cur = delta; cur->value || cur->strptr; cur++) {
606+ guint idx;
607+ if (match_strval_idx(cur->value, base, &idx)) {
608+ /* the base set already contains a definition,
609+ * we need to override it */
610+ memcpy((*dst)[idx], cur, sizeof(value_string));
611+ } else {
612+ /* append the entry to the end */
613+ memcpy((*dst)[num_out], cur, sizeof(value_string));
614+ num_out++;
615+ }
616+ }
617+
618+ return 0;
619+}
620+#endif
621+
622+static const gchar *
Holger Hans Peter Freyther9b5f1d72011-01-11 16:33:52 +0100623+_match_oml_fom_msgtype(const guint32 val, const value_string_ext *vs, gint *idx)
Harald Welteb88b6d32010-06-19 13:52:54 +0200624+{
625+ const char *ret;
Holger Hans Peter Freyther9b5f1d72011-01-11 16:33:52 +0100626+ ret = match_strval_idx(val, vs->_vs_p, idx);
Harald Welteb88b6d32010-06-19 13:52:54 +0200627+ if (!ret)
Holger Hans Peter Freyther9b5f1d72011-01-11 16:33:52 +0100628+ ret = match_strval_idx(val, _oml_fom_msgtype_vals, idx);
Harald Welteb88b6d32010-06-19 13:52:54 +0200629+ return ret;
630+}
631+
632+static const gchar *
Holger Hans Peter Freyther9b5f1d72011-01-11 16:33:52 +0100633+_match_oml_fom_attr(const guint32 val, const value_string_ext *vs, gint *idx)
Harald Welteb88b6d32010-06-19 13:52:54 +0200634+{
635+ const char *ret;
Holger Hans Peter Freyther9b5f1d72011-01-11 16:33:52 +0100636+ ret = match_strval_idx(val, vs->_vs_p, idx);
Harald Welteb88b6d32010-06-19 13:52:54 +0200637+ if (!ret)
Holger Hans Peter Freyther9b5f1d72011-01-11 16:33:52 +0100638+ ret = match_strval_idx(val, _oml_fom_attr_vals, idx);
Harald Welteb88b6d32010-06-19 13:52:54 +0200639+ return ret;
640+}
641+
Harald Welte6900c162009-06-25 20:50:57 +0200642+/* Section 9.4.4: Administrative State */
643+static const value_string oml_adm_state_vals[] = {
644+ { NM_STATE_LOCKED, "Locked" },
645+ { NM_STATE_UNLOCKED, "Unlocked" },
646+ { NM_STATE_SHUTDOWN, "Shutdown" },
647+ { NM_STATE_NULL, "Null" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200648+ { 0, NULL }
Harald Welte6900c162009-06-25 20:50:57 +0200649+};
650+
651+static const value_string oml_oper_state_vals[] = {
652+ { 1, "Disabled" },
653+ { 2, "Enabled" },
654+ { 0xff, "NULL" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200655+ { 0, NULL }
Harald Welte6900c162009-06-25 20:50:57 +0200656+};
657+
658+/* Section 9.4.7 Availability Status */
659+static const value_string oml_avail_state_vals[] = {
660+ { 0, "In test" },
661+ { 1, "Failed" },
662+ { 2, "Power off" },
663+ { 3, "Off line" },
664+ { 5, "Dependency" },
665+ { 6, "Degraded" },
666+ { 7, "Not installed" },
667+ { 0xff, "OK" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200668+ { 0, NULL }
Harald Welte6900c162009-06-25 20:50:57 +0200669+};
670+
671+/* Section 9.4.13: Channel Combination */
672+static const value_string oml_chan_comb_vals[] = {
673+ { NM_CHANC_TCHFull, "TCH/F" },
674+ { NM_CHANC_TCHHalf, "TCH/H" },
675+ { NM_CHANC_TCHHalf2, "TCH/H 2" },
676+ { NM_CHANC_SDCCH, "SDCCH" },
677+ { NM_CHANC_mainBCCH, "Main BCCH" },
678+ { NM_CHANC_BCCHComb, "Combined BCCH" },
679+ { NM_CHANC_BCCH, "BCCH" },
680+ { NM_CHANC_BCCH_CBCH, "BCCH+CBCH" },
681+ { NM_CHANC_SDCCH_CBCH, "SDCCH+CBCH" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200682+ { 0, NULL }
Harald Welte6900c162009-06-25 20:50:57 +0200683+};
684+
685+/* Section 9.4.16: Event Type */
686+static const value_string oml_event_type_vals[] = {
687+ { NM_EVT_COMM_FAIL, "Communication Failure" },
688+ { NM_EVT_QOS_FAIL, "QoS Failure" },
689+ { NM_EVT_PROC_FAIL, "Processor Failure" },
690+ { NM_EVT_EQUIP_FAIL, "Equipment Failure" },
691+ { NM_EVT_ENV_FAIL, "Environment Failure" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200692+ { 0, NULL }
Harald Welte6900c162009-06-25 20:50:57 +0200693+};
694+
695+/* Section 9.4.63: Perceived Severity */
696+static const value_string oml_severity_vals[] = {
697+ { NM_SEVER_CEASED, "Ceased" },
698+ { NM_SEVER_CRITICAL, "Critical" },
699+ { NM_SEVER_MAJOR, "Major" },
700+ { NM_SEVER_MINOR, "Minor" },
701+ { NM_SEVER_WARNING, "Warning" },
702+ { NM_SEVER_INDETERMINATE, "Indeterminate" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200703+ { 0, NULL }
Harald Welte6900c162009-06-25 20:50:57 +0200704+};
705+
706+/* Section 9.4.36: NACK Causes */
707+static const value_string oml_nack_cause[] = {
708+ { NM_NACK_INCORR_STRUCT, "Incorrect message structure" },
709+ { NM_NACK_MSGTYPE_INVAL, "Invalid message type value" },
710+ { NM_NACK_OBJCLASS_INVAL, "Invalid Object class value" },
711+ { NM_NACK_OBJCLASS_NOTSUPP, "Object Class not supported" },
712+ { NM_NACK_BTSNR_UNKN, "BTS Number unknown" },
713+ { NM_NACK_TRXNR_UNKN, "TRX Number unknown" },
714+ { NM_NACK_OBJINST_UNKN, "Object Instance unknown" },
715+ { NM_NACK_ATTRID_INVAL, "Invalid Attribute ID value" },
716+ { NM_NACK_ATTRID_NOTSUPP, "Attribute ID not supported" },
717+ { NM_NACK_PARAM_RANGE, "Parameter value out of range" },
718+ { NM_NACK_ATTRLIST_INCONSISTENT, "Inconsistency in Attribute list" },
719+ { NM_NACK_SPEC_IMPL_NOTSUPP, "Specified Implementation not supported" },
720+ { NM_NACK_CANT_PERFORM, "Message cannot be performed" },
721+ { NM_NACK_RES_NOTIMPL, "Resource not implemented" },
722+ { NM_NACK_RES_NOTAVAIL, "Resource not available" },
723+ { NM_NACK_FREQ_NOTAVAIL, "Frequency not available" },
724+ { NM_NACK_TEST_NOTSUPP, "Test not supported" },
725+ { NM_NACK_CAPACITY_RESTR, "Capacity restrictions" },
726+ { NM_NACK_PHYSCFG_NOTPERFORM, "Phys config cannot be performed" },
727+ { NM_NACK_TEST_NOTINIT, "Test not initiated" },
728+ { NM_NACK_PHYSCFG_NOTRESTORE, "Phys config cannot be restored" },
729+ { NM_NACK_TEST_NOSUCH, "No such Test" },
730+ { NM_NACK_TEST_NOSTOP, "Test cannot be stopped" },
731+ { NM_NACK_MSGINCONSIST_PHYSCFG, "Message inconsisten with physical config" },
732+ { NM_NACK_FILE_INCOMPLETE, "Complete file not received" },
733+ { NM_NACK_FILE_NOTAVAIL, "File not available at destination" },
734+ { NM_NACK_FILE_NOTACTIVATE, "File cannot be activated" },
735+ { NM_NACK_REQ_NOT_GRANT, "Request not granted" },
736+ { NM_NACK_WAIT, "Wait" },
737+ { NM_NACK_NOTH_REPORT_EXIST, "Nothing reportable existing" },
738+ { NM_NACK_MEAS_NOTSUPP, "Measurement not supported" },
739+ { NM_NACK_MEAS_NOTSTART, "Measurement not started" },
740+ { 0xff, "NULL" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200741+ { 0, NULL }
Harald Welte6900c162009-06-25 20:50:57 +0200742+};
743+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200744+static const value_string oml_test_no_vals[] = {
Harald Weltec9b484f2009-07-12 20:46:43 +0200745+ { NM_IPACC_TESTNO_RLOOP_ANT, "Radio Loop test via antenna" },
746+ { NM_IPACC_TESTNO_RLOOP_XCVR, "Radio Loop test via transceiver" },
747+ { NM_IPACC_TESTNO_FUNC_OBJ, "BTS Functional object self test" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200748+ { NM_IPACC_TESTNO_CHAN_USAGE, "Channel Usage" },
749+ { NM_IPACC_TESTNO_BCCH_CHAN_USAGE, "BCCH Channel Usage" },
750+ { NM_IPACC_TESTNO_FREQ_SYNC, "Frequency Synchronization" },
751+ { NM_IPACC_TESTNO_BCCH_INFO, "BCCH Information" },
Harald Weltec9b484f2009-07-12 20:46:43 +0200752+ { NM_IPACC_TESTNO_TX_BEACON, "Transmit Beacon" },
753+ { NM_IPACC_TESTNO_SYSINFO_MONITOR, "SysInfo Monitor" },
754+ { NM_IPACC_TESTNO_BCCCH_MONITOR, "BCCH & CCCH Monitor" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200755+ { 0, NULL }
Harald Welte1cc3fa82009-07-01 17:40:50 +0200756+};
757+
758+static const value_string ipacc_test_res_vals[] = {
759+ { NM_IPACC_TESTRES_SUCCESS, "Success" },
760+ { NM_IPACC_TESTRES_TIMEOUT, "Timeout" },
761+ { NM_IPACC_TESTRES_NO_CHANS, "No suitable channels available" },
762+ { NM_IPACC_TESTRES_PARTIAL, "Partial" },
763+ { NM_IPACC_TESTRES_STOPPED, "Stopped" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200764+ { 0, NULL }
Harald Welte1cc3fa82009-07-01 17:40:50 +0200765+};
766+
767+static const value_string ipacc_testres_ie_vals[] = {
768+ { NM_IPACC_TR_IE_FREQ_ERR_LIST, "Frequency Error List" },
769+ { NM_IPACC_TR_IE_CHAN_USAGE, "Channel Usage" },
770+ { NM_IPACC_TR_IE_BCCH_INFO, "BCCH Information" },
771+ { NM_IPACC_TR_IE_RESULT_DETAILS,"Result Details" },
772+ { NM_IPACC_TR_IE_FREQ_ERR, "Frequency Error" },
Harald Welteb88b6d32010-06-19 13:52:54 +0200773+ { 0, NULL }
Harald Welte1cc3fa82009-07-01 17:40:50 +0200774+};
775+
Pablo Neira Ayuso4fcd3572011-03-06 16:47:28 +0100776+/* ANSI C does not allow selective initialization of arrays, for that reason,
777+ * we initialize these three TLV definitions in proto_register_abis_oml(). */
778+static struct tlv_definition nm_att_tlvdef_base;
779+static struct tlv_definition nm_att_tlvdev_bs11;
780+static struct tlv_definition nm_att_tlvdef_ipa;
781+
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +0800782+static const struct tlv_def *
783+find_tlv_tag(guint8 tag)
784+{
785+ const struct tlv_def *specific;
786+
787+ if (global_oml_use_nano_bts)
788+ specific = &nm_att_tlvdef_ipa.def[tag];
789+ else
790+ specific = &nm_att_tlvdev_bs11.def[tag];
791+
Holger Hans Peter Freytherbdcf45c2010-06-06 21:33:52 +0800792+ if (specific->type != TLV_TYPE_UNKNOWN)
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +0800793+ return specific;
794+
795+ return &nm_att_tlvdef_base.def[tag];
796+}
797+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200798+/* Parse the ip.access specific BCCH Information IE embedded into the Test
799+ * Report IE */
800+static gint
801+ipacc_tr_ie_bcch(tvbuff_t *tvb, proto_tree *att_tree, int offset)
802+{
Harald Welte450129f2009-07-03 12:46:47 +0200803+ guint16 binfo_type, tmp;
804+
805+ binfo_type = tvb_get_ntohs(tvb, offset);
806+ offset += 2;
807+
808+ tmp = tvb_get_ntohs(tvb, offset);
Harald Welte1cc3fa82009-07-01 17:40:50 +0200809+
810+ /* FIXME: there are still some bugs remaining here */
811+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_arfcn,
812+ tvb, offset, 2, TRUE);
Harald Welte450129f2009-07-03 12:46:47 +0200813+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200814+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_f_qual,
815+ tvb, offset, 2, TRUE);
816+ offset += 2;
Harald Welte450129f2009-07-03 12:46:47 +0200817+
818+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_b_rxlev,
Harald Welte1cc3fa82009-07-01 17:40:50 +0200819+ tvb, offset++, 1, TRUE);
Harald Welte450129f2009-07-03 12:46:47 +0200820+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200821+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_rxqual,
822+ tvb, offset++, 1, TRUE);
Harald Welte450129f2009-07-03 12:46:47 +0200823+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200824+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_f_err,
825+ tvb, offset, 2, TRUE);
826+ offset += 2;
Harald Welte450129f2009-07-03 12:46:47 +0200827+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200828+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_frame_offs,
829+ tvb, offset, 2, TRUE);
830+ offset += 2;
831+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_framenr_offs,
832+ tvb, offset, 4, TRUE);
833+ offset += 4;
Harald Welte450129f2009-07-03 12:46:47 +0200834+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200835+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_bsic,
836+ tvb, offset++, 1, TRUE);
Harald Welte450129f2009-07-03 12:46:47 +0200837+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200838+ de_lai(tvb, att_tree, offset, 5, NULL, 0);
839+ offset += 5;
Harald Welte450129f2009-07-03 12:46:47 +0200840+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200841+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_cell_id,
842+ tvb, offset, 2, TRUE);
843+ offset += 2;
Harald Welte450129f2009-07-03 12:46:47 +0200844+
845+ if (binfo_type & 0x8000) {
846+ /* System Information 2 */
847+ /* FIXME: Parse 04.18 Neighbour Cell Description */
848+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_si2,
849+ tvb, offset, 16, TRUE);
850+ offset += 16;
851+ }
852+ if (binfo_type & 0x0001) {
853+ /* System Information 2bis */
854+ /* FIXME: Parse 04.18 Neighbour Cell Description */
855+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_si2bis,
856+ tvb, offset, 16, TRUE);
857+ offset += 16;
858+ }
859+ if (binfo_type & 0x0002) {
860+ /* System Information 2ter */
861+ /* FIXME: Parse 04.18 Neighbour Cell Description */
862+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_si2ter,
863+ tvb, offset, 16, TRUE);
864+ offset += 16;
865+ }
866+ if (binfo_type & 0x0004) {
867+ /* FIXME: Parse 04.18 Cell Channel Description */
868+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_chan_desc,
869+ tvb, offset, 16, TRUE);
870+ offset += 16;
871+ }
Harald Welte1cc3fa82009-07-01 17:40:50 +0200872+
873+ return offset;
874+}
875+
876+/* Parse the ip.access specific Channel Usage IE embedded into the Test
877+ * Report IE */
878+static gint
879+ipacc_tr_ie_chan_usage(tvbuff_t *tvb, proto_tree *att_tree, int offset)
880+{
881+ while (tvb_reported_length_remaining(tvb, offset) != 0) {
Holger Hans Peter Freyther8d66dfb2010-05-23 03:46:46 +0800882+ guint16 result;
883+
884+ result = tvb_get_ntohs(tvb, offset);
Harald Welte1cc3fa82009-07-01 17:40:50 +0200885+ proto_tree_add_uint(att_tree, hf_attr_ipa_tr_arfcn,
886+ tvb, offset, 2, result);
887+ proto_tree_add_uint(att_tree, hf_attr_ipa_tr_rxlev,
888+ tvb, offset, 2, result);
889+ offset += 2;
890+ }
891+ return offset;
892+}
893+
894+/* Parse the ip.access specific format of the standard test report IE */
895+static gint
896+dissect_ipacc_test_rep(proto_tree *tree, tvbuff_t *tvb)
897+{
898+ gint offset = 0;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200899+
900+ proto_tree_add_item(tree, hf_attr_ipa_test_res, tvb, offset++,
901+ 1, FALSE);
902+
903+ while (tvb_reported_length_remaining(tvb, offset) != 0) {
Holger Hans Peter Freyther8d66dfb2010-05-23 03:46:46 +0800904+ guint8 ie;
905+ guint16 len;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200906+ proto_item *ti;
907+ proto_tree *att_tree;
908+
Holger Hans Peter Freyther8d66dfb2010-05-23 03:46:46 +0800909+ ie = tvb_get_guint8(tvb, offset);
910+ len = tvb_get_ntohs(tvb, offset+1);
Harald Welte1cc3fa82009-07-01 17:40:50 +0200911+ ti = proto_tree_add_item(tree, hf_oml_ipa_tres_attr_tag, tvb,
912+ offset++, 1, FALSE);
913+ att_tree = proto_item_add_subtree(ti, ett_oml_fom_att);
914+ proto_tree_add_uint(att_tree, hf_oml_ipa_tres_attr_len, tvb,
915+ offset, 2, len);
916+ offset += 2;
917+
918+ switch (ie) {
919+ case NM_IPACC_TR_IE_CHAN_USAGE:
920+ offset = ipacc_tr_ie_chan_usage(tvb,
921+ att_tree, offset);
922+ break;
923+ case NM_IPACC_TR_IE_BCCH_INFO:
924+ offset = ipacc_tr_ie_bcch(tvb,
925+ att_tree, offset);
926+ break;
927+ default:
928+ break;
929+ }
930+ }
Harald Welteb16004c2009-07-11 19:44:53 +0200931+ return offset;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200932+}
933+
934+/* Dissect OML FOM Attributes after OML + FOM header */
Harald Welte6900c162009-06-25 20:50:57 +0200935+static gint
936+dissect_oml_attrs(tvbuff_t *tvb, int base_offs, packet_info *pinfo,
937+ proto_tree *tree)
938+{
939+ int offset = base_offs;
940+
941+ while (tvb_reported_length_remaining(tvb, offset) != 0) {
Harald Welte2c544c82009-07-11 16:41:15 +0200942+ guint i;
Harald Welte6900c162009-06-25 20:50:57 +0200943+ guint8 tag, val8;
Harald Welte2c544c82009-07-11 16:41:15 +0200944+ guint16 val16;
945+ guint32 val32;
Harald Welte6900c162009-06-25 20:50:57 +0200946+ unsigned int len, len_len, hlen;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200947+ const struct tlv_def *tdef;
Harald Welte6900c162009-06-25 20:50:57 +0200948+ proto_item *ti;
949+ proto_tree *att_tree;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200950+ tvbuff_t *sub_tvb;
Harald Welte6900c162009-06-25 20:50:57 +0200951+
952+ tag = tvb_get_guint8(tvb, offset);
Holger Hans Peter Freyther03425402010-05-23 06:20:14 +0800953+ tdef = find_tlv_tag(tag);
Harald Welte6900c162009-06-25 20:50:57 +0200954+
955+ switch (tdef->type) {
956+ case TLV_TYPE_FIXED:
957+ hlen = 1;
958+ len_len = 0;
959+ len = tdef->fixed_len;
960+ break;
961+ case TLV_TYPE_T:
962+ hlen = 1;
963+ len_len = 0;
964+ len = 0;
965+ break;
966+ case TLV_TYPE_TV:
967+ hlen = 1;
968+ len_len = 0;
969+ len = 1;
970+ break;
971+ case TLV_TYPE_TLV:
972+ hlen = 2;
973+ len_len = 1;
974+ len = tvb_get_guint8(tvb, offset+1);
975+ break;
976+ case TLV_TYPE_TL16V:
977+ hlen = 3;
978+ len_len = 2;
979+ len = tvb_get_guint8(tvb, offset+1) << 8 |
980+ tvb_get_guint8(tvb, offset+2);
981+ break;
Harald Welteb88b6d32010-06-19 13:52:54 +0200982+ case TLV_TYPE_TLV16:
983+ hlen = 2;
984+ len_len = 1;
985+ len = tvb_get_guint8(tvb, offset+1) * 2;
986+ break;
Holger Hans Peter Freytherbdcf45c2010-06-06 21:33:52 +0800987+ case TLV_TYPE_UNKNOWN: /* fall through */
Harald Welteb16004c2009-07-11 19:44:53 +0200988+ default:
989+ hlen = len_len = len = 0;
990+ DISSECTOR_ASSERT_NOT_REACHED();
991+ break;
Harald Welte6900c162009-06-25 20:50:57 +0200992+ }
993+
994+ ti = proto_tree_add_item(tree, hf_oml_fom_attr_tag, tvb,
995+ offset, 1, FALSE);
996+ att_tree = proto_item_add_subtree(ti, ett_oml_fom_att);
997+ proto_tree_add_uint(att_tree, hf_oml_fom_attr_len, tvb,
998+ offset+1, len_len, len);
999+ offset += hlen;
1000+
Harald Welte1cc3fa82009-07-01 17:40:50 +02001001+ sub_tvb = tvb_new_subset(tvb, offset, len, len);
1002+
Harald Welte6900c162009-06-25 20:50:57 +02001003+ switch (tag) {
1004+ /* parse only the most common IE for now */
1005+ case NM_ATT_ABIS_CHANNEL:
Harald Welte1cc3fa82009-07-01 17:40:50 +02001006+ proto_tree_add_item(att_tree, hf_attr_ach_btsp, tvb,
1007+ offset, 1, TRUE);
1008+ proto_tree_add_item(att_tree, hf_attr_ach_tslot, tvb,
1009+ offset+1, 1, TRUE);
1010+ proto_tree_add_item(att_tree, hf_attr_ach_sslot, tvb,
1011+ offset+2, 1, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +02001012+ break;
1013+ case NM_ATT_ADM_STATE:
1014+ proto_tree_add_item(att_tree, hf_attr_adm_state, tvb,
1015+ offset, len, FALSE);
Harald Welte2c544c82009-07-11 16:41:15 +02001016+ val8 = tvb_get_guint8(tvb, offset);
1017+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
1018+ val_to_str(val8, oml_adm_state_vals,
1019+ "%02x"));
Harald Welte6900c162009-06-25 20:50:57 +02001020+ break;
1021+ case NM_ATT_ARFCN_LIST:
Harald Welte2c544c82009-07-11 16:41:15 +02001022+ for (i = 0; i < len; i += 2) {
1023+ val16 = tvb_get_ntohs(tvb, offset + i);
1024+ proto_tree_add_uint(att_tree, hf_attr_arfcn,
1025+ tvb, offset + i, 2, val16);
1026+ }
Harald Welte6900c162009-06-25 20:50:57 +02001027+ break;
1028+ case NM_ATT_AVAIL_STATUS:
Harald Welte2c544c82009-07-11 16:41:15 +02001029+ /* Availability status can have length 0 */
1030+ if (len) {
1031+ val8 = tvb_get_guint8(tvb, offset);
1032+ proto_tree_add_item(att_tree,
1033+ hf_attr_avail_state, tvb,
1034+ offset, len, FALSE);
1035+ } else
1036+ val8 = 0xff;
1037+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
1038+ val_to_str(val8, oml_avail_state_vals,
1039+ "%02x"));
Harald Welte6900c162009-06-25 20:50:57 +02001040+ break;
1041+ case NM_ATT_BCCH_ARFCN:
Harald Welte1cc3fa82009-07-01 17:40:50 +02001042+ proto_tree_add_item(att_tree, hf_attr_bcch_arfcn, tvb,
Harald Welteb88b6d32010-06-19 13:52:54 +02001043+ offset, len, FALSE);
Harald Welte6900c162009-06-25 20:50:57 +02001044+ break;
1045+ case NM_ATT_BSIC:
Harald Welte1cc3fa82009-07-01 17:40:50 +02001046+ proto_tree_add_item(att_tree, hf_attr_bsic, tvb,
1047+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +02001048+ break;
1049+ case NM_ATT_CHAN_COMB:
Harald Welte1cc3fa82009-07-01 17:40:50 +02001050+ proto_tree_add_item(att_tree, hf_attr_chan_comb, tvb,
1051+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +02001052+ break;
1053+ case NM_ATT_EVENT_TYPE:
1054+ proto_tree_add_item(att_tree, hf_attr_event_type, tvb,
Harald Welte1cc3fa82009-07-01 17:40:50 +02001055+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +02001056+ break;
1057+ case NM_ATT_GSM_TIME:
Harald Welte1cc3fa82009-07-01 17:40:50 +02001058+ proto_tree_add_item(att_tree, hf_attr_gsm_time, tvb,
1059+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +02001060+ break;
1061+ case NM_ATT_OPER_STATE:
1062+ proto_tree_add_item(att_tree, hf_attr_oper_state, tvb,
1063+ offset, len, FALSE);
Harald Welte2c544c82009-07-11 16:41:15 +02001064+ val8 = tvb_get_guint8(tvb, offset);
1065+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
1066+ val_to_str(val8, oml_oper_state_vals,
1067+ "%02x"));
Harald Welte6900c162009-06-25 20:50:57 +02001068+ break;
1069+ case NM_ATT_TEI:
Harald Welte1cc3fa82009-07-01 17:40:50 +02001070+ proto_tree_add_item(att_tree, hf_attr_tei, tvb,
1071+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +02001072+ break;
1073+ case NM_ATT_TSC:
Harald Welte1cc3fa82009-07-01 17:40:50 +02001074+ proto_tree_add_item(att_tree, hf_attr_tsc, tvb,
1075+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +02001076+ break;
1077+ case NM_ATT_SEVERITY:
1078+ proto_tree_add_item(att_tree, hf_attr_severity, tvb,
Harald Welte1cc3fa82009-07-01 17:40:50 +02001079+ offset, len, TRUE);
1080+ break;
1081+ case NM_ATT_TEST_REPORT:
1082+ dissect_ipacc_test_rep(att_tree, sub_tvb);
1083+ break;
1084+ case NM_ATT_TEST_NO:
1085+ proto_tree_add_item(att_tree, hf_attr_test_no, tvb,
1086+ offset, len, TRUE);
Harald Welte2c544c82009-07-11 16:41:15 +02001087+ val8 = tvb_get_guint8(tvb, offset);
1088+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
1089+ val_to_str(val8, oml_test_no_vals,
1090+ "%02x"));
Harald Welte6900c162009-06-25 20:50:57 +02001091+ break;
Harald Welteb88b6d32010-06-19 13:52:54 +02001092+ case NM_ATT_HSN:
1093+ proto_tree_add_item(att_tree, hf_attr_hsn, tvb,
1094+ offset, len, TRUE);
1095+ break;
1096+ case NM_ATT_MAIO:
1097+ proto_tree_add_item(att_tree, hf_attr_maio, tvb,
1098+ offset, len, TRUE);
1099+ break;
1100+ default:
1101+ proto_tree_add_item(att_tree, hf_oml_fom_attr_val, tvb,
1102+ offset, len, FALSE);
1103+ }
Harald Welte6900c162009-06-25 20:50:57 +02001104+
Harald Welteb88b6d32010-06-19 13:52:54 +02001105+ if (global_oml_use_nano_bts) switch (tag) {
Harald Welte6900c162009-06-25 20:50:57 +02001106+ /* proprietary ip.access extensions */
Harald Weltec9b484f2009-07-12 20:46:43 +02001107+ case NM_ATT_IPACC_DST_IP:
Harald Welte2c544c82009-07-11 16:41:15 +02001108+ val32 = tvb_get_ntohl(tvb, offset);
1109+ proto_tree_add_ipv4(att_tree, hf_attr_ipa_rsl_ip, tvb,
1110+ offset, len, val32);
Harald Welte6900c162009-06-25 20:50:57 +02001111+ break;
Harald Weltec9b484f2009-07-12 20:46:43 +02001112+ case NM_ATT_IPACC_DST_IP_PORT:
Harald Welte2c544c82009-07-11 16:41:15 +02001113+ val16 = tvb_get_ntohs(tvb, offset);
1114+ proto_tree_add_uint(att_tree, hf_attr_ipa_rsl_port, tvb,
1115+ offset, len, val16);
Harald Welte6900c162009-06-25 20:50:57 +02001116+ break;
1117+ case NM_ATT_IPACC_LOCATION:
Harald Welte450129f2009-07-03 12:46:47 +02001118+ proto_tree_add_item(att_tree, hf_attr_ipa_location_name,
1119+ tvb, offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +02001120+ break;
1121+ case NM_ATT_IPACC_UNIT_ID:
Harald Welte450129f2009-07-03 12:46:47 +02001122+ proto_tree_add_item(att_tree, hf_attr_ipa_unit_id,
1123+ tvb, offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +02001124+ break;
1125+ case NM_ATT_IPACC_UNIT_NAME:
Harald Welte450129f2009-07-03 12:46:47 +02001126+ proto_tree_add_item(att_tree, hf_attr_ipa_unit_name,
1127+ tvb, offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +02001128+ break;
Harald Weltec9b484f2009-07-12 20:46:43 +02001129+ case NM_ATT_IPACC_PRIM_OML_CFG_LIST:
Harald Welte450129f2009-07-03 12:46:47 +02001130+ proto_tree_add_item(att_tree, hf_attr_ipa_prim_oml_ip,
1131+ tvb, offset+1, 4, TRUE);
1132+ proto_tree_add_item(att_tree, hf_attr_ipa_prim_oml_port,
1133+ tvb, offset+1+4, 2, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +02001134+ break;
Harald Welte450129f2009-07-03 12:46:47 +02001135+ case NM_ATT_IPACC_NV_FLAGS:
1136+ {
1137+ guint flags, mask;
1138+ flags = tvb_get_guint8(tvb, offset);
1139+ mask = tvb_get_guint8(tvb, offset+1);
1140+ flags |= tvb_get_guint8(tvb, offset+2) << 8;
1141+ mask |= tvb_get_guint8(tvb, offset+3) << 8;
1142+ proto_tree_add_uint(att_tree, hf_attr_ipa_nv_flags,
1143+ tvb, offset, 3, flags);
1144+ proto_tree_add_uint(att_tree, hf_attr_ipa_nv_mask,
1145+ tvb, offset+1, 3, mask);
1146+ }
Harald Welte6900c162009-06-25 20:50:57 +02001147+ break;
Harald Weltec9b484f2009-07-12 20:46:43 +02001148+ case NM_ATT_IPACC_RAC:
1149+ proto_tree_add_item(att_tree, hf_attr_ipa_rac,
1150+ tvb, offset, 1, TRUE);
1151+ break;
1152+ case NM_ATT_IPACC_NSEI:
1153+ val16 = tvb_get_ntohs(tvb, offset);
1154+ proto_tree_add_uint(att_tree, hf_attr_ipa_nsei,
1155+ tvb, offset, 2, val16);
1156+ break;
1157+ case NM_ATT_IPACC_NSVCI:
1158+ val16 = tvb_get_ntohs(tvb, offset);
1159+ proto_tree_add_uint(att_tree, hf_attr_ipa_nsvci,
1160+ tvb, offset, 2, val16);
1161+ break;
1162+ case NM_ATT_IPACC_BVCI:
1163+ val16 = tvb_get_ntohs(tvb, offset);
1164+ proto_tree_add_uint(att_tree, hf_attr_ipa_bvci,
1165+ tvb, offset, 2, val16);
1166+ break;
1167+ case NM_ATT_IPACC_NS_LINK_CFG:
1168+ val16 = tvb_get_ntohs(tvb, offset);
1169+ proto_tree_add_uint(att_tree, hf_attr_ipa_nsl_sport,
1170+ tvb, offset, 2, val16);
1171+ val32 = tvb_get_ipv4(tvb, offset+2);
1172+ proto_tree_add_ipv4(att_tree, hf_attr_ipa_nsl_daddr,
1173+ tvb, offset+2, 4, val32);
1174+ val16 = tvb_get_ntohs(tvb, offset+6);
1175+ proto_tree_add_uint(att_tree, hf_attr_ipa_nsl_dport,
1176+ tvb, offset+6, 2, val16);
1177+ break;
Harald Welte6900c162009-06-25 20:50:57 +02001178+ }
1179+ offset += len;
1180+ }
1181+ return offset;
1182+}
1183+
1184+static int
Harald Welte2c544c82009-07-11 16:41:15 +02001185+dissect_oml_fom(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
1186+ int offset, proto_item *top_ti)
Harald Welte6900c162009-06-25 20:50:57 +02001187+{
1188+ guint8 msg_type, obj_class, bts_nr, trx_nr, ts_nr;
1189+ proto_item *ti;
1190+ proto_tree *fom_tree;
1191+
1192+ msg_type = tvb_get_guint8(tvb, offset);
1193+ obj_class = tvb_get_guint8(tvb, offset+1);
1194+ bts_nr = tvb_get_guint8(tvb, offset+2);
1195+ trx_nr = tvb_get_guint8(tvb, offset+3);
1196+ ts_nr = tvb_get_guint8(tvb, offset+4);
Harald Welte2c544c82009-07-11 16:41:15 +02001197+ proto_item_append_text(top_ti, ", %s(%02x,%02x,%02x) %s ",
1198+ val_to_str(obj_class, oml_fom_objclass_vals, "%02x"),
1199+ bts_nr, trx_nr, ts_nr,
Harald Welteb88b6d32010-06-19 13:52:54 +02001200+ val_to_str_ext(msg_type, &oml_fom_msgtype_vse,
Harald Welte2c544c82009-07-11 16:41:15 +02001201+ "unknown 0x%x"));
1202+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s(%02x,%02x,%02x) %s ",
1203+ val_to_str(obj_class, oml_fom_objclass_vals, "%02x"),
1204+ bts_nr, trx_nr, ts_nr,
Harald Welteb88b6d32010-06-19 13:52:54 +02001205+ val_to_str_ext(msg_type, &oml_fom_msgtype_vse,
Harald Welte2c544c82009-07-11 16:41:15 +02001206+ "unknown 0x%x"));
Harald Welte6900c162009-06-25 20:50:57 +02001207+ ti = proto_tree_add_item(tree, hf_oml_fom_msgtype, tvb, offset++, 1, FALSE);
1208+ fom_tree = proto_item_add_subtree(ti, ett_oml_fom);
1209+ proto_tree_add_item(fom_tree, hf_oml_fom_objclass, tvb, offset++, 1, FALSE);
1210+ proto_tree_add_item(fom_tree, hf_oml_fom_inst_bts, tvb, offset++, 1, FALSE);
1211+ proto_tree_add_item(fom_tree, hf_oml_fom_inst_trx, tvb, offset++, 1, FALSE);
1212+ proto_tree_add_item(fom_tree, hf_oml_fom_inst_ts, tvb, offset++, 1, FALSE);
1213+
1214+
1215+ /* dissect the TLV objects in the message body */
1216+ offset = dissect_oml_attrs(tvb, offset, pinfo, fom_tree);
1217+
1218+ return offset;
1219+}
1220+
Harald Welte1cc3fa82009-07-01 17:40:50 +02001221+static const guint8 ipaccess_magic[] = "com.ipaccess";
1222+
1223+static int
Harald Welte2c544c82009-07-11 16:41:15 +02001224+dissect_oml_manuf(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
1225+ int offset, proto_item *top_ti)
Harald Welte1cc3fa82009-07-01 17:40:50 +02001226+{
1227+ if (tvb_get_guint8(tvb, offset) != 0x0d ||
1228+ tvb_memeql(tvb, offset+1, ipaccess_magic, sizeof(ipaccess_magic)))
1229+ return offset;
1230+
1231+ offset += sizeof(ipaccess_magic) + 1;
1232+
Harald Welte2c544c82009-07-11 16:41:15 +02001233+ return dissect_oml_fom(tvb, pinfo, tree, offset, top_ti);
Harald Welte1cc3fa82009-07-01 17:40:50 +02001234+}
Harald Welte6900c162009-06-25 20:50:57 +02001235+
1236+static void
1237+dissect_abis_oml(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
1238+{
1239+ proto_item *ti;
1240+ proto_tree *oml_tree;
Harald Welte6900c162009-06-25 20:50:57 +02001241+
1242+ int offset = 0;
1243+
Harald Welte2c544c82009-07-11 16:41:15 +02001244+ col_set_str(pinfo->cinfo, COL_PROTOCOL, "OML");
Harald Welte6900c162009-06-25 20:50:57 +02001245+
1246+ top_tree = tree;
1247+ if (tree) {
1248+ u_int8_t msg_disc = tvb_get_guint8(tvb, offset);
1249+
1250+ ti = proto_tree_add_item(tree, proto_abis_oml, tvb, 0, -1, FALSE);
1251+ oml_tree = proto_item_add_subtree(ti, ett_oml);
1252+
Harald Welte1cc3fa82009-07-01 17:40:50 +02001253+ proto_tree_add_item(oml_tree, hf_oml_msg_disc, tvb, offset++,
1254+ 1, TRUE);
1255+ proto_tree_add_item(oml_tree, hf_oml_placement, tvb, offset++,
1256+ 1, TRUE);
1257+ proto_tree_add_item(oml_tree, hf_oml_sequence, tvb, offset++,
1258+ 1, TRUE);
1259+ proto_tree_add_item(oml_tree, hf_oml_length, tvb, offset++,
1260+ 1, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +02001261+
1262+ switch (msg_disc) {
1263+ case ABIS_OM_MDISC_FOM:
Harald Welte2c544c82009-07-11 16:41:15 +02001264+ offset = dissect_oml_fom(tvb, pinfo, oml_tree,
1265+ offset, ti);
Harald Welte6900c162009-06-25 20:50:57 +02001266+ break;
Harald Welte1cc3fa82009-07-01 17:40:50 +02001267+ case ABIS_OM_MDISC_MANUF:
Harald Welte2c544c82009-07-11 16:41:15 +02001268+ offset = dissect_oml_manuf(tvb, pinfo, oml_tree, offset, ti);
Harald Welte1cc3fa82009-07-01 17:40:50 +02001269+ break;
Harald Welte6900c162009-06-25 20:50:57 +02001270+ case ABIS_OM_MDISC_MMI:
1271+ case ABIS_OM_MDISC_TRAU:
Harald Welte6900c162009-06-25 20:50:57 +02001272+ default:
1273+ break;
1274+ }
1275+ }
1276+}
1277+
1278+void
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +01001279+proto_reg_handoff_abis_oml(void);
1280+
1281+void
Harald Welte6900c162009-06-25 20:50:57 +02001282+proto_register_abis_oml(void)
1283+{
1284+ static hf_register_info hf[] = {
1285+ { &hf_oml_msg_disc,
1286+ { "Message Discriminator", "oml.msg_dsc",
1287+ FT_UINT8, BASE_HEX, VALS(oml_msg_disc_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001288+ "GSM 12.21 Message Discriminator", HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001289+ },
1290+ { &hf_oml_placement,
1291+ { "Placement Indicator", "oml.placement",
1292+ FT_UINT8, BASE_HEX, VALS(oml_placement_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001293+ "GSM 12.21 Placement Indicator", HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001294+ },
1295+ { &hf_oml_sequence,
1296+ { "Sequence Number", "oml.sequence",
1297+ FT_UINT8, BASE_HEX, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001298+ "Sequence Number (if multi-part msg)", HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001299+ },
1300+ { &hf_oml_length,
1301+ { "Length Indicator", "oml.length",
1302+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001303+ "Total length of payload", HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001304+ },
1305+ { &hf_oml_fom_msgtype,
1306+ { "FOM Message Type", "oml.fom.msg_type",
Harald Welteb88b6d32010-06-19 13:52:54 +02001307+ FT_UINT8, BASE_HEX|BASE_EXT_STRING, (&oml_fom_msgtype_vse), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001308+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001309+ },
1310+ { &hf_oml_fom_objclass,
1311+ { "FOM Object Class", "oml.fom.obj_class",
1312+ FT_UINT8, BASE_HEX, VALS(oml_fom_objclass_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001313+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001314+ },
1315+ { &hf_oml_fom_inst_bts,
1316+ { "FOM Object Instance BTS", "oml.fom.obj_inst.bts",
1317+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001318+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001319+ },
1320+ { &hf_oml_fom_inst_trx,
1321+ { "FOM Object Instance TRX", "oml.fom.obj_inst.trx",
1322+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001323+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001324+ },
1325+ { &hf_oml_fom_inst_ts,
1326+ { "FOM Object Instance TS", "oml.fom.obj_inst.ts",
1327+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001328+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001329+ },
1330+ { &hf_oml_fom_attr_tag,
1331+ { "FOM Attribute ID", "oml.fom.attr_id",
Harald Welteb88b6d32010-06-19 13:52:54 +02001332+ FT_UINT8, BASE_HEX|BASE_EXT_STRING, (&oml_fom_attr_vse), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001333+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001334+ },
1335+ { &hf_oml_fom_attr_len,
1336+ { "FOM Attribute Length", "oml.fom.attr_len",
1337+ FT_UINT16, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001338+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001339+ },
1340+ { &hf_oml_fom_attr_val,
1341+ { "FOM Attribute Value", "oml.fom.attr_val",
Harald Weltea165a422009-10-22 10:09:21 +02001342+ FT_BYTES, BASE_NONE, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001343+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001344+ },
1345+
1346+
1347+
1348+ /* OML Attributes */
1349+ { &hf_attr_adm_state,
1350+ { "Administrative State", "oml.fom.attr.adm_state",
1351+ FT_UINT8, BASE_HEX, VALS(oml_adm_state_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001352+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001353+ },
Harald Welte2c544c82009-07-11 16:41:15 +02001354+ { &hf_attr_arfcn,
1355+ { "ARFCN", "oml.fom.attr.arfcn",
1356+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1357+ },
Harald Welte6900c162009-06-25 20:50:57 +02001358+ { &hf_attr_oper_state,
1359+ { "Operational State", "oml.fom.attr.oper_state",
1360+ FT_UINT8, BASE_HEX, VALS(oml_oper_state_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001361+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001362+ },
1363+ { &hf_attr_avail_state,
1364+ { "Availability Status", "oml.fom.attr.avail_state",
1365+ FT_UINT8, BASE_HEX, VALS(oml_avail_state_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001366+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001367+ },
1368+ { &hf_attr_event_type,
1369+ { "Event Type", "oml.fom.attr.event_type",
1370+ FT_UINT8, BASE_HEX, VALS(oml_event_type_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001371+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001372+ },
1373+ { &hf_attr_severity,
1374+ { "Severity", "oml.fom.attr.severity",
1375+ FT_UINT8, BASE_HEX, VALS(oml_severity_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001376+ NULL, HFILL }
Harald Welte6900c162009-06-25 20:50:57 +02001377+ },
Harald Welte1cc3fa82009-07-01 17:40:50 +02001378+ { &hf_attr_bcch_arfcn,
1379+ { "BCCH ARFCN", "oml.fom.attr.bcch_arfcn",
1380+ FT_UINT16, BASE_DEC, NULL, 0,
1381+ "ARFCN of the BCCH", HFILL }
1382+ },
1383+ { &hf_attr_bsic,
1384+ { "BSIC", "oml.fom.attr.bsic",
1385+ FT_UINT16, BASE_HEX, NULL, 0,
1386+ "Base Station Identity Cdoe", HFILL }
1387+ },
1388+ { &hf_attr_test_no,
1389+ { "Test Number", "oml.fom.attr.test_no",
1390+ FT_UINT8, BASE_HEX, VALS(oml_test_no_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001391+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001392+ },
1393+ { &hf_attr_tsc,
1394+ { "TSC", "oml.fom.attr.tsc",
1395+ FT_UINT8, BASE_HEX, NULL, 0,
1396+ "Training Sequence Code", HFILL }
1397+ },
1398+ { &hf_attr_tei,
1399+ { "TEI", "oml.fom.attr.tei",
1400+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001401+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001402+ },
1403+ { &hf_attr_ach_btsp,
Harald Welte450129f2009-07-03 12:46:47 +02001404+ { "BTS E1 Port", "oml.fom.attr.abis_ch.bts_port",
Harald Welte1cc3fa82009-07-01 17:40:50 +02001405+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001406+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001407+ },
1408+ { &hf_attr_ach_tslot,
Harald Welte450129f2009-07-03 12:46:47 +02001409+ { "E1 Timeslot", "oml.fom.attr.abis_ch.timeslot",
Harald Welte1cc3fa82009-07-01 17:40:50 +02001410+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001411+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001412+ },
1413+ { &hf_attr_ach_sslot,
Harald Welte450129f2009-07-03 12:46:47 +02001414+ { "E1 Subslot", "oml.fom.attr.abis_ch.subslot",
Harald Welte1cc3fa82009-07-01 17:40:50 +02001415+ FT_UINT8, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001416+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001417+ },
1418+ { &hf_attr_gsm_time,
1419+ { "GSM Time", "oml.fom.attr.gsm_time",
1420+ FT_UINT16, BASE_DEC, NULL, 0,
1421+ "GSM Time", HFILL }
1422+ },
1423+ { &hf_attr_chan_comb,
1424+ { "Channel Combination", "oml.fom.attr.chan_comb",
1425+ FT_UINT8, BASE_HEX, VALS(oml_chan_comb_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001426+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001427+ },
Harald Welteb88b6d32010-06-19 13:52:54 +02001428+ { &hf_attr_hsn,
1429+ { "HSN", "oml.fom.attr.hsn",
1430+ FT_UINT8, BASE_DEC, NULL, 0,
1431+ "Hopping Sequence Number", HFILL }
1432+ },
1433+ { &hf_attr_maio,
1434+ { "MAIO", "oml.fom.attr.maio",
1435+ FT_UINT8, BASE_DEC, NULL, 0,
1436+ "Mobile Allocation Index Offset", HFILL }
1437+ },
1438+
Harald Welte1cc3fa82009-07-01 17:40:50 +02001439+ /* IP Access */
1440+ { &hf_oml_ipa_tres_attr_tag,
1441+ { "IPA Test Result Embedded IE",
1442+ "oml.fom.testrep.ipa_tag",
1443+ FT_UINT8, BASE_HEX, VALS(ipacc_testres_ie_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001444+ "Information Element embedded into the Test Result "
1445+ "of ip.access BTS", HFILL },
Harald Welte1cc3fa82009-07-01 17:40:50 +02001446+ },
1447+ { &hf_oml_ipa_tres_attr_len,
1448+ { "IPA Test Result Embedded IE Length",
1449+ "oml.fom.testrep.ipa_len",
1450+ FT_UINT16, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001451+ "Length of ip.access Test Result Embedded IE", HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001452+ },
1453+ { &hf_attr_ipa_test_res,
1454+ { "IPA Test Result", "oml.fom.testrep.result",
1455+ FT_UINT8, BASE_DEC, VALS(ipacc_test_res_vals), 0,
Harald Welte450129f2009-07-03 12:46:47 +02001456+ NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001457+ },
1458+ { &hf_attr_ipa_tr_rxlev,
1459+ { "Rx Level", "oml.fom.testrep.ipa_rxlev",
Harald Welte450129f2009-07-03 12:46:47 +02001460+ FT_UINT16, BASE_DEC, NULL, 0xfc00, NULL, HFILL }
1461+ },
1462+ { &hf_attr_ipa_tr_b_rxlev,
1463+ { "Rx Level", "oml.fom.testrep.ipa_rxlev_b",
1464+ FT_UINT8, BASE_DEC, NULL, 0, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001465+ },
1466+ { &hf_attr_ipa_tr_arfcn,
1467+ { "ARFCN", "oml.fom.testrep.ipa_arfcn",
Harald Welte450129f2009-07-03 12:46:47 +02001468+ FT_UINT16, BASE_DEC, NULL, 0x03ff, "ARFCN", HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001469+ },
1470+ { &hf_attr_ipa_tr_f_qual,
1471+ { "Frequency Quality", "oml.fom.testrep.ipa.freq_qual",
Harald Welte450129f2009-07-03 12:46:47 +02001472+ FT_UINT8, BASE_DEC, NULL, 0xfc, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001473+ },
1474+ { &hf_attr_ipa_tr_f_err,
1475+ { "Frequency Error", "oml.fom.testrep.ipa.freq_err",
Harald Welte450129f2009-07-03 12:46:47 +02001476+ FT_INT16, BASE_DEC, NULL, 0, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001477+ },
1478+ { &hf_attr_ipa_tr_rxqual,
1479+ { "Rx Quality", "oml.fom.testrep.ipa.rx_qual",
Harald Welte450129f2009-07-03 12:46:47 +02001480+ FT_UINT8, BASE_DEC, NULL, 0x7, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001481+ },
1482+ { &hf_attr_ipa_tr_frame_offs,
1483+ { "Frame Offset", "oml.fom.testrep.ipa.frame_offset",
Harald Welte450129f2009-07-03 12:46:47 +02001484+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001485+ },
1486+ { &hf_attr_ipa_tr_framenr_offs,
Harald Welte450129f2009-07-03 12:46:47 +02001487+ { "Frame Number Offset",
1488+ "oml.fom.testrep.ipa.framenr_offset",
1489+ FT_UINT32, BASE_DEC, NULL, 0, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001490+ },
1491+ { &hf_attr_ipa_tr_bsic,
1492+ { "BSIC", "oml.fom.testrep.ipa.bsic",
1493+ FT_UINT8, BASE_DEC, NULL, 0x3f,
1494+ "Base Station Identity Code", HFILL }
1495+ },
1496+ { &hf_attr_ipa_tr_cell_id,
1497+ { "Cell ID", "oml.fom.testrep.ipa.cell_id",
Harald Welte450129f2009-07-03 12:46:47 +02001498+ FT_UINT16, BASE_HEX, NULL, 0, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001499+ },
1500+ { &hf_attr_ipa_rsl_ip,
1501+ { "BSC RSL IP Address", "oml.fom.attr.ipa.rsl_ip",
1502+ FT_IPv4, BASE_NONE, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001503+ "IP Address to which the BTS establishes "
1504+ "the RSL link", HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001505+ },
1506+ { &hf_attr_ipa_rsl_port,
1507+ { "BSC RSL TCP Port", "oml.fom.attr.ipa.rsl_port",
1508+ FT_UINT16, BASE_DEC, NULL, 0,
Harald Welte450129f2009-07-03 12:46:47 +02001509+ "Port number to which the BST establishes "
1510+ "the RSL link", HFILL }
1511+ },
1512+ { &hf_attr_ipa_prim_oml_ip,
1513+ { "Primary OML IP Address",
1514+ "oml.fom.attr.ipa.prim_oml_ip",
1515+ FT_IPv4, BASE_NONE, NULL, 0,
1516+ "IP Address of the BSC for the primary OML link",
1517+ HFILL }
1518+ },
1519+ { &hf_attr_ipa_prim_oml_port,
1520+ { "Primary OML TCP Port",
1521+ "oml.fom.attr.ipa.prim_oml_port",
1522+ FT_UINT16, BASE_DEC, NULL, 0,
1523+ "TCP Port of the BSC for the primarly OML link",
1524+ HFILL }
1525+ },
1526+ { &hf_attr_ipa_location_name,
1527+ { "Location Name", "oml.fom.attr.ipa.loc_name",
1528+ FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL }
1529+ },
1530+ { &hf_attr_ipa_unit_name,
1531+ { "Unit Name", "oml.fom.attr.ipa.unit_name",
1532+ FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL }
1533+ },
1534+ { &hf_attr_ipa_unit_id,
1535+ { "Unit ID", "oml.fom.attr.ipa.unit_id",
1536+ FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL }
1537+ },
1538+ { &hf_attr_ipa_nv_flags,
1539+ { "NVRAM Config Flags", "oml.fom.attr.ipa.nv_flags",
1540+ FT_UINT16, BASE_HEX, NULL, 0xffff, NULL, HFILL }
1541+ },
1542+ { &hf_attr_ipa_nv_mask,
1543+ { "NVRAM Config Mask", "oml.fom.attr.ipa.nv_mask",
1544+ FT_UINT16, BASE_HEX, NULL, 0xffff, NULL, HFILL }
1545+ },
1546+ { &hf_attr_ipa_tr_si2,
1547+ { "System Information 2", "oml.fom.attr.ipa.si2",
Harald Weltea165a422009-10-22 10:09:21 +02001548+ FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL }
Harald Welte450129f2009-07-03 12:46:47 +02001549+ },
1550+ { &hf_attr_ipa_tr_si2bis,
1551+ { "System Information 2bis", "oml.fom.attr.ipa.si2bis",
Harald Weltea165a422009-10-22 10:09:21 +02001552+ FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL }
Harald Welte450129f2009-07-03 12:46:47 +02001553+ },
1554+ { &hf_attr_ipa_tr_si2ter,
1555+ { "System Information 2ter", "oml.fom.attr.ipa.si2ter",
Harald Weltea165a422009-10-22 10:09:21 +02001556+ FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL }
Harald Welte450129f2009-07-03 12:46:47 +02001557+ },
1558+ { &hf_attr_ipa_tr_chan_desc,
1559+ { "Cell Channel Description",
1560+ "oml.fom.attr.ipa.chan_desc",
Harald Weltea165a422009-10-22 10:09:21 +02001561+ FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL }
Harald Welte1cc3fa82009-07-01 17:40:50 +02001562+ },
Harald Weltec9b484f2009-07-12 20:46:43 +02001563+ { &hf_attr_ipa_nsl_sport,
1564+ { "NS Link IP Source Port",
1565+ "oml.fom.attr.ipa.nsl_sport",
1566+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1567+ },
1568+ { &hf_attr_ipa_nsl_daddr,
1569+ { "NS Link IP Destination Addr",
1570+ "oml.fom.attr.ipa.nsl_daddr",
1571+ FT_IPv4, BASE_NONE, NULL, 0, NULL, HFILL }
1572+ },
1573+ { &hf_attr_ipa_nsl_dport,
1574+ { "NS Link IP Destination Port",
1575+ "oml.fom.attr.ipa.nsl_dport",
1576+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1577+ },
1578+ { &hf_attr_ipa_nsei,
1579+ { "NSEI", "oml.fom.attr.ipa.nsei",
1580+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1581+ },
1582+ { &hf_attr_ipa_nsvci,
1583+ { "NSVCI", "oml.fom.attr.ipa.nsvci",
1584+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1585+ },
1586+ { &hf_attr_ipa_bvci,
1587+ { "BVCI", "oml.fom.attr.ipa.bvci",
1588+ FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1589+ },
1590+ { &hf_attr_ipa_rac,
1591+ { "RAC", "oml.fom.attr.ipa.rac",
1592+ FT_UINT8, BASE_HEX, NULL, 0,
1593+ "Routing Area Code", HFILL }
1594+ },
Harald Welte6900c162009-06-25 20:50:57 +02001595+ };
1596+ static gint *ett[] = {
1597+ &ett_oml,
1598+ &ett_oml_fom,
1599+ &ett_oml_fom_att,
1600+ };
1601+
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +01001602+ module_t *oml_module;
1603+
Pablo Neira Ayuso4fcd3572011-03-06 16:47:28 +01001604+#define NM_ATT_TLVDEF_BASE(_attr, _type, _fixed_len) \
1605+ nm_att_tlvdef_base.def[_attr].type = _type; \
1606+ nm_att_tlvdef_base.def[_attr].fixed_len = _fixed_len; \
1607+
1608+ /* From openbsc/src/abis_nm.c, converted to support ANSI C. */
1609+ NM_ATT_TLVDEF_BASE(NM_ATT_ABIS_CHANNEL, TLV_TYPE_FIXED, 3);
1610+ NM_ATT_TLVDEF_BASE(NM_ATT_ADD_INFO, TLV_TYPE_TL16V, 0);
1611+ NM_ATT_TLVDEF_BASE(NM_ATT_ADD_TEXT, TLV_TYPE_TL16V, 0);
1612+ NM_ATT_TLVDEF_BASE(NM_ATT_ADM_STATE, TLV_TYPE_TV, 0);
1613+ NM_ATT_TLVDEF_BASE(NM_ATT_ARFCN_LIST, TLV_TYPE_TL16V, 0);
1614+ NM_ATT_TLVDEF_BASE(NM_ATT_AUTON_REPORT, TLV_TYPE_TV, 0);
1615+ NM_ATT_TLVDEF_BASE(NM_ATT_AVAIL_STATUS, TLV_TYPE_TL16V, 0);
1616+ NM_ATT_TLVDEF_BASE(NM_ATT_BCCH_ARFCN, TLV_TYPE_FIXED, 2);
1617+ NM_ATT_TLVDEF_BASE(NM_ATT_BSIC, TLV_TYPE_TV, 0);
1618+ NM_ATT_TLVDEF_BASE(NM_ATT_BTS_AIR_TIMER, TLV_TYPE_TV, 0);
1619+ NM_ATT_TLVDEF_BASE(NM_ATT_CCCH_L_I_P, TLV_TYPE_TV, 0);
1620+ NM_ATT_TLVDEF_BASE(NM_ATT_CCCH_L_T, TLV_TYPE_TV, 0);
1621+ NM_ATT_TLVDEF_BASE(NM_ATT_CHAN_COMB, TLV_TYPE_TV, 0);
1622+ NM_ATT_TLVDEF_BASE(NM_ATT_CONN_FAIL_CRIT, TLV_TYPE_TL16V, 0);
1623+ NM_ATT_TLVDEF_BASE(NM_ATT_DEST, TLV_TYPE_TL16V, 0);
1624+ NM_ATT_TLVDEF_BASE(NM_ATT_EVENT_TYPE, TLV_TYPE_TV, 0);
1625+ NM_ATT_TLVDEF_BASE(NM_ATT_FILE_ID, TLV_TYPE_TL16V, 0);
1626+ NM_ATT_TLVDEF_BASE(NM_ATT_FILE_VERSION, TLV_TYPE_TL16V, 0);
1627+ NM_ATT_TLVDEF_BASE(NM_ATT_GSM_TIME, TLV_TYPE_FIXED, 2);
1628+ NM_ATT_TLVDEF_BASE(NM_ATT_HSN, TLV_TYPE_TV, 0);
1629+ NM_ATT_TLVDEF_BASE(NM_ATT_HW_CONFIG, TLV_TYPE_TL16V, 0);
1630+ NM_ATT_TLVDEF_BASE(NM_ATT_HW_DESC, TLV_TYPE_TLV, 0);
1631+ NM_ATT_TLVDEF_BASE(NM_ATT_INTAVE_PARAM, TLV_TYPE_TV, 0);
1632+ NM_ATT_TLVDEF_BASE(NM_ATT_INTERF_BOUND, TLV_TYPE_FIXED, 6);
1633+ NM_ATT_TLVDEF_BASE(NM_ATT_LIST_REQ_ATTR, TLV_TYPE_TL16V, 0);
1634+ NM_ATT_TLVDEF_BASE(NM_ATT_MAIO, TLV_TYPE_TV, 0);
1635+ NM_ATT_TLVDEF_BASE(NM_ATT_MANUF_STATE, TLV_TYPE_TV, 0);
1636+ NM_ATT_TLVDEF_BASE(NM_ATT_MANUF_THRESH, TLV_TYPE_TL16V, 0);
1637+ NM_ATT_TLVDEF_BASE(NM_ATT_MANUF_ID, TLV_TYPE_TL16V, 0);
1638+ NM_ATT_TLVDEF_BASE(NM_ATT_MAX_TA, TLV_TYPE_TV, 0);
1639+ NM_ATT_TLVDEF_BASE(NM_ATT_MDROP_LINK, TLV_TYPE_FIXED, 2);
1640+ NM_ATT_TLVDEF_BASE(NM_ATT_MDROP_NEXT, TLV_TYPE_FIXED, 2);
1641+ NM_ATT_TLVDEF_BASE(NM_ATT_NACK_CAUSES, TLV_TYPE_TV, 0);
1642+ NM_ATT_TLVDEF_BASE(NM_ATT_NY1, TLV_TYPE_TV, 0);
1643+ NM_ATT_TLVDEF_BASE(NM_ATT_OPER_STATE, TLV_TYPE_TV, 0);
1644+ NM_ATT_TLVDEF_BASE(NM_ATT_OVERL_PERIOD, TLV_TYPE_TL16V, 0);
1645+ NM_ATT_TLVDEF_BASE(NM_ATT_PHYS_CONF, TLV_TYPE_TL16V, 0);
1646+ NM_ATT_TLVDEF_BASE(NM_ATT_POWER_CLASS, TLV_TYPE_TV, 0);
1647+ NM_ATT_TLVDEF_BASE(NM_ATT_POWER_THRESH, TLV_TYPE_FIXED, 3);
1648+ NM_ATT_TLVDEF_BASE(NM_ATT_PROB_CAUSE, TLV_TYPE_FIXED, 3);
1649+ NM_ATT_TLVDEF_BASE(NM_ATT_RACH_B_THRESH, TLV_TYPE_TV, 0);
1650+ NM_ATT_TLVDEF_BASE(NM_ATT_LDAVG_SLOTS, TLV_TYPE_FIXED, 2);
1651+ NM_ATT_TLVDEF_BASE(NM_ATT_RAD_SUBC, TLV_TYPE_TV, 0);
1652+ NM_ATT_TLVDEF_BASE(NM_ATT_RF_MAXPOWR_R, TLV_TYPE_TV, 0);
1653+ NM_ATT_TLVDEF_BASE(NM_ATT_SITE_INPUTS, TLV_TYPE_TL16V, 0);
1654+ NM_ATT_TLVDEF_BASE(NM_ATT_SITE_OUTPUTS, TLV_TYPE_TL16V, 0);
1655+ NM_ATT_TLVDEF_BASE(NM_ATT_SOURCE, TLV_TYPE_TL16V, 0);
1656+ NM_ATT_TLVDEF_BASE(NM_ATT_SPEC_PROB, TLV_TYPE_TV, 0);
1657+ NM_ATT_TLVDEF_BASE(NM_ATT_START_TIME, TLV_TYPE_FIXED, 2);
1658+ NM_ATT_TLVDEF_BASE(NM_ATT_T200, TLV_TYPE_FIXED, 7);
1659+ NM_ATT_TLVDEF_BASE(NM_ATT_TEI, TLV_TYPE_TV, 0);
1660+ NM_ATT_TLVDEF_BASE(NM_ATT_TEST_DUR, TLV_TYPE_FIXED, 2);
1661+ NM_ATT_TLVDEF_BASE(NM_ATT_TEST_NO, TLV_TYPE_TV, 0);
1662+ NM_ATT_TLVDEF_BASE(NM_ATT_TEST_REPORT, TLV_TYPE_TL16V, 0);
1663+ NM_ATT_TLVDEF_BASE(NM_ATT_VSWR_THRESH, TLV_TYPE_FIXED, 2);
1664+ NM_ATT_TLVDEF_BASE(NM_ATT_WINDOW_SIZE, TLV_TYPE_TV, 0);
1665+ NM_ATT_TLVDEF_BASE(NM_ATT_TSC, TLV_TYPE_TV, 0);
1666+ NM_ATT_TLVDEF_BASE(NM_ATT_SW_CONFIG, TLV_TYPE_TL16V, 0);
1667+ NM_ATT_TLVDEF_BASE(NM_ATT_SEVERITY, TLV_TYPE_TV, 0);
1668+ NM_ATT_TLVDEF_BASE(NM_ATT_GET_ARI, TLV_TYPE_TL16V, 0);
1669+ NM_ATT_TLVDEF_BASE(NM_ATT_HW_CONF_CHG, TLV_TYPE_TL16V, 0);
1670+ NM_ATT_TLVDEF_BASE(NM_ATT_OUTST_ALARM, TLV_TYPE_TV, 0);
1671+ NM_ATT_TLVDEF_BASE(NM_ATT_FILE_DATA, TLV_TYPE_TL16V, 0);
1672+ NM_ATT_TLVDEF_BASE(NM_ATT_MEAS_RES, TLV_TYPE_TL16V, 0);
1673+
1674+ /* BS 11 specifics */
1675+#define NM_ATT_TLVDEV_BS11(_attr, _type, _fixed_len) \
1676+ nm_att_tlvdev_bs11.def[_attr].type = _type; \
1677+ nm_att_tlvdev_bs11.def[_attr].fixed_len = _fixed_len; \
1678+
1679+ /* different stndard IEs */
1680+ NM_ATT_TLVDEV_BS11(NM_ATT_OUTST_ALARM, TLV_TYPE_TLV, 0);
1681+ NM_ATT_TLVDEV_BS11(NM_ATT_HW_DESC, TLV_TYPE_TL16V, 0);
1682+ NM_ATT_TLVDEV_BS11(NM_ATT_ARFCN_LIST, TLV_TYPE_TLV16, 0);
1683+
1684+ /* proprietary IEs */
1685+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_ABIS_EXT_TIME, TLV_TYPE_TLV, 0);
1686+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_OM_LAPD_REL_TIMER, TLV_TYPE_FIXED, 2);
1687+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_SH_LAPD_INT_TIMER, TLV_TYPE_TLV, 0);
1688+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_EMERG_TIMER1, TLV_TYPE_TLV, 0);
1689+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_EMERG_TIMER2, TLV_TYPE_TLV, 0);
1690+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_BTSLS_HOPPING, TLV_TYPE_FIXED, 1);
1691+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_CELL_ALLOC_NR, TLV_TYPE_FIXED, 1);
1692+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_ENA_INTERF_CLASS, TLV_TYPE_FIXED, 1);
1693+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_FACCH_QUAL, TLV_TYPE_FIXED, 1);
1694+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_TSYNC, TLV_TYPE_FIXED, 2);
1695+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_TTRAU, TLV_TYPE_FIXED, 2);
1696+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_EXCESSIVE_DISTANCE,TLV_TYPE_TLV, 1);
1697+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_HOPPING_MODE, TLV_TYPE_TLV, 1);
1698+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_RF_RES_IND_PER, TLV_TYPE_FIXED, 1);
1699+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_RADIO_MEAS_GRAN, TLV_TYPE_TLV, 0);
1700+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_RADIO_MEAS_REP, TLV_TYPE_TLV, 0);
1701+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_EMRG_CFG_MEMBER, TLV_TYPE_TLV, 0);
1702+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_TRX_AREA, TLV_TYPE_TLV, 0);
1703+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_ESN_FW_CODE_NO, TLV_TYPE_TLV, 0);
1704+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_ESN_HW_CODE_NO, TLV_TYPE_TLV, 0);
1705+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_ESN_PCB_SERIAL, TLV_TYPE_TLV, 0);
1706+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_BOOT_SW_VERS, TLV_TYPE_TLV, 0);
1707+ NM_ATT_TLVDEV_BS11(0x59, TLV_TYPE_TLV, 0);
1708+ NM_ATT_TLVDEV_BS11(0xd5, TLV_TYPE_TLV, 0);
1709+ NM_ATT_TLVDEV_BS11(0xa8, TLV_TYPE_TLV, 0);
1710+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_PASSWORD, TLV_TYPE_TLV, 0);
1711+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_TXPWR, TLV_TYPE_TLV, 0);
1712+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_RSSI_OFFS, TLV_TYPE_TLV, 0);
1713+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_LINE_CFG, TLV_TYPE_TV, 0);
1714+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_L1_PROT_TYPE, TLV_TYPE_TV, 0);
1715+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_BIT_ERR_THESH, TLV_TYPE_FIXED, 2);
1716+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_DIVERSITY, TLV_TYPE_TLV, 0);
1717+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_LMT_LOGON_SESSION, TLV_TYPE_TLV, 0);
1718+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_LMT_LOGIN_TIME, TLV_TYPE_TLV, 0);
1719+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_LMT_USER_ACC_LEV, TLV_TYPE_TLV, 0);
1720+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_LMT_USER_NAME, TLV_TYPE_TLV, 0);
1721+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_BTS_STATE, TLV_TYPE_TLV, 0);
1722+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_E1_STATE, TLV_TYPE_TLV, 0);
1723+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_PLL_MODE, TLV_TYPE_TLV, 0);
1724+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_PLL, TLV_TYPE_TLV, 0);
1725+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_CCLK_ACCURACY, TLV_TYPE_TV, 0);
1726+ NM_ATT_TLVDEV_BS11(NM_ATT_BS11_CCLK_TYPE, TLV_TYPE_TV, 0);
1727+
1728+ /* ip.access specifics */
1729+#define NM_ATT_TLVDEF_IPA(_attr, _type, _fixed_len) \
1730+ nm_att_tlvdef_ipa.def[_attr].type = _type; \
1731+ nm_att_tlvdef_ipa.def[_attr].fixed_len = _fixed_len; \
1732+
1733+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_DST_IP, TLV_TYPE_FIXED, 4);
1734+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_DST_IP_PORT, TLV_TYPE_FIXED, 2);
1735+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_PRIM_OML_CFG, TLV_TYPE_TL16V, 0);
1736+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_NV_FLAGS, TLV_TYPE_TL16V, 0);
1737+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_FREQ_CTRL, TLV_TYPE_FIXED, 2);
1738+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_SEC_OML_CFG, TLV_TYPE_FIXED, 6);
1739+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_IP_IF_CFG, TLV_TYPE_FIXED, 8);
1740+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_IP_GW_CFG, TLV_TYPE_FIXED, 12);
1741+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_LOCATION, TLV_TYPE_TL16V, 0);
1742+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_UNIT_ID, TLV_TYPE_TL16V, 0);
1743+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_UNIT_NAME, TLV_TYPE_TL16V, 0);
1744+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_SNMP_CFG, TLV_TYPE_TL16V, 0);
1745+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_ALM_THRESH_LIST, TLV_TYPE_TL16V, 0);
1746+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_CUR_SW_CFG, TLV_TYPE_TL16V, 0);
1747+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_STREAM_ID, TLV_TYPE_TV, 0);
1748+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_RAC, TLV_TYPE_TL16V, 0);
1749+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_OBJ_VERSION, TLV_TYPE_TL16V, 0);
1750+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_GPRS_PAGING_CFG, TLV_TYPE_TL16V, 0);
1751+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_NSEI, TLV_TYPE_TL16V, 0);
1752+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_BVCI, TLV_TYPE_TL16V, 0);
1753+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_NSVCI, TLV_TYPE_TL16V, 0);
1754+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_NS_CFG, TLV_TYPE_TL16V, 0);
1755+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_BSSGP_CFG, TLV_TYPE_TL16V, 0);
1756+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_NS_LINK_CFG, TLV_TYPE_TL16V, 0);
1757+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_RLC_CFG, TLV_TYPE_TL16V, 0);
1758+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_SUPP_FEATURES, TLV_TYPE_TL16V, 0);
1759+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_CODING_SCHEMES, TLV_TYPE_TL16V, 0);
1760+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_RLC_CFG_2, TLV_TYPE_TL16V, 0);
1761+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_RLC_CFG_3, TLV_TYPE_TL16V, 0);
1762+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_PAGING_CFG, TLV_TYPE_FIXED, 2);
1763+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_FILE_DATA, TLV_TYPE_TL16V, 0);
1764+ NM_ATT_TLVDEF_IPA(NM_ATT_IPACC_CGI, TLV_TYPE_TL16V, 0);
1765+
Harald Welteb88b6d32010-06-19 13:52:54 +02001766+ /* assign our custom match functions */
Harald Welte6d42dbe2010-12-01 00:04:09 +01001767+ oml_fom_msgtype_vse._vs_match = _match_oml_fom_msgtype;
1768+ oml_fom_attr_vse._vs_match = _match_oml_fom_attr;
Harald Welteb88b6d32010-06-19 13:52:54 +02001769+
1770+ proto_abis_oml = proto_register_protocol("GSM A-bis OML", "A-bis OML",
Harald Welte6900c162009-06-25 20:50:57 +02001771+ "gsm_abis_oml");
1772+
1773+ proto_register_field_array(proto_abis_oml, hf, array_length(hf));
1774+
1775+ proto_register_subtree_array(ett, array_length(ett));
1776+
1777+ register_dissector("gsm_abis_oml", dissect_abis_oml, proto_abis_oml);
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +01001778+
Holger Hans Peter Freyther615e6502009-12-29 04:22:12 +01001779+ oml_module = prefs_register_protocol(proto_abis_oml, proto_reg_handoff_abis_oml);
1780+ prefs_register_bool_preference(oml_module, "use_ipaccess_oml",
1781+ "Use nanoBTS definitions",
1782+ "Use ipaccess nanoBTS specific definitions for OML",
1783+ &global_oml_use_nano_bts);
Harald Welte6900c162009-06-25 20:50:57 +02001784+}
1785+
Harald Welteb88b6d32010-06-19 13:52:54 +02001786+/* This function is called once at startup and every time the user hits
1787+ * 'apply' in the preferences dialogue */
Harald Welte6900c162009-06-25 20:50:57 +02001788+void
1789+proto_reg_handoff_abis_oml(void)
1790+{
Harald Welteb88b6d32010-06-19 13:52:54 +02001791+ static gboolean initialized = FALSE;
Harald Welte6900c162009-06-25 20:50:57 +02001792+
Harald Welteb88b6d32010-06-19 13:52:54 +02001793+ if (!initialized) {
1794+ dissector_handle_t abis_oml_handle;
1795+
1796+ abis_oml_handle = create_dissector_handle(dissect_abis_oml, proto_abis_oml);
1797+ dissector_add("lapd.gsm.sapi", LAPD_GSM_SAPI_OM_PROC, abis_oml_handle);
1798+
1799+ } else {
1800+ /* preferences have been changed */
1801+ }
1802+
1803+ if (global_oml_use_nano_bts == TRUE) {
1804+ /* initialize with nanobts definitions */
Harald Welte6d42dbe2010-12-01 00:04:09 +01001805+ oml_fom_msgtype_vse._vs_p = _oml_fom_msgtype_vals_ipa;
1806+ oml_fom_msgtype_vse._vs_num_entries =
1807+ array_length(_oml_fom_msgtype_vals_ipa)-1;
1808+ oml_fom_attr_vse._vs_p = oml_fom_attr_vals_ipa;
1809+ oml_fom_attr_vse._vs_num_entries =
1810+ array_length(oml_fom_attr_vals_ipa)-1;
Harald Welteb88b6d32010-06-19 13:52:54 +02001811+ } else {
1812+ /* initialize with BS11 defaults */
Harald Welte6d42dbe2010-12-01 00:04:09 +01001813+ oml_fom_msgtype_vse._vs_p = _oml_fom_msgtype_vals_bs11;
1814+ oml_fom_msgtype_vse._vs_num_entries =
1815+ array_length(_oml_fom_msgtype_vals_bs11)-1;
1816+ oml_fom_attr_vse._vs_p = oml_fom_attr_vals_bs11;
1817+ oml_fom_attr_vse._vs_num_entries =
1818+ array_length(oml_fom_attr_vals_bs11)-1;
Harald Welteb88b6d32010-06-19 13:52:54 +02001819+ }
Harald Welte6900c162009-06-25 20:50:57 +02001820+}
Pablo Neira Ayuso4fcd3572011-03-06 16:47:28 +01001821Index: wireshark/epan/dissectors/packet-gsm_abis_oml.h
1822===================================================================
1823--- /dev/null 1970-01-01 00:00:00.000000000 +0000
1824+++ wireshark/epan/dissectors/packet-gsm_abis_oml.h 2011-03-06 13:12:30.000000000 +0100
1825@@ -0,0 +1,667 @@
Harald Welte6900c162009-06-25 20:50:57 +02001826+/* GSM Network Management messages on the A-bis interface
1827+ * 3GPP TS 12.21 version 8.0.0 Release 1999 / ETSI TS 100 623 V8.0.0 */
1828+
1829+/* (C) 2008-2009 by Harald Welte <laforge@gnumonks.org>
1830+ * All Rights Reserved
1831+ *
1832+ * This program is free software; you can redistribute it and/or modify
1833+ * it under the terms of the GNU General Public License as published by
1834+ * the Free Software Foundation; either version 2 of the License, or
1835+ * (at your option) any later version.
1836+ *
1837+ * This program is distributed in the hope that it will be useful,
1838+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
1839+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1840+ * GNU General Public License for more details.
1841+ *
1842+ * You should have received a copy of the GNU General Public License along
1843+ * with this program; if not, write to the Free Software Foundation, Inc.,
1844+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
1845+ *
1846+ */
1847+
1848+#ifndef __PACKET_ABIS_OML_H__
1849+#define __PACKET_ABIS_OML_H__
1850+
1851+#include <sys/types.h>
1852+
1853+/* From openbsc/include/openbsc/abis_nm.h */
1854+
1855+/* generic header in front of every OML message according to TS 08.59 */
1856+struct abis_om_hdr {
1857+ guint8 mdisc;
1858+ guint8 placement;
1859+ guint8 sequence;
1860+ guint8 length;
1861+ guint8 data[0];
1862+} __attribute__ ((packed));
1863+
1864+#define ABIS_OM_MDISC_FOM 0x80
1865+#define ABIS_OM_MDISC_MMI 0x40
1866+#define ABIS_OM_MDISC_TRAU 0x20
1867+#define ABIS_OM_MDISC_MANUF 0x10
1868+#define ABIS_OM_PLACEMENT_ONLY 0x80
1869+#define ABIS_OM_PLACEMENT_FIRST 0x40
1870+#define ABIS_OM_PLACEMENT_MIDDLE 0x20
1871+#define ABIS_OM_PLACEMENT_LAST 0x10
1872+
1873+struct abis_om_obj_inst {
1874+ guint8 bts_nr;
1875+ guint8 trx_nr;
1876+ guint8 ts_nr;
1877+} __attribute__ ((packed));
1878+
1879+struct abis_om_fom_hdr {
1880+ guint8 msg_type;
1881+ guint8 obj_class;
1882+ struct abis_om_obj_inst obj_inst;
1883+ guint8 data[0];
1884+} __attribute__ ((packed));
1885+
1886+#define ABIS_OM_FOM_HDR_SIZE (sizeof(struct abis_om_hdr) + sizeof(struct abis_om_fom_hdr))
1887+
1888+/* Section 9.1: Message Types */
1889+enum abis_nm_msgtype {
1890+ /* SW Download Management Messages */
1891+ NM_MT_LOAD_INIT = 0x01,
1892+ NM_MT_LOAD_INIT_ACK,
1893+ NM_MT_LOAD_INIT_NACK,
1894+ NM_MT_LOAD_SEG,
1895+ NM_MT_LOAD_SEG_ACK,
1896+ NM_MT_LOAD_ABORT,
1897+ NM_MT_LOAD_END,
1898+ NM_MT_LOAD_END_ACK,
1899+ NM_MT_LOAD_END_NACK,
1900+ NM_MT_SW_ACT_REQ, /* BTS->BSC */
1901+ NM_MT_SW_ACT_REQ_ACK,
1902+ NM_MT_SW_ACT_REQ_NACK,
1903+ NM_MT_ACTIVATE_SW, /* BSC->BTS */
1904+ NM_MT_ACTIVATE_SW_ACK,
1905+ NM_MT_ACTIVATE_SW_NACK,
1906+ NM_MT_SW_ACTIVATED_REP, /* 0x10 */
1907+ /* A-bis Interface Management Messages */
1908+ NM_MT_ESTABLISH_TEI = 0x21,
1909+ NM_MT_ESTABLISH_TEI_ACK,
1910+ NM_MT_ESTABLISH_TEI_NACK,
1911+ NM_MT_CONN_TERR_SIGN,
1912+ NM_MT_CONN_TERR_SIGN_ACK,
1913+ NM_MT_CONN_TERR_SIGN_NACK,
1914+ NM_MT_DISC_TERR_SIGN,
1915+ NM_MT_DISC_TERR_SIGN_ACK,
1916+ NM_MT_DISC_TERR_SIGN_NACK,
1917+ NM_MT_CONN_TERR_TRAF,
1918+ NM_MT_CONN_TERR_TRAF_ACK,
1919+ NM_MT_CONN_TERR_TRAF_NACK,
1920+ NM_MT_DISC_TERR_TRAF,
1921+ NM_MT_DISC_TERR_TRAF_ACK,
1922+ NM_MT_DISC_TERR_TRAF_NACK,
1923+ /* Transmission Management Messages */
1924+ NM_MT_CONN_MDROP_LINK = 0x31,
1925+ NM_MT_CONN_MDROP_LINK_ACK,
1926+ NM_MT_CONN_MDROP_LINK_NACK,
1927+ NM_MT_DISC_MDROP_LINK,
1928+ NM_MT_DISC_MDROP_LINK_ACK,
1929+ NM_MT_DISC_MDROP_LINK_NACK,
1930+ /* Air Interface Management Messages */
1931+ NM_MT_SET_BTS_ATTR = 0x41,
1932+ NM_MT_SET_BTS_ATTR_ACK,
1933+ NM_MT_SET_BTS_ATTR_NACK,
1934+ NM_MT_SET_RADIO_ATTR,
1935+ NM_MT_SET_RADIO_ATTR_ACK,
1936+ NM_MT_SET_RADIO_ATTR_NACK,
1937+ NM_MT_SET_CHAN_ATTR,
1938+ NM_MT_SET_CHAN_ATTR_ACK,
1939+ NM_MT_SET_CHAN_ATTR_NACK,
1940+ /* Test Management Messages */
1941+ NM_MT_PERF_TEST = 0x51,
1942+ NM_MT_PERF_TEST_ACK,
1943+ NM_MT_PERF_TEST_NACK,
1944+ NM_MT_TEST_REP,
1945+ NM_MT_SEND_TEST_REP,
1946+ NM_MT_SEND_TEST_REP_ACK,
1947+ NM_MT_SEND_TEST_REP_NACK,
1948+ NM_MT_STOP_TEST,
1949+ NM_MT_STOP_TEST_ACK,
1950+ NM_MT_STOP_TEST_NACK,
1951+ /* State Management and Event Report Messages */
1952+ NM_MT_STATECHG_EVENT_REP = 0x61,
1953+ NM_MT_FAILURE_EVENT_REP,
1954+ NM_MT_STOP_EVENT_REP,
1955+ NM_MT_STOP_EVENT_REP_ACK,
1956+ NM_MT_STOP_EVENT_REP_NACK,
1957+ NM_MT_REST_EVENT_REP,
1958+ NM_MT_REST_EVENT_REP_ACK,
1959+ NM_MT_REST_EVENT_REP_NACK,
1960+ NM_MT_CHG_ADM_STATE,
1961+ NM_MT_CHG_ADM_STATE_ACK,
1962+ NM_MT_CHG_ADM_STATE_NACK,
1963+ NM_MT_CHG_ADM_STATE_REQ,
1964+ NM_MT_CHG_ADM_STATE_REQ_ACK,
1965+ NM_MT_CHG_ADM_STATE_REQ_NACK,
1966+ NM_MT_REP_OUTST_ALARMS = 0x93,
1967+ NM_MT_REP_OUTST_ALARMS_ACK,
1968+ NM_MT_REP_OUTST_ALARMS_NACK,
1969+ /* Equipment Management Messages */
1970+ NM_MT_CHANGEOVER = 0x71,
1971+ NM_MT_CHANGEOVER_ACK,
1972+ NM_MT_CHANGEOVER_NACK,
1973+ NM_MT_OPSTART,
1974+ NM_MT_OPSTART_ACK,
1975+ NM_MT_OPSTART_NACK,
1976+ NM_MT_REINIT,
1977+ NM_MT_REINIT_ACK,
1978+ NM_MT_REINIT_NACK,
1979+ NM_MT_SET_SITE_OUT, /* BS11: get alarm ?!? */
1980+ NM_MT_SET_SITE_OUT_ACK,
1981+ NM_MT_SET_SITE_OUT_NACK,
1982+ NM_MT_CHG_HW_CONF = 0x90,
1983+ NM_MT_CHG_HW_CONF_ACK,
1984+ NM_MT_CHG_HW_CONF_NACK,
1985+ /* Measurement Management Messages */
1986+ NM_MT_MEAS_RES_REQ = 0x8a,
1987+ NM_MT_MEAS_RES_RESP,
1988+ NM_MT_STOP_MEAS,
1989+ NM_MT_START_MEAS,
1990+ /* Other Messages */
1991+ NM_MT_GET_ATTR = 0x81,
1992+ NM_MT_GET_ATTR_RESP,
1993+ NM_MT_GET_ATTR_NACK,
1994+ NM_MT_SET_ALARM_THRES,
1995+ NM_MT_SET_ALARM_THRES_ACK,
1996+ NM_MT_SET_ALARM_THRES_NACK,
1997+
1998+ NM_MT_IPACC_RESTART = 0x87,
1999+ NM_MT_IPACC_RESTART_ACK,
2000+};
2001+
2002+enum abis_nm_msgtype_bs11 {
2003+ NM_MT_BS11_RESET_RESOURCE = 0x74,
2004+
2005+ NM_MT_BS11_BEGIN_DB_TX = 0xa3,
2006+ NM_MT_BS11_BEGIN_DB_TX_ACK,
2007+ NM_MT_BS11_BEGIN_DB_TX_NACK,
2008+ NM_MT_BS11_END_DB_TX = 0xa6,
2009+ NM_MT_BS11_END_DB_TX_ACK,
2010+ NM_MT_BS11_END_DB_TX_NACK,
2011+ NM_MT_BS11_CREATE_OBJ = 0xa9,
2012+ NM_MT_BS11_CREATE_OBJ_ACK,
2013+ NM_MT_BS11_CREATE_OBJ_NACK,
2014+ NM_MT_BS11_DELETE_OBJ = 0xac,
2015+ NM_MT_BS11_DELETE_OBJ_ACK,
2016+ NM_MT_BS11_DELETE_OBJ_NACK,
2017+
2018+ NM_MT_BS11_SET_ATTR = 0xd0,
2019+ NM_MT_BS11_SET_ATTR_ACK,
2020+ NM_MT_BS11_SET_ATTR_NACK,
2021+ NM_MT_BS11_LMT_SESSION = 0xdc,
2022+
2023+ NM_MT_BS11_GET_STATE = 0xe3,
2024+ NM_MT_BS11_GET_STATE_ACK,
2025+ NM_MT_BS11_LMT_LOGON = 0xe5,
2026+ NM_MT_BS11_LMT_LOGON_ACK,
2027+ NM_MT_BS11_RESTART = 0xe7,
2028+ NM_MT_BS11_RESTART_ACK,
2029+ NM_MT_BS11_DISCONNECT = 0xe9,
2030+ NM_MT_BS11_DISCONNECT_ACK,
2031+ NM_MT_BS11_LMT_LOGOFF = 0xec,
2032+ NM_MT_BS11_LMT_LOGOFF_ACK,
2033+ NM_MT_BS11_RECONNECT = 0xf1,
2034+ NM_MT_BS11_RECONNECT_ACK,
2035+};
2036+
2037+enum abis_nm_msgtype_ipacc {
2038+ NM_MT_IPACC_RSL_CONNECT = 0xe0,
2039+ NM_MT_IPACC_RSL_CONNECT_ACK,
2040+ NM_MT_IPACC_RSL_CONNECT_NACK,
Harald Welte1cc3fa82009-07-01 17:40:50 +02002041+ NM_MT_IPACC_RSL_DISCONNECT = 0xe3,
2042+ NM_MT_IPACC_RSL_DISCONNECT_ACK,
2043+ NM_MT_IPACC_RSL_DISCONNECT_NACK,
2044+ NM_MT_IPACC_CONN_TRAF = 0xe6,
2045+ NM_MT_IPACC_CONN_TRAF_ACK,
2046+ NM_MT_IPACC_CONN_TRAF_NACK,
Harald Weltec9b484f2009-07-12 20:46:43 +02002047+ NM_MT_IPACC_DISC_TRAF = 0xe9,
2048+ NM_MT_IPACC_DISC_TRAF_ACK,
2049+ NM_MT_IPACC_DISC_TRAF_NACK,
Harald Welte1cc3fa82009-07-01 17:40:50 +02002050+ NM_MT_IPACC_DEF_BOOT_SW = 0xec,
2051+ NM_MT_IPACC_DEF_BOOT_SW_ACK,
2052+ NM_MT_IPACC_DEF_BOOT_SW_NACK,
Harald Welte6900c162009-06-25 20:50:57 +02002053+ NM_MT_IPACC_SET_NVATTR = 0xef,
2054+ NM_MT_IPACC_SET_NVATTR_ACK,
2055+ NM_MT_IPACC_SET_NVATTR_NACK,
2056+ NM_MT_IPACC_GET_NVATTR = 0xf2,
2057+ NM_MT_IPACC_GET_NVATTR_ACK,
2058+ NM_MT_IPACC_GET_NVATTR_NACK,
Harald Weltec9b484f2009-07-12 20:46:43 +02002059+ NM_MT_IPACC_SET_ATTR = 0xf5,
2060+ NM_MT_IPACC_SET_ATTR_ACK,
2061+ NM_MT_IPACC_SET_ATTR_NACK,
2062+ NM_MT_IPACC_ATTR_CHG_EVT = 0xf8,
2063+ NM_MT_IPACC_SW_DEACT = 0xf9,
2064+ NM_MT_IPACC_SW_DEACT_ACK,
2065+ NM_MT_IPACC_SW_DEACT_NACK,
2066+ NM_MT_IPACC_MEAS_RES_REQ_NACK = 0xfc,
2067+ NM_MT_IPACC_START_MEAS_NACK,
2068+ NM_MT_IPACC_STOP_MEAS_NACK,
Harald Welte6900c162009-06-25 20:50:57 +02002069+};
2070+
2071+enum abis_nm_bs11_cell_alloc {
2072+ NM_BS11_CANR_GSM = 0x00,
2073+ NM_BS11_CANR_DCS1800 = 0x01,
2074+};
2075+
2076+/* Section 9.2: Object Class */
2077+enum abis_nm_obj_class {
2078+ NM_OC_SITE_MANAGER = 0x00,
2079+ NM_OC_BTS,
2080+ NM_OC_RADIO_CARRIER,
2081+ NM_OC_CHANNEL,
2082+ NM_OC_BASEB_TRANSC,
2083+ /* RFU: 05-FE */
2084+ NM_OC_BS11_ADJC = 0xa0,
2085+ NM_OC_BS11_HANDOVER = 0xa1,
2086+ NM_OC_BS11_PWR_CTRL = 0xa2,
2087+ NM_OC_BS11_BTSE = 0xa3, /* LMT? */
2088+ NM_OC_BS11_RACK = 0xa4,
2089+ NM_OC_BS11 = 0xa5, /* 01: ALCO */
2090+ NM_OC_BS11_TEST = 0xa6,
2091+ NM_OC_BS11_ENVABTSE = 0xa8,
2092+ NM_OC_BS11_BPORT = 0xa9,
2093+
2094+ NM_OC_GPRS_NSE = 0xf0,
2095+ NM_OC_GPRS_CELL = 0xf1,
2096+ NM_OC_GPRS_NSVC0 = 0xf2,
2097+ NM_OC_GPRS_NSVC1 = 0xf3,
2098+
2099+ NM_OC_NULL = 0xff,
2100+};
2101+
2102+/* Section 9.4: Attributes */
2103+enum abis_nm_attr {
2104+ NM_ATT_ABIS_CHANNEL = 0x01,
2105+ NM_ATT_ADD_INFO,
2106+ NM_ATT_ADD_TEXT,
2107+ NM_ATT_ADM_STATE,
2108+ NM_ATT_ARFCN_LIST,
2109+ NM_ATT_AUTON_REPORT,
2110+ NM_ATT_AVAIL_STATUS,
2111+ NM_ATT_BCCH_ARFCN,
2112+ NM_ATT_BSIC,
2113+ NM_ATT_BTS_AIR_TIMER,
2114+ NM_ATT_CCCH_L_I_P,
2115+ NM_ATT_CCCH_L_T,
2116+ NM_ATT_CHAN_COMB,
2117+ NM_ATT_CONN_FAIL_CRIT,
2118+ NM_ATT_DEST,
2119+ /* res */
2120+ NM_ATT_EVENT_TYPE = 0x11, /* BS11: file data ?!? */
2121+ NM_ATT_FILE_ID,
2122+ NM_ATT_FILE_VERSION,
2123+ NM_ATT_GSM_TIME,
2124+ NM_ATT_HSN,
2125+ NM_ATT_HW_CONFIG,
2126+ NM_ATT_HW_DESC,
2127+ NM_ATT_INTAVE_PARAM,
2128+ NM_ATT_INTERF_BOUND,
2129+ NM_ATT_LIST_REQ_ATTR,
2130+ NM_ATT_MAIO,
2131+ NM_ATT_MANUF_STATE,
2132+ NM_ATT_MANUF_THRESH,
2133+ NM_ATT_MANUF_ID,
2134+ NM_ATT_MAX_TA,
2135+ NM_ATT_MDROP_LINK, /* 0x20 */
2136+ NM_ATT_MDROP_NEXT,
2137+ NM_ATT_NACK_CAUSES,
2138+ NM_ATT_NY1,
2139+ NM_ATT_OPER_STATE,
2140+ NM_ATT_OVERL_PERIOD,
2141+ NM_ATT_PHYS_CONF,
2142+ NM_ATT_POWER_CLASS,
2143+ NM_ATT_POWER_THRESH,
2144+ NM_ATT_PROB_CAUSE,
2145+ NM_ATT_RACH_B_THRESH,
2146+ NM_ATT_LDAVG_SLOTS,
2147+ NM_ATT_RAD_SUBC,
2148+ NM_ATT_RF_MAXPOWR_R,
2149+ NM_ATT_SITE_INPUTS,
2150+ NM_ATT_SITE_OUTPUTS,
2151+ NM_ATT_SOURCE, /* 0x30 */
2152+ NM_ATT_SPEC_PROB,
2153+ NM_ATT_START_TIME,
2154+ NM_ATT_T200,
2155+ NM_ATT_TEI,
2156+ NM_ATT_TEST_DUR,
2157+ NM_ATT_TEST_NO,
2158+ NM_ATT_TEST_REPORT,
2159+ NM_ATT_VSWR_THRESH,
2160+ NM_ATT_WINDOW_SIZE,
2161+ /* Res */
2162+ NM_ATT_BS11_RSSI_OFFS = 0x3d,
2163+ NM_ATT_BS11_TXPWR = 0x3e,
2164+ NM_ATT_BS11_DIVERSITY = 0x3f,
2165+ /* Res */
2166+ NM_ATT_TSC = 0x40,
2167+ NM_ATT_SW_CONFIG,
2168+ NM_ATT_SW_DESCR,
2169+ NM_ATT_SEVERITY,
2170+ NM_ATT_GET_ARI,
2171+ NM_ATT_HW_CONF_CHG,
2172+ NM_ATT_OUTST_ALARM,
2173+ NM_ATT_FILE_DATA,
2174+ NM_ATT_MEAS_RES,
2175+ NM_ATT_MEAS_TYPE,
Harald Welteb88b6d32010-06-19 13:52:54 +02002176+};
Harald Welte6900c162009-06-25 20:50:57 +02002177+
Harald Welteb88b6d32010-06-19 13:52:54 +02002178+enum abis_nm_attr_bs11 {
2179+ NM_ATT_BS11_OM_LAPD_REL_TIMER = 0x02,
2180+ NM_ATT_BS11_EMERG_TIMER1 = 0x42,
2181+ NM_ATT_BS11_EMERG_TIMER2 = 0x44,
Harald Welte6900c162009-06-25 20:50:57 +02002182+ NM_ATT_BS11_ESN_FW_CODE_NO = 0x4c,
2183+ NM_ATT_BS11_ESN_HW_CODE_NO = 0x4f,
2184+
Harald Welteb88b6d32010-06-19 13:52:54 +02002185+ NM_ATT_BS11_FILE_DATA = NM_ATT_EVENT_TYPE,
2186+
Harald Welte6900c162009-06-25 20:50:57 +02002187+ NM_ATT_BS11_ESN_PCB_SERIAL = 0x55,
2188+ NM_ATT_BS11_EXCESSIVE_DISTANCE = 0x58,
2189+
2190+ NM_ATT_BS11_ALL_TEST_CATG = 0x60,
2191+ NM_ATT_BS11_BTSLS_HOPPING,
2192+ NM_ATT_BS11_CELL_ALLOC_NR,
2193+ NM_ATT_BS11_CELL_GLOBAL_ID,
2194+ NM_ATT_BS11_ENA_INTERF_CLASS = 0x66,
2195+ NM_ATT_BS11_ENA_INT_INTEC_HANDO = 0x67,
2196+ NM_ATT_BS11_ENA_INT_INTRC_HANDO = 0x68,
2197+ NM_ATT_BS11_ENA_MS_PWR_CTRL = 0x69,
2198+ NM_ATT_BS11_ENA_PWR_BDGT_HO = 0x6a,
2199+ NM_ATT_BS11_ENA_PWR_CTRL_RLFW = 0x6b,
2200+ NM_ATT_BS11_ENA_RXLEV_HO = 0x6c,
2201+ NM_ATT_BS11_ENA_RXQUAL_HO = 0x6d,
2202+ NM_ATT_BS11_FACCH_QUAL = 0x6e,
2203+
Harald Welte6900c162009-06-25 20:50:57 +02002204+ NM_ATT_BS11_RF_RES_IND_PER = 0x8f,
2205+
2206+ NM_ATT_BS11_RX_LEV_MIN_CELL = 0x90,
2207+ NM_ATT_BS11_ABIS_EXT_TIME = 0x91,
2208+ NM_ATT_BS11_TIMER_HO_REQUEST = 0x92,
2209+ NM_ATT_BS11_TIMER_NCELL = 0x93,
2210+ NM_ATT_BS11_TSYNC = 0x94,
2211+ NM_ATT_BS11_TTRAU = 0x95,
2212+ NM_ATT_BS11_EMRG_CFG_MEMBER = 0x9b,
2213+ NM_ATT_BS11_TRX_AREA = 0x9f,
2214+
2215+ NM_ATT_BS11_BCCH_RECONF = 0xd7,
2216+ NM_ATT_BS11_BIT_ERR_THESH = 0xa0,
2217+ NM_ATT_BS11_BOOT_SW_VERS = 0xa1,
2218+ NM_ATT_BS11_CCLK_ACCURACY = 0xa3,
2219+ NM_ATT_BS11_CCLK_TYPE = 0xa4,
2220+ NM_ATT_BS11_INP_IMPEDANCE = 0xaa,
2221+ NM_ATT_BS11_L1_PROT_TYPE = 0xab,
2222+ NM_ATT_BS11_LINE_CFG = 0xac,
2223+ NM_ATT_BS11_LI_PORT_1 = 0xad,
2224+ NM_ATT_BS11_LI_PORT_2 = 0xae,
2225+
2226+ NM_ATT_BS11_L1_REM_ALM_TYPE = 0xb0,
2227+ NM_ATT_BS11_SW_LOAD_INTENDED = 0xbb,
2228+ NM_ATT_BS11_SW_LOAD_SAFETY = 0xbc,
2229+ NM_ATT_BS11_SW_LOAD_STORED = 0xbd,
2230+
2231+ NM_ATT_BS11_VENDOR_NAME = 0xc1,
2232+ NM_ATT_BS11_HOPPING_MODE = 0xc5,
2233+ NM_ATT_BS11_LMT_LOGON_SESSION = 0xc6,
2234+ NM_ATT_BS11_LMT_LOGIN_TIME = 0xc7,
2235+ NM_ATT_BS11_LMT_USER_ACC_LEV = 0xc8,
2236+ NM_ATT_BS11_LMT_USER_NAME = 0xc9,
2237+
2238+ NM_ATT_BS11_L1_CONTROL_TS = 0xd8,
2239+ NM_ATT_BS11_RADIO_MEAS_GRAN = 0xdc, /* in SACCH multiframes */
2240+ NM_ATT_BS11_RADIO_MEAS_REP = 0xdd,
2241+
2242+ NM_ATT_BS11_SH_LAPD_INT_TIMER = 0xe8,
2243+
2244+ NM_ATT_BS11_BTS_STATE = 0xf0,
2245+ NM_ATT_BS11_E1_STATE = 0xf1,
2246+ NM_ATT_BS11_PLL = 0xf2,
2247+ NM_ATT_BS11_RX_OFFSET = 0xf3,
2248+ NM_ATT_BS11_ANT_TYPE = 0xf4,
2249+ NM_ATT_BS11_PLL_MODE = 0xfc,
2250+ NM_ATT_BS11_PASSWORD = 0xfd,
2251+};
Harald Welteb88b6d32010-06-19 13:52:54 +02002252+
2253+enum abis_nm_attr_ipa {
2254+ NM_ATT_IPACC_DST_IP = 0x80,
2255+ NM_ATT_IPACC_DST_IP_PORT = 0x81,
2256+ NM_ATT_IPACC_SSRC = 0x82, /* RTP Sync Source */
2257+ NM_ATT_IPACC_RTP_PAYLD_TYPE = 0x83,
2258+ NM_ATT_IPACC_BASEB_ID = 0x84,
2259+ NM_ATT_IPACC_STREAM_ID = 0x85,
2260+ NM_ATT_IPACC_NV_FLAGS = 0x86,
2261+ NM_ATT_IPACC_FREQ_CTRL = 0x87,
2262+ NM_ATT_IPACC_PRIM_OML_CFG = 0x88,
2263+ NM_ATT_IPACC_SEC_OML_CFG = 0x89,
2264+ NM_ATT_IPACC_IP_IF_CFG = 0x8a, /* IP interface */
2265+ NM_ATT_IPACC_IP_GW_CFG = 0x8b, /* IP gateway */
2266+ NM_ATT_IPACC_IN_SERV_TIME = 0x8c,
2267+ NM_ATT_IPACC_TRX_BTS_ASS = 0x8d,
2268+ NM_ATT_IPACC_LOCATION = 0x8e, /* string describing location */
2269+ NM_ATT_IPACC_PAGING_CFG = 0x8f,
2270+ NM_ATT_IPACC_FILE_DATA = 0x90,
2271+ NM_ATT_IPACC_UNIT_ID = 0x91, /* Site/BTS/TRX */
2272+ NM_ATT_IPACC_PARENT_UNIT_ID = 0x92,
2273+ NM_ATT_IPACC_UNIT_NAME = 0x93, /* default: nbts-<mac-as-string> */
2274+ NM_ATT_IPACC_SNMP_CFG = 0x94,
2275+ NM_ATT_IPACC_PRIM_OML_CFG_LIST = 0x95,
2276+ NM_ATT_IPACC_PRIM_OML_FB_TOUT = 0x96, /* fallback timeout */
2277+ NM_ATT_IPACC_CUR_SW_CFG = 0x97,
2278+ NM_ATT_IPACC_TIMING_BUS = 0x98,
2279+ NM_ATT_IPACC_CGI = 0x99, /* Cell Global ID */
2280+ NM_ATT_IPACC_RAC = 0x9a,
2281+ NM_ATT_IPACC_OBJ_VERSION = 0x9b,
2282+ NM_ATT_IPACC_GPRS_PAGING_CFG = 0x9c,
2283+ NM_ATT_IPACC_NSEI = 0x9d,
2284+ NM_ATT_IPACC_BVCI = 0x9e,
2285+ NM_ATT_IPACC_NSVCI = 0x9f,
2286+ NM_ATT_IPACC_NS_CFG = 0xa0,
2287+ NM_ATT_IPACC_BSSGP_CFG = 0xa1,
2288+ NM_ATT_IPACC_NS_LINK_CFG = 0xa2,
2289+ NM_ATT_IPACC_RLC_CFG = 0xa3,
2290+ NM_ATT_IPACC_ALM_THRESH_LIST = 0xa4,
2291+ NM_ATT_IPACC_MONIT_VAL_LIST = 0xa5,
2292+ NM_ATT_IPACC_TIB_CONTROL = 0xa6,
2293+ NM_ATT_IPACC_SUPP_FEATURES = 0xa7,
2294+ NM_ATT_IPACC_CODING_SCHEMES = 0xa8,
2295+ NM_ATT_IPACC_RLC_CFG_2 = 0xa9,
2296+ NM_ATT_IPACC_HEARTB_TOUT = 0xaa,
2297+ NM_ATT_IPACC_UPTIME = 0xab,
2298+ NM_ATT_IPACC_RLC_CFG_3 = 0xac,
2299+ NM_ATT_IPACC_SSL_CFG = 0xad,
2300+ NM_ATT_IPACC_SEC_POSSIBLE = 0xae,
2301+ NM_ATT_IPACC_IML_SSL_STATE = 0xaf,
2302+ NM_ATT_IPACC_REVOC_DATE = 0xb0,
2303+};
Harald Welte6900c162009-06-25 20:50:57 +02002304+
2305+/* Section 9.4.4: Administrative State */
2306+enum abis_nm_adm_state {
2307+ NM_STATE_LOCKED = 0x01,
2308+ NM_STATE_UNLOCKED = 0x02,
2309+ NM_STATE_SHUTDOWN = 0x03,
2310+ NM_STATE_NULL = 0xff,
2311+};
2312+
2313+/* Section 9.4.13: Channel Combination */
2314+enum abis_nm_chan_comb {
2315+ NM_CHANC_TCHFull = 0x00,
2316+ NM_CHANC_TCHHalf = 0x01,
2317+ NM_CHANC_TCHHalf2 = 0x02,
2318+ NM_CHANC_SDCCH = 0x03,
2319+ NM_CHANC_mainBCCH = 0x04,
2320+ NM_CHANC_BCCHComb = 0x05,
2321+ NM_CHANC_BCCH = 0x06,
2322+ NM_CHANC_BCCH_CBCH = 0x07,
2323+ NM_CHANC_SDCCH_CBCH = 0x08,
2324+};
2325+
2326+/* Section 9.4.16: Event Type */
2327+enum abis_nm_event_type {
2328+ NM_EVT_COMM_FAIL = 0x00,
2329+ NM_EVT_QOS_FAIL = 0x01,
2330+ NM_EVT_PROC_FAIL = 0x02,
2331+ NM_EVT_EQUIP_FAIL = 0x03,
2332+ NM_EVT_ENV_FAIL = 0x04,
2333+};
2334+
2335+/* Section: 9.4.63: Perceived Severity */
2336+enum abis_nm_severity {
2337+ NM_SEVER_CEASED = 0x00,
2338+ NM_SEVER_CRITICAL = 0x01,
2339+ NM_SEVER_MAJOR = 0x02,
2340+ NM_SEVER_MINOR = 0x03,
2341+ NM_SEVER_WARNING = 0x04,
2342+ NM_SEVER_INDETERMINATE = 0x05,
2343+};
2344+
2345+/* Section 9.4.43: Probable Cause Type */
2346+enum abis_nm_pcause_type {
2347+ NM_PCAUSE_T_X721 = 0x01,
2348+ NM_PCAUSE_T_GSM = 0x02,
2349+ NM_PCAUSE_T_MANUF = 0x03,
2350+};
2351+
2352+/* Section 9.4.36: NACK Causes */
2353+enum abis_nm_nack_cause {
2354+ /* General Nack Causes */
2355+ NM_NACK_INCORR_STRUCT = 0x01,
2356+ NM_NACK_MSGTYPE_INVAL = 0x02,
2357+ NM_NACK_OBJCLASS_INVAL = 0x05,
2358+ NM_NACK_OBJCLASS_NOTSUPP = 0x06,
2359+ NM_NACK_BTSNR_UNKN = 0x07,
2360+ NM_NACK_TRXNR_UNKN = 0x08,
2361+ NM_NACK_OBJINST_UNKN = 0x09,
2362+ NM_NACK_ATTRID_INVAL = 0x0c,
2363+ NM_NACK_ATTRID_NOTSUPP = 0x0d,
2364+ NM_NACK_PARAM_RANGE = 0x0e,
2365+ NM_NACK_ATTRLIST_INCONSISTENT = 0x0f,
2366+ NM_NACK_SPEC_IMPL_NOTSUPP = 0x10,
2367+ NM_NACK_CANT_PERFORM = 0x11,
2368+ /* Specific Nack Causes */
2369+ NM_NACK_RES_NOTIMPL = 0x19,
2370+ NM_NACK_RES_NOTAVAIL = 0x1a,
2371+ NM_NACK_FREQ_NOTAVAIL = 0x1b,
2372+ NM_NACK_TEST_NOTSUPP = 0x1c,
2373+ NM_NACK_CAPACITY_RESTR = 0x1d,
2374+ NM_NACK_PHYSCFG_NOTPERFORM = 0x1e,
2375+ NM_NACK_TEST_NOTINIT = 0x1f,
2376+ NM_NACK_PHYSCFG_NOTRESTORE = 0x20,
2377+ NM_NACK_TEST_NOSUCH = 0x21,
2378+ NM_NACK_TEST_NOSTOP = 0x22,
2379+ NM_NACK_MSGINCONSIST_PHYSCFG = 0x23,
2380+ NM_NACK_FILE_INCOMPLETE = 0x25,
2381+ NM_NACK_FILE_NOTAVAIL = 0x26,
2382+ NM_NACK_FILE_NOTACTIVATE = 0x27,
2383+ NM_NACK_REQ_NOT_GRANT = 0x28,
2384+ NM_NACK_WAIT = 0x29,
2385+ NM_NACK_NOTH_REPORT_EXIST = 0x2a,
2386+ NM_NACK_MEAS_NOTSUPP = 0x2b,
2387+ NM_NACK_MEAS_NOTSTART = 0x2c,
2388+};
2389+
2390+/* Section 9.4.1 */
2391+struct abis_nm_channel {
2392+ guint8 attrib;
2393+ guint8 bts_port;
2394+ guint8 timeslot;
2395+ guint8 subslot;
2396+} __attribute__ ((packed));
2397+
2398+/* Siemens BS-11 specific objects in the SienemsHW (0xA5) object class */
2399+enum abis_bs11_objtype {
2400+ BS11_OBJ_ALCO = 0x01,
2401+ BS11_OBJ_BBSIG = 0x02, /* obj_class: 0,1 */
2402+ BS11_OBJ_TRX1 = 0x03, /* only DEACTIVATE TRX1 */
2403+ BS11_OBJ_CCLK = 0x04,
2404+ BS11_OBJ_GPSU = 0x06,
2405+ BS11_OBJ_LI = 0x07,
2406+ BS11_OBJ_PA = 0x09, /* obj_class: 0, 1*/
2407+};
2408+
2409+enum abis_bs11_trx_power {
2410+ BS11_TRX_POWER_GSM_2W = 0x06,
2411+ BS11_TRX_POWER_GSM_250mW= 0x07,
2412+ BS11_TRX_POWER_GSM_80mW = 0x08,
2413+ BS11_TRX_POWER_GSM_30mW = 0x09,
2414+ BS11_TRX_POWER_DCS_3W = 0x0a,
2415+ BS11_TRX_POWER_DCS_1W6 = 0x0b,
2416+ BS11_TRX_POWER_DCS_500mW= 0x0c,
2417+ BS11_TRX_POWER_DCS_160mW= 0x0d,
2418+};
2419+
2420+enum abis_bs11_li_pll_mode {
2421+ BS11_LI_PLL_LOCKED = 2,
2422+ BS11_LI_PLL_STANDALONE = 3,
2423+};
2424+
2425+enum abis_bs11_phase {
2426+ BS11_STATE_SOFTWARE_RQD = 0x01,
2427+ BS11_STATE_LOAD_SMU_INTENDED = 0x11,
2428+ BS11_STATE_LOAD_SMU_SAFETY = 0x21,
2429+ BS11_STATE_LOAD_FAILED = 0x31,
2430+ BS11_STATE_LOAD_DIAGNOSTIC = 0x41,
2431+ BS11_STATE_WARM_UP = 0x51,
2432+ BS11_STATE_WARM_UP_2 = 0x52,
2433+ BS11_STATE_WAIT_MIN_CFG = 0x62,
2434+ BS11_STATE_MAINTENANCE = 0x72,
2435+ BS11_STATE_LOAD_MBCCU = 0x92,
2436+ BS11_STATE_WAIT_MIN_CFG_2 = 0xA2,
2437+ BS11_STATE_NORMAL = 0x03,
2438+ BS11_STATE_ABIS_LOAD = 0x13,
2439+};
2440+
2441+/* From openbsc/include/openbsc/tlv.h */
2442+enum tlv_type {
Holger Hans Peter Freytherbdcf45c2010-06-06 21:33:52 +08002443+ TLV_TYPE_UNKNOWN,
Harald Welte6900c162009-06-25 20:50:57 +02002444+ TLV_TYPE_FIXED,
2445+ TLV_TYPE_T,
2446+ TLV_TYPE_TV,
2447+ TLV_TYPE_TLV,
2448+ TLV_TYPE_TL16V,
Harald Welteb88b6d32010-06-19 13:52:54 +02002449+ TLV_TYPE_TLV16,
Harald Welte6900c162009-06-25 20:50:57 +02002450+};
2451+
2452+struct tlv_def {
2453+ enum tlv_type type;
2454+ u_int8_t fixed_len;
2455+};
2456+
2457+struct tlv_definition {
2458+ struct tlv_def def[0xff];
2459+};
2460+
Harald Welte1cc3fa82009-07-01 17:40:50 +02002461+enum abis_nm_ipacc_test_no {
Harald Weltec9b484f2009-07-12 20:46:43 +02002462+ NM_IPACC_TESTNO_RLOOP_ANT = 0x01,
2463+ NM_IPACC_TESTNO_RLOOP_XCVR = 0x02,
2464+ NM_IPACC_TESTNO_FUNC_OBJ = 0x03,
Harald Welte1cc3fa82009-07-01 17:40:50 +02002465+ NM_IPACC_TESTNO_CHAN_USAGE = 0x40,
2466+ NM_IPACC_TESTNO_BCCH_CHAN_USAGE = 0x41,
2467+ NM_IPACC_TESTNO_FREQ_SYNC = 0x42,
2468+ NM_IPACC_TESTNO_BCCH_INFO = 0x43,
2469+ NM_IPACC_TESTNO_TX_BEACON = 0x44,
Harald Weltec9b484f2009-07-12 20:46:43 +02002470+ NM_IPACC_TESTNO_SYSINFO_MONITOR = 0x45,
2471+ NM_IPACC_TESTNO_BCCCH_MONITOR = 0x46,
Harald Welte1cc3fa82009-07-01 17:40:50 +02002472+};
2473+
2474+/* first byte after length inside NM_ATT_TEST_REPORT */
2475+enum abis_nm_ipacc_test_res {
2476+ NM_IPACC_TESTRES_SUCCESS = 0,
2477+ NM_IPACC_TESTRES_TIMEOUT = 1,
2478+ NM_IPACC_TESTRES_NO_CHANS = 2,
2479+ NM_IPACC_TESTRES_PARTIAL = 3,
2480+ NM_IPACC_TESTRES_STOPPED = 4,
2481+};
2482+
2483+/* internal IE inside NM_ATT_TEST_REPORT */
2484+enum abis_nm_ipacc_testres_ie {
2485+ NM_IPACC_TR_IE_FREQ_ERR_LIST = 3,
2486+ NM_IPACC_TR_IE_CHAN_USAGE = 4,
2487+ NM_IPACC_TR_IE_BCCH_INFO = 6,
2488+ NM_IPACC_TR_IE_RESULT_DETAILS = 8,
2489+ NM_IPACC_TR_IE_FREQ_ERR = 18,
2490+};
Harald Welte6900c162009-06-25 20:50:57 +02002491+
Harald Welte6900c162009-06-25 20:50:57 +02002492+#endif /* _NM_H */