blob: 4b899162320291c40fe2040a6e97544da3981a9f [file] [log] [blame]
Harald Welte6900c162009-06-25 20:50:57 +02001Index: wireshark/epan/dissectors/Makefile.common
2===================================================================
3--- wireshark.orig/epan/dissectors/Makefile.common 2009-06-24 13:35:12.000000000 +0200
4+++ wireshark/epan/dissectors/Makefile.common 2009-06-24 13:35:54.000000000 +0200
5@@ -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
16+++ wireshark/epan/dissectors/packet-abis_oml.c 2009-06-24 15:26:50.000000000 +0200
17@@ -0,0 +1,776 @@
18+/* 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"
54+
55+/* initialize the protocol and registered fields */
56+static int proto_abis_oml = -1;
57+
58+/* OML header */
59+static int hf_oml_msg_disc = -1;
60+static int hf_oml_placement = -1;
61+static int hf_oml_sequence = -1;
62+static int hf_oml_length = -1;
63+/* FOM header */
64+static int hf_oml_fom_msgtype = -1;
65+static int hf_oml_fom_objclass = -1;
66+static int hf_oml_fom_inst_bts = -1;
67+static int hf_oml_fom_inst_trx = -1;
68+static int hf_oml_fom_inst_ts = -1;
69+static int hf_oml_fom_attr_tag = -1;
70+static int hf_oml_fom_attr_len = -1;
71+static int hf_oml_fom_attr_val = -1;
72+/* FOM attributes */
73+static int hf_attr_adm_state = -1;
74+static int hf_attr_oper_state = -1;
75+static int hf_attr_avail_state = -1;
76+static int hf_attr_event_type = -1;
77+static int hf_attr_severity = -1;
78+
79+/* initialize the subtree pointers */
80+static int ett_oml = -1;
81+static int ett_oml_fom = -1;
82+static int ett_oml_fom_att = -1;
83+
84+static proto_tree *top_tree;
85+
86+/* TS 12.21 Chapter 8.1 / TS 08.59 */
87+static const value_string oml_msg_disc_vals[] = {
88+ { ABIS_OM_MDISC_FOM, "Formatted O&M" },
89+ { ABIS_OM_MDISC_MMI, "MMI Transfer" },
90+ { ABIS_OM_MDISC_TRAU, "TRAU O&M" },
91+ { ABIS_OM_MDISC_MANUF, "Manufacturer specific" },
92+};
93+
94+/* TS 12.21 Chapter 8.1.1 */
95+static const value_string oml_placement_vals[] = {
96+ { ABIS_OM_PLACEMENT_ONLY, "Only" },
97+ { ABIS_OM_PLACEMENT_FIRST, "First" },
98+ { ABIS_OM_PLACEMENT_MIDDLE, "Middle" },
99+ { ABIS_OM_PLACEMENT_LAST, "Last" },
100+};
101+
102+/* TS 12.21 Chapter 9.2 */
103+static const value_string oml_fom_msgtype_vals[] = {
104+ { NM_MT_LOAD_INIT, "Software Load Init" },
105+ { NM_MT_LOAD_INIT_ACK, "Software Load Init ACK" },
106+ { NM_MT_LOAD_INIT_NACK, "Software Load Init NACK" },
107+ { NM_MT_LOAD_SEG, "Software Load Segment" },
108+ { NM_MT_LOAD_SEG_ACK, "Software Load Segment ACK" },
109+ { NM_MT_LOAD_END, "Software Load End" },
110+ { NM_MT_LOAD_END_ACK, "Software Load End ACK" },
111+ { NM_MT_LOAD_END_NACK, "Software Load End NACK" },
112+ { NM_MT_SW_ACT_REQ, "Software Activate Request" },
113+ { NM_MT_SW_ACT_REQ_ACK, "Software Activate Request ACK" },
114+ { NM_MT_SW_ACT_REQ_NACK, "Software Activate Request NACK" },
115+ { NM_MT_ACTIVATE_SW, "Activate Software" },
116+ { NM_MT_ACTIVATE_SW_ACK, "Activate Software ACK" },
117+ { NM_MT_ACTIVATE_SW_NACK, "Activate Software NACK" },
118+ { NM_MT_SW_ACTIVATED_REP, "Software Activated Report" },
119+ { NM_MT_ESTABLISH_TEI, "Establish TEI" },
120+ { NM_MT_ESTABLISH_TEI_ACK, "Establish TEI ACK" },
121+ { NM_MT_ESTABLISH_TEI_NACK, "Establish TEI NACK" },
122+ { NM_MT_CONN_TERR_SIGN, "Connect Terrestrial Signalling" },
123+ { NM_MT_CONN_TERR_SIGN_ACK, "Connect Terrestrial Signalling ACK" },
124+ { NM_MT_CONN_TERR_SIGN_NACK, "Connect Terrestrial Signalling NACK" },
125+ { NM_MT_DISC_TERR_SIGN, "Disconnect Terrestrial Signalling" },
126+ { NM_MT_DISC_TERR_SIGN_ACK, "Disconnect Terrestrial Signalling ACK" },
127+ { NM_MT_DISC_TERR_SIGN_NACK, "Disconnect Terrestrial Signalling NACK" },
128+ { NM_MT_CONN_TERR_TRAF, "Connect Terrestrial Traffic" },
129+ { NM_MT_CONN_TERR_TRAF_ACK, "Connect Terrestrial Traffic ACK" },
130+ { NM_MT_CONN_TERR_TRAF_NACK, "Connect Terrestrial Traffic NACK" },
131+ { NM_MT_DISC_TERR_TRAF, "Disconnect Terrestrial Traffic" },
132+ { NM_MT_DISC_TERR_TRAF_ACK, "Disconnect Terrestrial Traffic ACK" },
133+ { NM_MT_DISC_TERR_TRAF_NACK, "Disconnect Terrestrial Traffic NACK" },
134+ { NM_MT_CONN_MDROP_LINK, "Connect Multi-Drop Link" },
135+ { NM_MT_CONN_MDROP_LINK_ACK, "Connect Multi-Drop Link ACK" },
136+ { NM_MT_CONN_MDROP_LINK_NACK, "Connect Multi-Drop Link NACK" },
137+ { NM_MT_DISC_MDROP_LINK, "Disconnect Multi-Drop Link" },
138+ { NM_MT_DISC_MDROP_LINK_ACK, "Disconnect Multi-Drop Link ACK" },
139+ { NM_MT_DISC_MDROP_LINK_NACK, "Disconnect Multi-Drop Link NACK" },
140+ { NM_MT_SET_BTS_ATTR, "Set BTS Attributes" },
141+ { NM_MT_SET_BTS_ATTR_ACK, "Set BTS Attributes ACK" },
142+ { NM_MT_SET_BTS_ATTR_NACK, "Set BTS Attributes NACK" },
143+ { NM_MT_SET_RADIO_ATTR, "Set Radio Carrier Attributes" },
144+ { NM_MT_SET_RADIO_ATTR_ACK, "Set Radio Carrier Attributes ACK" },
145+ { NM_MT_SET_RADIO_ATTR_NACK, "Set Radio Carrier Attributes NACK" },
146+ { NM_MT_SET_CHAN_ATTR, "Set Channel Attributes" },
147+ { NM_MT_SET_CHAN_ATTR_ACK, "Set Channel Attributes ACK" },
148+ { NM_MT_SET_CHAN_ATTR_NACK, "Set Channel Attributes NACK" },
149+ { NM_MT_PERF_TEST, "Perform Test" },
150+ { NM_MT_PERF_TEST_ACK, "Perform Test ACK" },
151+ { NM_MT_PERF_TEST_NACK, "Perform Test NACK" },
152+ { NM_MT_TEST_REP, "Test Report" },
153+ { NM_MT_SEND_TEST_REP, "Send Test Report" },
154+ { NM_MT_SEND_TEST_REP_ACK, "Send Test Report ACK" },
155+ { NM_MT_SEND_TEST_REP_NACK, "Send Test Report NACK" },
156+ { NM_MT_STOP_TEST, "Stop Test" },
157+ { NM_MT_STOP_TEST_ACK, "Stop Test ACK" },
158+ { NM_MT_STOP_TEST_NACK, "Stop Test NACK" },
159+ { NM_MT_STATECHG_EVENT_REP, "State Changed Event Report" },
160+ { NM_MT_FAILURE_EVENT_REP, "Failure Event Report" },
161+ { NM_MT_STOP_EVENT_REP, "Stop Sending Event Reports" },
162+ { NM_MT_STOP_EVENT_REP_ACK, "Stop Sending Event Reports ACK" },
163+ { NM_MT_STOP_EVENT_REP_NACK, "Stop Sending Event Reports NACK" },
164+ { NM_MT_REST_EVENT_REP, "Restart Sending Event Reports" },
165+ { NM_MT_REST_EVENT_REP_ACK, "Restart Sending Event Reports ACK" },
166+ { NM_MT_REST_EVENT_REP_NACK, "Restart Sending Event Reports NACK" },
167+ { NM_MT_CHG_ADM_STATE, "Change Administrative State" },
168+ { NM_MT_CHG_ADM_STATE_ACK, "Change Administrative State ACK" },
169+ { NM_MT_CHG_ADM_STATE_NACK, "Change Administrative State NACK" },
170+ { NM_MT_CHG_ADM_STATE_REQ, "Change Administrative State Request" },
171+ { NM_MT_CHG_ADM_STATE_REQ_ACK, "Change Administrative State Request ACK" },
172+ { NM_MT_CHG_ADM_STATE_REQ_NACK, "Change Administrative State Request NACK" },
173+ { NM_MT_REP_OUTST_ALARMS, "Report Outstanding Alarms" },
174+ { NM_MT_REP_OUTST_ALARMS_ACK, "Report Outstanding Alarms ACK" },
175+ { NM_MT_REP_OUTST_ALARMS_NACK, "Report Outstanding Alarms NACK" },
176+ { NM_MT_CHANGEOVER, "Changeover" },
177+ { NM_MT_CHANGEOVER_ACK, "Changeover ACK" },
178+ { NM_MT_CHANGEOVER_NACK, "Changeover NACK" },
179+ { NM_MT_OPSTART, "Opstart" },
180+ { NM_MT_OPSTART_ACK, "Opstart ACK" },
181+ { NM_MT_OPSTART_NACK, "Opstart NACK" },
182+ { NM_MT_REINIT, "Reinitialize" },
183+ { NM_MT_REINIT_ACK, "Reinitialize ACK" },
184+ { NM_MT_REINIT_NACK, "Reinitialize NACK" },
185+ { NM_MT_SET_SITE_OUT, "Set Site Outputs" },
186+ { NM_MT_SET_SITE_OUT_ACK, "Set Site Outputs ACK" },
187+ { NM_MT_SET_SITE_OUT_NACK, "Set Site Outputs NACK" },
188+ { NM_MT_CHG_HW_CONF, "Change HW Configuration" },
189+ { NM_MT_CHG_HW_CONF_ACK, "Change HW Configuration ACK" },
190+ { NM_MT_CHG_HW_CONF_NACK, "Change HW Configuration NACK" },
191+ { NM_MT_MEAS_RES_REQ, "Measurement Result Request" },
192+ { NM_MT_MEAS_RES_RESP, "Measurement Result Response" },
193+ { NM_MT_STOP_MEAS, "Stop Measurement" },
194+ { NM_MT_START_MEAS, "Start Measurement" },
195+ { NM_MT_GET_ATTR, "Get Attributes" },
196+ { NM_MT_GET_ATTR_RESP, "Get Attributes Response" },
197+ { NM_MT_GET_ATTR_NACK, "Get Attributes NACK" },
198+ { NM_MT_SET_ALARM_THRES, "Set Alarm Threshold" },
199+ { NM_MT_SET_ALARM_THRES_ACK, "Set Alarm Threshold ACK" },
200+ { NM_MT_SET_ALARM_THRES_NACK, "Set Alarm Threshold NACK" },
201+ /* proprietary, not in the standard */
202+ { NM_MT_IPACC_RESTART, "IPA Restart" },
203+ { NM_MT_IPACC_RESTART_ACK, "IPA Restart ACK" },
204+ { NM_MT_IPACC_RSL_CONNECT, "IPA RSL Connect" },
205+ { NM_MT_IPACC_RSL_CONNECT_ACK, "IPA RSL Connect ACK" },
206+ { NM_MT_IPACC_RSL_CONNECT_NACK, "IPA RSL Connect NACK" },
207+ { NM_MT_IPACC_SET_NVATTR, "IPA Set NVRAM Attributes" },
208+ { NM_MT_IPACC_SET_NVATTR_ACK, "IPA Set NVRAM Attributes ACK" },
209+ { NM_MT_IPACC_SET_NVATTR_NACK, "IPA Set NVRAM Attributes NACK" },
210+ { NM_MT_IPACC_GET_NVATTR, "IPA Get NVRAM Attributes" },
211+ { NM_MT_IPACC_GET_NVATTR_ACK, "IPA Get NVRAM Attributes ACK" },
212+ { NM_MT_IPACC_GET_NVATTR_NACK, "IPA Get NVRAM Attributes NACK" },
213+ { NM_MT_BS11_RESET_RESOURCE, "SIE Reset Resource" },
214+ { NM_MT_BS11_BEGIN_DB_TX, "SIE Begin Database Transmission" },
215+ { NM_MT_BS11_BEGIN_DB_TX_ACK, "SIE Begin Database Transmission ACK" },
216+ { NM_MT_BS11_BEGIN_DB_TX_NACK, "SIE Begin Database Transmission NACK" },
217+ { NM_MT_BS11_END_DB_TX, "SIE End Database Transmission" },
218+ { NM_MT_BS11_END_DB_TX_ACK, "SIE End Database Transmission ACK" },
219+ { NM_MT_BS11_END_DB_TX_NACK, "SIE End Database Transmission NACK" },
220+ { NM_MT_BS11_CREATE_OBJ, "SIE Create Object" },
221+ { NM_MT_BS11_CREATE_OBJ_ACK, "SIE Create Object ACK" },
222+ { NM_MT_BS11_CREATE_OBJ_NACK, "SIE Create Object NACK" },
223+ { NM_MT_BS11_DELETE_OBJ, "SIE Delete Object" },
224+ { NM_MT_BS11_DELETE_OBJ_ACK, "SIE Delete Object ACK" },
225+ { NM_MT_BS11_DELETE_OBJ_NACK, "SIE Delete Object NACK" },
226+ { NM_MT_BS11_GET_STATE, "SIE Get State" },
227+ { NM_MT_BS11_GET_STATE_ACK, "SIE Get State ACK" },
228+ { NM_MT_BS11_LMT_LOGON, "SIE LMT Logon" },
229+ { NM_MT_BS11_LMT_LOGON_ACK, "SIE LMT Logon ACK" },
230+ { NM_MT_BS11_RESTART, "SIE Restart" },
231+ { NM_MT_BS11_RESTART_ACK, "SIE Restart ACK" },
232+ { NM_MT_BS11_DISCONNECT, "SIE Disconnect BTS" },
233+ { NM_MT_BS11_DISCONNECT_ACK, "SIE Disconnect BTS ACK" },
234+ { NM_MT_BS11_LMT_LOGOFF, "SIE LMT Logoff" },
235+ { NM_MT_BS11_LMT_LOGOFF_ACK, "SIE LMT Logoff ACK" },
236+ { NM_MT_BS11_RECONNECT, "SIE Reconnect BTS" },
237+ { NM_MT_BS11_RECONNECT_ACK, "SIE Reconnect BTS ACK" },
238+};
239+
240+/* TS 12.21 Section 9.2: Object Class */
241+static const value_string oml_fom_objclass_vals[] = {
242+ { NM_OC_SITE_MANAGER, "BTS Site Manager" },
243+ { NM_OC_BTS, "BTS" },
244+ { NM_OC_RADIO_CARRIER, "Radio Carrier" },
245+ { NM_OC_CHANNEL, "Radio Channel" },
246+ { NM_OC_BASEB_TRANSC, "Baseband Transceiver" },
247+ /* proprietary, vendor specific */
248+ { NM_OC_BS11_ADJC, "SIE Adjacend Channel" },
249+ { NM_OC_BS11_HANDOVER, "SIE Handover" },
250+ { NM_OC_BS11_PWR_CTRL, "SIE Power Control" },
251+ { NM_OC_BS11_BTSE, "SIE BTSE" },
252+ { NM_OC_BS11_RACK, "SIE Rack" },
253+ { NM_OC_BS11, "SIE SiemensHW" },
254+ { NM_OC_BS11_TEST, "SIE Test" },
255+ { NM_OC_BS11_ENVABTSE, "SIE EnvaBTSE" },
256+ { NM_OC_BS11_BPORT, "SIE BPort" },
257+ { NM_OC_GPRS_NSE, "GPRS NSE" },
258+ { NM_OC_GPRS_CELL, "GPRS Cell" },
259+ { NM_OC_GPRS_NSVC0, "GPRS NSVC0" },
260+ { NM_OC_GPRS_NSVC1, "GPRS NSVC1" },
261+ { NM_OC_NULL, "NULL" },
262+};
263+
264+/* TS 12.21 Section 9.4: Attributes */
265+static const value_string oml_fom_attr_vals[] = {
266+ { NM_ATT_ABIS_CHANNEL, "A-bis Channel" },
267+ { NM_ATT_ADD_INFO, "Additional Information" },
268+ { NM_ATT_ADD_TEXT, "Additional Text" },
269+ { NM_ATT_ADM_STATE, "Administrative State" },
270+ { NM_ATT_ARFCN_LIST, "ARFCN List" },
271+ { NM_ATT_AUTON_REPORT, "Autonomously Report" },
272+ { NM_ATT_AVAIL_STATUS, "Availability Status" },
273+ { NM_ATT_BCCH_ARFCN, "BCCH ARFCN" },
274+ { NM_ATT_BSIC, "BSIC" },
275+ { NM_ATT_BTS_AIR_TIMER, "BTS Air Timer" },
276+ { NM_ATT_CCCH_L_I_P, "CCCH Load Indication Period" },
277+ { NM_ATT_CCCH_L_T, "CCCH Load Threshold" },
278+ { NM_ATT_CHAN_COMB, "Channel Combination" },
279+ { NM_ATT_CONN_FAIL_CRIT, "Connection Fail Criterion" },
280+ { NM_ATT_DEST, "Destination" },
281+ { NM_ATT_EVENT_TYPE, "Event Type" },
282+ { NM_ATT_FILE_ID, "File ID" },
283+ { NM_ATT_FILE_VERSION, "File Version" },
284+ { NM_ATT_GSM_TIME, "GSM Time" },
285+ { NM_ATT_HSN, "HSN" },
286+ { NM_ATT_HW_CONFIG, "HW Configuration" },
287+ { NM_ATT_HW_DESC, "HW Description" },
288+ { NM_ATT_INTAVE_PARAM, "Intave Parameter" },
289+ { NM_ATT_LIST_REQ_ATTR, "List of required Attributes" },
290+ { NM_ATT_MAIO, "MAIO" },
291+ { NM_ATT_MANUF_STATE, "Manufacturer Dependent State" },
292+ { NM_ATT_MANUF_THRESH, "Manufacturer Dependent Thresholds" },
293+ { NM_ATT_MANUF_ID, "Manufacturer Id" },
294+ { NM_ATT_MAX_TA, "Maximum Timing Advance" },
295+ { NM_ATT_MDROP_LINK, "Multi-drop BSC Link" },
296+ { NM_ATT_MDROP_NEXT, "Multi-drop next BTS Link" },
297+ { NM_ATT_NACK_CAUSES, "NACK Causes" },
298+ { NM_ATT_NY1, "Ny1" },
299+ { NM_ATT_OPER_STATE, "Operational State" },
300+ { NM_ATT_OVERL_PERIOD, "Overload Period" },
301+ { NM_ATT_PHYS_CONF, "Physical Config" },
302+ { NM_ATT_POWER_CLASS, "Power Class" },
303+ { NM_ATT_POWER_THRESH, "Power Output Thresholds" },
304+ { NM_ATT_PROB_CAUSE, "Probable Cause" },
305+ { NM_ATT_RACH_B_THRESH, "RACH Busy Threshold" },
306+ { NM_ATT_LDAVG_SLOTS, "RACH Load Averaging Slots" },
307+ { NM_ATT_RAD_SUBC, "Radio Sub Channel" },
308+ { NM_ATT_RF_MAXPOWR_R, "RF Max Power Reduction" },
309+ { NM_ATT_SITE_INPUTS, "Site Inputs" },
310+ { NM_ATT_SITE_OUTPUTS, "Site Outputs" },
311+ { NM_ATT_SOURCE, "Source" },
312+ { NM_ATT_SPEC_PROB, "Specific Problems" },
313+ { NM_ATT_START_TIME, "Starting Time" },
314+ { NM_ATT_T200, "T200" },
315+ { NM_ATT_TEI, "TEI" },
316+ { NM_ATT_TEST_DUR, "Test Duration" },
317+ { NM_ATT_TEST_NO, "Test No" },
318+ { NM_ATT_TEST_REPORT, "Test Report Info" },
319+ { NM_ATT_VSWR_THRESH, "VSWR Thresholds " },
320+ { NM_ATT_WINDOW_SIZE, "Window Size" },
321+ { NM_ATT_BS11_RSSI_OFFS, "SIE RSSI Offset" },
322+ { NM_ATT_BS11_TXPWR, "SIE TX Power" },
323+ { NM_ATT_BS11_DIVERSITY, "SIE Diversity" },
324+ { NM_ATT_TSC, "Training Sequence Code" },
325+ { NM_ATT_SW_CONFIG, "SW Configuration" },
326+ { NM_ATT_SW_DESCR, "SW Description" },
327+ { NM_ATT_SEVERITY, "Perceived Severity" },
328+ { NM_ATT_GET_ARI, "Get ARI" },
329+ { NM_ATT_HW_CONF_CHG, "HW Configuration Change" },
330+ { NM_ATT_OUTST_ALARM, "Outstanding Alarm" },
331+ { NM_ATT_FILE_DATA, "File Data" },
332+ { NM_ATT_MEAS_RES, "Measurement Result" },
333+ { NM_ATT_MEAS_TYPE, "Measurement Type" },
334+ { NM_ATT_BS11_ESN_FW_CODE_NO, "SIE ESN FW Code Number" },
335+ { NM_ATT_BS11_ESN_HW_CODE_NO, "SIE ESN HW Code Number" },
336+ { NM_ATT_BS11_ESN_PCB_SERIAL, "SIE ESN PCB Serial Number" },
337+ { NM_ATT_BS11_EXCESSIVE_DISTANCE, "SIE Excessive Distance" },
338+ { NM_ATT_BS11_ALL_TEST_CATG, "SIE All Test Categories" },
339+ { NM_ATT_BS11_BTSLS_HOPPING, "SIE BTS LS Hopping" },
340+ { NM_ATT_BS11_CELL_ALLOC_NR, "SIE Cell Allocation Number" },
341+ { NM_ATT_BS11_CELL_GLOBAL_ID, "SIE Cell Global ID" },
342+ { NM_ATT_BS11_ENA_INTERF_CLASS, "SIE Enable Interference Class" },
343+ /* FIXME */
344+ { NM_ATT_BS11_ENA_MS_PWR_CTRL, "SIE Enable MS Power Control" },
345+ { NM_ATT_BS11_ENA_PWR_BDGT_HO, "SIE Enable Power Budget HO" },
346+ { NM_ATT_BS11_ENA_RXLEV_HO, "SIE Enable RxLevel HO" },
347+ { NM_ATT_BS11_ENA_RXQUAL_HO, "SIE Enable RxQual HO" },
348+ { NM_ATT_BS11_FACCH_QUAL, "SIE FACCH Quality" },
349+ { NM_ATT_IPACC_RSL_BSC_IP, "IPA BSC RSL IP Address" },
350+ { NM_ATT_IPACC_RSL_BSC_PORT, "IPA BSC RSL TCP Port" },
351+ { NM_ATT_IPACC_LOCATION, "IPA Location Name" },
352+ { NM_ATT_IPACC_UNIT_ID, "IPA Unit ID" },
353+ { NM_ATT_IPACC_UNIT_NAME, "IPA Unit Name" },
354+ { NM_ATT_IPACC_PRIM_OML_IP, "IPA Primary OML IP Address" },
355+ { NM_ATT_IPACC_SEC_OML_IP, "IPA Secondary OML IP Address" },
356+ /* FIXME: More SIE */
357+};
358+
359+/* Section 9.4.4: Administrative State */
360+static const value_string oml_adm_state_vals[] = {
361+ { NM_STATE_LOCKED, "Locked" },
362+ { NM_STATE_UNLOCKED, "Unlocked" },
363+ { NM_STATE_SHUTDOWN, "Shutdown" },
364+ { NM_STATE_NULL, "Null" },
365+};
366+
367+static const value_string oml_oper_state_vals[] = {
368+ { 1, "Disabled" },
369+ { 2, "Enabled" },
370+ { 0xff, "NULL" },
371+};
372+
373+/* Section 9.4.7 Availability Status */
374+static const value_string oml_avail_state_vals[] = {
375+ { 0, "In test" },
376+ { 1, "Failed" },
377+ { 2, "Power off" },
378+ { 3, "Off line" },
379+ { 5, "Dependency" },
380+ { 6, "Degraded" },
381+ { 7, "Not installed" },
382+ { 0xff, "OK" },
383+};
384+
385+/* Section 9.4.13: Channel Combination */
386+static const value_string oml_chan_comb_vals[] = {
387+ { NM_CHANC_TCHFull, "TCH/F" },
388+ { NM_CHANC_TCHHalf, "TCH/H" },
389+ { NM_CHANC_TCHHalf2, "TCH/H 2" },
390+ { NM_CHANC_SDCCH, "SDCCH" },
391+ { NM_CHANC_mainBCCH, "Main BCCH" },
392+ { NM_CHANC_BCCHComb, "Combined BCCH" },
393+ { NM_CHANC_BCCH, "BCCH" },
394+ { NM_CHANC_BCCH_CBCH, "BCCH+CBCH" },
395+ { NM_CHANC_SDCCH_CBCH, "SDCCH+CBCH" },
396+};
397+
398+/* Section 9.4.16: Event Type */
399+static const value_string oml_event_type_vals[] = {
400+ { NM_EVT_COMM_FAIL, "Communication Failure" },
401+ { NM_EVT_QOS_FAIL, "QoS Failure" },
402+ { NM_EVT_PROC_FAIL, "Processor Failure" },
403+ { NM_EVT_EQUIP_FAIL, "Equipment Failure" },
404+ { NM_EVT_ENV_FAIL, "Environment Failure" },
405+};
406+
407+/* Section 9.4.63: Perceived Severity */
408+static const value_string oml_severity_vals[] = {
409+ { NM_SEVER_CEASED, "Ceased" },
410+ { NM_SEVER_CRITICAL, "Critical" },
411+ { NM_SEVER_MAJOR, "Major" },
412+ { NM_SEVER_MINOR, "Minor" },
413+ { NM_SEVER_WARNING, "Warning" },
414+ { NM_SEVER_INDETERMINATE, "Indeterminate" },
415+};
416+
417+/* Section 9.4.36: NACK Causes */
418+static const value_string oml_nack_cause[] = {
419+ { NM_NACK_INCORR_STRUCT, "Incorrect message structure" },
420+ { NM_NACK_MSGTYPE_INVAL, "Invalid message type value" },
421+ { NM_NACK_OBJCLASS_INVAL, "Invalid Object class value" },
422+ { NM_NACK_OBJCLASS_NOTSUPP, "Object Class not supported" },
423+ { NM_NACK_BTSNR_UNKN, "BTS Number unknown" },
424+ { NM_NACK_TRXNR_UNKN, "TRX Number unknown" },
425+ { NM_NACK_OBJINST_UNKN, "Object Instance unknown" },
426+ { NM_NACK_ATTRID_INVAL, "Invalid Attribute ID value" },
427+ { NM_NACK_ATTRID_NOTSUPP, "Attribute ID not supported" },
428+ { NM_NACK_PARAM_RANGE, "Parameter value out of range" },
429+ { NM_NACK_ATTRLIST_INCONSISTENT, "Inconsistency in Attribute list" },
430+ { NM_NACK_SPEC_IMPL_NOTSUPP, "Specified Implementation not supported" },
431+ { NM_NACK_CANT_PERFORM, "Message cannot be performed" },
432+ { NM_NACK_RES_NOTIMPL, "Resource not implemented" },
433+ { NM_NACK_RES_NOTAVAIL, "Resource not available" },
434+ { NM_NACK_FREQ_NOTAVAIL, "Frequency not available" },
435+ { NM_NACK_TEST_NOTSUPP, "Test not supported" },
436+ { NM_NACK_CAPACITY_RESTR, "Capacity restrictions" },
437+ { NM_NACK_PHYSCFG_NOTPERFORM, "Phys config cannot be performed" },
438+ { NM_NACK_TEST_NOTINIT, "Test not initiated" },
439+ { NM_NACK_PHYSCFG_NOTRESTORE, "Phys config cannot be restored" },
440+ { NM_NACK_TEST_NOSUCH, "No such Test" },
441+ { NM_NACK_TEST_NOSTOP, "Test cannot be stopped" },
442+ { NM_NACK_MSGINCONSIST_PHYSCFG, "Message inconsisten with physical config" },
443+ { NM_NACK_FILE_INCOMPLETE, "Complete file not received" },
444+ { NM_NACK_FILE_NOTAVAIL, "File not available at destination" },
445+ { NM_NACK_FILE_NOTACTIVATE, "File cannot be activated" },
446+ { NM_NACK_REQ_NOT_GRANT, "Request not granted" },
447+ { NM_NACK_WAIT, "Wait" },
448+ { NM_NACK_NOTH_REPORT_EXIST, "Nothing reportable existing" },
449+ { NM_NACK_MEAS_NOTSUPP, "Measurement not supported" },
450+ { NM_NACK_MEAS_NOTSTART, "Measurement not started" },
451+ { 0xff, "NULL" },
452+};
453+
454+static gint
455+dissect_oml_attrs(tvbuff_t *tvb, int base_offs, packet_info *pinfo,
456+ proto_tree *tree)
457+{
458+ int offset = base_offs;
459+
460+ while (tvb_reported_length_remaining(tvb, offset) != 0) {
461+ guint8 tag, val8;
462+ guint16 val16;
463+ unsigned int len, len_len, hlen;
464+ struct tlv_def *tdef;
465+ proto_item *ti;
466+ proto_tree *att_tree;
467+
468+ tag = tvb_get_guint8(tvb, offset);
469+ tdef = &nm_att_tlvdef.def[tag];
470+
471+ switch (tdef->type) {
472+ case TLV_TYPE_FIXED:
473+ hlen = 1;
474+ len_len = 0;
475+ len = tdef->fixed_len;
476+ break;
477+ case TLV_TYPE_T:
478+ hlen = 1;
479+ len_len = 0;
480+ len = 0;
481+ break;
482+ case TLV_TYPE_TV:
483+ hlen = 1;
484+ len_len = 0;
485+ len = 1;
486+ break;
487+ case TLV_TYPE_TLV:
488+ hlen = 2;
489+ len_len = 1;
490+ len = tvb_get_guint8(tvb, offset+1);
491+ break;
492+ case TLV_TYPE_TL16V:
493+ hlen = 3;
494+ len_len = 2;
495+ len = tvb_get_guint8(tvb, offset+1) << 8 |
496+ tvb_get_guint8(tvb, offset+2);
497+ break;
498+ }
499+
500+ ti = proto_tree_add_item(tree, hf_oml_fom_attr_tag, tvb,
501+ offset, 1, FALSE);
502+ att_tree = proto_item_add_subtree(ti, ett_oml_fom_att);
503+ proto_tree_add_uint(att_tree, hf_oml_fom_attr_len, tvb,
504+ offset+1, len_len, len);
505+ offset += hlen;
506+
507+ switch (tag) {
508+ /* parse only the most common IE for now */
509+ case NM_ATT_ABIS_CHANNEL:
510+ break;
511+ case NM_ATT_ADM_STATE:
512+ proto_tree_add_item(att_tree, hf_attr_adm_state, tvb,
513+ offset, len, FALSE);
514+ if (check_col(pinfo->cinfo, COL_INFO)) {
515+ val8 = tvb_get_guint8(tvb, offset);
516+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
517+ val_to_str(val8,
518+ oml_adm_state_vals,
519+ "%02x"));
520+ }
521+ break;
522+ case NM_ATT_ARFCN_LIST:
523+ break;
524+ case NM_ATT_AVAIL_STATUS:
525+ proto_tree_add_item(att_tree, hf_attr_avail_state, tvb,
526+ offset, len, FALSE);
527+ if (check_col(pinfo->cinfo, COL_INFO)) {
528+ /* Availability status can have length 0 */
529+ if (len)
530+ val8 = tvb_get_guint8(tvb, offset);
531+ else
532+ val8 = 0xff;
533+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
534+ val_to_str(val8,
535+ oml_avail_state_vals,
536+ "%02x"));
537+ }
538+
539+ break;
540+ case NM_ATT_BCCH_ARFCN:
541+ break;
542+ case NM_ATT_BSIC:
543+ break;
544+ case NM_ATT_CHAN_COMB:
545+ break;
546+ case NM_ATT_EVENT_TYPE:
547+ proto_tree_add_item(att_tree, hf_attr_event_type, tvb,
548+ offset, len, FALSE);
549+ break;
550+ case NM_ATT_FILE_ID:
551+ break;
552+ case NM_ATT_FILE_VERSION:
553+ break;
554+ case NM_ATT_GSM_TIME:
555+ break;
556+ case NM_ATT_MANUF_STATE:
557+ break;
558+ case NM_ATT_OPER_STATE:
559+ proto_tree_add_item(att_tree, hf_attr_oper_state, tvb,
560+ offset, len, FALSE);
561+ if (check_col(pinfo->cinfo, COL_INFO)) {
562+ val8 = tvb_get_guint8(tvb, offset);
563+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
564+ val_to_str(val8,
565+ oml_oper_state_vals,
566+ "%02x"));
567+ }
568+ break;
569+ case NM_ATT_TEI:
570+ break;
571+ case NM_ATT_TSC:
572+ break;
573+ case NM_ATT_SEVERITY:
574+ proto_tree_add_item(att_tree, hf_attr_severity, tvb,
575+ offset, len, FALSE);
576+ break;
577+
578+ /* proprietary ip.access extensions */
579+ case NM_ATT_IPACC_RSL_BSC_IP:
580+ break;
581+ case NM_ATT_IPACC_RSL_BSC_PORT:
582+ break;
583+ case NM_ATT_IPACC_LOCATION:
584+ break;
585+ case NM_ATT_IPACC_UNIT_ID:
586+ break;
587+ case NM_ATT_IPACC_UNIT_NAME:
588+ break;
589+ case NM_ATT_IPACC_PRIM_OML_IP:
590+ break;
591+ case NM_ATT_IPACC_SEC_OML_IP:
592+ break;
593+ default:
594+ proto_tree_add_item(att_tree, hf_oml_fom_attr_val, tvb,
595+ offset, len, FALSE);
596+ }
597+ offset += len;
598+ }
599+ return offset;
600+}
601+
602+static int
603+dissect_oml_fom(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, int offset)
604+{
605+ guint8 msg_type, obj_class, bts_nr, trx_nr, ts_nr;
606+ proto_item *ti;
607+ proto_tree *fom_tree;
608+
609+ msg_type = tvb_get_guint8(tvb, offset);
610+ obj_class = tvb_get_guint8(tvb, offset+1);
611+ bts_nr = tvb_get_guint8(tvb, offset+2);
612+ trx_nr = tvb_get_guint8(tvb, offset+3);
613+ ts_nr = tvb_get_guint8(tvb, offset+4);
614+ if (check_col(pinfo->cinfo, COL_INFO)) {
615+ col_append_fstr(pinfo->cinfo, COL_INFO, "%s(%02x,%02x,%02x) %s ",
616+ val_to_str(obj_class, oml_fom_objclass_vals, "%02x"),
617+ bts_nr, trx_nr, ts_nr,
618+ val_to_str(msg_type, oml_fom_msgtype_vals,
619+ "unknown 0x%x"));
620+ }
621+ ti = proto_tree_add_item(tree, hf_oml_fom_msgtype, tvb, offset++, 1, FALSE);
622+ fom_tree = proto_item_add_subtree(ti, ett_oml_fom);
623+ proto_tree_add_item(fom_tree, hf_oml_fom_objclass, tvb, offset++, 1, FALSE);
624+ proto_tree_add_item(fom_tree, hf_oml_fom_inst_bts, tvb, offset++, 1, FALSE);
625+ proto_tree_add_item(fom_tree, hf_oml_fom_inst_trx, tvb, offset++, 1, FALSE);
626+ proto_tree_add_item(fom_tree, hf_oml_fom_inst_ts, tvb, offset++, 1, FALSE);
627+
628+
629+ /* dissect the TLV objects in the message body */
630+ offset = dissect_oml_attrs(tvb, offset, pinfo, fom_tree);
631+
632+ return offset;
633+}
634+
635+
636+static void
637+dissect_abis_oml(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
638+{
639+ proto_item *ti;
640+ proto_tree *oml_tree;
641+ guint8 msg_type;
642+
643+ int offset = 0;
644+
645+ if (check_col(pinfo->cinfo, COL_PROTOCOL))
646+ col_set_str(pinfo->cinfo, COL_PROTOCOL, "OML");
647+#if 0
648+ if (check_col(pinfo->cinfo, COL_INFO))
649+ col_clear(pinfo->cinfo, COL_INFO);
650+#endif
651+
652+ top_tree = tree;
653+ if (tree) {
654+ u_int8_t msg_disc = tvb_get_guint8(tvb, offset);
655+
656+ ti = proto_tree_add_item(tree, proto_abis_oml, tvb, 0, -1, FALSE);
657+ oml_tree = proto_item_add_subtree(ti, ett_oml);
658+
659+ proto_tree_add_item(oml_tree, hf_oml_msg_disc, tvb, offset++, 1, FALSE);
660+ proto_tree_add_item(oml_tree, hf_oml_placement, tvb, offset++, 1, FALSE);
661+ proto_tree_add_item(oml_tree, hf_oml_sequence, tvb, offset++, 1, FALSE);
662+ proto_tree_add_item(oml_tree, hf_oml_length, tvb, offset++, 1, FALSE);
663+
664+ switch (msg_disc) {
665+ case ABIS_OM_MDISC_FOM:
666+ offset = dissect_oml_fom(tvb, pinfo, oml_tree, offset);
667+ break;
668+ case ABIS_OM_MDISC_MMI:
669+ case ABIS_OM_MDISC_TRAU:
670+ case ABIS_OM_MDISC_MANUF:
671+ default:
672+ break;
673+ }
674+ }
675+}
676+
677+void
678+proto_register_abis_oml(void)
679+{
680+ static hf_register_info hf[] = {
681+ { &hf_oml_msg_disc,
682+ { "Message Discriminator", "oml.msg_dsc",
683+ FT_UINT8, BASE_HEX, VALS(oml_msg_disc_vals), 0,
684+ "Message Discriminator", HFILL }
685+ },
686+ { &hf_oml_placement,
687+ { "Placement Indicator", "oml.placement",
688+ FT_UINT8, BASE_HEX, VALS(oml_placement_vals), 0,
689+ "Placement Indicator", HFILL }
690+ },
691+ { &hf_oml_sequence,
692+ { "Sequence Number", "oml.sequence",
693+ FT_UINT8, BASE_HEX, NULL, 0,
694+ "Sequence Number", HFILL }
695+ },
696+ { &hf_oml_length,
697+ { "Length Indicator", "oml.length",
698+ FT_UINT8, BASE_DEC, NULL, 0,
699+ "Length Indicator", HFILL }
700+ },
701+ { &hf_oml_fom_msgtype,
702+ { "FOM Message Type", "oml.fom.msg_type",
703+ FT_UINT8, BASE_HEX, VALS(oml_fom_msgtype_vals), 0,
704+ "FOM Message Type", HFILL }
705+ },
706+ { &hf_oml_fom_objclass,
707+ { "FOM Object Class", "oml.fom.obj_class",
708+ FT_UINT8, BASE_HEX, VALS(oml_fom_objclass_vals), 0,
709+ "FOM Object Class", HFILL }
710+ },
711+ { &hf_oml_fom_inst_bts,
712+ { "FOM Object Instance BTS", "oml.fom.obj_inst.bts",
713+ FT_UINT8, BASE_DEC, NULL, 0,
714+ "FOM Object Instance TRX", HFILL }
715+ },
716+ { &hf_oml_fom_inst_trx,
717+ { "FOM Object Instance TRX", "oml.fom.obj_inst.trx",
718+ FT_UINT8, BASE_DEC, NULL, 0,
719+ "FOM Object Instance TRX", HFILL }
720+ },
721+ { &hf_oml_fom_inst_ts,
722+ { "FOM Object Instance TS", "oml.fom.obj_inst.ts",
723+ FT_UINT8, BASE_DEC, NULL, 0,
724+ "FOM Object Instance TS", HFILL }
725+ },
726+ { &hf_oml_fom_attr_tag,
727+ { "FOM Attribute ID", "oml.fom.attr_id",
728+ FT_UINT8, BASE_HEX, VALS(oml_fom_attr_vals), 0,
729+ "FOM Attribute ID", HFILL }
730+ },
731+ { &hf_oml_fom_attr_len,
732+ { "FOM Attribute Length", "oml.fom.attr_len",
733+ FT_UINT16, BASE_DEC, NULL, 0,
734+ "FOM Attribute Length", HFILL }
735+ },
736+ { &hf_oml_fom_attr_val,
737+ { "FOM Attribute Value", "oml.fom.attr_val",
738+ FT_BYTES, BASE_HEX, NULL, 0,
739+ "FOM Attribute Value", HFILL }
740+ },
741+
742+
743+
744+ /* OML Attributes */
745+ { &hf_attr_adm_state,
746+ { "Administrative State", "oml.fom.attr.adm_state",
747+ FT_UINT8, BASE_HEX, VALS(oml_adm_state_vals), 0,
748+ "Administrative State", HFILL }
749+ },
750+ { &hf_attr_oper_state,
751+ { "Operational State", "oml.fom.attr.oper_state",
752+ FT_UINT8, BASE_HEX, VALS(oml_oper_state_vals), 0,
753+ "Operational State", HFILL }
754+ },
755+ { &hf_attr_avail_state,
756+ { "Availability Status", "oml.fom.attr.avail_state",
757+ FT_UINT8, BASE_HEX, VALS(oml_avail_state_vals), 0,
758+ "Availability Status", HFILL }
759+ },
760+ { &hf_attr_event_type,
761+ { "Event Type", "oml.fom.attr.event_type",
762+ FT_UINT8, BASE_HEX, VALS(oml_event_type_vals), 0,
763+ "Event Type", HFILL }
764+ },
765+ { &hf_attr_severity,
766+ { "Severity", "oml.fom.attr.severity",
767+ FT_UINT8, BASE_HEX, VALS(oml_severity_vals), 0,
768+ "Severity", HFILL }
769+ },
770+ };
771+ static gint *ett[] = {
772+ &ett_oml,
773+ &ett_oml_fom,
774+ &ett_oml_fom_att,
775+ };
776+
777+ proto_abis_oml = proto_register_protocol("GSM A-bis OML", "OML",
778+ "gsm_abis_oml");
779+
780+ proto_register_field_array(proto_abis_oml, hf, array_length(hf));
781+
782+ proto_register_subtree_array(ett, array_length(ett));
783+
784+ register_dissector("gsm_abis_oml", dissect_abis_oml, proto_abis_oml);
785+}
786+
787+void
788+proto_reg_handoff_abis_oml(void)
789+{
790+ dissector_handle_t abis_oml_handle;
791+
792+ abis_oml_handle = find_dissector("abis_oml");
793+}
794Index: wireshark/epan/dissectors/packet-abis_oml.h
795===================================================================
796--- /dev/null 1970-01-01 00:00:00.000000000 +0000
797+++ wireshark/epan/dissectors/packet-abis_oml.h 2009-06-24 13:35:54.000000000 +0200
798@@ -0,0 +1,665 @@
799+/* GSM Network Management messages on the A-bis interface
800+ * 3GPP TS 12.21 version 8.0.0 Release 1999 / ETSI TS 100 623 V8.0.0 */
801+
802+/* (C) 2008-2009 by Harald Welte <laforge@gnumonks.org>
803+ * All Rights Reserved
804+ *
805+ * This program is free software; you can redistribute it and/or modify
806+ * it under the terms of the GNU General Public License as published by
807+ * the Free Software Foundation; either version 2 of the License, or
808+ * (at your option) any later version.
809+ *
810+ * This program is distributed in the hope that it will be useful,
811+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
812+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
813+ * GNU General Public License for more details.
814+ *
815+ * You should have received a copy of the GNU General Public License along
816+ * with this program; if not, write to the Free Software Foundation, Inc.,
817+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
818+ *
819+ */
820+
821+#ifndef __PACKET_ABIS_OML_H__
822+#define __PACKET_ABIS_OML_H__
823+
824+#include <sys/types.h>
825+
826+/* From openbsc/include/openbsc/abis_nm.h */
827+
828+/* generic header in front of every OML message according to TS 08.59 */
829+struct abis_om_hdr {
830+ guint8 mdisc;
831+ guint8 placement;
832+ guint8 sequence;
833+ guint8 length;
834+ guint8 data[0];
835+} __attribute__ ((packed));
836+
837+#define ABIS_OM_MDISC_FOM 0x80
838+#define ABIS_OM_MDISC_MMI 0x40
839+#define ABIS_OM_MDISC_TRAU 0x20
840+#define ABIS_OM_MDISC_MANUF 0x10
841+#define ABIS_OM_PLACEMENT_ONLY 0x80
842+#define ABIS_OM_PLACEMENT_FIRST 0x40
843+#define ABIS_OM_PLACEMENT_MIDDLE 0x20
844+#define ABIS_OM_PLACEMENT_LAST 0x10
845+
846+struct abis_om_obj_inst {
847+ guint8 bts_nr;
848+ guint8 trx_nr;
849+ guint8 ts_nr;
850+} __attribute__ ((packed));
851+
852+struct abis_om_fom_hdr {
853+ guint8 msg_type;
854+ guint8 obj_class;
855+ struct abis_om_obj_inst obj_inst;
856+ guint8 data[0];
857+} __attribute__ ((packed));
858+
859+#define ABIS_OM_FOM_HDR_SIZE (sizeof(struct abis_om_hdr) + sizeof(struct abis_om_fom_hdr))
860+
861+/* Section 9.1: Message Types */
862+enum abis_nm_msgtype {
863+ /* SW Download Management Messages */
864+ NM_MT_LOAD_INIT = 0x01,
865+ NM_MT_LOAD_INIT_ACK,
866+ NM_MT_LOAD_INIT_NACK,
867+ NM_MT_LOAD_SEG,
868+ NM_MT_LOAD_SEG_ACK,
869+ NM_MT_LOAD_ABORT,
870+ NM_MT_LOAD_END,
871+ NM_MT_LOAD_END_ACK,
872+ NM_MT_LOAD_END_NACK,
873+ NM_MT_SW_ACT_REQ, /* BTS->BSC */
874+ NM_MT_SW_ACT_REQ_ACK,
875+ NM_MT_SW_ACT_REQ_NACK,
876+ NM_MT_ACTIVATE_SW, /* BSC->BTS */
877+ NM_MT_ACTIVATE_SW_ACK,
878+ NM_MT_ACTIVATE_SW_NACK,
879+ NM_MT_SW_ACTIVATED_REP, /* 0x10 */
880+ /* A-bis Interface Management Messages */
881+ NM_MT_ESTABLISH_TEI = 0x21,
882+ NM_MT_ESTABLISH_TEI_ACK,
883+ NM_MT_ESTABLISH_TEI_NACK,
884+ NM_MT_CONN_TERR_SIGN,
885+ NM_MT_CONN_TERR_SIGN_ACK,
886+ NM_MT_CONN_TERR_SIGN_NACK,
887+ NM_MT_DISC_TERR_SIGN,
888+ NM_MT_DISC_TERR_SIGN_ACK,
889+ NM_MT_DISC_TERR_SIGN_NACK,
890+ NM_MT_CONN_TERR_TRAF,
891+ NM_MT_CONN_TERR_TRAF_ACK,
892+ NM_MT_CONN_TERR_TRAF_NACK,
893+ NM_MT_DISC_TERR_TRAF,
894+ NM_MT_DISC_TERR_TRAF_ACK,
895+ NM_MT_DISC_TERR_TRAF_NACK,
896+ /* Transmission Management Messages */
897+ NM_MT_CONN_MDROP_LINK = 0x31,
898+ NM_MT_CONN_MDROP_LINK_ACK,
899+ NM_MT_CONN_MDROP_LINK_NACK,
900+ NM_MT_DISC_MDROP_LINK,
901+ NM_MT_DISC_MDROP_LINK_ACK,
902+ NM_MT_DISC_MDROP_LINK_NACK,
903+ /* Air Interface Management Messages */
904+ NM_MT_SET_BTS_ATTR = 0x41,
905+ NM_MT_SET_BTS_ATTR_ACK,
906+ NM_MT_SET_BTS_ATTR_NACK,
907+ NM_MT_SET_RADIO_ATTR,
908+ NM_MT_SET_RADIO_ATTR_ACK,
909+ NM_MT_SET_RADIO_ATTR_NACK,
910+ NM_MT_SET_CHAN_ATTR,
911+ NM_MT_SET_CHAN_ATTR_ACK,
912+ NM_MT_SET_CHAN_ATTR_NACK,
913+ /* Test Management Messages */
914+ NM_MT_PERF_TEST = 0x51,
915+ NM_MT_PERF_TEST_ACK,
916+ NM_MT_PERF_TEST_NACK,
917+ NM_MT_TEST_REP,
918+ NM_MT_SEND_TEST_REP,
919+ NM_MT_SEND_TEST_REP_ACK,
920+ NM_MT_SEND_TEST_REP_NACK,
921+ NM_MT_STOP_TEST,
922+ NM_MT_STOP_TEST_ACK,
923+ NM_MT_STOP_TEST_NACK,
924+ /* State Management and Event Report Messages */
925+ NM_MT_STATECHG_EVENT_REP = 0x61,
926+ NM_MT_FAILURE_EVENT_REP,
927+ NM_MT_STOP_EVENT_REP,
928+ NM_MT_STOP_EVENT_REP_ACK,
929+ NM_MT_STOP_EVENT_REP_NACK,
930+ NM_MT_REST_EVENT_REP,
931+ NM_MT_REST_EVENT_REP_ACK,
932+ NM_MT_REST_EVENT_REP_NACK,
933+ NM_MT_CHG_ADM_STATE,
934+ NM_MT_CHG_ADM_STATE_ACK,
935+ NM_MT_CHG_ADM_STATE_NACK,
936+ NM_MT_CHG_ADM_STATE_REQ,
937+ NM_MT_CHG_ADM_STATE_REQ_ACK,
938+ NM_MT_CHG_ADM_STATE_REQ_NACK,
939+ NM_MT_REP_OUTST_ALARMS = 0x93,
940+ NM_MT_REP_OUTST_ALARMS_ACK,
941+ NM_MT_REP_OUTST_ALARMS_NACK,
942+ /* Equipment Management Messages */
943+ NM_MT_CHANGEOVER = 0x71,
944+ NM_MT_CHANGEOVER_ACK,
945+ NM_MT_CHANGEOVER_NACK,
946+ NM_MT_OPSTART,
947+ NM_MT_OPSTART_ACK,
948+ NM_MT_OPSTART_NACK,
949+ NM_MT_REINIT,
950+ NM_MT_REINIT_ACK,
951+ NM_MT_REINIT_NACK,
952+ NM_MT_SET_SITE_OUT, /* BS11: get alarm ?!? */
953+ NM_MT_SET_SITE_OUT_ACK,
954+ NM_MT_SET_SITE_OUT_NACK,
955+ NM_MT_CHG_HW_CONF = 0x90,
956+ NM_MT_CHG_HW_CONF_ACK,
957+ NM_MT_CHG_HW_CONF_NACK,
958+ /* Measurement Management Messages */
959+ NM_MT_MEAS_RES_REQ = 0x8a,
960+ NM_MT_MEAS_RES_RESP,
961+ NM_MT_STOP_MEAS,
962+ NM_MT_START_MEAS,
963+ /* Other Messages */
964+ NM_MT_GET_ATTR = 0x81,
965+ NM_MT_GET_ATTR_RESP,
966+ NM_MT_GET_ATTR_NACK,
967+ NM_MT_SET_ALARM_THRES,
968+ NM_MT_SET_ALARM_THRES_ACK,
969+ NM_MT_SET_ALARM_THRES_NACK,
970+
971+ NM_MT_IPACC_RESTART = 0x87,
972+ NM_MT_IPACC_RESTART_ACK,
973+};
974+
975+enum abis_nm_msgtype_bs11 {
976+ NM_MT_BS11_RESET_RESOURCE = 0x74,
977+
978+ NM_MT_BS11_BEGIN_DB_TX = 0xa3,
979+ NM_MT_BS11_BEGIN_DB_TX_ACK,
980+ NM_MT_BS11_BEGIN_DB_TX_NACK,
981+ NM_MT_BS11_END_DB_TX = 0xa6,
982+ NM_MT_BS11_END_DB_TX_ACK,
983+ NM_MT_BS11_END_DB_TX_NACK,
984+ NM_MT_BS11_CREATE_OBJ = 0xa9,
985+ NM_MT_BS11_CREATE_OBJ_ACK,
986+ NM_MT_BS11_CREATE_OBJ_NACK,
987+ NM_MT_BS11_DELETE_OBJ = 0xac,
988+ NM_MT_BS11_DELETE_OBJ_ACK,
989+ NM_MT_BS11_DELETE_OBJ_NACK,
990+
991+ NM_MT_BS11_SET_ATTR = 0xd0,
992+ NM_MT_BS11_SET_ATTR_ACK,
993+ NM_MT_BS11_SET_ATTR_NACK,
994+ NM_MT_BS11_LMT_SESSION = 0xdc,
995+
996+ NM_MT_BS11_GET_STATE = 0xe3,
997+ NM_MT_BS11_GET_STATE_ACK,
998+ NM_MT_BS11_LMT_LOGON = 0xe5,
999+ NM_MT_BS11_LMT_LOGON_ACK,
1000+ NM_MT_BS11_RESTART = 0xe7,
1001+ NM_MT_BS11_RESTART_ACK,
1002+ NM_MT_BS11_DISCONNECT = 0xe9,
1003+ NM_MT_BS11_DISCONNECT_ACK,
1004+ NM_MT_BS11_LMT_LOGOFF = 0xec,
1005+ NM_MT_BS11_LMT_LOGOFF_ACK,
1006+ NM_MT_BS11_RECONNECT = 0xf1,
1007+ NM_MT_BS11_RECONNECT_ACK,
1008+};
1009+
1010+enum abis_nm_msgtype_ipacc {
1011+ NM_MT_IPACC_RSL_CONNECT = 0xe0,
1012+ NM_MT_IPACC_RSL_CONNECT_ACK,
1013+ NM_MT_IPACC_RSL_CONNECT_NACK,
1014+ NM_MT_IPACC_SET_NVATTR = 0xef,
1015+ NM_MT_IPACC_SET_NVATTR_ACK,
1016+ NM_MT_IPACC_SET_NVATTR_NACK,
1017+ NM_MT_IPACC_GET_NVATTR = 0xf2,
1018+ NM_MT_IPACC_GET_NVATTR_ACK,
1019+ NM_MT_IPACC_GET_NVATTR_NACK,
1020+};
1021+
1022+enum abis_nm_bs11_cell_alloc {
1023+ NM_BS11_CANR_GSM = 0x00,
1024+ NM_BS11_CANR_DCS1800 = 0x01,
1025+};
1026+
1027+/* Section 9.2: Object Class */
1028+enum abis_nm_obj_class {
1029+ NM_OC_SITE_MANAGER = 0x00,
1030+ NM_OC_BTS,
1031+ NM_OC_RADIO_CARRIER,
1032+ NM_OC_CHANNEL,
1033+ NM_OC_BASEB_TRANSC,
1034+ /* RFU: 05-FE */
1035+ NM_OC_BS11_ADJC = 0xa0,
1036+ NM_OC_BS11_HANDOVER = 0xa1,
1037+ NM_OC_BS11_PWR_CTRL = 0xa2,
1038+ NM_OC_BS11_BTSE = 0xa3, /* LMT? */
1039+ NM_OC_BS11_RACK = 0xa4,
1040+ NM_OC_BS11 = 0xa5, /* 01: ALCO */
1041+ NM_OC_BS11_TEST = 0xa6,
1042+ NM_OC_BS11_ENVABTSE = 0xa8,
1043+ NM_OC_BS11_BPORT = 0xa9,
1044+
1045+ NM_OC_GPRS_NSE = 0xf0,
1046+ NM_OC_GPRS_CELL = 0xf1,
1047+ NM_OC_GPRS_NSVC0 = 0xf2,
1048+ NM_OC_GPRS_NSVC1 = 0xf3,
1049+
1050+ NM_OC_NULL = 0xff,
1051+};
1052+
1053+/* Section 9.4: Attributes */
1054+enum abis_nm_attr {
1055+ NM_ATT_ABIS_CHANNEL = 0x01,
1056+ NM_ATT_ADD_INFO,
1057+ NM_ATT_ADD_TEXT,
1058+ NM_ATT_ADM_STATE,
1059+ NM_ATT_ARFCN_LIST,
1060+ NM_ATT_AUTON_REPORT,
1061+ NM_ATT_AVAIL_STATUS,
1062+ NM_ATT_BCCH_ARFCN,
1063+ NM_ATT_BSIC,
1064+ NM_ATT_BTS_AIR_TIMER,
1065+ NM_ATT_CCCH_L_I_P,
1066+ NM_ATT_CCCH_L_T,
1067+ NM_ATT_CHAN_COMB,
1068+ NM_ATT_CONN_FAIL_CRIT,
1069+ NM_ATT_DEST,
1070+ /* res */
1071+ NM_ATT_EVENT_TYPE = 0x11, /* BS11: file data ?!? */
1072+ NM_ATT_FILE_ID,
1073+ NM_ATT_FILE_VERSION,
1074+ NM_ATT_GSM_TIME,
1075+ NM_ATT_HSN,
1076+ NM_ATT_HW_CONFIG,
1077+ NM_ATT_HW_DESC,
1078+ NM_ATT_INTAVE_PARAM,
1079+ NM_ATT_INTERF_BOUND,
1080+ NM_ATT_LIST_REQ_ATTR,
1081+ NM_ATT_MAIO,
1082+ NM_ATT_MANUF_STATE,
1083+ NM_ATT_MANUF_THRESH,
1084+ NM_ATT_MANUF_ID,
1085+ NM_ATT_MAX_TA,
1086+ NM_ATT_MDROP_LINK, /* 0x20 */
1087+ NM_ATT_MDROP_NEXT,
1088+ NM_ATT_NACK_CAUSES,
1089+ NM_ATT_NY1,
1090+ NM_ATT_OPER_STATE,
1091+ NM_ATT_OVERL_PERIOD,
1092+ NM_ATT_PHYS_CONF,
1093+ NM_ATT_POWER_CLASS,
1094+ NM_ATT_POWER_THRESH,
1095+ NM_ATT_PROB_CAUSE,
1096+ NM_ATT_RACH_B_THRESH,
1097+ NM_ATT_LDAVG_SLOTS,
1098+ NM_ATT_RAD_SUBC,
1099+ NM_ATT_RF_MAXPOWR_R,
1100+ NM_ATT_SITE_INPUTS,
1101+ NM_ATT_SITE_OUTPUTS,
1102+ NM_ATT_SOURCE, /* 0x30 */
1103+ NM_ATT_SPEC_PROB,
1104+ NM_ATT_START_TIME,
1105+ NM_ATT_T200,
1106+ NM_ATT_TEI,
1107+ NM_ATT_TEST_DUR,
1108+ NM_ATT_TEST_NO,
1109+ NM_ATT_TEST_REPORT,
1110+ NM_ATT_VSWR_THRESH,
1111+ NM_ATT_WINDOW_SIZE,
1112+ /* Res */
1113+ NM_ATT_BS11_RSSI_OFFS = 0x3d,
1114+ NM_ATT_BS11_TXPWR = 0x3e,
1115+ NM_ATT_BS11_DIVERSITY = 0x3f,
1116+ /* Res */
1117+ NM_ATT_TSC = 0x40,
1118+ NM_ATT_SW_CONFIG,
1119+ NM_ATT_SW_DESCR,
1120+ NM_ATT_SEVERITY,
1121+ NM_ATT_GET_ARI,
1122+ NM_ATT_HW_CONF_CHG,
1123+ NM_ATT_OUTST_ALARM,
1124+ NM_ATT_FILE_DATA,
1125+ NM_ATT_MEAS_RES,
1126+ NM_ATT_MEAS_TYPE,
1127+
1128+ NM_ATT_BS11_ESN_FW_CODE_NO = 0x4c,
1129+ NM_ATT_BS11_ESN_HW_CODE_NO = 0x4f,
1130+
1131+ NM_ATT_BS11_ESN_PCB_SERIAL = 0x55,
1132+ NM_ATT_BS11_EXCESSIVE_DISTANCE = 0x58,
1133+
1134+ NM_ATT_BS11_ALL_TEST_CATG = 0x60,
1135+ NM_ATT_BS11_BTSLS_HOPPING,
1136+ NM_ATT_BS11_CELL_ALLOC_NR,
1137+ NM_ATT_BS11_CELL_GLOBAL_ID,
1138+ NM_ATT_BS11_ENA_INTERF_CLASS = 0x66,
1139+ NM_ATT_BS11_ENA_INT_INTEC_HANDO = 0x67,
1140+ NM_ATT_BS11_ENA_INT_INTRC_HANDO = 0x68,
1141+ NM_ATT_BS11_ENA_MS_PWR_CTRL = 0x69,
1142+ NM_ATT_BS11_ENA_PWR_BDGT_HO = 0x6a,
1143+ NM_ATT_BS11_ENA_PWR_CTRL_RLFW = 0x6b,
1144+ NM_ATT_BS11_ENA_RXLEV_HO = 0x6c,
1145+ NM_ATT_BS11_ENA_RXQUAL_HO = 0x6d,
1146+ NM_ATT_BS11_FACCH_QUAL = 0x6e,
1147+
1148+ NM_ATT_IPACC_RSL_BSC_IP = 0x80,
1149+ NM_ATT_IPACC_RSL_BSC_PORT = 0x81,
1150+ NM_ATT_IPACC_LOCATION = 0x8e, /* string describing location */
1151+ NM_ATT_IPACC_UNIT_ID = 0x91, /* Site/BTS/TRX */
1152+ NM_ATT_IPACC_UNIT_NAME = 0x93, /* default: nbts-<mac-as-string> */
1153+ NM_ATT_IPACC_PRIM_OML_IP = 0x95,
1154+ NM_ATT_IPACC_SEC_OML_IP = 0x96,
1155+
1156+ NM_ATT_BS11_RF_RES_IND_PER = 0x8f,
1157+
1158+ NM_ATT_BS11_RX_LEV_MIN_CELL = 0x90,
1159+ NM_ATT_BS11_ABIS_EXT_TIME = 0x91,
1160+ NM_ATT_BS11_TIMER_HO_REQUEST = 0x92,
1161+ NM_ATT_BS11_TIMER_NCELL = 0x93,
1162+ NM_ATT_BS11_TSYNC = 0x94,
1163+ NM_ATT_BS11_TTRAU = 0x95,
1164+ NM_ATT_BS11_EMRG_CFG_MEMBER = 0x9b,
1165+ NM_ATT_BS11_TRX_AREA = 0x9f,
1166+
1167+ NM_ATT_BS11_BCCH_RECONF = 0xd7,
1168+ NM_ATT_BS11_BIT_ERR_THESH = 0xa0,
1169+ NM_ATT_BS11_BOOT_SW_VERS = 0xa1,
1170+ NM_ATT_BS11_CCLK_ACCURACY = 0xa3,
1171+ NM_ATT_BS11_CCLK_TYPE = 0xa4,
1172+ NM_ATT_BS11_INP_IMPEDANCE = 0xaa,
1173+ NM_ATT_BS11_L1_PROT_TYPE = 0xab,
1174+ NM_ATT_BS11_LINE_CFG = 0xac,
1175+ NM_ATT_BS11_LI_PORT_1 = 0xad,
1176+ NM_ATT_BS11_LI_PORT_2 = 0xae,
1177+
1178+ NM_ATT_BS11_L1_REM_ALM_TYPE = 0xb0,
1179+ NM_ATT_BS11_SW_LOAD_INTENDED = 0xbb,
1180+ NM_ATT_BS11_SW_LOAD_SAFETY = 0xbc,
1181+ NM_ATT_BS11_SW_LOAD_STORED = 0xbd,
1182+
1183+ NM_ATT_BS11_VENDOR_NAME = 0xc1,
1184+ NM_ATT_BS11_HOPPING_MODE = 0xc5,
1185+ NM_ATT_BS11_LMT_LOGON_SESSION = 0xc6,
1186+ NM_ATT_BS11_LMT_LOGIN_TIME = 0xc7,
1187+ NM_ATT_BS11_LMT_USER_ACC_LEV = 0xc8,
1188+ NM_ATT_BS11_LMT_USER_NAME = 0xc9,
1189+
1190+ NM_ATT_BS11_L1_CONTROL_TS = 0xd8,
1191+ NM_ATT_BS11_RADIO_MEAS_GRAN = 0xdc, /* in SACCH multiframes */
1192+ NM_ATT_BS11_RADIO_MEAS_REP = 0xdd,
1193+
1194+ NM_ATT_BS11_SH_LAPD_INT_TIMER = 0xe8,
1195+
1196+ NM_ATT_BS11_BTS_STATE = 0xf0,
1197+ NM_ATT_BS11_E1_STATE = 0xf1,
1198+ NM_ATT_BS11_PLL = 0xf2,
1199+ NM_ATT_BS11_RX_OFFSET = 0xf3,
1200+ NM_ATT_BS11_ANT_TYPE = 0xf4,
1201+ NM_ATT_BS11_PLL_MODE = 0xfc,
1202+ NM_ATT_BS11_PASSWORD = 0xfd,
1203+};
1204+#define NM_ATT_BS11_FILE_DATA NM_ATT_EVENT_TYPE
1205+
1206+/* Section 9.4.4: Administrative State */
1207+enum abis_nm_adm_state {
1208+ NM_STATE_LOCKED = 0x01,
1209+ NM_STATE_UNLOCKED = 0x02,
1210+ NM_STATE_SHUTDOWN = 0x03,
1211+ NM_STATE_NULL = 0xff,
1212+};
1213+
1214+/* Section 9.4.13: Channel Combination */
1215+enum abis_nm_chan_comb {
1216+ NM_CHANC_TCHFull = 0x00,
1217+ NM_CHANC_TCHHalf = 0x01,
1218+ NM_CHANC_TCHHalf2 = 0x02,
1219+ NM_CHANC_SDCCH = 0x03,
1220+ NM_CHANC_mainBCCH = 0x04,
1221+ NM_CHANC_BCCHComb = 0x05,
1222+ NM_CHANC_BCCH = 0x06,
1223+ NM_CHANC_BCCH_CBCH = 0x07,
1224+ NM_CHANC_SDCCH_CBCH = 0x08,
1225+};
1226+
1227+/* Section 9.4.16: Event Type */
1228+enum abis_nm_event_type {
1229+ NM_EVT_COMM_FAIL = 0x00,
1230+ NM_EVT_QOS_FAIL = 0x01,
1231+ NM_EVT_PROC_FAIL = 0x02,
1232+ NM_EVT_EQUIP_FAIL = 0x03,
1233+ NM_EVT_ENV_FAIL = 0x04,
1234+};
1235+
1236+/* Section: 9.4.63: Perceived Severity */
1237+enum abis_nm_severity {
1238+ NM_SEVER_CEASED = 0x00,
1239+ NM_SEVER_CRITICAL = 0x01,
1240+ NM_SEVER_MAJOR = 0x02,
1241+ NM_SEVER_MINOR = 0x03,
1242+ NM_SEVER_WARNING = 0x04,
1243+ NM_SEVER_INDETERMINATE = 0x05,
1244+};
1245+
1246+/* Section 9.4.43: Probable Cause Type */
1247+enum abis_nm_pcause_type {
1248+ NM_PCAUSE_T_X721 = 0x01,
1249+ NM_PCAUSE_T_GSM = 0x02,
1250+ NM_PCAUSE_T_MANUF = 0x03,
1251+};
1252+
1253+/* Section 9.4.36: NACK Causes */
1254+enum abis_nm_nack_cause {
1255+ /* General Nack Causes */
1256+ NM_NACK_INCORR_STRUCT = 0x01,
1257+ NM_NACK_MSGTYPE_INVAL = 0x02,
1258+ NM_NACK_OBJCLASS_INVAL = 0x05,
1259+ NM_NACK_OBJCLASS_NOTSUPP = 0x06,
1260+ NM_NACK_BTSNR_UNKN = 0x07,
1261+ NM_NACK_TRXNR_UNKN = 0x08,
1262+ NM_NACK_OBJINST_UNKN = 0x09,
1263+ NM_NACK_ATTRID_INVAL = 0x0c,
1264+ NM_NACK_ATTRID_NOTSUPP = 0x0d,
1265+ NM_NACK_PARAM_RANGE = 0x0e,
1266+ NM_NACK_ATTRLIST_INCONSISTENT = 0x0f,
1267+ NM_NACK_SPEC_IMPL_NOTSUPP = 0x10,
1268+ NM_NACK_CANT_PERFORM = 0x11,
1269+ /* Specific Nack Causes */
1270+ NM_NACK_RES_NOTIMPL = 0x19,
1271+ NM_NACK_RES_NOTAVAIL = 0x1a,
1272+ NM_NACK_FREQ_NOTAVAIL = 0x1b,
1273+ NM_NACK_TEST_NOTSUPP = 0x1c,
1274+ NM_NACK_CAPACITY_RESTR = 0x1d,
1275+ NM_NACK_PHYSCFG_NOTPERFORM = 0x1e,
1276+ NM_NACK_TEST_NOTINIT = 0x1f,
1277+ NM_NACK_PHYSCFG_NOTRESTORE = 0x20,
1278+ NM_NACK_TEST_NOSUCH = 0x21,
1279+ NM_NACK_TEST_NOSTOP = 0x22,
1280+ NM_NACK_MSGINCONSIST_PHYSCFG = 0x23,
1281+ NM_NACK_FILE_INCOMPLETE = 0x25,
1282+ NM_NACK_FILE_NOTAVAIL = 0x26,
1283+ NM_NACK_FILE_NOTACTIVATE = 0x27,
1284+ NM_NACK_REQ_NOT_GRANT = 0x28,
1285+ NM_NACK_WAIT = 0x29,
1286+ NM_NACK_NOTH_REPORT_EXIST = 0x2a,
1287+ NM_NACK_MEAS_NOTSUPP = 0x2b,
1288+ NM_NACK_MEAS_NOTSTART = 0x2c,
1289+};
1290+
1291+/* Section 9.4.1 */
1292+struct abis_nm_channel {
1293+ guint8 attrib;
1294+ guint8 bts_port;
1295+ guint8 timeslot;
1296+ guint8 subslot;
1297+} __attribute__ ((packed));
1298+
1299+/* Siemens BS-11 specific objects in the SienemsHW (0xA5) object class */
1300+enum abis_bs11_objtype {
1301+ BS11_OBJ_ALCO = 0x01,
1302+ BS11_OBJ_BBSIG = 0x02, /* obj_class: 0,1 */
1303+ BS11_OBJ_TRX1 = 0x03, /* only DEACTIVATE TRX1 */
1304+ BS11_OBJ_CCLK = 0x04,
1305+ BS11_OBJ_GPSU = 0x06,
1306+ BS11_OBJ_LI = 0x07,
1307+ BS11_OBJ_PA = 0x09, /* obj_class: 0, 1*/
1308+};
1309+
1310+enum abis_bs11_trx_power {
1311+ BS11_TRX_POWER_GSM_2W = 0x06,
1312+ BS11_TRX_POWER_GSM_250mW= 0x07,
1313+ BS11_TRX_POWER_GSM_80mW = 0x08,
1314+ BS11_TRX_POWER_GSM_30mW = 0x09,
1315+ BS11_TRX_POWER_DCS_3W = 0x0a,
1316+ BS11_TRX_POWER_DCS_1W6 = 0x0b,
1317+ BS11_TRX_POWER_DCS_500mW= 0x0c,
1318+ BS11_TRX_POWER_DCS_160mW= 0x0d,
1319+};
1320+
1321+enum abis_bs11_li_pll_mode {
1322+ BS11_LI_PLL_LOCKED = 2,
1323+ BS11_LI_PLL_STANDALONE = 3,
1324+};
1325+
1326+enum abis_bs11_phase {
1327+ BS11_STATE_SOFTWARE_RQD = 0x01,
1328+ BS11_STATE_LOAD_SMU_INTENDED = 0x11,
1329+ BS11_STATE_LOAD_SMU_SAFETY = 0x21,
1330+ BS11_STATE_LOAD_FAILED = 0x31,
1331+ BS11_STATE_LOAD_DIAGNOSTIC = 0x41,
1332+ BS11_STATE_WARM_UP = 0x51,
1333+ BS11_STATE_WARM_UP_2 = 0x52,
1334+ BS11_STATE_WAIT_MIN_CFG = 0x62,
1335+ BS11_STATE_MAINTENANCE = 0x72,
1336+ BS11_STATE_LOAD_MBCCU = 0x92,
1337+ BS11_STATE_WAIT_MIN_CFG_2 = 0xA2,
1338+ BS11_STATE_NORMAL = 0x03,
1339+ BS11_STATE_ABIS_LOAD = 0x13,
1340+};
1341+
1342+/* From openbsc/include/openbsc/tlv.h */
1343+enum tlv_type {
1344+ TLV_TYPE_FIXED,
1345+ TLV_TYPE_T,
1346+ TLV_TYPE_TV,
1347+ TLV_TYPE_TLV,
1348+ TLV_TYPE_TL16V,
1349+};
1350+
1351+struct tlv_def {
1352+ enum tlv_type type;
1353+ u_int8_t fixed_len;
1354+};
1355+
1356+struct tlv_definition {
1357+ struct tlv_def def[0xff];
1358+};
1359+
1360+
1361+/* From openbsc/src/abis_nm.c */
1362+static const struct tlv_definition nm_att_tlvdef = {
1363+ .def = {
1364+ [NM_ATT_ABIS_CHANNEL] = { TLV_TYPE_FIXED, 3 },
1365+ [NM_ATT_ADD_INFO] = { TLV_TYPE_TL16V, 0 },
1366+ [NM_ATT_ADD_TEXT] = { TLV_TYPE_TL16V },
1367+ [NM_ATT_ADM_STATE] = { TLV_TYPE_TV },
1368+ [NM_ATT_ARFCN_LIST]= { TLV_TYPE_TL16V },
1369+ [NM_ATT_AUTON_REPORT] = { TLV_TYPE_TV },
1370+ [NM_ATT_AVAIL_STATUS] = { TLV_TYPE_TL16V },
1371+ [NM_ATT_BCCH_ARFCN] = { TLV_TYPE_FIXED, 2 },
1372+ [NM_ATT_BSIC] = { TLV_TYPE_TV },
1373+ [NM_ATT_BTS_AIR_TIMER] = { TLV_TYPE_TV },
1374+ [NM_ATT_CCCH_L_I_P] = { TLV_TYPE_TV },
1375+ [NM_ATT_CCCH_L_T] = { TLV_TYPE_TV },
1376+ [NM_ATT_CHAN_COMB] = { TLV_TYPE_TV },
1377+ [NM_ATT_CONN_FAIL_CRIT] = { TLV_TYPE_TL16V },
1378+ [NM_ATT_DEST] = { TLV_TYPE_TL16V },
1379+ [NM_ATT_EVENT_TYPE] = { TLV_TYPE_TV },
1380+ [NM_ATT_FILE_DATA] = { TLV_TYPE_TL16V },
1381+ [NM_ATT_FILE_ID] = { TLV_TYPE_TL16V },
1382+ [NM_ATT_FILE_VERSION] = { TLV_TYPE_TL16V },
1383+ [NM_ATT_GSM_TIME] = { TLV_TYPE_FIXED, 2 },
1384+ [NM_ATT_HSN] = { TLV_TYPE_TV },
1385+ [NM_ATT_HW_CONFIG] = { TLV_TYPE_TL16V },
1386+ [NM_ATT_HW_DESC] = { TLV_TYPE_TL16V },
1387+ [NM_ATT_INTAVE_PARAM] = { TLV_TYPE_TV },
1388+ [NM_ATT_INTERF_BOUND] = { TLV_TYPE_FIXED, 6 },
1389+ [NM_ATT_LIST_REQ_ATTR] = { TLV_TYPE_TL16V },
1390+ [NM_ATT_MAIO] = { TLV_TYPE_TV },
1391+ [NM_ATT_MANUF_STATE] = { TLV_TYPE_TV },
1392+ [NM_ATT_MANUF_THRESH] = { TLV_TYPE_TL16V },
1393+ [NM_ATT_MANUF_ID] = { TLV_TYPE_TL16V },
1394+ [NM_ATT_MAX_TA] = { TLV_TYPE_TV },
1395+ [NM_ATT_MDROP_LINK] = { TLV_TYPE_FIXED, 2 },
1396+ [NM_ATT_MDROP_NEXT] = { TLV_TYPE_FIXED, 2 },
1397+ [NM_ATT_NACK_CAUSES] = { TLV_TYPE_TV },
1398+ [NM_ATT_NY1] = { TLV_TYPE_TV },
1399+ [NM_ATT_OPER_STATE] = { TLV_TYPE_TV },
1400+ [NM_ATT_OVERL_PERIOD] = { TLV_TYPE_TL16V },
1401+ [NM_ATT_PHYS_CONF] = { TLV_TYPE_TL16V },
1402+ [NM_ATT_POWER_CLASS] = { TLV_TYPE_TV },
1403+ [NM_ATT_POWER_THRESH] = { TLV_TYPE_FIXED, 3 },
1404+ [NM_ATT_PROB_CAUSE] = { TLV_TYPE_FIXED, 3 },
1405+ [NM_ATT_RACH_B_THRESH] = { TLV_TYPE_TV },
1406+ [NM_ATT_LDAVG_SLOTS] = { TLV_TYPE_FIXED, 2 },
1407+ [NM_ATT_RAD_SUBC] = { TLV_TYPE_TV },
1408+ [NM_ATT_RF_MAXPOWR_R] = { TLV_TYPE_TV },
1409+ [NM_ATT_SITE_INPUTS] = { TLV_TYPE_TL16V },
1410+ [NM_ATT_SITE_OUTPUTS] = { TLV_TYPE_TL16V },
1411+ [NM_ATT_SOURCE] = { TLV_TYPE_TL16V },
1412+ [NM_ATT_SPEC_PROB] = { TLV_TYPE_TV },
1413+ [NM_ATT_START_TIME] = { TLV_TYPE_FIXED, 2 },
1414+ [NM_ATT_T200] = { TLV_TYPE_FIXED, 7 },
1415+ [NM_ATT_TEI] = { TLV_TYPE_TV },
1416+ [NM_ATT_TEST_DUR] = { TLV_TYPE_FIXED, 2 },
1417+ [NM_ATT_TEST_NO] = { TLV_TYPE_TV },
1418+ [NM_ATT_TEST_REPORT] = { TLV_TYPE_TL16V, },
1419+ [NM_ATT_VSWR_THRESH] = { TLV_TYPE_FIXED, 2 },
1420+ [NM_ATT_WINDOW_SIZE] = { TLV_TYPE_TV },
1421+ [NM_ATT_TSC] = { TLV_TYPE_TV },
1422+ [NM_ATT_SW_CONFIG] = { TLV_TYPE_TL16V },
1423+ [NM_ATT_SEVERITY] = { TLV_TYPE_TV },
1424+ [NM_ATT_GET_ARI] = { TLV_TYPE_TL16V },
1425+ [NM_ATT_HW_CONF_CHG] = { TLV_TYPE_TL16V },
1426+ [NM_ATT_OUTST_ALARM] = { TLV_TYPE_TV },
1427+ [NM_ATT_FILE_DATA] = { TLV_TYPE_TL16V },
1428+ [NM_ATT_MEAS_RES] = { TLV_TYPE_TL16V },
1429+ /* BS11 specifics */
1430+ [NM_ATT_BS11_ESN_FW_CODE_NO] = { TLV_TYPE_TLV },
1431+ [NM_ATT_BS11_ESN_HW_CODE_NO] = { TLV_TYPE_TLV },
1432+ [NM_ATT_BS11_ESN_PCB_SERIAL] = { TLV_TYPE_TLV },
1433+ [NM_ATT_BS11_BOOT_SW_VERS] = { TLV_TYPE_TLV },
1434+ [0xd5] = { TLV_TYPE_TLV },
1435+ [0xa8] = { TLV_TYPE_TLV },
1436+ [NM_ATT_BS11_PASSWORD] = { TLV_TYPE_TLV },
1437+ [NM_ATT_BS11_TXPWR] = { TLV_TYPE_TLV },
1438+ [NM_ATT_BS11_RSSI_OFFS] = { TLV_TYPE_TLV },
1439+ [NM_ATT_BS11_LINE_CFG] = { TLV_TYPE_TV },
1440+ [NM_ATT_BS11_L1_PROT_TYPE] = { TLV_TYPE_TV },
1441+ [NM_ATT_BS11_BIT_ERR_THESH] = { TLV_TYPE_FIXED, 2 },
1442+ [NM_ATT_BS11_DIVERSITY] = { TLV_TYPE_TLV },
1443+ [NM_ATT_BS11_LMT_LOGON_SESSION]={ TLV_TYPE_TLV },
1444+ [NM_ATT_BS11_LMT_LOGIN_TIME] = { TLV_TYPE_TLV },
1445+ [NM_ATT_BS11_LMT_USER_ACC_LEV] ={ TLV_TYPE_TLV },
1446+ [NM_ATT_BS11_LMT_USER_NAME] = { TLV_TYPE_TLV },
1447+ [NM_ATT_BS11_BTS_STATE] = { TLV_TYPE_TLV },
1448+ [NM_ATT_BS11_E1_STATE] = { TLV_TYPE_TLV },
1449+ [NM_ATT_BS11_PLL_MODE] = { TLV_TYPE_TLV },
1450+ [NM_ATT_BS11_PLL] = { TLV_TYPE_TLV },
1451+ [NM_ATT_BS11_CCLK_ACCURACY] = { TLV_TYPE_TV },
1452+ [NM_ATT_BS11_CCLK_TYPE] = { TLV_TYPE_TV },
1453+ /* ip.access specifics */
1454+ [NM_ATT_IPACC_RSL_BSC_IP] = { TLV_TYPE_FIXED, 4 },
1455+ [NM_ATT_IPACC_RSL_BSC_PORT] = { TLV_TYPE_FIXED, 2 },
1456+ [NM_ATT_IPACC_PRIM_OML_IP] = { TLV_TYPE_FIXED, 6 },
1457+ [0x95] = { TLV_TYPE_FIXED, 2 },
1458+ [0x85] = { TLV_TYPE_TV },
1459+
1460+ },
1461+};
1462+
1463+#endif /* _NM_H */