blob: e54868c4380e1e2988fe530a8ba3441cdc6b5693 [file] [log] [blame]
Harald Welte6900c162009-06-25 20:50:57 +02001Index: wireshark/epan/dissectors/Makefile.common
2===================================================================
Harald Welte1cc3fa82009-07-01 17:40:50 +02003--- wireshark.orig/epan/dissectors/Makefile.common 2009-06-25 15:04:16.000000000 +0200
4+++ wireshark/epan/dissectors/Makefile.common 2009-06-29 13:30:06.000000000 +0200
Harald Welte6900c162009-06-25 20:50:57 +02005@@ -874,6 +874,7 @@
6 #
7 DIRTY_DISSECTOR_SRC = \
8 packet-abis_ip.c \
9+ packet-abis_oml.c \
10 packet-k12.c \
11 packet-nbd.c \
12 packet-sccp.c \
13Index: wireshark/epan/dissectors/packet-abis_oml.c
14===================================================================
15--- /dev/null 1970-01-01 00:00:00.000000000 +0000
Harald Welte1cc3fa82009-07-01 17:40:50 +020016+++ wireshark/epan/dissectors/packet-abis_oml.c 2009-07-01 17:39:35.000000000 +0200
17@@ -0,0 +1,1115 @@
Harald Welte6900c162009-06-25 20:50:57 +020018+/* packet-abis_oml.c
19+ * Routines for packet dissection of GSM A-bis over IP (3GPP TS 12.21)
20+ * Copyright 2009 by Harald Welte <laforge@gnumonks.org>
21+ * based on A-bis OML code in OpenBSC
22+ *
23+ * $Id$
24+ *
25+ * Wireshark - Network traffic analyzer
26+ * By Gerald Combs <gerald@wireshark.org>
27+ * Copyright 1998 Gerald Combs
28+ *
29+ * This program is free software; you can redistribute it and/or
30+ * modify it under the terms of the GNU General Public License
31+ * as published by the Free Software Foundation; either version 2
32+ * of the License, or (at your option) any later version.
33+ *
34+ * This program is distributed in the hope that it will be useful,
35+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
36+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
37+ * GNU General Public License for more details.
38+ *
39+ * You should have received a copy of the GNU General Public License
40+ * along with this program; if not, write to the Free Software
41+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
42+ */
43+
44+#ifdef HAVE_CONFIG_H
45+# include "config.h"
46+#endif
47+
48+#include <glib.h>
49+
50+#include <epan/packet.h>
51+#include <epan/emem.h>
52+
53+#include "packet-abis_oml.h"
Harald Welte1cc3fa82009-07-01 17:40:50 +020054+#include "packet-gsm_a_common.h"
Harald Welte6900c162009-06-25 20:50:57 +020055+
56+/* initialize the protocol and registered fields */
57+static int proto_abis_oml = -1;
58+
59+/* OML header */
60+static int hf_oml_msg_disc = -1;
61+static int hf_oml_placement = -1;
62+static int hf_oml_sequence = -1;
63+static int hf_oml_length = -1;
64+/* FOM header */
65+static int hf_oml_fom_msgtype = -1;
66+static int hf_oml_fom_objclass = -1;
67+static int hf_oml_fom_inst_bts = -1;
68+static int hf_oml_fom_inst_trx = -1;
69+static int hf_oml_fom_inst_ts = -1;
70+static int hf_oml_fom_attr_tag = -1;
71+static int hf_oml_fom_attr_len = -1;
72+static int hf_oml_fom_attr_val = -1;
73+/* FOM attributes */
74+static int hf_attr_adm_state = -1;
75+static int hf_attr_oper_state = -1;
76+static int hf_attr_avail_state = -1;
77+static int hf_attr_event_type = -1;
78+static int hf_attr_severity = -1;
Harald Welte1cc3fa82009-07-01 17:40:50 +020079+static int hf_attr_bcch_arfcn = -1;
80+static int hf_attr_bsic = -1;
81+static int hf_attr_test_no = -1;
82+static int hf_attr_tsc = -1;
83+static int hf_attr_tei = -1;
84+static int hf_attr_ach_btsp = -1;
85+static int hf_attr_ach_tslot = -1;
86+static int hf_attr_ach_sslot = -1;
87+static int hf_attr_gsm_time = -1;
88+static int hf_attr_chan_comb = -1;
89+/* Ipaccess */
90+static int hf_oml_ipa_tres_attr_tag = -1;
91+static int hf_oml_ipa_tres_attr_len = -1;
92+static int hf_attr_ipa_test_res = -1;
93+static int hf_attr_ipa_tr_rxlev = -1;
94+static int hf_attr_ipa_tr_arfcn = -1;
95+static int hf_attr_ipa_tr_f_qual = -1;
96+static int hf_attr_ipa_tr_f_err = -1;
97+static int hf_attr_ipa_tr_rxqual = -1;
98+static int hf_attr_ipa_tr_frame_offs = -1;
99+static int hf_attr_ipa_tr_framenr_offs = -1;
100+static int hf_attr_ipa_tr_bsic = -1;
101+static int hf_attr_ipa_tr_cell_id = -1;
102+static int hf_attr_ipa_rsl_ip = -1;
103+static int hf_attr_ipa_rsl_port = -1;
Harald Welte6900c162009-06-25 20:50:57 +0200104+
105+/* initialize the subtree pointers */
106+static int ett_oml = -1;
107+static int ett_oml_fom = -1;
108+static int ett_oml_fom_att = -1;
109+
110+static proto_tree *top_tree;
111+
112+/* TS 12.21 Chapter 8.1 / TS 08.59 */
113+static const value_string oml_msg_disc_vals[] = {
114+ { ABIS_OM_MDISC_FOM, "Formatted O&M" },
115+ { ABIS_OM_MDISC_MMI, "MMI Transfer" },
116+ { ABIS_OM_MDISC_TRAU, "TRAU O&M" },
117+ { ABIS_OM_MDISC_MANUF, "Manufacturer specific" },
118+};
119+
120+/* TS 12.21 Chapter 8.1.1 */
121+static const value_string oml_placement_vals[] = {
122+ { ABIS_OM_PLACEMENT_ONLY, "Only" },
123+ { ABIS_OM_PLACEMENT_FIRST, "First" },
124+ { ABIS_OM_PLACEMENT_MIDDLE, "Middle" },
125+ { ABIS_OM_PLACEMENT_LAST, "Last" },
126+};
127+
128+/* TS 12.21 Chapter 9.2 */
129+static const value_string oml_fom_msgtype_vals[] = {
130+ { NM_MT_LOAD_INIT, "Software Load Init" },
131+ { NM_MT_LOAD_INIT_ACK, "Software Load Init ACK" },
132+ { NM_MT_LOAD_INIT_NACK, "Software Load Init NACK" },
133+ { NM_MT_LOAD_SEG, "Software Load Segment" },
134+ { NM_MT_LOAD_SEG_ACK, "Software Load Segment ACK" },
135+ { NM_MT_LOAD_END, "Software Load End" },
136+ { NM_MT_LOAD_END_ACK, "Software Load End ACK" },
137+ { NM_MT_LOAD_END_NACK, "Software Load End NACK" },
138+ { NM_MT_SW_ACT_REQ, "Software Activate Request" },
139+ { NM_MT_SW_ACT_REQ_ACK, "Software Activate Request ACK" },
140+ { NM_MT_SW_ACT_REQ_NACK, "Software Activate Request NACK" },
141+ { NM_MT_ACTIVATE_SW, "Activate Software" },
142+ { NM_MT_ACTIVATE_SW_ACK, "Activate Software ACK" },
143+ { NM_MT_ACTIVATE_SW_NACK, "Activate Software NACK" },
144+ { NM_MT_SW_ACTIVATED_REP, "Software Activated Report" },
145+ { NM_MT_ESTABLISH_TEI, "Establish TEI" },
146+ { NM_MT_ESTABLISH_TEI_ACK, "Establish TEI ACK" },
147+ { NM_MT_ESTABLISH_TEI_NACK, "Establish TEI NACK" },
148+ { NM_MT_CONN_TERR_SIGN, "Connect Terrestrial Signalling" },
149+ { NM_MT_CONN_TERR_SIGN_ACK, "Connect Terrestrial Signalling ACK" },
150+ { NM_MT_CONN_TERR_SIGN_NACK, "Connect Terrestrial Signalling NACK" },
151+ { NM_MT_DISC_TERR_SIGN, "Disconnect Terrestrial Signalling" },
152+ { NM_MT_DISC_TERR_SIGN_ACK, "Disconnect Terrestrial Signalling ACK" },
153+ { NM_MT_DISC_TERR_SIGN_NACK, "Disconnect Terrestrial Signalling NACK" },
154+ { NM_MT_CONN_TERR_TRAF, "Connect Terrestrial Traffic" },
155+ { NM_MT_CONN_TERR_TRAF_ACK, "Connect Terrestrial Traffic ACK" },
156+ { NM_MT_CONN_TERR_TRAF_NACK, "Connect Terrestrial Traffic NACK" },
157+ { NM_MT_DISC_TERR_TRAF, "Disconnect Terrestrial Traffic" },
158+ { NM_MT_DISC_TERR_TRAF_ACK, "Disconnect Terrestrial Traffic ACK" },
159+ { NM_MT_DISC_TERR_TRAF_NACK, "Disconnect Terrestrial Traffic NACK" },
160+ { NM_MT_CONN_MDROP_LINK, "Connect Multi-Drop Link" },
161+ { NM_MT_CONN_MDROP_LINK_ACK, "Connect Multi-Drop Link ACK" },
162+ { NM_MT_CONN_MDROP_LINK_NACK, "Connect Multi-Drop Link NACK" },
163+ { NM_MT_DISC_MDROP_LINK, "Disconnect Multi-Drop Link" },
164+ { NM_MT_DISC_MDROP_LINK_ACK, "Disconnect Multi-Drop Link ACK" },
165+ { NM_MT_DISC_MDROP_LINK_NACK, "Disconnect Multi-Drop Link NACK" },
166+ { NM_MT_SET_BTS_ATTR, "Set BTS Attributes" },
167+ { NM_MT_SET_BTS_ATTR_ACK, "Set BTS Attributes ACK" },
168+ { NM_MT_SET_BTS_ATTR_NACK, "Set BTS Attributes NACK" },
169+ { NM_MT_SET_RADIO_ATTR, "Set Radio Carrier Attributes" },
170+ { NM_MT_SET_RADIO_ATTR_ACK, "Set Radio Carrier Attributes ACK" },
171+ { NM_MT_SET_RADIO_ATTR_NACK, "Set Radio Carrier Attributes NACK" },
172+ { NM_MT_SET_CHAN_ATTR, "Set Channel Attributes" },
173+ { NM_MT_SET_CHAN_ATTR_ACK, "Set Channel Attributes ACK" },
174+ { NM_MT_SET_CHAN_ATTR_NACK, "Set Channel Attributes NACK" },
175+ { NM_MT_PERF_TEST, "Perform Test" },
176+ { NM_MT_PERF_TEST_ACK, "Perform Test ACK" },
177+ { NM_MT_PERF_TEST_NACK, "Perform Test NACK" },
178+ { NM_MT_TEST_REP, "Test Report" },
179+ { NM_MT_SEND_TEST_REP, "Send Test Report" },
180+ { NM_MT_SEND_TEST_REP_ACK, "Send Test Report ACK" },
181+ { NM_MT_SEND_TEST_REP_NACK, "Send Test Report NACK" },
182+ { NM_MT_STOP_TEST, "Stop Test" },
183+ { NM_MT_STOP_TEST_ACK, "Stop Test ACK" },
184+ { NM_MT_STOP_TEST_NACK, "Stop Test NACK" },
185+ { NM_MT_STATECHG_EVENT_REP, "State Changed Event Report" },
186+ { NM_MT_FAILURE_EVENT_REP, "Failure Event Report" },
187+ { NM_MT_STOP_EVENT_REP, "Stop Sending Event Reports" },
188+ { NM_MT_STOP_EVENT_REP_ACK, "Stop Sending Event Reports ACK" },
189+ { NM_MT_STOP_EVENT_REP_NACK, "Stop Sending Event Reports NACK" },
190+ { NM_MT_REST_EVENT_REP, "Restart Sending Event Reports" },
191+ { NM_MT_REST_EVENT_REP_ACK, "Restart Sending Event Reports ACK" },
192+ { NM_MT_REST_EVENT_REP_NACK, "Restart Sending Event Reports NACK" },
193+ { NM_MT_CHG_ADM_STATE, "Change Administrative State" },
194+ { NM_MT_CHG_ADM_STATE_ACK, "Change Administrative State ACK" },
195+ { NM_MT_CHG_ADM_STATE_NACK, "Change Administrative State NACK" },
196+ { NM_MT_CHG_ADM_STATE_REQ, "Change Administrative State Request" },
197+ { NM_MT_CHG_ADM_STATE_REQ_ACK, "Change Administrative State Request ACK" },
198+ { NM_MT_CHG_ADM_STATE_REQ_NACK, "Change Administrative State Request NACK" },
199+ { NM_MT_REP_OUTST_ALARMS, "Report Outstanding Alarms" },
200+ { NM_MT_REP_OUTST_ALARMS_ACK, "Report Outstanding Alarms ACK" },
201+ { NM_MT_REP_OUTST_ALARMS_NACK, "Report Outstanding Alarms NACK" },
202+ { NM_MT_CHANGEOVER, "Changeover" },
203+ { NM_MT_CHANGEOVER_ACK, "Changeover ACK" },
204+ { NM_MT_CHANGEOVER_NACK, "Changeover NACK" },
205+ { NM_MT_OPSTART, "Opstart" },
206+ { NM_MT_OPSTART_ACK, "Opstart ACK" },
207+ { NM_MT_OPSTART_NACK, "Opstart NACK" },
208+ { NM_MT_REINIT, "Reinitialize" },
209+ { NM_MT_REINIT_ACK, "Reinitialize ACK" },
210+ { NM_MT_REINIT_NACK, "Reinitialize NACK" },
211+ { NM_MT_SET_SITE_OUT, "Set Site Outputs" },
212+ { NM_MT_SET_SITE_OUT_ACK, "Set Site Outputs ACK" },
213+ { NM_MT_SET_SITE_OUT_NACK, "Set Site Outputs NACK" },
214+ { NM_MT_CHG_HW_CONF, "Change HW Configuration" },
215+ { NM_MT_CHG_HW_CONF_ACK, "Change HW Configuration ACK" },
216+ { NM_MT_CHG_HW_CONF_NACK, "Change HW Configuration NACK" },
217+ { NM_MT_MEAS_RES_REQ, "Measurement Result Request" },
218+ { NM_MT_MEAS_RES_RESP, "Measurement Result Response" },
219+ { NM_MT_STOP_MEAS, "Stop Measurement" },
220+ { NM_MT_START_MEAS, "Start Measurement" },
221+ { NM_MT_GET_ATTR, "Get Attributes" },
222+ { NM_MT_GET_ATTR_RESP, "Get Attributes Response" },
223+ { NM_MT_GET_ATTR_NACK, "Get Attributes NACK" },
224+ { NM_MT_SET_ALARM_THRES, "Set Alarm Threshold" },
225+ { NM_MT_SET_ALARM_THRES_ACK, "Set Alarm Threshold ACK" },
226+ { NM_MT_SET_ALARM_THRES_NACK, "Set Alarm Threshold NACK" },
227+ /* proprietary, not in the standard */
228+ { NM_MT_IPACC_RESTART, "IPA Restart" },
229+ { NM_MT_IPACC_RESTART_ACK, "IPA Restart ACK" },
230+ { NM_MT_IPACC_RSL_CONNECT, "IPA RSL Connect" },
231+ { NM_MT_IPACC_RSL_CONNECT_ACK, "IPA RSL Connect ACK" },
232+ { NM_MT_IPACC_RSL_CONNECT_NACK, "IPA RSL Connect NACK" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200233+ { NM_MT_IPACC_RSL_DISCONNECT, "IPA RSL Disconnect" },
234+ { NM_MT_IPACC_RSL_DISCONNECT_ACK, "IPA RSL Disconnect ACK" },
235+ { NM_MT_IPACC_RSL_DISCONNECT_NACK, "IPA RSL Disconnect NACK" },
236+ { NM_MT_IPACC_CONN_TRAF, "IPA Connect Traffic" },
237+ { NM_MT_IPACC_CONN_TRAF_ACK, "IPA Connect Traffic ACK" },
238+ { NM_MT_IPACC_CONN_TRAF_NACK, "IPA Connect Traffic NACK" },
239+ { NM_MT_IPACC_DEF_BOOT_SW, "IPA Default Boot Software" },
240+ { NM_MT_IPACC_DEF_BOOT_SW_ACK, "IPA Default Boot Software ACK" },
241+ { NM_MT_IPACC_DEF_BOOT_SW_NACK, "IPA Default Boot Software NACK" },
Harald Welte6900c162009-06-25 20:50:57 +0200242+ { NM_MT_IPACC_SET_NVATTR, "IPA Set NVRAM Attributes" },
243+ { NM_MT_IPACC_SET_NVATTR_ACK, "IPA Set NVRAM Attributes ACK" },
244+ { NM_MT_IPACC_SET_NVATTR_NACK, "IPA Set NVRAM Attributes NACK" },
245+ { NM_MT_IPACC_GET_NVATTR, "IPA Get NVRAM Attributes" },
246+ { NM_MT_IPACC_GET_NVATTR_ACK, "IPA Get NVRAM Attributes ACK" },
247+ { NM_MT_IPACC_GET_NVATTR_NACK, "IPA Get NVRAM Attributes NACK" },
248+ { NM_MT_BS11_RESET_RESOURCE, "SIE Reset Resource" },
249+ { NM_MT_BS11_BEGIN_DB_TX, "SIE Begin Database Transmission" },
250+ { NM_MT_BS11_BEGIN_DB_TX_ACK, "SIE Begin Database Transmission ACK" },
251+ { NM_MT_BS11_BEGIN_DB_TX_NACK, "SIE Begin Database Transmission NACK" },
252+ { NM_MT_BS11_END_DB_TX, "SIE End Database Transmission" },
253+ { NM_MT_BS11_END_DB_TX_ACK, "SIE End Database Transmission ACK" },
254+ { NM_MT_BS11_END_DB_TX_NACK, "SIE End Database Transmission NACK" },
255+ { NM_MT_BS11_CREATE_OBJ, "SIE Create Object" },
256+ { NM_MT_BS11_CREATE_OBJ_ACK, "SIE Create Object ACK" },
257+ { NM_MT_BS11_CREATE_OBJ_NACK, "SIE Create Object NACK" },
258+ { NM_MT_BS11_DELETE_OBJ, "SIE Delete Object" },
259+ { NM_MT_BS11_DELETE_OBJ_ACK, "SIE Delete Object ACK" },
260+ { NM_MT_BS11_DELETE_OBJ_NACK, "SIE Delete Object NACK" },
261+ { NM_MT_BS11_GET_STATE, "SIE Get State" },
262+ { NM_MT_BS11_GET_STATE_ACK, "SIE Get State ACK" },
263+ { NM_MT_BS11_LMT_LOGON, "SIE LMT Logon" },
264+ { NM_MT_BS11_LMT_LOGON_ACK, "SIE LMT Logon ACK" },
265+ { NM_MT_BS11_RESTART, "SIE Restart" },
266+ { NM_MT_BS11_RESTART_ACK, "SIE Restart ACK" },
267+ { NM_MT_BS11_DISCONNECT, "SIE Disconnect BTS" },
268+ { NM_MT_BS11_DISCONNECT_ACK, "SIE Disconnect BTS ACK" },
269+ { NM_MT_BS11_LMT_LOGOFF, "SIE LMT Logoff" },
270+ { NM_MT_BS11_LMT_LOGOFF_ACK, "SIE LMT Logoff ACK" },
271+ { NM_MT_BS11_RECONNECT, "SIE Reconnect BTS" },
272+ { NM_MT_BS11_RECONNECT_ACK, "SIE Reconnect BTS ACK" },
273+};
274+
275+/* TS 12.21 Section 9.2: Object Class */
276+static const value_string oml_fom_objclass_vals[] = {
277+ { NM_OC_SITE_MANAGER, "BTS Site Manager" },
278+ { NM_OC_BTS, "BTS" },
279+ { NM_OC_RADIO_CARRIER, "Radio Carrier" },
280+ { NM_OC_CHANNEL, "Radio Channel" },
281+ { NM_OC_BASEB_TRANSC, "Baseband Transceiver" },
282+ /* proprietary, vendor specific */
283+ { NM_OC_BS11_ADJC, "SIE Adjacend Channel" },
284+ { NM_OC_BS11_HANDOVER, "SIE Handover" },
285+ { NM_OC_BS11_PWR_CTRL, "SIE Power Control" },
286+ { NM_OC_BS11_BTSE, "SIE BTSE" },
287+ { NM_OC_BS11_RACK, "SIE Rack" },
288+ { NM_OC_BS11, "SIE SiemensHW" },
289+ { NM_OC_BS11_TEST, "SIE Test" },
290+ { NM_OC_BS11_ENVABTSE, "SIE EnvaBTSE" },
291+ { NM_OC_BS11_BPORT, "SIE BPort" },
292+ { NM_OC_GPRS_NSE, "GPRS NSE" },
293+ { NM_OC_GPRS_CELL, "GPRS Cell" },
294+ { NM_OC_GPRS_NSVC0, "GPRS NSVC0" },
295+ { NM_OC_GPRS_NSVC1, "GPRS NSVC1" },
296+ { NM_OC_NULL, "NULL" },
297+};
298+
299+/* TS 12.21 Section 9.4: Attributes */
300+static const value_string oml_fom_attr_vals[] = {
301+ { NM_ATT_ABIS_CHANNEL, "A-bis Channel" },
302+ { NM_ATT_ADD_INFO, "Additional Information" },
303+ { NM_ATT_ADD_TEXT, "Additional Text" },
304+ { NM_ATT_ADM_STATE, "Administrative State" },
305+ { NM_ATT_ARFCN_LIST, "ARFCN List" },
306+ { NM_ATT_AUTON_REPORT, "Autonomously Report" },
307+ { NM_ATT_AVAIL_STATUS, "Availability Status" },
308+ { NM_ATT_BCCH_ARFCN, "BCCH ARFCN" },
309+ { NM_ATT_BSIC, "BSIC" },
310+ { NM_ATT_BTS_AIR_TIMER, "BTS Air Timer" },
311+ { NM_ATT_CCCH_L_I_P, "CCCH Load Indication Period" },
312+ { NM_ATT_CCCH_L_T, "CCCH Load Threshold" },
313+ { NM_ATT_CHAN_COMB, "Channel Combination" },
314+ { NM_ATT_CONN_FAIL_CRIT, "Connection Fail Criterion" },
315+ { NM_ATT_DEST, "Destination" },
316+ { NM_ATT_EVENT_TYPE, "Event Type" },
317+ { NM_ATT_FILE_ID, "File ID" },
318+ { NM_ATT_FILE_VERSION, "File Version" },
319+ { NM_ATT_GSM_TIME, "GSM Time" },
320+ { NM_ATT_HSN, "HSN" },
321+ { NM_ATT_HW_CONFIG, "HW Configuration" },
322+ { NM_ATT_HW_DESC, "HW Description" },
323+ { NM_ATT_INTAVE_PARAM, "Intave Parameter" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200324+ { NM_ATT_INTERF_BOUND, "Interference Boundaries" },
Harald Welte6900c162009-06-25 20:50:57 +0200325+ { NM_ATT_LIST_REQ_ATTR, "List of required Attributes" },
326+ { NM_ATT_MAIO, "MAIO" },
327+ { NM_ATT_MANUF_STATE, "Manufacturer Dependent State" },
328+ { NM_ATT_MANUF_THRESH, "Manufacturer Dependent Thresholds" },
329+ { NM_ATT_MANUF_ID, "Manufacturer Id" },
330+ { NM_ATT_MAX_TA, "Maximum Timing Advance" },
331+ { NM_ATT_MDROP_LINK, "Multi-drop BSC Link" },
332+ { NM_ATT_MDROP_NEXT, "Multi-drop next BTS Link" },
333+ { NM_ATT_NACK_CAUSES, "NACK Causes" },
334+ { NM_ATT_NY1, "Ny1" },
335+ { NM_ATT_OPER_STATE, "Operational State" },
336+ { NM_ATT_OVERL_PERIOD, "Overload Period" },
337+ { NM_ATT_PHYS_CONF, "Physical Config" },
338+ { NM_ATT_POWER_CLASS, "Power Class" },
339+ { NM_ATT_POWER_THRESH, "Power Output Thresholds" },
340+ { NM_ATT_PROB_CAUSE, "Probable Cause" },
341+ { NM_ATT_RACH_B_THRESH, "RACH Busy Threshold" },
342+ { NM_ATT_LDAVG_SLOTS, "RACH Load Averaging Slots" },
343+ { NM_ATT_RAD_SUBC, "Radio Sub Channel" },
344+ { NM_ATT_RF_MAXPOWR_R, "RF Max Power Reduction" },
345+ { NM_ATT_SITE_INPUTS, "Site Inputs" },
346+ { NM_ATT_SITE_OUTPUTS, "Site Outputs" },
347+ { NM_ATT_SOURCE, "Source" },
348+ { NM_ATT_SPEC_PROB, "Specific Problems" },
349+ { NM_ATT_START_TIME, "Starting Time" },
350+ { NM_ATT_T200, "T200" },
351+ { NM_ATT_TEI, "TEI" },
352+ { NM_ATT_TEST_DUR, "Test Duration" },
353+ { NM_ATT_TEST_NO, "Test No" },
354+ { NM_ATT_TEST_REPORT, "Test Report Info" },
355+ { NM_ATT_VSWR_THRESH, "VSWR Thresholds " },
356+ { NM_ATT_WINDOW_SIZE, "Window Size" },
357+ { NM_ATT_BS11_RSSI_OFFS, "SIE RSSI Offset" },
358+ { NM_ATT_BS11_TXPWR, "SIE TX Power" },
359+ { NM_ATT_BS11_DIVERSITY, "SIE Diversity" },
360+ { NM_ATT_TSC, "Training Sequence Code" },
361+ { NM_ATT_SW_CONFIG, "SW Configuration" },
362+ { NM_ATT_SW_DESCR, "SW Description" },
363+ { NM_ATT_SEVERITY, "Perceived Severity" },
364+ { NM_ATT_GET_ARI, "Get ARI" },
365+ { NM_ATT_HW_CONF_CHG, "HW Configuration Change" },
366+ { NM_ATT_OUTST_ALARM, "Outstanding Alarm" },
367+ { NM_ATT_FILE_DATA, "File Data" },
368+ { NM_ATT_MEAS_RES, "Measurement Result" },
369+ { NM_ATT_MEAS_TYPE, "Measurement Type" },
370+ { NM_ATT_BS11_ESN_FW_CODE_NO, "SIE ESN FW Code Number" },
371+ { NM_ATT_BS11_ESN_HW_CODE_NO, "SIE ESN HW Code Number" },
372+ { NM_ATT_BS11_ESN_PCB_SERIAL, "SIE ESN PCB Serial Number" },
373+ { NM_ATT_BS11_EXCESSIVE_DISTANCE, "SIE Excessive Distance" },
374+ { NM_ATT_BS11_ALL_TEST_CATG, "SIE All Test Categories" },
375+ { NM_ATT_BS11_BTSLS_HOPPING, "SIE BTS LS Hopping" },
376+ { NM_ATT_BS11_CELL_ALLOC_NR, "SIE Cell Allocation Number" },
377+ { NM_ATT_BS11_CELL_GLOBAL_ID, "SIE Cell Global ID" },
378+ { NM_ATT_BS11_ENA_INTERF_CLASS, "SIE Enable Interference Class" },
379+ /* FIXME */
380+ { NM_ATT_BS11_ENA_MS_PWR_CTRL, "SIE Enable MS Power Control" },
381+ { NM_ATT_BS11_ENA_PWR_BDGT_HO, "SIE Enable Power Budget HO" },
382+ { NM_ATT_BS11_ENA_RXLEV_HO, "SIE Enable RxLevel HO" },
383+ { NM_ATT_BS11_ENA_RXQUAL_HO, "SIE Enable RxQual HO" },
384+ { NM_ATT_BS11_FACCH_QUAL, "SIE FACCH Quality" },
385+ { NM_ATT_IPACC_RSL_BSC_IP, "IPA BSC RSL IP Address" },
386+ { NM_ATT_IPACC_RSL_BSC_PORT, "IPA BSC RSL TCP Port" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200387+ { NM_ATT_IPACC_NV_FLAGS, "IPA NVRAM Flags" },
388+ { NM_ATT_IPACC_FREQ_CTRL, "IPA Frequency Control" },
389+ { NM_ATT_IPACC_IP_IF_CFG, "IPA IP Interface Config" },
390+ { NM_ATT_IPACC_IP_GW_CFG, "IPA IP Gateway Config" },
391+ { NM_ATT_IPACC_IN_SERV_TIME, "IPA In Service Time" },
Harald Welte6900c162009-06-25 20:50:57 +0200392+ { NM_ATT_IPACC_LOCATION, "IPA Location Name" },
393+ { NM_ATT_IPACC_UNIT_ID, "IPA Unit ID" },
394+ { NM_ATT_IPACC_UNIT_NAME, "IPA Unit Name" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200395+ { NM_ATT_IPACC_SNMP_CFG, "IPA SNMP Config" },
Harald Welte6900c162009-06-25 20:50:57 +0200396+ { NM_ATT_IPACC_PRIM_OML_IP, "IPA Primary OML IP Address" },
397+ { NM_ATT_IPACC_SEC_OML_IP, "IPA Secondary OML IP Address" },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200398+ { NM_ATT_IPACC_CUR_SW_CFG, "IPA Current Software Config" },
399+ { NM_ATT_IPACC_ALM_THRESH_LIST, "IPA Alarm Threshold List" },
400+ { NM_ATT_IPACC_UPTIME, "IPA Uptime" },
401+ { NM_ATT_IPACC_SSL_CFG, "IPA SSL Configuration" },
402+ { NM_ATT_IPACC_SEC_POSSIBLE, "IPA Security Possoble" },
403+ { NM_ATT_IPACC_REVOC_DATE, "IPA Revocation Date" },
Harald Welte6900c162009-06-25 20:50:57 +0200404+ /* FIXME: More SIE */
405+};
406+
407+/* Section 9.4.4: Administrative State */
408+static const value_string oml_adm_state_vals[] = {
409+ { NM_STATE_LOCKED, "Locked" },
410+ { NM_STATE_UNLOCKED, "Unlocked" },
411+ { NM_STATE_SHUTDOWN, "Shutdown" },
412+ { NM_STATE_NULL, "Null" },
413+};
414+
415+static const value_string oml_oper_state_vals[] = {
416+ { 1, "Disabled" },
417+ { 2, "Enabled" },
418+ { 0xff, "NULL" },
419+};
420+
421+/* Section 9.4.7 Availability Status */
422+static const value_string oml_avail_state_vals[] = {
423+ { 0, "In test" },
424+ { 1, "Failed" },
425+ { 2, "Power off" },
426+ { 3, "Off line" },
427+ { 5, "Dependency" },
428+ { 6, "Degraded" },
429+ { 7, "Not installed" },
430+ { 0xff, "OK" },
431+};
432+
433+/* Section 9.4.13: Channel Combination */
434+static const value_string oml_chan_comb_vals[] = {
435+ { NM_CHANC_TCHFull, "TCH/F" },
436+ { NM_CHANC_TCHHalf, "TCH/H" },
437+ { NM_CHANC_TCHHalf2, "TCH/H 2" },
438+ { NM_CHANC_SDCCH, "SDCCH" },
439+ { NM_CHANC_mainBCCH, "Main BCCH" },
440+ { NM_CHANC_BCCHComb, "Combined BCCH" },
441+ { NM_CHANC_BCCH, "BCCH" },
442+ { NM_CHANC_BCCH_CBCH, "BCCH+CBCH" },
443+ { NM_CHANC_SDCCH_CBCH, "SDCCH+CBCH" },
444+};
445+
446+/* Section 9.4.16: Event Type */
447+static const value_string oml_event_type_vals[] = {
448+ { NM_EVT_COMM_FAIL, "Communication Failure" },
449+ { NM_EVT_QOS_FAIL, "QoS Failure" },
450+ { NM_EVT_PROC_FAIL, "Processor Failure" },
451+ { NM_EVT_EQUIP_FAIL, "Equipment Failure" },
452+ { NM_EVT_ENV_FAIL, "Environment Failure" },
453+};
454+
455+/* Section 9.4.63: Perceived Severity */
456+static const value_string oml_severity_vals[] = {
457+ { NM_SEVER_CEASED, "Ceased" },
458+ { NM_SEVER_CRITICAL, "Critical" },
459+ { NM_SEVER_MAJOR, "Major" },
460+ { NM_SEVER_MINOR, "Minor" },
461+ { NM_SEVER_WARNING, "Warning" },
462+ { NM_SEVER_INDETERMINATE, "Indeterminate" },
463+};
464+
465+/* Section 9.4.36: NACK Causes */
466+static const value_string oml_nack_cause[] = {
467+ { NM_NACK_INCORR_STRUCT, "Incorrect message structure" },
468+ { NM_NACK_MSGTYPE_INVAL, "Invalid message type value" },
469+ { NM_NACK_OBJCLASS_INVAL, "Invalid Object class value" },
470+ { NM_NACK_OBJCLASS_NOTSUPP, "Object Class not supported" },
471+ { NM_NACK_BTSNR_UNKN, "BTS Number unknown" },
472+ { NM_NACK_TRXNR_UNKN, "TRX Number unknown" },
473+ { NM_NACK_OBJINST_UNKN, "Object Instance unknown" },
474+ { NM_NACK_ATTRID_INVAL, "Invalid Attribute ID value" },
475+ { NM_NACK_ATTRID_NOTSUPP, "Attribute ID not supported" },
476+ { NM_NACK_PARAM_RANGE, "Parameter value out of range" },
477+ { NM_NACK_ATTRLIST_INCONSISTENT, "Inconsistency in Attribute list" },
478+ { NM_NACK_SPEC_IMPL_NOTSUPP, "Specified Implementation not supported" },
479+ { NM_NACK_CANT_PERFORM, "Message cannot be performed" },
480+ { NM_NACK_RES_NOTIMPL, "Resource not implemented" },
481+ { NM_NACK_RES_NOTAVAIL, "Resource not available" },
482+ { NM_NACK_FREQ_NOTAVAIL, "Frequency not available" },
483+ { NM_NACK_TEST_NOTSUPP, "Test not supported" },
484+ { NM_NACK_CAPACITY_RESTR, "Capacity restrictions" },
485+ { NM_NACK_PHYSCFG_NOTPERFORM, "Phys config cannot be performed" },
486+ { NM_NACK_TEST_NOTINIT, "Test not initiated" },
487+ { NM_NACK_PHYSCFG_NOTRESTORE, "Phys config cannot be restored" },
488+ { NM_NACK_TEST_NOSUCH, "No such Test" },
489+ { NM_NACK_TEST_NOSTOP, "Test cannot be stopped" },
490+ { NM_NACK_MSGINCONSIST_PHYSCFG, "Message inconsisten with physical config" },
491+ { NM_NACK_FILE_INCOMPLETE, "Complete file not received" },
492+ { NM_NACK_FILE_NOTAVAIL, "File not available at destination" },
493+ { NM_NACK_FILE_NOTACTIVATE, "File cannot be activated" },
494+ { NM_NACK_REQ_NOT_GRANT, "Request not granted" },
495+ { NM_NACK_WAIT, "Wait" },
496+ { NM_NACK_NOTH_REPORT_EXIST, "Nothing reportable existing" },
497+ { NM_NACK_MEAS_NOTSUPP, "Measurement not supported" },
498+ { NM_NACK_MEAS_NOTSTART, "Measurement not started" },
499+ { 0xff, "NULL" },
500+};
501+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200502+static const value_string oml_test_no_vals[] = {
503+ { NM_IPACC_TESTNO_CHAN_USAGE, "Channel Usage" },
504+ { NM_IPACC_TESTNO_BCCH_CHAN_USAGE, "BCCH Channel Usage" },
505+ { NM_IPACC_TESTNO_FREQ_SYNC, "Frequency Synchronization" },
506+ { NM_IPACC_TESTNO_BCCH_INFO, "BCCH Information" },
507+ { NM_IPACC_TESTNO_TX_BEACON, "Tx Beacon" },
508+};
509+
510+static const value_string ipacc_test_res_vals[] = {
511+ { NM_IPACC_TESTRES_SUCCESS, "Success" },
512+ { NM_IPACC_TESTRES_TIMEOUT, "Timeout" },
513+ { NM_IPACC_TESTRES_NO_CHANS, "No suitable channels available" },
514+ { NM_IPACC_TESTRES_PARTIAL, "Partial" },
515+ { NM_IPACC_TESTRES_STOPPED, "Stopped" },
516+};
517+
518+static const value_string ipacc_testres_ie_vals[] = {
519+ { NM_IPACC_TR_IE_FREQ_ERR_LIST, "Frequency Error List" },
520+ { NM_IPACC_TR_IE_CHAN_USAGE, "Channel Usage" },
521+ { NM_IPACC_TR_IE_BCCH_INFO, "BCCH Information" },
522+ { NM_IPACC_TR_IE_RESULT_DETAILS,"Result Details" },
523+ { NM_IPACC_TR_IE_FREQ_ERR, "Frequency Error" },
524+};
525+
526+/* Parse the ip.access specific BCCH Information IE embedded into the Test
527+ * Report IE */
528+static gint
529+ipacc_tr_ie_bcch(tvbuff_t *tvb, proto_tree *att_tree, int offset)
530+{
531+ guint16 binfo_type = tvb_get_ntohs(tvb, offset);
532+ guint16 tmp = tvb_get_ntohs(tvb, offset+2);
533+
534+ /* FIXME: there are still some bugs remaining here */
535+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_arfcn,
536+ tvb, offset, 2, TRUE);
537+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_f_qual,
538+ tvb, offset, 2, TRUE);
539+ offset += 2;
540+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_rxlev,
541+ tvb, offset++, 1, TRUE);
542+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_rxqual,
543+ tvb, offset++, 1, TRUE);
544+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_f_err,
545+ tvb, offset, 2, TRUE);
546+ offset += 2;
547+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_frame_offs,
548+ tvb, offset, 2, TRUE);
549+ offset += 2;
550+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_framenr_offs,
551+ tvb, offset, 4, TRUE);
552+ offset += 4;
553+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_bsic,
554+ tvb, offset++, 1, TRUE);
555+ de_lai(tvb, att_tree, offset, 5, NULL, 0);
556+ offset += 5;
557+ proto_tree_add_item(att_tree, hf_attr_ipa_tr_cell_id,
558+ tvb, offset, 2, TRUE);
559+ offset += 2;
560+ /* FIXME: parse GSM 04.18 IE's */
561+
562+ return offset;
563+}
564+
565+/* Parse the ip.access specific Channel Usage IE embedded into the Test
566+ * Report IE */
567+static gint
568+ipacc_tr_ie_chan_usage(tvbuff_t *tvb, proto_tree *att_tree, int offset)
569+{
570+ while (tvb_reported_length_remaining(tvb, offset) != 0) {
571+ guint16 result = tvb_get_ntohs(tvb, offset);
572+ proto_tree_add_uint(att_tree, hf_attr_ipa_tr_arfcn,
573+ tvb, offset, 2, result);
574+ proto_tree_add_uint(att_tree, hf_attr_ipa_tr_rxlev,
575+ tvb, offset, 2, result);
576+ offset += 2;
577+ }
578+ return offset;
579+}
580+
581+/* Parse the ip.access specific format of the standard test report IE */
582+static gint
583+dissect_ipacc_test_rep(proto_tree *tree, tvbuff_t *tvb)
584+{
585+ gint offset = 0;
586+ guint8 test_res = tvb_get_guint8(tvb, offset);
587+
588+ proto_tree_add_item(tree, hf_attr_ipa_test_res, tvb, offset++,
589+ 1, FALSE);
590+
591+ while (tvb_reported_length_remaining(tvb, offset) != 0) {
592+ guint8 ie = tvb_get_guint8(tvb, offset);
593+ guint16 len = tvb_get_ntohs(tvb, offset+1);
594+ proto_item *ti;
595+ proto_tree *att_tree;
596+
597+ ti = proto_tree_add_item(tree, hf_oml_ipa_tres_attr_tag, tvb,
598+ offset++, 1, FALSE);
599+ att_tree = proto_item_add_subtree(ti, ett_oml_fom_att);
600+ proto_tree_add_uint(att_tree, hf_oml_ipa_tres_attr_len, tvb,
601+ offset, 2, len);
602+ offset += 2;
603+
604+ switch (ie) {
605+ case NM_IPACC_TR_IE_CHAN_USAGE:
606+ offset = ipacc_tr_ie_chan_usage(tvb,
607+ att_tree, offset);
608+ break;
609+ case NM_IPACC_TR_IE_BCCH_INFO:
610+ offset = ipacc_tr_ie_bcch(tvb,
611+ att_tree, offset);
612+ break;
613+ default:
614+ break;
615+ }
616+ }
617+}
618+
619+/* Dissect OML FOM Attributes after OML + FOM header */
Harald Welte6900c162009-06-25 20:50:57 +0200620+static gint
621+dissect_oml_attrs(tvbuff_t *tvb, int base_offs, packet_info *pinfo,
622+ proto_tree *tree)
623+{
624+ int offset = base_offs;
625+
626+ while (tvb_reported_length_remaining(tvb, offset) != 0) {
627+ guint8 tag, val8;
Harald Welte6900c162009-06-25 20:50:57 +0200628+ unsigned int len, len_len, hlen;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200629+ const struct tlv_def *tdef;
Harald Welte6900c162009-06-25 20:50:57 +0200630+ proto_item *ti;
631+ proto_tree *att_tree;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200632+ tvbuff_t *sub_tvb;
Harald Welte6900c162009-06-25 20:50:57 +0200633+
634+ tag = tvb_get_guint8(tvb, offset);
635+ tdef = &nm_att_tlvdef.def[tag];
636+
637+ switch (tdef->type) {
638+ case TLV_TYPE_FIXED:
639+ hlen = 1;
640+ len_len = 0;
641+ len = tdef->fixed_len;
642+ break;
643+ case TLV_TYPE_T:
644+ hlen = 1;
645+ len_len = 0;
646+ len = 0;
647+ break;
648+ case TLV_TYPE_TV:
649+ hlen = 1;
650+ len_len = 0;
651+ len = 1;
652+ break;
653+ case TLV_TYPE_TLV:
654+ hlen = 2;
655+ len_len = 1;
656+ len = tvb_get_guint8(tvb, offset+1);
657+ break;
658+ case TLV_TYPE_TL16V:
659+ hlen = 3;
660+ len_len = 2;
661+ len = tvb_get_guint8(tvb, offset+1) << 8 |
662+ tvb_get_guint8(tvb, offset+2);
663+ break;
664+ }
665+
666+ ti = proto_tree_add_item(tree, hf_oml_fom_attr_tag, tvb,
667+ offset, 1, FALSE);
668+ att_tree = proto_item_add_subtree(ti, ett_oml_fom_att);
669+ proto_tree_add_uint(att_tree, hf_oml_fom_attr_len, tvb,
670+ offset+1, len_len, len);
671+ offset += hlen;
672+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200673+ sub_tvb = tvb_new_subset(tvb, offset, len, len);
674+
Harald Welte6900c162009-06-25 20:50:57 +0200675+ switch (tag) {
676+ /* parse only the most common IE for now */
677+ case NM_ATT_ABIS_CHANNEL:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200678+ proto_tree_add_item(att_tree, hf_attr_ach_btsp, tvb,
679+ offset, 1, TRUE);
680+ proto_tree_add_item(att_tree, hf_attr_ach_tslot, tvb,
681+ offset+1, 1, TRUE);
682+ proto_tree_add_item(att_tree, hf_attr_ach_sslot, tvb,
683+ offset+2, 1, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200684+ break;
685+ case NM_ATT_ADM_STATE:
686+ proto_tree_add_item(att_tree, hf_attr_adm_state, tvb,
687+ offset, len, FALSE);
688+ if (check_col(pinfo->cinfo, COL_INFO)) {
689+ val8 = tvb_get_guint8(tvb, offset);
690+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
691+ val_to_str(val8,
692+ oml_adm_state_vals,
693+ "%02x"));
694+ }
695+ break;
696+ case NM_ATT_ARFCN_LIST:
697+ break;
698+ case NM_ATT_AVAIL_STATUS:
699+ proto_tree_add_item(att_tree, hf_attr_avail_state, tvb,
700+ offset, len, FALSE);
701+ if (check_col(pinfo->cinfo, COL_INFO)) {
702+ /* Availability status can have length 0 */
703+ if (len)
704+ val8 = tvb_get_guint8(tvb, offset);
705+ else
706+ val8 = 0xff;
707+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
708+ val_to_str(val8,
709+ oml_avail_state_vals,
710+ "%02x"));
711+ }
712+
713+ break;
714+ case NM_ATT_BCCH_ARFCN:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200715+ proto_tree_add_item(att_tree, hf_attr_bcch_arfcn, tvb,
716+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200717+ break;
718+ case NM_ATT_BSIC:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200719+ proto_tree_add_item(att_tree, hf_attr_bsic, tvb,
720+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200721+ break;
722+ case NM_ATT_CHAN_COMB:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200723+ proto_tree_add_item(att_tree, hf_attr_chan_comb, tvb,
724+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200725+ break;
726+ case NM_ATT_EVENT_TYPE:
727+ proto_tree_add_item(att_tree, hf_attr_event_type, tvb,
Harald Welte1cc3fa82009-07-01 17:40:50 +0200728+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200729+ break;
730+ case NM_ATT_GSM_TIME:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200731+ proto_tree_add_item(att_tree, hf_attr_gsm_time, tvb,
732+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200733+ break;
734+ case NM_ATT_OPER_STATE:
735+ proto_tree_add_item(att_tree, hf_attr_oper_state, tvb,
736+ offset, len, FALSE);
737+ if (check_col(pinfo->cinfo, COL_INFO)) {
738+ val8 = tvb_get_guint8(tvb, offset);
739+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
740+ val_to_str(val8,
741+ oml_oper_state_vals,
742+ "%02x"));
743+ }
744+ break;
745+ case NM_ATT_TEI:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200746+ proto_tree_add_item(att_tree, hf_attr_tei, tvb,
747+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200748+ break;
749+ case NM_ATT_TSC:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200750+ proto_tree_add_item(att_tree, hf_attr_tsc, tvb,
751+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200752+ break;
753+ case NM_ATT_SEVERITY:
754+ proto_tree_add_item(att_tree, hf_attr_severity, tvb,
Harald Welte1cc3fa82009-07-01 17:40:50 +0200755+ offset, len, TRUE);
756+ break;
757+ case NM_ATT_TEST_REPORT:
758+ dissect_ipacc_test_rep(att_tree, sub_tvb);
759+ break;
760+ case NM_ATT_TEST_NO:
761+ proto_tree_add_item(att_tree, hf_attr_test_no, tvb,
762+ offset, len, TRUE);
763+ if (check_col(pinfo->cinfo, COL_INFO)) {
764+ val8 = tvb_get_guint8(tvb, offset);
765+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
766+ val_to_str(val8,
767+ oml_test_no_vals,
768+ "%02x"));
769+ }
Harald Welte6900c162009-06-25 20:50:57 +0200770+ break;
771+
772+ /* proprietary ip.access extensions */
773+ case NM_ATT_IPACC_RSL_BSC_IP:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200774+ proto_tree_add_item(att_tree, hf_attr_ipa_rsl_ip, tvb,
775+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200776+ break;
777+ case NM_ATT_IPACC_RSL_BSC_PORT:
Harald Welte1cc3fa82009-07-01 17:40:50 +0200778+ proto_tree_add_item(att_tree, hf_attr_ipa_rsl_port, tvb,
779+ offset, len, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200780+ break;
781+ case NM_ATT_IPACC_LOCATION:
782+ break;
783+ case NM_ATT_IPACC_UNIT_ID:
784+ break;
785+ case NM_ATT_IPACC_UNIT_NAME:
786+ break;
787+ case NM_ATT_IPACC_PRIM_OML_IP:
788+ break;
789+ case NM_ATT_IPACC_SEC_OML_IP:
790+ break;
791+ default:
792+ proto_tree_add_item(att_tree, hf_oml_fom_attr_val, tvb,
793+ offset, len, FALSE);
794+ }
795+ offset += len;
796+ }
797+ return offset;
798+}
799+
800+static int
801+dissect_oml_fom(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, int offset)
802+{
803+ guint8 msg_type, obj_class, bts_nr, trx_nr, ts_nr;
804+ proto_item *ti;
805+ proto_tree *fom_tree;
806+
807+ msg_type = tvb_get_guint8(tvb, offset);
808+ obj_class = tvb_get_guint8(tvb, offset+1);
809+ bts_nr = tvb_get_guint8(tvb, offset+2);
810+ trx_nr = tvb_get_guint8(tvb, offset+3);
811+ ts_nr = tvb_get_guint8(tvb, offset+4);
812+ if (check_col(pinfo->cinfo, COL_INFO)) {
813+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s(%02x,%02x,%02x) %s ",
814+ val_to_str(obj_class, oml_fom_objclass_vals, "%02x"),
815+ bts_nr, trx_nr, ts_nr,
816+ val_to_str(msg_type, oml_fom_msgtype_vals,
817+ "unknown 0x%x"));
818+ }
819+ ti = proto_tree_add_item(tree, hf_oml_fom_msgtype, tvb, offset++, 1, FALSE);
820+ fom_tree = proto_item_add_subtree(ti, ett_oml_fom);
821+ proto_tree_add_item(fom_tree, hf_oml_fom_objclass, tvb, offset++, 1, FALSE);
822+ proto_tree_add_item(fom_tree, hf_oml_fom_inst_bts, tvb, offset++, 1, FALSE);
823+ proto_tree_add_item(fom_tree, hf_oml_fom_inst_trx, tvb, offset++, 1, FALSE);
824+ proto_tree_add_item(fom_tree, hf_oml_fom_inst_ts, tvb, offset++, 1, FALSE);
825+
826+
827+ /* dissect the TLV objects in the message body */
828+ offset = dissect_oml_attrs(tvb, offset, pinfo, fom_tree);
829+
830+ return offset;
831+}
832+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200833+static const guint8 ipaccess_magic[] = "com.ipaccess";
834+
835+static int
836+dissect_oml_manuf(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, int offset)
837+{
838+ if (tvb_get_guint8(tvb, offset) != 0x0d ||
839+ tvb_memeql(tvb, offset+1, ipaccess_magic, sizeof(ipaccess_magic)))
840+ return offset;
841+
842+ offset += sizeof(ipaccess_magic) + 1;
843+
844+ return dissect_oml_fom(tvb, pinfo, tree, offset);
845+}
Harald Welte6900c162009-06-25 20:50:57 +0200846+
847+static void
848+dissect_abis_oml(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
849+{
850+ proto_item *ti;
851+ proto_tree *oml_tree;
Harald Welte6900c162009-06-25 20:50:57 +0200852+
853+ int offset = 0;
854+
855+ if (check_col(pinfo->cinfo, COL_PROTOCOL))
856+ col_set_str(pinfo->cinfo, COL_PROTOCOL, "OML");
857+#if 0
858+ if (check_col(pinfo->cinfo, COL_INFO))
859+ col_clear(pinfo->cinfo, COL_INFO);
860+#endif
861+
862+ top_tree = tree;
863+ if (tree) {
864+ u_int8_t msg_disc = tvb_get_guint8(tvb, offset);
865+
866+ ti = proto_tree_add_item(tree, proto_abis_oml, tvb, 0, -1, FALSE);
867+ oml_tree = proto_item_add_subtree(ti, ett_oml);
868+
Harald Welte1cc3fa82009-07-01 17:40:50 +0200869+ proto_tree_add_item(oml_tree, hf_oml_msg_disc, tvb, offset++,
870+ 1, TRUE);
871+ proto_tree_add_item(oml_tree, hf_oml_placement, tvb, offset++,
872+ 1, TRUE);
873+ proto_tree_add_item(oml_tree, hf_oml_sequence, tvb, offset++,
874+ 1, TRUE);
875+ proto_tree_add_item(oml_tree, hf_oml_length, tvb, offset++,
876+ 1, TRUE);
Harald Welte6900c162009-06-25 20:50:57 +0200877+
878+ switch (msg_disc) {
879+ case ABIS_OM_MDISC_FOM:
880+ offset = dissect_oml_fom(tvb, pinfo, oml_tree, offset);
881+ break;
Harald Welte1cc3fa82009-07-01 17:40:50 +0200882+ case ABIS_OM_MDISC_MANUF:
883+ offset = dissect_oml_manuf(tvb, pinfo, oml_tree, offset);
884+ break;
Harald Welte6900c162009-06-25 20:50:57 +0200885+ case ABIS_OM_MDISC_MMI:
886+ case ABIS_OM_MDISC_TRAU:
Harald Welte6900c162009-06-25 20:50:57 +0200887+ default:
888+ break;
889+ }
890+ }
891+}
892+
893+void
894+proto_register_abis_oml(void)
895+{
896+ static hf_register_info hf[] = {
897+ { &hf_oml_msg_disc,
898+ { "Message Discriminator", "oml.msg_dsc",
899+ FT_UINT8, BASE_HEX, VALS(oml_msg_disc_vals), 0,
900+ "Message Discriminator", HFILL }
901+ },
902+ { &hf_oml_placement,
903+ { "Placement Indicator", "oml.placement",
904+ FT_UINT8, BASE_HEX, VALS(oml_placement_vals), 0,
905+ "Placement Indicator", HFILL }
906+ },
907+ { &hf_oml_sequence,
908+ { "Sequence Number", "oml.sequence",
909+ FT_UINT8, BASE_HEX, NULL, 0,
910+ "Sequence Number", HFILL }
911+ },
912+ { &hf_oml_length,
913+ { "Length Indicator", "oml.length",
914+ FT_UINT8, BASE_DEC, NULL, 0,
915+ "Length Indicator", HFILL }
916+ },
917+ { &hf_oml_fom_msgtype,
918+ { "FOM Message Type", "oml.fom.msg_type",
919+ FT_UINT8, BASE_HEX, VALS(oml_fom_msgtype_vals), 0,
920+ "FOM Message Type", HFILL }
921+ },
922+ { &hf_oml_fom_objclass,
923+ { "FOM Object Class", "oml.fom.obj_class",
924+ FT_UINT8, BASE_HEX, VALS(oml_fom_objclass_vals), 0,
925+ "FOM Object Class", HFILL }
926+ },
927+ { &hf_oml_fom_inst_bts,
928+ { "FOM Object Instance BTS", "oml.fom.obj_inst.bts",
929+ FT_UINT8, BASE_DEC, NULL, 0,
930+ "FOM Object Instance TRX", HFILL }
931+ },
932+ { &hf_oml_fom_inst_trx,
933+ { "FOM Object Instance TRX", "oml.fom.obj_inst.trx",
934+ FT_UINT8, BASE_DEC, NULL, 0,
935+ "FOM Object Instance TRX", HFILL }
936+ },
937+ { &hf_oml_fom_inst_ts,
938+ { "FOM Object Instance TS", "oml.fom.obj_inst.ts",
939+ FT_UINT8, BASE_DEC, NULL, 0,
940+ "FOM Object Instance TS", HFILL }
941+ },
942+ { &hf_oml_fom_attr_tag,
943+ { "FOM Attribute ID", "oml.fom.attr_id",
944+ FT_UINT8, BASE_HEX, VALS(oml_fom_attr_vals), 0,
945+ "FOM Attribute ID", HFILL }
946+ },
947+ { &hf_oml_fom_attr_len,
948+ { "FOM Attribute Length", "oml.fom.attr_len",
949+ FT_UINT16, BASE_DEC, NULL, 0,
950+ "FOM Attribute Length", HFILL }
951+ },
952+ { &hf_oml_fom_attr_val,
953+ { "FOM Attribute Value", "oml.fom.attr_val",
954+ FT_BYTES, BASE_HEX, NULL, 0,
955+ "FOM Attribute Value", HFILL }
956+ },
957+
958+
959+
960+ /* OML Attributes */
961+ { &hf_attr_adm_state,
962+ { "Administrative State", "oml.fom.attr.adm_state",
963+ FT_UINT8, BASE_HEX, VALS(oml_adm_state_vals), 0,
964+ "Administrative State", HFILL }
965+ },
966+ { &hf_attr_oper_state,
967+ { "Operational State", "oml.fom.attr.oper_state",
968+ FT_UINT8, BASE_HEX, VALS(oml_oper_state_vals), 0,
969+ "Operational State", HFILL }
970+ },
971+ { &hf_attr_avail_state,
972+ { "Availability Status", "oml.fom.attr.avail_state",
973+ FT_UINT8, BASE_HEX, VALS(oml_avail_state_vals), 0,
974+ "Availability Status", HFILL }
975+ },
976+ { &hf_attr_event_type,
977+ { "Event Type", "oml.fom.attr.event_type",
978+ FT_UINT8, BASE_HEX, VALS(oml_event_type_vals), 0,
979+ "Event Type", HFILL }
980+ },
981+ { &hf_attr_severity,
982+ { "Severity", "oml.fom.attr.severity",
983+ FT_UINT8, BASE_HEX, VALS(oml_severity_vals), 0,
984+ "Severity", HFILL }
985+ },
Harald Welte1cc3fa82009-07-01 17:40:50 +0200986+ { &hf_attr_bcch_arfcn,
987+ { "BCCH ARFCN", "oml.fom.attr.bcch_arfcn",
988+ FT_UINT16, BASE_DEC, NULL, 0,
989+ "ARFCN of the BCCH", HFILL }
990+ },
991+ { &hf_attr_bsic,
992+ { "BSIC", "oml.fom.attr.bsic",
993+ FT_UINT16, BASE_HEX, NULL, 0,
994+ "Base Station Identity Cdoe", HFILL }
995+ },
996+ { &hf_attr_test_no,
997+ { "Test Number", "oml.fom.attr.test_no",
998+ FT_UINT8, BASE_HEX, VALS(oml_test_no_vals), 0,
999+ "Test Number", HFILL }
1000+ },
1001+ { &hf_attr_tsc,
1002+ { "TSC", "oml.fom.attr.tsc",
1003+ FT_UINT8, BASE_HEX, NULL, 0,
1004+ "Training Sequence Code", HFILL }
1005+ },
1006+ { &hf_attr_tei,
1007+ { "TEI", "oml.fom.attr.tei",
1008+ FT_UINT8, BASE_DEC, NULL, 0,
1009+ "TEI", HFILL }
1010+ },
1011+ { &hf_attr_ach_btsp,
1012+ { "BTS Port", "oml.fom.attr.abis_ch.bts_port",
1013+ FT_UINT8, BASE_DEC, NULL, 0,
1014+ "BTS Port", HFILL }
1015+ },
1016+ { &hf_attr_ach_tslot,
1017+ { "Timeslot", "oml.fom.attr.abis_ch.timeslot",
1018+ FT_UINT8, BASE_DEC, NULL, 0,
1019+ "Time Slot", HFILL }
1020+ },
1021+ { &hf_attr_ach_sslot,
1022+ { "Subslot", "oml.fom.attr.abis_ch.subslot",
1023+ FT_UINT8, BASE_DEC, NULL, 0,
1024+ "Subslot", HFILL }
1025+ },
1026+ { &hf_attr_gsm_time,
1027+ { "GSM Time", "oml.fom.attr.gsm_time",
1028+ FT_UINT16, BASE_DEC, NULL, 0,
1029+ "GSM Time", HFILL }
1030+ },
1031+ { &hf_attr_chan_comb,
1032+ { "Channel Combination", "oml.fom.attr.chan_comb",
1033+ FT_UINT8, BASE_HEX, VALS(oml_chan_comb_vals), 0,
1034+ "Channel Combination", HFILL }
1035+ },
1036+ /* IP Access */
1037+ { &hf_oml_ipa_tres_attr_tag,
1038+ { "IPA Test Result Embedded IE",
1039+ "oml.fom.testrep.ipa_tag",
1040+ FT_UINT8, BASE_HEX, VALS(ipacc_testres_ie_vals), 0,
1041+ "IPA Test Result Embedded IE", HFILL },
1042+ },
1043+ { &hf_oml_ipa_tres_attr_len,
1044+ { "IPA Test Result Embedded IE Length",
1045+ "oml.fom.testrep.ipa_len",
1046+ FT_UINT16, BASE_DEC, NULL, 0,
1047+ "IPA Test Result Embedded IE Length", HFILL }
1048+ },
1049+ { &hf_attr_ipa_test_res,
1050+ { "IPA Test Result", "oml.fom.testrep.result",
1051+ FT_UINT8, BASE_DEC, VALS(ipacc_test_res_vals), 0,
1052+ "IPA Test Result", HFILL }
1053+ },
1054+ { &hf_attr_ipa_tr_rxlev,
1055+ { "Rx Level", "oml.fom.testrep.ipa_rxlev",
1056+ FT_UINT16, BASE_DEC, NULL, 0xfc00,
1057+ "Rx Level", HFILL }
1058+ },
1059+ { &hf_attr_ipa_tr_arfcn,
1060+ { "ARFCN", "oml.fom.testrep.ipa_arfcn",
1061+ FT_UINT16, BASE_DEC, NULL, 0x03ff,
1062+ "ARFCN", HFILL }
1063+ },
1064+ { &hf_attr_ipa_tr_f_qual,
1065+ { "Frequency Quality", "oml.fom.testrep.ipa.freq_qual",
1066+ FT_UINT8, BASE_DEC, NULL, 0xfc,
1067+ "Frequency Quality", HFILL }
1068+ },
1069+ { &hf_attr_ipa_tr_f_err,
1070+ { "Frequency Error", "oml.fom.testrep.ipa.freq_err",
1071+ FT_UINT16, BASE_DEC, NULL, 0,
1072+ "Frequency Error", HFILL }
1073+ },
1074+ { &hf_attr_ipa_tr_rxqual,
1075+ { "Rx Quality", "oml.fom.testrep.ipa.rx_qual",
1076+ FT_UINT8, BASE_DEC, NULL, 0x7,
1077+ "Rx Quality", HFILL }
1078+ },
1079+ { &hf_attr_ipa_tr_frame_offs,
1080+ { "Frame Offset", "oml.fom.testrep.ipa.frame_offset",
1081+ FT_UINT16, BASE_DEC, NULL, 0,
1082+ "Frame Offset", HFILL }
1083+ },
1084+ { &hf_attr_ipa_tr_framenr_offs,
1085+ { "Frame Number Offset", "oml.fom.testrep.ipa.framenr_offset",
1086+ FT_UINT32, BASE_DEC, NULL, 0,
1087+ "Frame Number Offset", HFILL }
1088+ },
1089+ { &hf_attr_ipa_tr_bsic,
1090+ { "BSIC", "oml.fom.testrep.ipa.bsic",
1091+ FT_UINT8, BASE_DEC, NULL, 0x3f,
1092+ "Base Station Identity Code", HFILL }
1093+ },
1094+ { &hf_attr_ipa_tr_cell_id,
1095+ { "Cell ID", "oml.fom.testrep.ipa.cell_id",
1096+ FT_UINT16, BASE_HEX, NULL, 0,
1097+ "Cell ID", HFILL }
1098+ },
1099+ { &hf_attr_ipa_rsl_ip,
1100+ { "BSC RSL IP Address", "oml.fom.attr.ipa.rsl_ip",
1101+ FT_IPv4, BASE_NONE, NULL, 0,
1102+ "BSC RSL IP Address", HFILL }
1103+ },
1104+ { &hf_attr_ipa_rsl_port,
1105+ { "BSC RSL TCP Port", "oml.fom.attr.ipa.rsl_port",
1106+ FT_UINT16, BASE_DEC, NULL, 0,
1107+ "BSC RSL TCP Port", HFILL }
1108+ },
Harald Welte6900c162009-06-25 20:50:57 +02001109+ };
1110+ static gint *ett[] = {
1111+ &ett_oml,
1112+ &ett_oml_fom,
1113+ &ett_oml_fom_att,
1114+ };
1115+
1116+ proto_abis_oml = proto_register_protocol("GSM A-bis OML", "OML",
1117+ "gsm_abis_oml");
1118+
1119+ proto_register_field_array(proto_abis_oml, hf, array_length(hf));
1120+
1121+ proto_register_subtree_array(ett, array_length(ett));
1122+
1123+ register_dissector("gsm_abis_oml", dissect_abis_oml, proto_abis_oml);
1124+}
1125+
1126+void
1127+proto_reg_handoff_abis_oml(void)
1128+{
1129+ dissector_handle_t abis_oml_handle;
1130+
1131+ abis_oml_handle = find_dissector("abis_oml");
1132+}
1133Index: wireshark/epan/dissectors/packet-abis_oml.h
1134===================================================================
1135--- /dev/null 1970-01-01 00:00:00.000000000 +0000
Harald Welte1cc3fa82009-07-01 17:40:50 +02001136+++ wireshark/epan/dissectors/packet-abis_oml.h 2009-07-01 11:27:15.000000000 +0200
1137@@ -0,0 +1,714 @@
Harald Welte6900c162009-06-25 20:50:57 +02001138+/* GSM Network Management messages on the A-bis interface
1139+ * 3GPP TS 12.21 version 8.0.0 Release 1999 / ETSI TS 100 623 V8.0.0 */
1140+
1141+/* (C) 2008-2009 by Harald Welte <laforge@gnumonks.org>
1142+ * All Rights Reserved
1143+ *
1144+ * This program is free software; you can redistribute it and/or modify
1145+ * it under the terms of the GNU General Public License as published by
1146+ * the Free Software Foundation; either version 2 of the License, or
1147+ * (at your option) any later version.
1148+ *
1149+ * This program is distributed in the hope that it will be useful,
1150+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
1151+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1152+ * GNU General Public License for more details.
1153+ *
1154+ * You should have received a copy of the GNU General Public License along
1155+ * with this program; if not, write to the Free Software Foundation, Inc.,
1156+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
1157+ *
1158+ */
1159+
1160+#ifndef __PACKET_ABIS_OML_H__
1161+#define __PACKET_ABIS_OML_H__
1162+
1163+#include <sys/types.h>
1164+
1165+/* From openbsc/include/openbsc/abis_nm.h */
1166+
1167+/* generic header in front of every OML message according to TS 08.59 */
1168+struct abis_om_hdr {
1169+ guint8 mdisc;
1170+ guint8 placement;
1171+ guint8 sequence;
1172+ guint8 length;
1173+ guint8 data[0];
1174+} __attribute__ ((packed));
1175+
1176+#define ABIS_OM_MDISC_FOM 0x80
1177+#define ABIS_OM_MDISC_MMI 0x40
1178+#define ABIS_OM_MDISC_TRAU 0x20
1179+#define ABIS_OM_MDISC_MANUF 0x10
1180+#define ABIS_OM_PLACEMENT_ONLY 0x80
1181+#define ABIS_OM_PLACEMENT_FIRST 0x40
1182+#define ABIS_OM_PLACEMENT_MIDDLE 0x20
1183+#define ABIS_OM_PLACEMENT_LAST 0x10
1184+
1185+struct abis_om_obj_inst {
1186+ guint8 bts_nr;
1187+ guint8 trx_nr;
1188+ guint8 ts_nr;
1189+} __attribute__ ((packed));
1190+
1191+struct abis_om_fom_hdr {
1192+ guint8 msg_type;
1193+ guint8 obj_class;
1194+ struct abis_om_obj_inst obj_inst;
1195+ guint8 data[0];
1196+} __attribute__ ((packed));
1197+
1198+#define ABIS_OM_FOM_HDR_SIZE (sizeof(struct abis_om_hdr) + sizeof(struct abis_om_fom_hdr))
1199+
1200+/* Section 9.1: Message Types */
1201+enum abis_nm_msgtype {
1202+ /* SW Download Management Messages */
1203+ NM_MT_LOAD_INIT = 0x01,
1204+ NM_MT_LOAD_INIT_ACK,
1205+ NM_MT_LOAD_INIT_NACK,
1206+ NM_MT_LOAD_SEG,
1207+ NM_MT_LOAD_SEG_ACK,
1208+ NM_MT_LOAD_ABORT,
1209+ NM_MT_LOAD_END,
1210+ NM_MT_LOAD_END_ACK,
1211+ NM_MT_LOAD_END_NACK,
1212+ NM_MT_SW_ACT_REQ, /* BTS->BSC */
1213+ NM_MT_SW_ACT_REQ_ACK,
1214+ NM_MT_SW_ACT_REQ_NACK,
1215+ NM_MT_ACTIVATE_SW, /* BSC->BTS */
1216+ NM_MT_ACTIVATE_SW_ACK,
1217+ NM_MT_ACTIVATE_SW_NACK,
1218+ NM_MT_SW_ACTIVATED_REP, /* 0x10 */
1219+ /* A-bis Interface Management Messages */
1220+ NM_MT_ESTABLISH_TEI = 0x21,
1221+ NM_MT_ESTABLISH_TEI_ACK,
1222+ NM_MT_ESTABLISH_TEI_NACK,
1223+ NM_MT_CONN_TERR_SIGN,
1224+ NM_MT_CONN_TERR_SIGN_ACK,
1225+ NM_MT_CONN_TERR_SIGN_NACK,
1226+ NM_MT_DISC_TERR_SIGN,
1227+ NM_MT_DISC_TERR_SIGN_ACK,
1228+ NM_MT_DISC_TERR_SIGN_NACK,
1229+ NM_MT_CONN_TERR_TRAF,
1230+ NM_MT_CONN_TERR_TRAF_ACK,
1231+ NM_MT_CONN_TERR_TRAF_NACK,
1232+ NM_MT_DISC_TERR_TRAF,
1233+ NM_MT_DISC_TERR_TRAF_ACK,
1234+ NM_MT_DISC_TERR_TRAF_NACK,
1235+ /* Transmission Management Messages */
1236+ NM_MT_CONN_MDROP_LINK = 0x31,
1237+ NM_MT_CONN_MDROP_LINK_ACK,
1238+ NM_MT_CONN_MDROP_LINK_NACK,
1239+ NM_MT_DISC_MDROP_LINK,
1240+ NM_MT_DISC_MDROP_LINK_ACK,
1241+ NM_MT_DISC_MDROP_LINK_NACK,
1242+ /* Air Interface Management Messages */
1243+ NM_MT_SET_BTS_ATTR = 0x41,
1244+ NM_MT_SET_BTS_ATTR_ACK,
1245+ NM_MT_SET_BTS_ATTR_NACK,
1246+ NM_MT_SET_RADIO_ATTR,
1247+ NM_MT_SET_RADIO_ATTR_ACK,
1248+ NM_MT_SET_RADIO_ATTR_NACK,
1249+ NM_MT_SET_CHAN_ATTR,
1250+ NM_MT_SET_CHAN_ATTR_ACK,
1251+ NM_MT_SET_CHAN_ATTR_NACK,
1252+ /* Test Management Messages */
1253+ NM_MT_PERF_TEST = 0x51,
1254+ NM_MT_PERF_TEST_ACK,
1255+ NM_MT_PERF_TEST_NACK,
1256+ NM_MT_TEST_REP,
1257+ NM_MT_SEND_TEST_REP,
1258+ NM_MT_SEND_TEST_REP_ACK,
1259+ NM_MT_SEND_TEST_REP_NACK,
1260+ NM_MT_STOP_TEST,
1261+ NM_MT_STOP_TEST_ACK,
1262+ NM_MT_STOP_TEST_NACK,
1263+ /* State Management and Event Report Messages */
1264+ NM_MT_STATECHG_EVENT_REP = 0x61,
1265+ NM_MT_FAILURE_EVENT_REP,
1266+ NM_MT_STOP_EVENT_REP,
1267+ NM_MT_STOP_EVENT_REP_ACK,
1268+ NM_MT_STOP_EVENT_REP_NACK,
1269+ NM_MT_REST_EVENT_REP,
1270+ NM_MT_REST_EVENT_REP_ACK,
1271+ NM_MT_REST_EVENT_REP_NACK,
1272+ NM_MT_CHG_ADM_STATE,
1273+ NM_MT_CHG_ADM_STATE_ACK,
1274+ NM_MT_CHG_ADM_STATE_NACK,
1275+ NM_MT_CHG_ADM_STATE_REQ,
1276+ NM_MT_CHG_ADM_STATE_REQ_ACK,
1277+ NM_MT_CHG_ADM_STATE_REQ_NACK,
1278+ NM_MT_REP_OUTST_ALARMS = 0x93,
1279+ NM_MT_REP_OUTST_ALARMS_ACK,
1280+ NM_MT_REP_OUTST_ALARMS_NACK,
1281+ /* Equipment Management Messages */
1282+ NM_MT_CHANGEOVER = 0x71,
1283+ NM_MT_CHANGEOVER_ACK,
1284+ NM_MT_CHANGEOVER_NACK,
1285+ NM_MT_OPSTART,
1286+ NM_MT_OPSTART_ACK,
1287+ NM_MT_OPSTART_NACK,
1288+ NM_MT_REINIT,
1289+ NM_MT_REINIT_ACK,
1290+ NM_MT_REINIT_NACK,
1291+ NM_MT_SET_SITE_OUT, /* BS11: get alarm ?!? */
1292+ NM_MT_SET_SITE_OUT_ACK,
1293+ NM_MT_SET_SITE_OUT_NACK,
1294+ NM_MT_CHG_HW_CONF = 0x90,
1295+ NM_MT_CHG_HW_CONF_ACK,
1296+ NM_MT_CHG_HW_CONF_NACK,
1297+ /* Measurement Management Messages */
1298+ NM_MT_MEAS_RES_REQ = 0x8a,
1299+ NM_MT_MEAS_RES_RESP,
1300+ NM_MT_STOP_MEAS,
1301+ NM_MT_START_MEAS,
1302+ /* Other Messages */
1303+ NM_MT_GET_ATTR = 0x81,
1304+ NM_MT_GET_ATTR_RESP,
1305+ NM_MT_GET_ATTR_NACK,
1306+ NM_MT_SET_ALARM_THRES,
1307+ NM_MT_SET_ALARM_THRES_ACK,
1308+ NM_MT_SET_ALARM_THRES_NACK,
1309+
1310+ NM_MT_IPACC_RESTART = 0x87,
1311+ NM_MT_IPACC_RESTART_ACK,
1312+};
1313+
1314+enum abis_nm_msgtype_bs11 {
1315+ NM_MT_BS11_RESET_RESOURCE = 0x74,
1316+
1317+ NM_MT_BS11_BEGIN_DB_TX = 0xa3,
1318+ NM_MT_BS11_BEGIN_DB_TX_ACK,
1319+ NM_MT_BS11_BEGIN_DB_TX_NACK,
1320+ NM_MT_BS11_END_DB_TX = 0xa6,
1321+ NM_MT_BS11_END_DB_TX_ACK,
1322+ NM_MT_BS11_END_DB_TX_NACK,
1323+ NM_MT_BS11_CREATE_OBJ = 0xa9,
1324+ NM_MT_BS11_CREATE_OBJ_ACK,
1325+ NM_MT_BS11_CREATE_OBJ_NACK,
1326+ NM_MT_BS11_DELETE_OBJ = 0xac,
1327+ NM_MT_BS11_DELETE_OBJ_ACK,
1328+ NM_MT_BS11_DELETE_OBJ_NACK,
1329+
1330+ NM_MT_BS11_SET_ATTR = 0xd0,
1331+ NM_MT_BS11_SET_ATTR_ACK,
1332+ NM_MT_BS11_SET_ATTR_NACK,
1333+ NM_MT_BS11_LMT_SESSION = 0xdc,
1334+
1335+ NM_MT_BS11_GET_STATE = 0xe3,
1336+ NM_MT_BS11_GET_STATE_ACK,
1337+ NM_MT_BS11_LMT_LOGON = 0xe5,
1338+ NM_MT_BS11_LMT_LOGON_ACK,
1339+ NM_MT_BS11_RESTART = 0xe7,
1340+ NM_MT_BS11_RESTART_ACK,
1341+ NM_MT_BS11_DISCONNECT = 0xe9,
1342+ NM_MT_BS11_DISCONNECT_ACK,
1343+ NM_MT_BS11_LMT_LOGOFF = 0xec,
1344+ NM_MT_BS11_LMT_LOGOFF_ACK,
1345+ NM_MT_BS11_RECONNECT = 0xf1,
1346+ NM_MT_BS11_RECONNECT_ACK,
1347+};
1348+
1349+enum abis_nm_msgtype_ipacc {
1350+ NM_MT_IPACC_RSL_CONNECT = 0xe0,
1351+ NM_MT_IPACC_RSL_CONNECT_ACK,
1352+ NM_MT_IPACC_RSL_CONNECT_NACK,
Harald Welte1cc3fa82009-07-01 17:40:50 +02001353+ NM_MT_IPACC_RSL_DISCONNECT = 0xe3,
1354+ NM_MT_IPACC_RSL_DISCONNECT_ACK,
1355+ NM_MT_IPACC_RSL_DISCONNECT_NACK,
1356+ NM_MT_IPACC_CONN_TRAF = 0xe6,
1357+ NM_MT_IPACC_CONN_TRAF_ACK,
1358+ NM_MT_IPACC_CONN_TRAF_NACK,
1359+ NM_MT_IPACC_DEF_BOOT_SW = 0xec,
1360+ NM_MT_IPACC_DEF_BOOT_SW_ACK,
1361+ NM_MT_IPACC_DEF_BOOT_SW_NACK,
Harald Welte6900c162009-06-25 20:50:57 +02001362+ NM_MT_IPACC_SET_NVATTR = 0xef,
1363+ NM_MT_IPACC_SET_NVATTR_ACK,
1364+ NM_MT_IPACC_SET_NVATTR_NACK,
1365+ NM_MT_IPACC_GET_NVATTR = 0xf2,
1366+ NM_MT_IPACC_GET_NVATTR_ACK,
1367+ NM_MT_IPACC_GET_NVATTR_NACK,
1368+};
1369+
1370+enum abis_nm_bs11_cell_alloc {
1371+ NM_BS11_CANR_GSM = 0x00,
1372+ NM_BS11_CANR_DCS1800 = 0x01,
1373+};
1374+
1375+/* Section 9.2: Object Class */
1376+enum abis_nm_obj_class {
1377+ NM_OC_SITE_MANAGER = 0x00,
1378+ NM_OC_BTS,
1379+ NM_OC_RADIO_CARRIER,
1380+ NM_OC_CHANNEL,
1381+ NM_OC_BASEB_TRANSC,
1382+ /* RFU: 05-FE */
1383+ NM_OC_BS11_ADJC = 0xa0,
1384+ NM_OC_BS11_HANDOVER = 0xa1,
1385+ NM_OC_BS11_PWR_CTRL = 0xa2,
1386+ NM_OC_BS11_BTSE = 0xa3, /* LMT? */
1387+ NM_OC_BS11_RACK = 0xa4,
1388+ NM_OC_BS11 = 0xa5, /* 01: ALCO */
1389+ NM_OC_BS11_TEST = 0xa6,
1390+ NM_OC_BS11_ENVABTSE = 0xa8,
1391+ NM_OC_BS11_BPORT = 0xa9,
1392+
1393+ NM_OC_GPRS_NSE = 0xf0,
1394+ NM_OC_GPRS_CELL = 0xf1,
1395+ NM_OC_GPRS_NSVC0 = 0xf2,
1396+ NM_OC_GPRS_NSVC1 = 0xf3,
1397+
1398+ NM_OC_NULL = 0xff,
1399+};
1400+
1401+/* Section 9.4: Attributes */
1402+enum abis_nm_attr {
1403+ NM_ATT_ABIS_CHANNEL = 0x01,
1404+ NM_ATT_ADD_INFO,
1405+ NM_ATT_ADD_TEXT,
1406+ NM_ATT_ADM_STATE,
1407+ NM_ATT_ARFCN_LIST,
1408+ NM_ATT_AUTON_REPORT,
1409+ NM_ATT_AVAIL_STATUS,
1410+ NM_ATT_BCCH_ARFCN,
1411+ NM_ATT_BSIC,
1412+ NM_ATT_BTS_AIR_TIMER,
1413+ NM_ATT_CCCH_L_I_P,
1414+ NM_ATT_CCCH_L_T,
1415+ NM_ATT_CHAN_COMB,
1416+ NM_ATT_CONN_FAIL_CRIT,
1417+ NM_ATT_DEST,
1418+ /* res */
1419+ NM_ATT_EVENT_TYPE = 0x11, /* BS11: file data ?!? */
1420+ NM_ATT_FILE_ID,
1421+ NM_ATT_FILE_VERSION,
1422+ NM_ATT_GSM_TIME,
1423+ NM_ATT_HSN,
1424+ NM_ATT_HW_CONFIG,
1425+ NM_ATT_HW_DESC,
1426+ NM_ATT_INTAVE_PARAM,
1427+ NM_ATT_INTERF_BOUND,
1428+ NM_ATT_LIST_REQ_ATTR,
1429+ NM_ATT_MAIO,
1430+ NM_ATT_MANUF_STATE,
1431+ NM_ATT_MANUF_THRESH,
1432+ NM_ATT_MANUF_ID,
1433+ NM_ATT_MAX_TA,
1434+ NM_ATT_MDROP_LINK, /* 0x20 */
1435+ NM_ATT_MDROP_NEXT,
1436+ NM_ATT_NACK_CAUSES,
1437+ NM_ATT_NY1,
1438+ NM_ATT_OPER_STATE,
1439+ NM_ATT_OVERL_PERIOD,
1440+ NM_ATT_PHYS_CONF,
1441+ NM_ATT_POWER_CLASS,
1442+ NM_ATT_POWER_THRESH,
1443+ NM_ATT_PROB_CAUSE,
1444+ NM_ATT_RACH_B_THRESH,
1445+ NM_ATT_LDAVG_SLOTS,
1446+ NM_ATT_RAD_SUBC,
1447+ NM_ATT_RF_MAXPOWR_R,
1448+ NM_ATT_SITE_INPUTS,
1449+ NM_ATT_SITE_OUTPUTS,
1450+ NM_ATT_SOURCE, /* 0x30 */
1451+ NM_ATT_SPEC_PROB,
1452+ NM_ATT_START_TIME,
1453+ NM_ATT_T200,
1454+ NM_ATT_TEI,
1455+ NM_ATT_TEST_DUR,
1456+ NM_ATT_TEST_NO,
1457+ NM_ATT_TEST_REPORT,
1458+ NM_ATT_VSWR_THRESH,
1459+ NM_ATT_WINDOW_SIZE,
1460+ /* Res */
1461+ NM_ATT_BS11_RSSI_OFFS = 0x3d,
1462+ NM_ATT_BS11_TXPWR = 0x3e,
1463+ NM_ATT_BS11_DIVERSITY = 0x3f,
1464+ /* Res */
1465+ NM_ATT_TSC = 0x40,
1466+ NM_ATT_SW_CONFIG,
1467+ NM_ATT_SW_DESCR,
1468+ NM_ATT_SEVERITY,
1469+ NM_ATT_GET_ARI,
1470+ NM_ATT_HW_CONF_CHG,
1471+ NM_ATT_OUTST_ALARM,
1472+ NM_ATT_FILE_DATA,
1473+ NM_ATT_MEAS_RES,
1474+ NM_ATT_MEAS_TYPE,
1475+
1476+ NM_ATT_BS11_ESN_FW_CODE_NO = 0x4c,
1477+ NM_ATT_BS11_ESN_HW_CODE_NO = 0x4f,
1478+
1479+ NM_ATT_BS11_ESN_PCB_SERIAL = 0x55,
1480+ NM_ATT_BS11_EXCESSIVE_DISTANCE = 0x58,
1481+
1482+ NM_ATT_BS11_ALL_TEST_CATG = 0x60,
1483+ NM_ATT_BS11_BTSLS_HOPPING,
1484+ NM_ATT_BS11_CELL_ALLOC_NR,
1485+ NM_ATT_BS11_CELL_GLOBAL_ID,
1486+ NM_ATT_BS11_ENA_INTERF_CLASS = 0x66,
1487+ NM_ATT_BS11_ENA_INT_INTEC_HANDO = 0x67,
1488+ NM_ATT_BS11_ENA_INT_INTRC_HANDO = 0x68,
1489+ NM_ATT_BS11_ENA_MS_PWR_CTRL = 0x69,
1490+ NM_ATT_BS11_ENA_PWR_BDGT_HO = 0x6a,
1491+ NM_ATT_BS11_ENA_PWR_CTRL_RLFW = 0x6b,
1492+ NM_ATT_BS11_ENA_RXLEV_HO = 0x6c,
1493+ NM_ATT_BS11_ENA_RXQUAL_HO = 0x6d,
1494+ NM_ATT_BS11_FACCH_QUAL = 0x6e,
1495+
1496+ NM_ATT_IPACC_RSL_BSC_IP = 0x80,
1497+ NM_ATT_IPACC_RSL_BSC_PORT = 0x81,
Harald Welte1cc3fa82009-07-01 17:40:50 +02001498+ NM_ATT_IPACC_NV_FLAGS = 0x86,
1499+ NM_ATT_IPACC_FREQ_CTRL = 0x87,
1500+ NM_ATT_IPACC_IP_IF_CFG = 0x8a, /* IP interface */
1501+ NM_ATT_IPACC_IP_GW_CFG = 0x8b, /* IP gateway */
1502+ NM_ATT_IPACC_IN_SERV_TIME = 0x8c,
Harald Welte6900c162009-06-25 20:50:57 +02001503+ NM_ATT_IPACC_LOCATION = 0x8e, /* string describing location */
1504+ NM_ATT_IPACC_UNIT_ID = 0x91, /* Site/BTS/TRX */
1505+ NM_ATT_IPACC_UNIT_NAME = 0x93, /* default: nbts-<mac-as-string> */
Harald Welte1cc3fa82009-07-01 17:40:50 +02001506+ NM_ATT_IPACC_SNMP_CFG = 0x94,
Harald Welte6900c162009-06-25 20:50:57 +02001507+ NM_ATT_IPACC_PRIM_OML_IP = 0x95,
1508+ NM_ATT_IPACC_SEC_OML_IP = 0x96,
Harald Welte1cc3fa82009-07-01 17:40:50 +02001509+ NM_ATT_IPACC_CUR_SW_CFG = 0x97,
1510+
1511+ NM_ATT_IPACC_ALM_THRESH_LIST = 0xa4,
1512+ NM_ATT_IPACC_UPTIME = 0xab,
1513+ NM_ATT_IPACC_SSL_CFG = 0xad,
1514+ NM_ATT_IPACC_SEC_POSSIBLE = 0xae,
1515+ NM_ATT_IPACC_REVOC_DATE = 0xb0,
1516+
Harald Welte6900c162009-06-25 20:50:57 +02001517+
1518+ NM_ATT_BS11_RF_RES_IND_PER = 0x8f,
1519+
1520+ NM_ATT_BS11_RX_LEV_MIN_CELL = 0x90,
1521+ NM_ATT_BS11_ABIS_EXT_TIME = 0x91,
1522+ NM_ATT_BS11_TIMER_HO_REQUEST = 0x92,
1523+ NM_ATT_BS11_TIMER_NCELL = 0x93,
1524+ NM_ATT_BS11_TSYNC = 0x94,
1525+ NM_ATT_BS11_TTRAU = 0x95,
1526+ NM_ATT_BS11_EMRG_CFG_MEMBER = 0x9b,
1527+ NM_ATT_BS11_TRX_AREA = 0x9f,
1528+
1529+ NM_ATT_BS11_BCCH_RECONF = 0xd7,
1530+ NM_ATT_BS11_BIT_ERR_THESH = 0xa0,
1531+ NM_ATT_BS11_BOOT_SW_VERS = 0xa1,
1532+ NM_ATT_BS11_CCLK_ACCURACY = 0xa3,
1533+ NM_ATT_BS11_CCLK_TYPE = 0xa4,
1534+ NM_ATT_BS11_INP_IMPEDANCE = 0xaa,
1535+ NM_ATT_BS11_L1_PROT_TYPE = 0xab,
1536+ NM_ATT_BS11_LINE_CFG = 0xac,
1537+ NM_ATT_BS11_LI_PORT_1 = 0xad,
1538+ NM_ATT_BS11_LI_PORT_2 = 0xae,
1539+
1540+ NM_ATT_BS11_L1_REM_ALM_TYPE = 0xb0,
1541+ NM_ATT_BS11_SW_LOAD_INTENDED = 0xbb,
1542+ NM_ATT_BS11_SW_LOAD_SAFETY = 0xbc,
1543+ NM_ATT_BS11_SW_LOAD_STORED = 0xbd,
1544+
1545+ NM_ATT_BS11_VENDOR_NAME = 0xc1,
1546+ NM_ATT_BS11_HOPPING_MODE = 0xc5,
1547+ NM_ATT_BS11_LMT_LOGON_SESSION = 0xc6,
1548+ NM_ATT_BS11_LMT_LOGIN_TIME = 0xc7,
1549+ NM_ATT_BS11_LMT_USER_ACC_LEV = 0xc8,
1550+ NM_ATT_BS11_LMT_USER_NAME = 0xc9,
1551+
1552+ NM_ATT_BS11_L1_CONTROL_TS = 0xd8,
1553+ NM_ATT_BS11_RADIO_MEAS_GRAN = 0xdc, /* in SACCH multiframes */
1554+ NM_ATT_BS11_RADIO_MEAS_REP = 0xdd,
1555+
1556+ NM_ATT_BS11_SH_LAPD_INT_TIMER = 0xe8,
1557+
1558+ NM_ATT_BS11_BTS_STATE = 0xf0,
1559+ NM_ATT_BS11_E1_STATE = 0xf1,
1560+ NM_ATT_BS11_PLL = 0xf2,
1561+ NM_ATT_BS11_RX_OFFSET = 0xf3,
1562+ NM_ATT_BS11_ANT_TYPE = 0xf4,
1563+ NM_ATT_BS11_PLL_MODE = 0xfc,
1564+ NM_ATT_BS11_PASSWORD = 0xfd,
1565+};
1566+#define NM_ATT_BS11_FILE_DATA NM_ATT_EVENT_TYPE
1567+
1568+/* Section 9.4.4: Administrative State */
1569+enum abis_nm_adm_state {
1570+ NM_STATE_LOCKED = 0x01,
1571+ NM_STATE_UNLOCKED = 0x02,
1572+ NM_STATE_SHUTDOWN = 0x03,
1573+ NM_STATE_NULL = 0xff,
1574+};
1575+
1576+/* Section 9.4.13: Channel Combination */
1577+enum abis_nm_chan_comb {
1578+ NM_CHANC_TCHFull = 0x00,
1579+ NM_CHANC_TCHHalf = 0x01,
1580+ NM_CHANC_TCHHalf2 = 0x02,
1581+ NM_CHANC_SDCCH = 0x03,
1582+ NM_CHANC_mainBCCH = 0x04,
1583+ NM_CHANC_BCCHComb = 0x05,
1584+ NM_CHANC_BCCH = 0x06,
1585+ NM_CHANC_BCCH_CBCH = 0x07,
1586+ NM_CHANC_SDCCH_CBCH = 0x08,
1587+};
1588+
1589+/* Section 9.4.16: Event Type */
1590+enum abis_nm_event_type {
1591+ NM_EVT_COMM_FAIL = 0x00,
1592+ NM_EVT_QOS_FAIL = 0x01,
1593+ NM_EVT_PROC_FAIL = 0x02,
1594+ NM_EVT_EQUIP_FAIL = 0x03,
1595+ NM_EVT_ENV_FAIL = 0x04,
1596+};
1597+
1598+/* Section: 9.4.63: Perceived Severity */
1599+enum abis_nm_severity {
1600+ NM_SEVER_CEASED = 0x00,
1601+ NM_SEVER_CRITICAL = 0x01,
1602+ NM_SEVER_MAJOR = 0x02,
1603+ NM_SEVER_MINOR = 0x03,
1604+ NM_SEVER_WARNING = 0x04,
1605+ NM_SEVER_INDETERMINATE = 0x05,
1606+};
1607+
1608+/* Section 9.4.43: Probable Cause Type */
1609+enum abis_nm_pcause_type {
1610+ NM_PCAUSE_T_X721 = 0x01,
1611+ NM_PCAUSE_T_GSM = 0x02,
1612+ NM_PCAUSE_T_MANUF = 0x03,
1613+};
1614+
1615+/* Section 9.4.36: NACK Causes */
1616+enum abis_nm_nack_cause {
1617+ /* General Nack Causes */
1618+ NM_NACK_INCORR_STRUCT = 0x01,
1619+ NM_NACK_MSGTYPE_INVAL = 0x02,
1620+ NM_NACK_OBJCLASS_INVAL = 0x05,
1621+ NM_NACK_OBJCLASS_NOTSUPP = 0x06,
1622+ NM_NACK_BTSNR_UNKN = 0x07,
1623+ NM_NACK_TRXNR_UNKN = 0x08,
1624+ NM_NACK_OBJINST_UNKN = 0x09,
1625+ NM_NACK_ATTRID_INVAL = 0x0c,
1626+ NM_NACK_ATTRID_NOTSUPP = 0x0d,
1627+ NM_NACK_PARAM_RANGE = 0x0e,
1628+ NM_NACK_ATTRLIST_INCONSISTENT = 0x0f,
1629+ NM_NACK_SPEC_IMPL_NOTSUPP = 0x10,
1630+ NM_NACK_CANT_PERFORM = 0x11,
1631+ /* Specific Nack Causes */
1632+ NM_NACK_RES_NOTIMPL = 0x19,
1633+ NM_NACK_RES_NOTAVAIL = 0x1a,
1634+ NM_NACK_FREQ_NOTAVAIL = 0x1b,
1635+ NM_NACK_TEST_NOTSUPP = 0x1c,
1636+ NM_NACK_CAPACITY_RESTR = 0x1d,
1637+ NM_NACK_PHYSCFG_NOTPERFORM = 0x1e,
1638+ NM_NACK_TEST_NOTINIT = 0x1f,
1639+ NM_NACK_PHYSCFG_NOTRESTORE = 0x20,
1640+ NM_NACK_TEST_NOSUCH = 0x21,
1641+ NM_NACK_TEST_NOSTOP = 0x22,
1642+ NM_NACK_MSGINCONSIST_PHYSCFG = 0x23,
1643+ NM_NACK_FILE_INCOMPLETE = 0x25,
1644+ NM_NACK_FILE_NOTAVAIL = 0x26,
1645+ NM_NACK_FILE_NOTACTIVATE = 0x27,
1646+ NM_NACK_REQ_NOT_GRANT = 0x28,
1647+ NM_NACK_WAIT = 0x29,
1648+ NM_NACK_NOTH_REPORT_EXIST = 0x2a,
1649+ NM_NACK_MEAS_NOTSUPP = 0x2b,
1650+ NM_NACK_MEAS_NOTSTART = 0x2c,
1651+};
1652+
1653+/* Section 9.4.1 */
1654+struct abis_nm_channel {
1655+ guint8 attrib;
1656+ guint8 bts_port;
1657+ guint8 timeslot;
1658+ guint8 subslot;
1659+} __attribute__ ((packed));
1660+
1661+/* Siemens BS-11 specific objects in the SienemsHW (0xA5) object class */
1662+enum abis_bs11_objtype {
1663+ BS11_OBJ_ALCO = 0x01,
1664+ BS11_OBJ_BBSIG = 0x02, /* obj_class: 0,1 */
1665+ BS11_OBJ_TRX1 = 0x03, /* only DEACTIVATE TRX1 */
1666+ BS11_OBJ_CCLK = 0x04,
1667+ BS11_OBJ_GPSU = 0x06,
1668+ BS11_OBJ_LI = 0x07,
1669+ BS11_OBJ_PA = 0x09, /* obj_class: 0, 1*/
1670+};
1671+
1672+enum abis_bs11_trx_power {
1673+ BS11_TRX_POWER_GSM_2W = 0x06,
1674+ BS11_TRX_POWER_GSM_250mW= 0x07,
1675+ BS11_TRX_POWER_GSM_80mW = 0x08,
1676+ BS11_TRX_POWER_GSM_30mW = 0x09,
1677+ BS11_TRX_POWER_DCS_3W = 0x0a,
1678+ BS11_TRX_POWER_DCS_1W6 = 0x0b,
1679+ BS11_TRX_POWER_DCS_500mW= 0x0c,
1680+ BS11_TRX_POWER_DCS_160mW= 0x0d,
1681+};
1682+
1683+enum abis_bs11_li_pll_mode {
1684+ BS11_LI_PLL_LOCKED = 2,
1685+ BS11_LI_PLL_STANDALONE = 3,
1686+};
1687+
1688+enum abis_bs11_phase {
1689+ BS11_STATE_SOFTWARE_RQD = 0x01,
1690+ BS11_STATE_LOAD_SMU_INTENDED = 0x11,
1691+ BS11_STATE_LOAD_SMU_SAFETY = 0x21,
1692+ BS11_STATE_LOAD_FAILED = 0x31,
1693+ BS11_STATE_LOAD_DIAGNOSTIC = 0x41,
1694+ BS11_STATE_WARM_UP = 0x51,
1695+ BS11_STATE_WARM_UP_2 = 0x52,
1696+ BS11_STATE_WAIT_MIN_CFG = 0x62,
1697+ BS11_STATE_MAINTENANCE = 0x72,
1698+ BS11_STATE_LOAD_MBCCU = 0x92,
1699+ BS11_STATE_WAIT_MIN_CFG_2 = 0xA2,
1700+ BS11_STATE_NORMAL = 0x03,
1701+ BS11_STATE_ABIS_LOAD = 0x13,
1702+};
1703+
1704+/* From openbsc/include/openbsc/tlv.h */
1705+enum tlv_type {
1706+ TLV_TYPE_FIXED,
1707+ TLV_TYPE_T,
1708+ TLV_TYPE_TV,
1709+ TLV_TYPE_TLV,
1710+ TLV_TYPE_TL16V,
1711+};
1712+
1713+struct tlv_def {
1714+ enum tlv_type type;
1715+ u_int8_t fixed_len;
1716+};
1717+
1718+struct tlv_definition {
1719+ struct tlv_def def[0xff];
1720+};
1721+
Harald Welte1cc3fa82009-07-01 17:40:50 +02001722+enum abis_nm_ipacc_test_no {
1723+ NM_IPACC_TESTNO_CHAN_USAGE = 0x40,
1724+ NM_IPACC_TESTNO_BCCH_CHAN_USAGE = 0x41,
1725+ NM_IPACC_TESTNO_FREQ_SYNC = 0x42,
1726+ NM_IPACC_TESTNO_BCCH_INFO = 0x43,
1727+ NM_IPACC_TESTNO_TX_BEACON = 0x44,
1728+};
1729+
1730+/* first byte after length inside NM_ATT_TEST_REPORT */
1731+enum abis_nm_ipacc_test_res {
1732+ NM_IPACC_TESTRES_SUCCESS = 0,
1733+ NM_IPACC_TESTRES_TIMEOUT = 1,
1734+ NM_IPACC_TESTRES_NO_CHANS = 2,
1735+ NM_IPACC_TESTRES_PARTIAL = 3,
1736+ NM_IPACC_TESTRES_STOPPED = 4,
1737+};
1738+
1739+/* internal IE inside NM_ATT_TEST_REPORT */
1740+enum abis_nm_ipacc_testres_ie {
1741+ NM_IPACC_TR_IE_FREQ_ERR_LIST = 3,
1742+ NM_IPACC_TR_IE_CHAN_USAGE = 4,
1743+ NM_IPACC_TR_IE_BCCH_INFO = 6,
1744+ NM_IPACC_TR_IE_RESULT_DETAILS = 8,
1745+ NM_IPACC_TR_IE_FREQ_ERR = 18,
1746+};
Harald Welte6900c162009-06-25 20:50:57 +02001747+
1748+/* From openbsc/src/abis_nm.c */
1749+static const struct tlv_definition nm_att_tlvdef = {
1750+ .def = {
1751+ [NM_ATT_ABIS_CHANNEL] = { TLV_TYPE_FIXED, 3 },
1752+ [NM_ATT_ADD_INFO] = { TLV_TYPE_TL16V, 0 },
1753+ [NM_ATT_ADD_TEXT] = { TLV_TYPE_TL16V },
1754+ [NM_ATT_ADM_STATE] = { TLV_TYPE_TV },
1755+ [NM_ATT_ARFCN_LIST]= { TLV_TYPE_TL16V },
1756+ [NM_ATT_AUTON_REPORT] = { TLV_TYPE_TV },
1757+ [NM_ATT_AVAIL_STATUS] = { TLV_TYPE_TL16V },
1758+ [NM_ATT_BCCH_ARFCN] = { TLV_TYPE_FIXED, 2 },
1759+ [NM_ATT_BSIC] = { TLV_TYPE_TV },
1760+ [NM_ATT_BTS_AIR_TIMER] = { TLV_TYPE_TV },
1761+ [NM_ATT_CCCH_L_I_P] = { TLV_TYPE_TV },
1762+ [NM_ATT_CCCH_L_T] = { TLV_TYPE_TV },
1763+ [NM_ATT_CHAN_COMB] = { TLV_TYPE_TV },
1764+ [NM_ATT_CONN_FAIL_CRIT] = { TLV_TYPE_TL16V },
1765+ [NM_ATT_DEST] = { TLV_TYPE_TL16V },
1766+ [NM_ATT_EVENT_TYPE] = { TLV_TYPE_TV },
1767+ [NM_ATT_FILE_DATA] = { TLV_TYPE_TL16V },
1768+ [NM_ATT_FILE_ID] = { TLV_TYPE_TL16V },
1769+ [NM_ATT_FILE_VERSION] = { TLV_TYPE_TL16V },
1770+ [NM_ATT_GSM_TIME] = { TLV_TYPE_FIXED, 2 },
1771+ [NM_ATT_HSN] = { TLV_TYPE_TV },
1772+ [NM_ATT_HW_CONFIG] = { TLV_TYPE_TL16V },
1773+ [NM_ATT_HW_DESC] = { TLV_TYPE_TL16V },
1774+ [NM_ATT_INTAVE_PARAM] = { TLV_TYPE_TV },
1775+ [NM_ATT_INTERF_BOUND] = { TLV_TYPE_FIXED, 6 },
1776+ [NM_ATT_LIST_REQ_ATTR] = { TLV_TYPE_TL16V },
1777+ [NM_ATT_MAIO] = { TLV_TYPE_TV },
1778+ [NM_ATT_MANUF_STATE] = { TLV_TYPE_TV },
1779+ [NM_ATT_MANUF_THRESH] = { TLV_TYPE_TL16V },
1780+ [NM_ATT_MANUF_ID] = { TLV_TYPE_TL16V },
1781+ [NM_ATT_MAX_TA] = { TLV_TYPE_TV },
1782+ [NM_ATT_MDROP_LINK] = { TLV_TYPE_FIXED, 2 },
1783+ [NM_ATT_MDROP_NEXT] = { TLV_TYPE_FIXED, 2 },
1784+ [NM_ATT_NACK_CAUSES] = { TLV_TYPE_TV },
1785+ [NM_ATT_NY1] = { TLV_TYPE_TV },
1786+ [NM_ATT_OPER_STATE] = { TLV_TYPE_TV },
1787+ [NM_ATT_OVERL_PERIOD] = { TLV_TYPE_TL16V },
1788+ [NM_ATT_PHYS_CONF] = { TLV_TYPE_TL16V },
1789+ [NM_ATT_POWER_CLASS] = { TLV_TYPE_TV },
1790+ [NM_ATT_POWER_THRESH] = { TLV_TYPE_FIXED, 3 },
1791+ [NM_ATT_PROB_CAUSE] = { TLV_TYPE_FIXED, 3 },
1792+ [NM_ATT_RACH_B_THRESH] = { TLV_TYPE_TV },
1793+ [NM_ATT_LDAVG_SLOTS] = { TLV_TYPE_FIXED, 2 },
1794+ [NM_ATT_RAD_SUBC] = { TLV_TYPE_TV },
1795+ [NM_ATT_RF_MAXPOWR_R] = { TLV_TYPE_TV },
1796+ [NM_ATT_SITE_INPUTS] = { TLV_TYPE_TL16V },
1797+ [NM_ATT_SITE_OUTPUTS] = { TLV_TYPE_TL16V },
1798+ [NM_ATT_SOURCE] = { TLV_TYPE_TL16V },
1799+ [NM_ATT_SPEC_PROB] = { TLV_TYPE_TV },
1800+ [NM_ATT_START_TIME] = { TLV_TYPE_FIXED, 2 },
1801+ [NM_ATT_T200] = { TLV_TYPE_FIXED, 7 },
1802+ [NM_ATT_TEI] = { TLV_TYPE_TV },
1803+ [NM_ATT_TEST_DUR] = { TLV_TYPE_FIXED, 2 },
1804+ [NM_ATT_TEST_NO] = { TLV_TYPE_TV },
1805+ [NM_ATT_TEST_REPORT] = { TLV_TYPE_TL16V, },
1806+ [NM_ATT_VSWR_THRESH] = { TLV_TYPE_FIXED, 2 },
1807+ [NM_ATT_WINDOW_SIZE] = { TLV_TYPE_TV },
1808+ [NM_ATT_TSC] = { TLV_TYPE_TV },
1809+ [NM_ATT_SW_CONFIG] = { TLV_TYPE_TL16V },
1810+ [NM_ATT_SEVERITY] = { TLV_TYPE_TV },
1811+ [NM_ATT_GET_ARI] = { TLV_TYPE_TL16V },
1812+ [NM_ATT_HW_CONF_CHG] = { TLV_TYPE_TL16V },
1813+ [NM_ATT_OUTST_ALARM] = { TLV_TYPE_TV },
1814+ [NM_ATT_FILE_DATA] = { TLV_TYPE_TL16V },
1815+ [NM_ATT_MEAS_RES] = { TLV_TYPE_TL16V },
1816+ /* BS11 specifics */
1817+ [NM_ATT_BS11_ESN_FW_CODE_NO] = { TLV_TYPE_TLV },
1818+ [NM_ATT_BS11_ESN_HW_CODE_NO] = { TLV_TYPE_TLV },
1819+ [NM_ATT_BS11_ESN_PCB_SERIAL] = { TLV_TYPE_TLV },
1820+ [NM_ATT_BS11_BOOT_SW_VERS] = { TLV_TYPE_TLV },
1821+ [0xd5] = { TLV_TYPE_TLV },
1822+ [0xa8] = { TLV_TYPE_TLV },
1823+ [NM_ATT_BS11_PASSWORD] = { TLV_TYPE_TLV },
1824+ [NM_ATT_BS11_TXPWR] = { TLV_TYPE_TLV },
1825+ [NM_ATT_BS11_RSSI_OFFS] = { TLV_TYPE_TLV },
1826+ [NM_ATT_BS11_LINE_CFG] = { TLV_TYPE_TV },
1827+ [NM_ATT_BS11_L1_PROT_TYPE] = { TLV_TYPE_TV },
1828+ [NM_ATT_BS11_BIT_ERR_THESH] = { TLV_TYPE_FIXED, 2 },
1829+ [NM_ATT_BS11_DIVERSITY] = { TLV_TYPE_TLV },
1830+ [NM_ATT_BS11_LMT_LOGON_SESSION]={ TLV_TYPE_TLV },
1831+ [NM_ATT_BS11_LMT_LOGIN_TIME] = { TLV_TYPE_TLV },
1832+ [NM_ATT_BS11_LMT_USER_ACC_LEV] ={ TLV_TYPE_TLV },
1833+ [NM_ATT_BS11_LMT_USER_NAME] = { TLV_TYPE_TLV },
1834+ [NM_ATT_BS11_BTS_STATE] = { TLV_TYPE_TLV },
1835+ [NM_ATT_BS11_E1_STATE] = { TLV_TYPE_TLV },
1836+ [NM_ATT_BS11_PLL_MODE] = { TLV_TYPE_TLV },
1837+ [NM_ATT_BS11_PLL] = { TLV_TYPE_TLV },
1838+ [NM_ATT_BS11_CCLK_ACCURACY] = { TLV_TYPE_TV },
1839+ [NM_ATT_BS11_CCLK_TYPE] = { TLV_TYPE_TV },
1840+ /* ip.access specifics */
1841+ [NM_ATT_IPACC_RSL_BSC_IP] = { TLV_TYPE_FIXED, 4 },
1842+ [NM_ATT_IPACC_RSL_BSC_PORT] = { TLV_TYPE_FIXED, 2 },
1843+ [NM_ATT_IPACC_PRIM_OML_IP] = { TLV_TYPE_FIXED, 6 },
1844+ [0x95] = { TLV_TYPE_FIXED, 2 },
Harald Welte1cc3fa82009-07-01 17:40:50 +02001845+ [0x9b] = { TLV_TYPE_TL16V },
Harald Welte6900c162009-06-25 20:50:57 +02001846+ [0x85] = { TLV_TYPE_TV },
1847+
1848+ },
1849+};
1850+
1851+#endif /* _NM_H */