subscr: Kick the queue in case of a paging timeout
[openbsc.git] / wireshark / abis_oml.patch
blobab51a1259efb43fe1e6c70c11391f44034b38de9
1 From b659280ff645354bb55529b05114419b9f0efd6f Mon Sep 17 00:00:00 2001
2 From: Holger Hans Peter Freyther <zecke@selfish.org>
3 Date: Mon, 19 Apr 2010 13:23:51 +0800
4 Subject: [PATCH 1/2] Add the Abis OML patch.
6 ---
7 epan/dissectors/Makefile.common | 1 +
8 epan/dissectors/packet-gsm_abis_oml.c | 1405 +++++++++++++++++++++++++++++++++
9 epan/dissectors/packet-gsm_abis_oml.h | 800 +++++++++++++++++++
10 3 files changed, 2206 insertions(+), 0 deletions(-)
11 create mode 100644 epan/dissectors/packet-gsm_abis_oml.c
12 create mode 100644 epan/dissectors/packet-gsm_abis_oml.h
14 Index: wireshark/epan/dissectors/Makefile.common
15 ===================================================================
16 --- wireshark.orig/epan/dissectors/Makefile.common
17 +++ wireshark/epan/dissectors/Makefile.common
18 @@ -495,6 +495,7 @@
19 packet-gsm_a_gm.c \
20 packet-gsm_a_rp.c \
21 packet-gsm_a_rr.c \
22 + packet-gsm_abis_oml.c \
23 packet-gsm_ipa.c \
24 packet-gsm_bsslap.c \
25 packet-gsm_bssmap_le.c \
26 Index: wireshark/epan/dissectors/packet-gsm_abis_oml.c
27 ===================================================================
28 --- /dev/null
29 +++ wireshark/epan/dissectors/packet-gsm_abis_oml.c
30 @@ -0,0 +1,1608 @@
31 +/* packet-abis_oml.c
32 + * Routines for packet dissection of GSM A-bis over IP (3GPP TS 12.21)
33 + * Copyright 2009-2010 by Harald Welte <laforge@gnumonks.org>
34 + * Copyright 2009 by Holger Hans Peter Freyther <zecke@selfish.org>
35 + * based on A-bis OML code in OpenBSC
36 + *
37 + * $Id$
38 + *
39 + * Wireshark - Network traffic analyzer
40 + * By Gerald Combs <gerald@wireshark.org>
41 + * Copyright 1998 Gerald Combs
42 + *
43 + * This program is free software; you can redistribute it and/or
44 + * modify it under the terms of the GNU General Public License
45 + * as published by the Free Software Foundation; either version 2
46 + * of the License, or (at your option) any later version.
47 + *
48 + * This program is distributed in the hope that it will be useful,
49 + * but WITHOUT ANY WARRANTY; without even the implied warranty of
50 + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
51 + * GNU General Public License for more details.
52 + *
53 + * You should have received a copy of the GNU General Public License
54 + * along with this program; if not, write to the Free Software
55 + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
56 + */
58 +#ifdef HAVE_CONFIG_H
59 +# include "config.h"
60 +#endif
62 +#include <glib.h>
64 +#include <epan/packet.h>
65 +#include <epan/emem.h>
66 +#include <epan/lapd_sapi.h>
67 +#include <epan/prefs.h>
69 +#include "packet-gsm_abis_oml.h"
70 +#include "packet-gsm_a_common.h"
72 +#include <stdio.h>
74 +/* initialize the protocol and registered fields */
75 +static int proto_abis_oml = -1;
77 +/* OML header */
78 +static int hf_oml_msg_disc = -1;
79 +static int hf_oml_placement = -1;
80 +static int hf_oml_sequence = -1;
81 +static int hf_oml_length = -1;
82 +/* FOM header */
83 +static int hf_oml_fom_msgtype = -1;
84 +static int hf_oml_fom_objclass = -1;
85 +static int hf_oml_fom_inst_bts = -1;
86 +static int hf_oml_fom_inst_trx = -1;
87 +static int hf_oml_fom_inst_ts = -1;
88 +static int hf_oml_fom_attr_tag = -1;
89 +static int hf_oml_fom_attr_len = -1;
90 +static int hf_oml_fom_attr_val = -1;
91 +/* FOM attributes */
92 +static int hf_attr_adm_state = -1;
93 +static int hf_attr_arfcn = -1;
94 +static int hf_attr_oper_state = -1;
95 +static int hf_attr_avail_state = -1;
96 +static int hf_attr_event_type = -1;
97 +static int hf_attr_severity = -1;
98 +static int hf_attr_bcch_arfcn = -1;
99 +static int hf_attr_bsic = -1;
100 +static int hf_attr_test_no = -1;
101 +static int hf_attr_tsc = -1;
102 +static int hf_attr_tei = -1;
103 +static int hf_attr_ach_btsp = -1;
104 +static int hf_attr_ach_tslot = -1;
105 +static int hf_attr_ach_sslot = -1;
106 +static int hf_attr_gsm_time = -1;
107 +static int hf_attr_chan_comb = -1;
108 +static int hf_attr_hsn = -1;
109 +static int hf_attr_maio = -1;
110 +/* Ipaccess */
111 +static int hf_oml_ipa_tres_attr_tag = -1;
112 +static int hf_oml_ipa_tres_attr_len = -1;
113 +static int hf_attr_ipa_test_res = -1;
114 +static int hf_attr_ipa_tr_rxlev = -1;
115 +static int hf_attr_ipa_tr_b_rxlev = -1;
116 +static int hf_attr_ipa_tr_arfcn = -1;
117 +static int hf_attr_ipa_tr_f_qual = -1;
118 +static int hf_attr_ipa_tr_f_err = -1;
119 +static int hf_attr_ipa_tr_rxqual = -1;
120 +static int hf_attr_ipa_tr_frame_offs = -1;
121 +static int hf_attr_ipa_tr_framenr_offs = -1;
122 +static int hf_attr_ipa_tr_bsic = -1;
123 +static int hf_attr_ipa_tr_cell_id = -1;
124 +static int hf_attr_ipa_tr_si2 = -1;
125 +static int hf_attr_ipa_tr_si2bis = -1;
126 +static int hf_attr_ipa_tr_si2ter = -1;
127 +static int hf_attr_ipa_tr_chan_desc = -1;
128 +static int hf_attr_ipa_rsl_ip = -1;
129 +static int hf_attr_ipa_rsl_port = -1;
130 +static int hf_attr_ipa_prim_oml_ip = -1;
131 +static int hf_attr_ipa_prim_oml_port = -1;
132 +static int hf_attr_ipa_location_name = -1;
133 +static int hf_attr_ipa_unit_id = -1;
134 +static int hf_attr_ipa_unit_name = -1;
135 +static int hf_attr_ipa_nv_flags = -1;
136 +static int hf_attr_ipa_nv_mask = -1;
137 +static int hf_attr_ipa_nsl_sport = -1;
138 +static int hf_attr_ipa_nsl_daddr = -1;
139 +static int hf_attr_ipa_nsl_dport = -1;
140 +static int hf_attr_ipa_nsei = -1;
141 +static int hf_attr_ipa_nsvci = -1;
142 +static int hf_attr_ipa_bvci = -1;
143 +static int hf_attr_ipa_rac = -1;
145 +/* initialize the subtree pointers */
146 +static int ett_oml = -1;
147 +static int ett_oml_fom = -1;
148 +static int ett_oml_fom_att = -1;
150 +/* Decode things as nanoBTS traces */
151 +static gboolean global_oml_use_nano_bts = TRUE;
153 +static proto_tree *top_tree;
155 +/* TS 12.21 Chapter 8.1 / TS 08.59 */
156 +static const value_string oml_msg_disc_vals[] = {
157 + { ABIS_OM_MDISC_FOM, "Formatted O&M" },
158 + { ABIS_OM_MDISC_MMI, "MMI Transfer" },
159 + { ABIS_OM_MDISC_TRAU, "TRAU O&M" },
160 + { ABIS_OM_MDISC_MANUF, "Manufacturer specific" },
163 +/* TS 12.21 Chapter 8.1.1 */
164 +static const value_string oml_placement_vals[] = {
165 + { ABIS_OM_PLACEMENT_ONLY, "Only" },
166 + { ABIS_OM_PLACEMENT_FIRST, "First" },
167 + { ABIS_OM_PLACEMENT_MIDDLE, "Middle" },
168 + { ABIS_OM_PLACEMENT_LAST, "Last" },
171 +/* Standard Message Types as per TS 12.21 Chapter 9.2 */
172 +static const value_string _oml_fom_msgtype_vals[] = {
173 + { NM_MT_LOAD_INIT, "Software Load Init" },
174 + { NM_MT_LOAD_INIT_ACK, "Software Load Init ACK" },
175 + { NM_MT_LOAD_INIT_NACK, "Software Load Init NACK" },
176 + { NM_MT_LOAD_SEG, "Software Load Segment" },
177 + { NM_MT_LOAD_SEG_ACK, "Software Load Segment ACK" },
178 + { NM_MT_LOAD_END, "Software Load End" },
179 + { NM_MT_LOAD_END_ACK, "Software Load End ACK" },
180 + { NM_MT_LOAD_END_NACK, "Software Load End NACK" },
181 + { NM_MT_SW_ACT_REQ, "Software Activate Request" },
182 + { NM_MT_SW_ACT_REQ_ACK, "Software Activate Request ACK" },
183 + { NM_MT_SW_ACT_REQ_NACK, "Software Activate Request NACK" },
184 + { NM_MT_ACTIVATE_SW, "Activate Software" },
185 + { NM_MT_ACTIVATE_SW_ACK, "Activate Software ACK" },
186 + { NM_MT_ACTIVATE_SW_NACK, "Activate Software NACK" },
187 + { NM_MT_SW_ACTIVATED_REP, "Software Activated Report" },
188 + { NM_MT_ESTABLISH_TEI, "Establish TEI" },
189 + { NM_MT_ESTABLISH_TEI_ACK, "Establish TEI ACK" },
190 + { NM_MT_ESTABLISH_TEI_NACK, "Establish TEI NACK" },
191 + { NM_MT_CONN_TERR_SIGN, "Connect Terrestrial Signalling" },
192 + { NM_MT_CONN_TERR_SIGN_ACK, "Connect Terrestrial Signalling ACK" },
193 + { NM_MT_CONN_TERR_SIGN_NACK, "Connect Terrestrial Signalling NACK" },
194 + { NM_MT_DISC_TERR_SIGN, "Disconnect Terrestrial Signalling" },
195 + { NM_MT_DISC_TERR_SIGN_ACK, "Disconnect Terrestrial Signalling ACK" },
196 + { NM_MT_DISC_TERR_SIGN_NACK, "Disconnect Terrestrial Signalling NACK" },
197 + { NM_MT_CONN_TERR_TRAF, "Connect Terrestrial Traffic" },
198 + { NM_MT_CONN_TERR_TRAF_ACK, "Connect Terrestrial Traffic ACK" },
199 + { NM_MT_CONN_TERR_TRAF_NACK, "Connect Terrestrial Traffic NACK" },
200 + { NM_MT_DISC_TERR_TRAF, "Disconnect Terrestrial Traffic" },
201 + { NM_MT_DISC_TERR_TRAF_ACK, "Disconnect Terrestrial Traffic ACK" },
202 + { NM_MT_DISC_TERR_TRAF_NACK, "Disconnect Terrestrial Traffic NACK" },
203 + { NM_MT_CONN_MDROP_LINK, "Connect Multi-Drop Link" },
204 + { NM_MT_CONN_MDROP_LINK_ACK, "Connect Multi-Drop Link ACK" },
205 + { NM_MT_CONN_MDROP_LINK_NACK, "Connect Multi-Drop Link NACK" },
206 + { NM_MT_DISC_MDROP_LINK, "Disconnect Multi-Drop Link" },
207 + { NM_MT_DISC_MDROP_LINK_ACK, "Disconnect Multi-Drop Link ACK" },
208 + { NM_MT_DISC_MDROP_LINK_NACK, "Disconnect Multi-Drop Link NACK" },
209 + { NM_MT_SET_BTS_ATTR, "Set BTS Attributes" },
210 + { NM_MT_SET_BTS_ATTR_ACK, "Set BTS Attributes ACK" },
211 + { NM_MT_SET_BTS_ATTR_NACK, "Set BTS Attributes NACK" },
212 + { NM_MT_SET_RADIO_ATTR, "Set Radio Carrier Attributes" },
213 + { NM_MT_SET_RADIO_ATTR_ACK, "Set Radio Carrier Attributes ACK" },
214 + { NM_MT_SET_RADIO_ATTR_NACK, "Set Radio Carrier Attributes NACK" },
215 + { NM_MT_SET_CHAN_ATTR, "Set Channel Attributes" },
216 + { NM_MT_SET_CHAN_ATTR_ACK, "Set Channel Attributes ACK" },
217 + { NM_MT_SET_CHAN_ATTR_NACK, "Set Channel Attributes NACK" },
218 + { NM_MT_PERF_TEST, "Perform Test" },
219 + { NM_MT_PERF_TEST_ACK, "Perform Test ACK" },
220 + { NM_MT_PERF_TEST_NACK, "Perform Test NACK" },
221 + { NM_MT_TEST_REP, "Test Report" },
222 + { NM_MT_SEND_TEST_REP, "Send Test Report" },
223 + { NM_MT_SEND_TEST_REP_ACK, "Send Test Report ACK" },
224 + { NM_MT_SEND_TEST_REP_NACK, "Send Test Report NACK" },
225 + { NM_MT_STOP_TEST, "Stop Test" },
226 + { NM_MT_STOP_TEST_ACK, "Stop Test ACK" },
227 + { NM_MT_STOP_TEST_NACK, "Stop Test NACK" },
228 + { NM_MT_STATECHG_EVENT_REP, "State Changed Event Report" },
229 + { NM_MT_FAILURE_EVENT_REP, "Failure Event Report" },
230 + { NM_MT_STOP_EVENT_REP, "Stop Sending Event Reports" },
231 + { NM_MT_STOP_EVENT_REP_ACK, "Stop Sending Event Reports ACK" },
232 + { NM_MT_STOP_EVENT_REP_NACK, "Stop Sending Event Reports NACK" },
233 + { NM_MT_REST_EVENT_REP, "Restart Sending Event Reports" },
234 + { NM_MT_REST_EVENT_REP_ACK, "Restart Sending Event Reports ACK" },
235 + { NM_MT_REST_EVENT_REP_NACK, "Restart Sending Event Reports NACK" },
236 + { NM_MT_CHG_ADM_STATE, "Change Administrative State" },
237 + { NM_MT_CHG_ADM_STATE_ACK, "Change Administrative State ACK" },
238 + { NM_MT_CHG_ADM_STATE_NACK, "Change Administrative State NACK" },
239 + { NM_MT_CHG_ADM_STATE_REQ, "Change Administrative State Request" },
240 + { NM_MT_CHG_ADM_STATE_REQ_ACK, "Change Administrative State Request ACK" },
241 + { NM_MT_CHG_ADM_STATE_REQ_NACK, "Change Administrative State Request NACK" },
242 + { NM_MT_REP_OUTST_ALARMS, "Report Outstanding Alarms" },
243 + { NM_MT_REP_OUTST_ALARMS_ACK, "Report Outstanding Alarms ACK" },
244 + { NM_MT_REP_OUTST_ALARMS_NACK, "Report Outstanding Alarms NACK" },
245 + { NM_MT_CHANGEOVER, "Changeover" },
246 + { NM_MT_CHANGEOVER_ACK, "Changeover ACK" },
247 + { NM_MT_CHANGEOVER_NACK, "Changeover NACK" },
248 + { NM_MT_OPSTART, "Opstart" },
249 + { NM_MT_OPSTART_ACK, "Opstart ACK" },
250 + { NM_MT_OPSTART_NACK, "Opstart NACK" },
251 + { NM_MT_REINIT, "Reinitialize" },
252 + { NM_MT_REINIT_ACK, "Reinitialize ACK" },
253 + { NM_MT_REINIT_NACK, "Reinitialize NACK" },
254 + { NM_MT_SET_SITE_OUT, "Set Site Outputs" },
255 + { NM_MT_SET_SITE_OUT_ACK, "Set Site Outputs ACK" },
256 + { NM_MT_SET_SITE_OUT_NACK, "Set Site Outputs NACK" },
257 + { NM_MT_CHG_HW_CONF, "Change HW Configuration" },
258 + { NM_MT_CHG_HW_CONF_ACK, "Change HW Configuration ACK" },
259 + { NM_MT_CHG_HW_CONF_NACK, "Change HW Configuration NACK" },
260 + { NM_MT_MEAS_RES_REQ, "Measurement Result Request" },
261 + { NM_MT_MEAS_RES_RESP, "Measurement Result Response" },
262 + { NM_MT_STOP_MEAS, "Stop Measurement" },
263 + { NM_MT_START_MEAS, "Start Measurement" },
264 + { NM_MT_GET_ATTR, "Get Attributes" },
265 + { NM_MT_GET_ATTR_RESP, "Get Attributes Response" },
266 + { NM_MT_GET_ATTR_NACK, "Get Attributes NACK" },
267 + { NM_MT_SET_ALARM_THRES, "Set Alarm Threshold" },
268 + { NM_MT_SET_ALARM_THRES_ACK, "Set Alarm Threshold ACK" },
269 + { NM_MT_SET_ALARM_THRES_NACK, "Set Alarm Threshold NACK" },
270 + { 0, NULL }
273 +/* proprietary ip.access message types, not in the standard */
274 +static const value_string _oml_fom_msgtype_vals_ipa[] = {
275 + { NM_MT_IPACC_RESTART, "IPA Restart" },
276 + { NM_MT_IPACC_RESTART_ACK, "IPA Restart ACK" },
277 + { NM_MT_IPACC_RSL_CONNECT, "IPA RSL Connect" },
278 + { NM_MT_IPACC_RSL_CONNECT_ACK, "IPA RSL Connect ACK" },
279 + { NM_MT_IPACC_RSL_CONNECT_NACK, "IPA RSL Connect NACK" },
280 + { NM_MT_IPACC_RSL_DISCONNECT, "IPA RSL Disconnect" },
281 + { NM_MT_IPACC_RSL_DISCONNECT_ACK, "IPA RSL Disconnect ACK" },
282 + { NM_MT_IPACC_RSL_DISCONNECT_NACK, "IPA RSL Disconnect NACK" },
283 + { NM_MT_IPACC_CONN_TRAF, "IPA Connect Traffic" },
284 + { NM_MT_IPACC_CONN_TRAF_ACK, "IPA Connect Traffic ACK" },
285 + { NM_MT_IPACC_CONN_TRAF_NACK, "IPA Connect Traffic NACK" },
286 + { NM_MT_IPACC_DISC_TRAF, "IPA Disconnect Traffic" },
287 + { NM_MT_IPACC_DISC_TRAF_ACK, "IPA Disconnect Traffic ACK" },
288 + { NM_MT_IPACC_DISC_TRAF_NACK, "IPA Disconnect Traffic NACK" },
289 + { NM_MT_IPACC_DEF_BOOT_SW, "IPA Default Boot Software" },
290 + { NM_MT_IPACC_DEF_BOOT_SW_ACK, "IPA Default Boot Software ACK" },
291 + { NM_MT_IPACC_DEF_BOOT_SW_NACK, "IPA Default Boot Software NACK" },
292 + { NM_MT_IPACC_SET_NVATTR, "IPA Set NVRAM Attributes" },
293 + { NM_MT_IPACC_SET_NVATTR_ACK, "IPA Set NVRAM Attributes ACK" },
294 + { NM_MT_IPACC_SET_NVATTR_NACK, "IPA Set NVRAM Attributes NACK" },
295 + { NM_MT_IPACC_GET_NVATTR, "IPA Get NVRAM Attributes" },
296 + { NM_MT_IPACC_GET_NVATTR_ACK, "IPA Get NVRAM Attributes ACK" },
297 + { NM_MT_IPACC_GET_NVATTR_NACK, "IPA Get NVRAM Attributes NACK" },
298 + { NM_MT_IPACC_SET_ATTR, "IPA Set Attributes" },
299 + { NM_MT_IPACC_SET_ATTR_ACK, "IPA Set Attributes ACK" },
300 + { NM_MT_IPACC_SET_ATTR_NACK, "IPA Set Attributes NACK" },
301 + { NM_MT_IPACC_ATTR_CHG_EVT, "IPA Attribute Change Event" },
302 + { NM_MT_IPACC_SW_DEACT, "IPA Software Deactivate" },
303 + { NM_MT_IPACC_SW_DEACT_ACK, "IPA Software Deactivate ACK" },
304 + { NM_MT_IPACC_SW_DEACT_NACK, "IPA Software Deactivate NACK" },
305 + { NM_MT_IPACC_MEAS_RES_REQ_NACK,"IPA Measurement Result Request NACK" },
306 + { NM_MT_IPACC_START_MEAS_NACK, "IPA Start Measurement NACK" },
307 + { NM_MT_IPACC_STOP_MEAS_NACK, "IPA Stop Measurement NACK" },
308 + { 0, NULL }
311 +/* proprietary Siemens message types, not in the standard */
312 +static const value_string _oml_fom_msgtype_vals_bs11[] = {
313 + { NM_MT_BS11_RESET_RESOURCE, "SIE Reset Resource" },
314 + { NM_MT_BS11_BEGIN_DB_TX, "SIE Begin Database Transmission" },
315 + { NM_MT_BS11_BEGIN_DB_TX_ACK, "SIE Begin Database Transmission ACK" },
316 + { NM_MT_BS11_BEGIN_DB_TX_NACK, "SIE Begin Database Transmission NACK" },
317 + { NM_MT_BS11_END_DB_TX, "SIE End Database Transmission" },
318 + { NM_MT_BS11_END_DB_TX_ACK, "SIE End Database Transmission ACK" },
319 + { NM_MT_BS11_END_DB_TX_NACK, "SIE End Database Transmission NACK" },
320 + { NM_MT_BS11_CREATE_OBJ, "SIE Create Object" },
321 + { NM_MT_BS11_CREATE_OBJ_ACK, "SIE Create Object ACK" },
322 + { NM_MT_BS11_CREATE_OBJ_NACK, "SIE Create Object NACK" },
323 + { NM_MT_BS11_DELETE_OBJ, "SIE Delete Object" },
324 + { NM_MT_BS11_DELETE_OBJ_ACK, "SIE Delete Object ACK" },
325 + { NM_MT_BS11_DELETE_OBJ_NACK, "SIE Delete Object NACK" },
326 + { NM_MT_BS11_SET_ATTR, "SIE Set Attribute" },
327 + { NM_MT_BS11_SET_ATTR_ACK, "SIE Set Attribute ACK" },
328 + { NM_MT_BS11_SET_ATTR_NACK, "SIE Set Attribute NACK" },
329 + { NM_MT_BS11_GET_STATE, "SIE Get State" },
330 + { NM_MT_BS11_GET_STATE_ACK, "SIE Get State ACK" },
331 + { NM_MT_BS11_LMT_LOGON, "SIE LMT Logon" },
332 + { NM_MT_BS11_LMT_LOGON_ACK, "SIE LMT Logon ACK" },
333 + { NM_MT_BS11_RESTART, "SIE Restart" },
334 + { NM_MT_BS11_RESTART_ACK, "SIE Restart ACK" },
335 + { NM_MT_BS11_DISCONNECT, "SIE Disconnect BTS" },
336 + { NM_MT_BS11_DISCONNECT_ACK, "SIE Disconnect BTS ACK" },
337 + { NM_MT_BS11_LMT_LOGOFF, "SIE LMT Logoff" },
338 + { NM_MT_BS11_LMT_LOGOFF_ACK, "SIE LMT Logoff ACK" },
339 + { NM_MT_BS11_RECONNECT, "SIE Reconnect BTS" },
340 + { NM_MT_BS11_RECONNECT_ACK, "SIE Reconnect BTS ACK" },
341 + { 0, NULL }
344 +/* initialize with the standard message types only */
345 +static value_string_ext oml_fom_msgtype_vse = VALUE_STRING_EXT_INIT(_oml_fom_msgtype_vals);
347 +/* TS 12.21 Section 9.2: Object Class */
348 +static const value_string oml_fom_objclass_vals[] = {
349 + { NM_OC_SITE_MANAGER, "BTS Site Manager" },
350 + { NM_OC_BTS, "BTS" },
351 + { NM_OC_RADIO_CARRIER, "Radio Carrier" },
352 + { NM_OC_CHANNEL, "Radio Channel" },
353 + { NM_OC_BASEB_TRANSC, "Baseband Transceiver" },
355 + /* proprietary, vendor specific */
356 + { NM_OC_BS11_ADJC, "SIE Adjacend Channel" },
357 + { NM_OC_BS11_HANDOVER, "SIE Handover" },
358 + { NM_OC_BS11_PWR_CTRL, "SIE Power Control" },
359 + { NM_OC_BS11_BTSE, "SIE BTSE" },
360 + { NM_OC_BS11_RACK, "SIE Rack" },
361 + { NM_OC_BS11, "SIE SiemensHW" },
362 + { NM_OC_BS11_TEST, "SIE Test" },
363 + { NM_OC_BS11_ENVABTSE, "SIE EnvaBTSE" },
364 + { NM_OC_BS11_BPORT, "SIE BPort" },
366 + { NM_OC_GPRS_NSE, "GPRS NSE" },
367 + { NM_OC_GPRS_CELL, "GPRS Cell" },
368 + { NM_OC_GPRS_NSVC0, "GPRS NSVC0" },
369 + { NM_OC_GPRS_NSVC1, "GPRS NSVC1" },
371 + { NM_OC_NULL, "NULL" },
372 + { 0, NULL }
375 +/* TS 12.21 Section 9.4: Attributes */
376 +static const value_string _oml_fom_attr_vals[] = {
377 + { NM_ATT_ABIS_CHANNEL, "A-bis Channel" },
378 + { NM_ATT_ADD_INFO, "Additional Information" },
379 + { NM_ATT_ADD_TEXT, "Additional Text" },
380 + { NM_ATT_ADM_STATE, "Administrative State" },
381 + { NM_ATT_ARFCN_LIST, "ARFCN List" },
382 + { NM_ATT_AUTON_REPORT, "Autonomously Report" },
383 + { NM_ATT_AVAIL_STATUS, "Availability Status" },
384 + { NM_ATT_BCCH_ARFCN, "BCCH ARFCN" },
385 + { NM_ATT_BSIC, "BSIC" },
386 + { NM_ATT_BTS_AIR_TIMER, "BTS Air Timer" },
387 + { NM_ATT_CCCH_L_I_P, "CCCH Load Indication Period" },
388 + { NM_ATT_CCCH_L_T, "CCCH Load Threshold" },
389 + { NM_ATT_CHAN_COMB, "Channel Combination" },
390 + { NM_ATT_CONN_FAIL_CRIT, "Connection Fail Criterion" },
391 + { NM_ATT_DEST, "Destination" },
392 + { NM_ATT_EVENT_TYPE, "Event Type" },
393 + { NM_ATT_FILE_ID, "File ID" },
394 + { NM_ATT_FILE_VERSION, "File Version" },
395 + { NM_ATT_GSM_TIME, "GSM Time" },
396 + { NM_ATT_HSN, "HSN" },
397 + { NM_ATT_HW_CONFIG, "HW Configuration" },
398 + { NM_ATT_HW_DESC, "HW Description" },
399 + { NM_ATT_INTAVE_PARAM, "Intave Parameter" },
400 + { NM_ATT_INTERF_BOUND, "Interference Boundaries" },
401 + { NM_ATT_LIST_REQ_ATTR, "List of required Attributes" },
402 + { NM_ATT_MAIO, "MAIO" },
403 + { NM_ATT_MANUF_STATE, "Manufacturer Dependent State" },
404 + { NM_ATT_MANUF_THRESH, "Manufacturer Dependent Thresholds" },
405 + { NM_ATT_MANUF_ID, "Manufacturer Id" },
406 + { NM_ATT_MAX_TA, "Maximum Timing Advance" },
407 + { NM_ATT_MDROP_LINK, "Multi-drop BSC Link" },
408 + { NM_ATT_MDROP_NEXT, "Multi-drop next BTS Link" },
409 + { NM_ATT_NACK_CAUSES, "NACK Causes" },
410 + { NM_ATT_NY1, "Ny1" },
411 + { NM_ATT_OPER_STATE, "Operational State" },
412 + { NM_ATT_OVERL_PERIOD, "Overload Period" },
413 + { NM_ATT_PHYS_CONF, "Physical Config" },
414 + { NM_ATT_POWER_CLASS, "Power Class" },
415 + { NM_ATT_POWER_THRESH, "Power Output Thresholds" },
416 + { NM_ATT_PROB_CAUSE, "Probable Cause" },
417 + { NM_ATT_RACH_B_THRESH, "RACH Busy Threshold" },
418 + { NM_ATT_LDAVG_SLOTS, "RACH Load Averaging Slots" },
419 + { NM_ATT_RAD_SUBC, "Radio Sub Channel" },
420 + { NM_ATT_RF_MAXPOWR_R, "RF Max Power Reduction" },
421 + { NM_ATT_SITE_INPUTS, "Site Inputs" },
422 + { NM_ATT_SITE_OUTPUTS, "Site Outputs" },
423 + { NM_ATT_SOURCE, "Source" },
424 + { NM_ATT_SPEC_PROB, "Specific Problems" },
425 + { NM_ATT_START_TIME, "Starting Time" },
426 + { NM_ATT_T200, "T200" },
427 + { NM_ATT_TEI, "TEI" },
428 + { NM_ATT_TEST_DUR, "Test Duration" },
429 + { NM_ATT_TEST_NO, "Test No" },
430 + { NM_ATT_TEST_REPORT, "Test Report Info" },
431 + { NM_ATT_VSWR_THRESH, "VSWR Thresholds " },
432 + { NM_ATT_WINDOW_SIZE, "Window Size" },
433 + { NM_ATT_BS11_RSSI_OFFS, "SIE RSSI Offset" },
434 + { NM_ATT_BS11_TXPWR, "SIE TX Power" },
435 + { NM_ATT_BS11_DIVERSITY, "SIE Diversity" },
436 + { NM_ATT_TSC, "Training Sequence Code" },
437 + { NM_ATT_SW_CONFIG, "SW Configuration" },
438 + { NM_ATT_SW_DESCR, "SW Description" },
439 + { NM_ATT_SEVERITY, "Perceived Severity" },
440 + { NM_ATT_GET_ARI, "Get ARI" },
441 + { NM_ATT_HW_CONF_CHG, "HW Configuration Change" },
442 + { NM_ATT_OUTST_ALARM, "Outstanding Alarm" },
443 + { NM_ATT_FILE_DATA, "File Data" },
444 + { NM_ATT_MEAS_RES, "Measurement Result" },
445 + { NM_ATT_MEAS_TYPE, "Measurement Type" },
446 + { 0, NULL }
449 +static value_string_ext oml_fom_attr_vse = VALUE_STRING_EXT_INIT(_oml_fom_attr_vals);
451 +/* proprietary Siemens attributes, not in the standard */
452 +static const value_string oml_fom_attr_vals_bs11[] = {
453 + { NM_ATT_BS11_OM_LAPD_REL_TIMER,"SIE OML LAPD Release Timer" },
454 + { NM_ATT_BS11_RF_RES_IND_PER, "SIE RF Resource Indication Period" },
455 + { NM_ATT_BS11_RX_LEV_MIN_CELL, "SIE RxLevel Min Cell" },
456 + { NM_ATT_BS11_ABIS_EXT_TIME, "SIE A-bis external time" },
457 + { NM_ATT_BS11_TIMER_HO_REQUEST, "SIE Timer Handover Request" },
458 + { NM_ATT_BS11_TIMER_NCELL, "SIE Timer nCell" },
459 + { NM_ATT_BS11_TSYNC, "SIE Timer Tsync" },
460 + { NM_ATT_BS11_TTRAU, "SIE Timer Ttrau" },
461 + { NM_ATT_BS11_EMRG_CFG_MEMBER, "SIE Emergency Config Member" },
462 + { NM_ATT_BS11_TRX_AREA, "SIE TRX Area" },
463 + { NM_ATT_BS11_BCCH_RECONF, "SIE BCCH Reconfiguration" },
464 + { NM_ATT_BS11_BIT_ERR_THESH, "SIE Bit Error Threshold" },
465 + { NM_ATT_BS11_BOOT_SW_VERS, "SIE Boot Software Version" },
466 + { NM_ATT_BS11_CCLK_ACCURACY, "SIE CCLK Accuracy" },
467 + { NM_ATT_BS11_CCLK_TYPE, "SIE CCLK Type" },
468 + { NM_ATT_BS11_INP_IMPEDANCE, "SIE Input Impedance" },
469 + { NM_ATT_BS11_L1_PROT_TYPE, "SIE L1 Protocol Type" },
470 + { NM_ATT_BS11_LINE_CFG, "SIE Line Configuration" },
471 + { NM_ATT_BS11_LI_PORT_1, "SIE Line Interface Port 1" },
472 + { NM_ATT_BS11_LI_PORT_2, "SIE Line Interface Port 2" },
473 + { NM_ATT_BS11_L1_REM_ALM_TYPE, "SIE L1 Remote Alarm Type" },
474 + { NM_ATT_BS11_SW_LOAD_INTENDED, "SIE Software Load Intended" },
475 + { NM_ATT_BS11_SW_LOAD_SAFETY, "SIE Software Load Safety" },
476 + { NM_ATT_BS11_SW_LOAD_STORED, "SIE Software Load Stored" },
477 + { NM_ATT_BS11_VENDOR_NAME, "SIE Vendor Name" },
478 + { NM_ATT_BS11_HOPPING_MODE, "SIE Hopping Mode" },
479 + { NM_ATT_BS11_LMT_LOGON_SESSION,"SIE LMT Logon Session" },
480 + { NM_ATT_BS11_LMT_LOGIN_TIME, "SIE LMT Login Time" },
481 + { NM_ATT_BS11_LMT_USER_ACC_LEV, "SIE LMT User Account Level" },
482 + { NM_ATT_BS11_LMT_USER_NAME, "SIE LMT User Account Name" },
483 + { NM_ATT_BS11_L1_CONTROL_TS, "SIE L1 Control TS" },
484 + { NM_ATT_BS11_RADIO_MEAS_GRAN, "SIE Radio Measurement Granularity" },
485 + { NM_ATT_BS11_RADIO_MEAS_REP, "SIE Rdadio Measurement Report" },
486 + { NM_ATT_BS11_SH_LAPD_INT_TIMER,"SIE LAPD Internal Timer" },
487 + { NM_ATT_BS11_BTS_STATE, "SIE BTS State" },
488 + { NM_ATT_BS11_E1_STATE, "SIE E1 State" },
489 + { NM_ATT_BS11_PLL, "SIE PLL" },
490 + { NM_ATT_BS11_RX_OFFSET, "SIE Rx Offset" },
491 + { NM_ATT_BS11_ANT_TYPE, "SIE Antenna Type" },
492 + { NM_ATT_BS11_PLL_MODE, "SIE PLL Mode" },
493 + { NM_ATT_BS11_PASSWORD, "SIE Password" },
494 + { NM_ATT_BS11_ESN_FW_CODE_NO, "SIE ESN FW Code Number" },
495 + { NM_ATT_BS11_ESN_HW_CODE_NO, "SIE ESN HW Code Number" },
496 + { NM_ATT_BS11_ESN_PCB_SERIAL, "SIE ESN PCB Serial Number" },
497 + { NM_ATT_BS11_EXCESSIVE_DISTANCE, "SIE Excessive Distance" },
498 + { NM_ATT_BS11_ALL_TEST_CATG, "SIE All Test Categories" },
499 + { NM_ATT_BS11_BTSLS_HOPPING, "SIE BTS LS Hopping" },
500 + { NM_ATT_BS11_CELL_ALLOC_NR, "SIE Cell Allocation Number" },
501 + { NM_ATT_BS11_CELL_GLOBAL_ID, "SIE Cell Global ID" },
502 + { NM_ATT_BS11_ENA_INTERF_CLASS, "SIE Enable Interference Class" },
503 + { NM_ATT_BS11_ENA_INT_INTEC_HANDO, "SIE Enable Int Intec Handover" },
504 + { NM_ATT_BS11_ENA_INT_INTRC_HANDO, "SIE Enable Int Intrc Handover" },
505 + { NM_ATT_BS11_ENA_MS_PWR_CTRL, "SIE Enable MS Power Control" },
506 + { NM_ATT_BS11_ENA_PWR_BDGT_HO, "SIE Enable Power Budget HO" },
507 + { NM_ATT_BS11_ENA_RXLEV_HO, "SIE Enable RxLevel HO" },
508 + { NM_ATT_BS11_ENA_RXQUAL_HO, "SIE Enable RxQual HO" },
509 + { NM_ATT_BS11_FACCH_QUAL, "SIE FACCH Quality" },
510 + { 0, NULL }
513 +/* proprietary ip.access attributes, not in the standard */
514 +static const value_string oml_fom_attr_vals_ipa[] = {
515 + { NM_ATT_IPACC_DST_IP, "IPA Destination IP Address" },
516 + { NM_ATT_IPACC_DST_IP_PORT, "IPA Destionation IP Port" },
517 + { NM_ATT_IPACC_SSRC, "IPA RTP SSRC" },
518 + { NM_ATT_IPACC_RTP_PAYLD_TYPE, "IPA RTP Payload Type" },
519 + { NM_ATT_IPACC_BASEB_ID, "IPA Baseband Identifier" },
520 + { NM_ATT_IPACC_STREAM_ID, "IPA Stream Identifier" },
521 + { NM_ATT_IPACC_NV_FLAGS, "IPA NVRAM Flags" },
522 + { NM_ATT_IPACC_FREQ_CTRL, "IPA Frequency Control" },
523 + { NM_ATT_IPACC_PRIM_OML_CFG, "IPA Primary OML Config" },
524 + { NM_ATT_IPACC_SEC_OML_CFG, "IPA Secondary OML Config" },
525 + { NM_ATT_IPACC_IP_IF_CFG, "IPA IP Interface Config" },
526 + { NM_ATT_IPACC_IP_GW_CFG, "IPA IP Gateway Config" },
527 + { NM_ATT_IPACC_IN_SERV_TIME, "IPA In Service Time" },
528 + { NM_ATT_IPACC_TRX_BTS_ASS, "IPA TRX BTS Assignment" },
529 + { NM_ATT_IPACC_LOCATION, "IPA BTS Location Name" },
530 + { NM_ATT_IPACC_PAGING_CFG, "IPA Paging Configuration" },
531 + { NM_ATT_IPACC_FILE_DATA, "IPA File Data" },
532 + { NM_ATT_IPACC_UNIT_ID, "IPA Unit ID" },
533 + { NM_ATT_IPACC_PARENT_UNIT_ID, "IPA Parent Unit ID" },
534 + { NM_ATT_IPACC_UNIT_NAME, "IPA Unit Name" },
535 + { NM_ATT_IPACC_SNMP_CFG, "IPA SNMP Config" },
536 + { NM_ATT_IPACC_PRIM_OML_CFG_LIST, "IPA Primary OML Config List" },
537 + { NM_ATT_IPACC_PRIM_OML_FB_TOUT,"IPA Primary OML Fallback Timeout" },
538 + { NM_ATT_IPACC_CUR_SW_CFG, "IPA Current Software Config" },
539 + { NM_ATT_IPACC_TIMING_BUS, "IPA Timing Bus" },
540 + { NM_ATT_IPACC_CGI, "IPA CGI" },
541 + { NM_ATT_IPACC_RAC, "IPA RAC" },
542 + { NM_ATT_IPACC_OBJ_VERSION, "IPA Object Version" },
543 + { NM_ATT_IPACC_GPRS_PAGING_CFG, "IPA GPRS Paging Configuration" },
544 + { NM_ATT_IPACC_NSEI, "IPA NSEI" },
545 + { NM_ATT_IPACC_BVCI, "IPA BVCI" },
546 + { NM_ATT_IPACC_NSVCI, "IPA NSVCI" },
547 + { NM_ATT_IPACC_NS_CFG, "IPA NS Configuration" },
548 + { NM_ATT_IPACC_BSSGP_CFG, "IPA BSSGP Configuration" },
549 + { NM_ATT_IPACC_NS_LINK_CFG, "IPA NS Link Configuration" },
550 + { NM_ATT_IPACC_RLC_CFG, "IPA RLC Configuration" },
551 + { NM_ATT_IPACC_ALM_THRESH_LIST, "IPA Alarm Threshold List" },
552 + { NM_ATT_IPACC_MONIT_VAL_LIST, "IPA Monitored Value List" },
553 + { NM_ATT_IPACC_TIB_CONTROL, "IPA Timing Interface Bus Control" },
554 + { NM_ATT_IPACC_SUPP_FEATURES, "IPA Supported Features" },
555 + { NM_ATT_IPACC_CODING_SCHEMES, "IPA Coding Schemes" },
556 + { NM_ATT_IPACC_RLC_CFG_2, "IPA RLC Configuration 2" },
557 + { NM_ATT_IPACC_HEARTB_TOUT, "IPA Heartbeat Timeout" },
558 + { NM_ATT_IPACC_UPTIME, "IPA Uptime" },
559 + { NM_ATT_IPACC_RLC_CFG_3, "IPA RLC Configuration 3" },
560 + { NM_ATT_IPACC_SSL_CFG, "IPA SSL Configuration" },
561 + { NM_ATT_IPACC_SEC_POSSIBLE, "IPA Security Possible" },
562 + { NM_ATT_IPACC_IML_SSL_STATE, "IPA IML SSL State" },
563 + { NM_ATT_IPACC_REVOC_DATE, "IPA Revocation Date" },
564 + { 0, NULL }
567 +#if 0
568 +static gint merge_value_strings(value_string **dst, const value_string *base, const value_string delta)
570 + const value_string *cur;
571 + guint num_base, num_delta, num_max, num_out;
573 + for (cur = base; cur->value || cur->strptr; cur++)
574 + num_base++;
575 + for (cur = delta; cur->value || cur->strptr; cur++)
576 + num_delta++;
577 + num_max = num_base + num_delta + 1; /* terminating entry */
579 + *dst = g_malloc(sizeof(value_string) * num_max);
580 + if (!*dst)
581 + return -ENOMEM;
582 + /* zero-initialize the entire array so we always are zero-
583 + * terminated */
584 + memset(*dst, 0, sizeof(value_string * num_max));
586 + /* initialize with the 'base' */
587 + memcpy(*dst, base, sizeof(value_string)*num_base);
588 + num_out = num_base;
590 + /* patch/append the delta */
591 + for (cur = delta; cur->value || cur->strptr; cur++) {
592 + guint idx;
593 + if (match_strval_idx(cur->value, base, &idx)) {
594 + /* the base set already contains a definition,
595 + * we need to override it */
596 + memcpy((*dst)[idx], cur, sizeof(value_string));
597 + } else {
598 + /* append the entry to the end */
599 + memcpy((*dst)[num_out], cur, sizeof(value_string));
600 + num_out++;
604 + return 0;
606 +#endif
608 +static const gchar *
609 +_match_oml_fom_msgtype(const guint32 val, const value_string_ext *vs)
611 + const char *ret;
612 + ret = match_strval(val, vs->_vs_p);
613 + if (!ret)
614 + ret = match_strval(val, _oml_fom_msgtype_vals);
615 + return ret;
618 +static const gchar *
619 +_match_oml_fom_attr(const guint32 val, const value_string_ext *vs)
621 + const char *ret;
622 + ret = match_strval(val, vs->_vs_p);
623 + if (!ret)
624 + ret = match_strval(val, _oml_fom_attr_vals);
625 + return ret;
628 +/* Section 9.4.4: Administrative State */
629 +static const value_string oml_adm_state_vals[] = {
630 + { NM_STATE_LOCKED, "Locked" },
631 + { NM_STATE_UNLOCKED, "Unlocked" },
632 + { NM_STATE_SHUTDOWN, "Shutdown" },
633 + { NM_STATE_NULL, "Null" },
634 + { 0, NULL }
637 +static const value_string oml_oper_state_vals[] = {
638 + { 1, "Disabled" },
639 + { 2, "Enabled" },
640 + { 0xff, "NULL" },
641 + { 0, NULL }
644 +/* Section 9.4.7 Availability Status */
645 +static const value_string oml_avail_state_vals[] = {
646 + { 0, "In test" },
647 + { 1, "Failed" },
648 + { 2, "Power off" },
649 + { 3, "Off line" },
650 + { 5, "Dependency" },
651 + { 6, "Degraded" },
652 + { 7, "Not installed" },
653 + { 0xff, "OK" },
654 + { 0, NULL }
657 +/* Section 9.4.13: Channel Combination */
658 +static const value_string oml_chan_comb_vals[] = {
659 + { NM_CHANC_TCHFull, "TCH/F" },
660 + { NM_CHANC_TCHHalf, "TCH/H" },
661 + { NM_CHANC_TCHHalf2, "TCH/H 2" },
662 + { NM_CHANC_SDCCH, "SDCCH" },
663 + { NM_CHANC_mainBCCH, "Main BCCH" },
664 + { NM_CHANC_BCCHComb, "Combined BCCH" },
665 + { NM_CHANC_BCCH, "BCCH" },
666 + { NM_CHANC_BCCH_CBCH, "BCCH+CBCH" },
667 + { NM_CHANC_SDCCH_CBCH, "SDCCH+CBCH" },
668 + { 0, NULL }
671 +/* Section 9.4.16: Event Type */
672 +static const value_string oml_event_type_vals[] = {
673 + { NM_EVT_COMM_FAIL, "Communication Failure" },
674 + { NM_EVT_QOS_FAIL, "QoS Failure" },
675 + { NM_EVT_PROC_FAIL, "Processor Failure" },
676 + { NM_EVT_EQUIP_FAIL, "Equipment Failure" },
677 + { NM_EVT_ENV_FAIL, "Environment Failure" },
678 + { 0, NULL }
681 +/* Section 9.4.63: Perceived Severity */
682 +static const value_string oml_severity_vals[] = {
683 + { NM_SEVER_CEASED, "Ceased" },
684 + { NM_SEVER_CRITICAL, "Critical" },
685 + { NM_SEVER_MAJOR, "Major" },
686 + { NM_SEVER_MINOR, "Minor" },
687 + { NM_SEVER_WARNING, "Warning" },
688 + { NM_SEVER_INDETERMINATE, "Indeterminate" },
689 + { 0, NULL }
692 +/* Section 9.4.36: NACK Causes */
693 +static const value_string oml_nack_cause[] = {
694 + { NM_NACK_INCORR_STRUCT, "Incorrect message structure" },
695 + { NM_NACK_MSGTYPE_INVAL, "Invalid message type value" },
696 + { NM_NACK_OBJCLASS_INVAL, "Invalid Object class value" },
697 + { NM_NACK_OBJCLASS_NOTSUPP, "Object Class not supported" },
698 + { NM_NACK_BTSNR_UNKN, "BTS Number unknown" },
699 + { NM_NACK_TRXNR_UNKN, "TRX Number unknown" },
700 + { NM_NACK_OBJINST_UNKN, "Object Instance unknown" },
701 + { NM_NACK_ATTRID_INVAL, "Invalid Attribute ID value" },
702 + { NM_NACK_ATTRID_NOTSUPP, "Attribute ID not supported" },
703 + { NM_NACK_PARAM_RANGE, "Parameter value out of range" },
704 + { NM_NACK_ATTRLIST_INCONSISTENT, "Inconsistency in Attribute list" },
705 + { NM_NACK_SPEC_IMPL_NOTSUPP, "Specified Implementation not supported" },
706 + { NM_NACK_CANT_PERFORM, "Message cannot be performed" },
707 + { NM_NACK_RES_NOTIMPL, "Resource not implemented" },
708 + { NM_NACK_RES_NOTAVAIL, "Resource not available" },
709 + { NM_NACK_FREQ_NOTAVAIL, "Frequency not available" },
710 + { NM_NACK_TEST_NOTSUPP, "Test not supported" },
711 + { NM_NACK_CAPACITY_RESTR, "Capacity restrictions" },
712 + { NM_NACK_PHYSCFG_NOTPERFORM, "Phys config cannot be performed" },
713 + { NM_NACK_TEST_NOTINIT, "Test not initiated" },
714 + { NM_NACK_PHYSCFG_NOTRESTORE, "Phys config cannot be restored" },
715 + { NM_NACK_TEST_NOSUCH, "No such Test" },
716 + { NM_NACK_TEST_NOSTOP, "Test cannot be stopped" },
717 + { NM_NACK_MSGINCONSIST_PHYSCFG, "Message inconsisten with physical config" },
718 + { NM_NACK_FILE_INCOMPLETE, "Complete file not received" },
719 + { NM_NACK_FILE_NOTAVAIL, "File not available at destination" },
720 + { NM_NACK_FILE_NOTACTIVATE, "File cannot be activated" },
721 + { NM_NACK_REQ_NOT_GRANT, "Request not granted" },
722 + { NM_NACK_WAIT, "Wait" },
723 + { NM_NACK_NOTH_REPORT_EXIST, "Nothing reportable existing" },
724 + { NM_NACK_MEAS_NOTSUPP, "Measurement not supported" },
725 + { NM_NACK_MEAS_NOTSTART, "Measurement not started" },
726 + { 0xff, "NULL" },
727 + { 0, NULL }
730 +static const value_string oml_test_no_vals[] = {
731 + { NM_IPACC_TESTNO_RLOOP_ANT, "Radio Loop test via antenna" },
732 + { NM_IPACC_TESTNO_RLOOP_XCVR, "Radio Loop test via transceiver" },
733 + { NM_IPACC_TESTNO_FUNC_OBJ, "BTS Functional object self test" },
734 + { NM_IPACC_TESTNO_CHAN_USAGE, "Channel Usage" },
735 + { NM_IPACC_TESTNO_BCCH_CHAN_USAGE, "BCCH Channel Usage" },
736 + { NM_IPACC_TESTNO_FREQ_SYNC, "Frequency Synchronization" },
737 + { NM_IPACC_TESTNO_BCCH_INFO, "BCCH Information" },
738 + { NM_IPACC_TESTNO_TX_BEACON, "Transmit Beacon" },
739 + { NM_IPACC_TESTNO_SYSINFO_MONITOR, "SysInfo Monitor" },
740 + { NM_IPACC_TESTNO_BCCCH_MONITOR, "BCCH & CCCH Monitor" },
741 + { 0, NULL }
744 +static const value_string ipacc_test_res_vals[] = {
745 + { NM_IPACC_TESTRES_SUCCESS, "Success" },
746 + { NM_IPACC_TESTRES_TIMEOUT, "Timeout" },
747 + { NM_IPACC_TESTRES_NO_CHANS, "No suitable channels available" },
748 + { NM_IPACC_TESTRES_PARTIAL, "Partial" },
749 + { NM_IPACC_TESTRES_STOPPED, "Stopped" },
750 + { 0, NULL }
753 +static const value_string ipacc_testres_ie_vals[] = {
754 + { NM_IPACC_TR_IE_FREQ_ERR_LIST, "Frequency Error List" },
755 + { NM_IPACC_TR_IE_CHAN_USAGE, "Channel Usage" },
756 + { NM_IPACC_TR_IE_BCCH_INFO, "BCCH Information" },
757 + { NM_IPACC_TR_IE_RESULT_DETAILS,"Result Details" },
758 + { NM_IPACC_TR_IE_FREQ_ERR, "Frequency Error" },
759 + { 0, NULL }
762 +static const struct tlv_def *
763 +find_tlv_tag(guint8 tag)
765 + const struct tlv_def *specific;
767 + if (global_oml_use_nano_bts)
768 + specific = &nm_att_tlvdef_ipa.def[tag];
769 + else
770 + specific = &nm_att_tlvdev_bs11.def[tag];
772 + if (specific->type != TLV_TYPE_UNKNOWN)
773 + return specific;
775 + return &nm_att_tlvdef_base.def[tag];
778 +/* Parse the ip.access specific BCCH Information IE embedded into the Test
779 + * Report IE */
780 +static gint
781 +ipacc_tr_ie_bcch(tvbuff_t *tvb, proto_tree *att_tree, int offset)
783 + guint16 binfo_type, tmp;
785 + binfo_type = tvb_get_ntohs(tvb, offset);
786 + offset += 2;
788 + tmp = tvb_get_ntohs(tvb, offset);
790 + /* FIXME: there are still some bugs remaining here */
791 + proto_tree_add_item(att_tree, hf_attr_ipa_tr_arfcn,
792 + tvb, offset, 2, TRUE);
794 + proto_tree_add_item(att_tree, hf_attr_ipa_tr_f_qual,
795 + tvb, offset, 2, TRUE);
796 + offset += 2;
798 + proto_tree_add_item(att_tree, hf_attr_ipa_tr_b_rxlev,
799 + tvb, offset++, 1, TRUE);
801 + proto_tree_add_item(att_tree, hf_attr_ipa_tr_rxqual,
802 + tvb, offset++, 1, TRUE);
804 + proto_tree_add_item(att_tree, hf_attr_ipa_tr_f_err,
805 + tvb, offset, 2, TRUE);
806 + offset += 2;
808 + proto_tree_add_item(att_tree, hf_attr_ipa_tr_frame_offs,
809 + tvb, offset, 2, TRUE);
810 + offset += 2;
811 + proto_tree_add_item(att_tree, hf_attr_ipa_tr_framenr_offs,
812 + tvb, offset, 4, TRUE);
813 + offset += 4;
815 + proto_tree_add_item(att_tree, hf_attr_ipa_tr_bsic,
816 + tvb, offset++, 1, TRUE);
818 + de_lai(tvb, att_tree, offset, 5, NULL, 0);
819 + offset += 5;
821 + proto_tree_add_item(att_tree, hf_attr_ipa_tr_cell_id,
822 + tvb, offset, 2, TRUE);
823 + offset += 2;
825 + if (binfo_type & 0x8000) {
826 + /* System Information 2 */
827 + /* FIXME: Parse 04.18 Neighbour Cell Description */
828 + proto_tree_add_item(att_tree, hf_attr_ipa_tr_si2,
829 + tvb, offset, 16, TRUE);
830 + offset += 16;
832 + if (binfo_type & 0x0001) {
833 + /* System Information 2bis */
834 + /* FIXME: Parse 04.18 Neighbour Cell Description */
835 + proto_tree_add_item(att_tree, hf_attr_ipa_tr_si2bis,
836 + tvb, offset, 16, TRUE);
837 + offset += 16;
839 + if (binfo_type & 0x0002) {
840 + /* System Information 2ter */
841 + /* FIXME: Parse 04.18 Neighbour Cell Description */
842 + proto_tree_add_item(att_tree, hf_attr_ipa_tr_si2ter,
843 + tvb, offset, 16, TRUE);
844 + offset += 16;
846 + if (binfo_type & 0x0004) {
847 + /* FIXME: Parse 04.18 Cell Channel Description */
848 + proto_tree_add_item(att_tree, hf_attr_ipa_tr_chan_desc,
849 + tvb, offset, 16, TRUE);
850 + offset += 16;
853 + return offset;
856 +/* Parse the ip.access specific Channel Usage IE embedded into the Test
857 + * Report IE */
858 +static gint
859 +ipacc_tr_ie_chan_usage(tvbuff_t *tvb, proto_tree *att_tree, int offset)
861 + while (tvb_reported_length_remaining(tvb, offset) != 0) {
862 + guint16 result;
864 + result = tvb_get_ntohs(tvb, offset);
865 + proto_tree_add_uint(att_tree, hf_attr_ipa_tr_arfcn,
866 + tvb, offset, 2, result);
867 + proto_tree_add_uint(att_tree, hf_attr_ipa_tr_rxlev,
868 + tvb, offset, 2, result);
869 + offset += 2;
871 + return offset;
874 +/* Parse the ip.access specific format of the standard test report IE */
875 +static gint
876 +dissect_ipacc_test_rep(proto_tree *tree, tvbuff_t *tvb)
878 + gint offset = 0;
880 + proto_tree_add_item(tree, hf_attr_ipa_test_res, tvb, offset++,
881 + 1, FALSE);
883 + while (tvb_reported_length_remaining(tvb, offset) != 0) {
884 + guint8 ie;
885 + guint16 len;
886 + proto_item *ti;
887 + proto_tree *att_tree;
889 + ie = tvb_get_guint8(tvb, offset);
890 + len = tvb_get_ntohs(tvb, offset+1);
891 + ti = proto_tree_add_item(tree, hf_oml_ipa_tres_attr_tag, tvb,
892 + offset++, 1, FALSE);
893 + att_tree = proto_item_add_subtree(ti, ett_oml_fom_att);
894 + proto_tree_add_uint(att_tree, hf_oml_ipa_tres_attr_len, tvb,
895 + offset, 2, len);
896 + offset += 2;
898 + switch (ie) {
899 + case NM_IPACC_TR_IE_CHAN_USAGE:
900 + offset = ipacc_tr_ie_chan_usage(tvb,
901 + att_tree, offset);
902 + break;
903 + case NM_IPACC_TR_IE_BCCH_INFO:
904 + offset = ipacc_tr_ie_bcch(tvb,
905 + att_tree, offset);
906 + break;
907 + default:
908 + break;
911 + return offset;
914 +/* Dissect OML FOM Attributes after OML + FOM header */
915 +static gint
916 +dissect_oml_attrs(tvbuff_t *tvb, int base_offs, packet_info *pinfo,
917 + proto_tree *tree)
919 + int offset = base_offs;
921 + while (tvb_reported_length_remaining(tvb, offset) != 0) {
922 + guint i;
923 + guint8 tag, val8;
924 + guint16 val16;
925 + guint32 val32;
926 + unsigned int len, len_len, hlen;
927 + const struct tlv_def *tdef;
928 + proto_item *ti;
929 + proto_tree *att_tree;
930 + tvbuff_t *sub_tvb;
932 + tag = tvb_get_guint8(tvb, offset);
933 + tdef = find_tlv_tag(tag);
935 + switch (tdef->type) {
936 + case TLV_TYPE_FIXED:
937 + hlen = 1;
938 + len_len = 0;
939 + len = tdef->fixed_len;
940 + break;
941 + case TLV_TYPE_T:
942 + hlen = 1;
943 + len_len = 0;
944 + len = 0;
945 + break;
946 + case TLV_TYPE_TV:
947 + hlen = 1;
948 + len_len = 0;
949 + len = 1;
950 + break;
951 + case TLV_TYPE_TLV:
952 + hlen = 2;
953 + len_len = 1;
954 + len = tvb_get_guint8(tvb, offset+1);
955 + break;
956 + case TLV_TYPE_TL16V:
957 + hlen = 3;
958 + len_len = 2;
959 + len = tvb_get_guint8(tvb, offset+1) << 8 |
960 + tvb_get_guint8(tvb, offset+2);
961 + break;
962 + case TLV_TYPE_TLV16:
963 + hlen = 2;
964 + len_len = 1;
965 + len = tvb_get_guint8(tvb, offset+1) * 2;
966 + break;
967 + case TLV_TYPE_UNKNOWN: /* fall through */
968 + default:
969 + hlen = len_len = len = 0;
970 + DISSECTOR_ASSERT_NOT_REACHED();
971 + break;
974 + ti = proto_tree_add_item(tree, hf_oml_fom_attr_tag, tvb,
975 + offset, 1, FALSE);
976 + att_tree = proto_item_add_subtree(ti, ett_oml_fom_att);
977 + proto_tree_add_uint(att_tree, hf_oml_fom_attr_len, tvb,
978 + offset+1, len_len, len);
979 + offset += hlen;
981 + sub_tvb = tvb_new_subset(tvb, offset, len, len);
983 + switch (tag) {
984 + /* parse only the most common IE for now */
985 + case NM_ATT_ABIS_CHANNEL:
986 + proto_tree_add_item(att_tree, hf_attr_ach_btsp, tvb,
987 + offset, 1, TRUE);
988 + proto_tree_add_item(att_tree, hf_attr_ach_tslot, tvb,
989 + offset+1, 1, TRUE);
990 + proto_tree_add_item(att_tree, hf_attr_ach_sslot, tvb,
991 + offset+2, 1, TRUE);
992 + break;
993 + case NM_ATT_ADM_STATE:
994 + proto_tree_add_item(att_tree, hf_attr_adm_state, tvb,
995 + offset, len, FALSE);
996 + val8 = tvb_get_guint8(tvb, offset);
997 + col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
998 + val_to_str(val8, oml_adm_state_vals,
999 + "%02x"));
1000 + break;
1001 + case NM_ATT_ARFCN_LIST:
1002 + for (i = 0; i < len; i += 2) {
1003 + val16 = tvb_get_ntohs(tvb, offset + i);
1004 + proto_tree_add_uint(att_tree, hf_attr_arfcn,
1005 + tvb, offset + i, 2, val16);
1007 + break;
1008 + case NM_ATT_AVAIL_STATUS:
1009 + /* Availability status can have length 0 */
1010 + if (len) {
1011 + val8 = tvb_get_guint8(tvb, offset);
1012 + proto_tree_add_item(att_tree,
1013 + hf_attr_avail_state, tvb,
1014 + offset, len, FALSE);
1015 + } else
1016 + val8 = 0xff;
1017 + col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
1018 + val_to_str(val8, oml_avail_state_vals,
1019 + "%02x"));
1020 + break;
1021 + case NM_ATT_BCCH_ARFCN:
1022 + proto_tree_add_item(att_tree, hf_attr_bcch_arfcn, tvb,
1023 + offset, len, FALSE);
1024 + break;
1025 + case NM_ATT_BSIC:
1026 + proto_tree_add_item(att_tree, hf_attr_bsic, tvb,
1027 + offset, len, TRUE);
1028 + break;
1029 + case NM_ATT_CHAN_COMB:
1030 + proto_tree_add_item(att_tree, hf_attr_chan_comb, tvb,
1031 + offset, len, TRUE);
1032 + break;
1033 + case NM_ATT_EVENT_TYPE:
1034 + proto_tree_add_item(att_tree, hf_attr_event_type, tvb,
1035 + offset, len, TRUE);
1036 + break;
1037 + case NM_ATT_GSM_TIME:
1038 + proto_tree_add_item(att_tree, hf_attr_gsm_time, tvb,
1039 + offset, len, TRUE);
1040 + break;
1041 + case NM_ATT_OPER_STATE:
1042 + proto_tree_add_item(att_tree, hf_attr_oper_state, tvb,
1043 + offset, len, FALSE);
1044 + val8 = tvb_get_guint8(tvb, offset);
1045 + col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
1046 + val_to_str(val8, oml_oper_state_vals,
1047 + "%02x"));
1048 + break;
1049 + case NM_ATT_TEI:
1050 + proto_tree_add_item(att_tree, hf_attr_tei, tvb,
1051 + offset, len, TRUE);
1052 + break;
1053 + case NM_ATT_TSC:
1054 + proto_tree_add_item(att_tree, hf_attr_tsc, tvb,
1055 + offset, len, TRUE);
1056 + break;
1057 + case NM_ATT_SEVERITY:
1058 + proto_tree_add_item(att_tree, hf_attr_severity, tvb,
1059 + offset, len, TRUE);
1060 + break;
1061 + case NM_ATT_TEST_REPORT:
1062 + dissect_ipacc_test_rep(att_tree, sub_tvb);
1063 + break;
1064 + case NM_ATT_TEST_NO:
1065 + proto_tree_add_item(att_tree, hf_attr_test_no, tvb,
1066 + offset, len, TRUE);
1067 + val8 = tvb_get_guint8(tvb, offset);
1068 + col_append_fstr(pinfo->cinfo, COL_INFO, "%s ",
1069 + val_to_str(val8, oml_test_no_vals,
1070 + "%02x"));
1071 + break;
1072 + case NM_ATT_HSN:
1073 + proto_tree_add_item(att_tree, hf_attr_hsn, tvb,
1074 + offset, len, TRUE);
1075 + break;
1076 + case NM_ATT_MAIO:
1077 + proto_tree_add_item(att_tree, hf_attr_maio, tvb,
1078 + offset, len, TRUE);
1079 + break;
1080 + default:
1081 + proto_tree_add_item(att_tree, hf_oml_fom_attr_val, tvb,
1082 + offset, len, FALSE);
1085 + if (global_oml_use_nano_bts) switch (tag) {
1086 + /* proprietary ip.access extensions */
1087 + case NM_ATT_IPACC_DST_IP:
1088 + val32 = tvb_get_ntohl(tvb, offset);
1089 + proto_tree_add_ipv4(att_tree, hf_attr_ipa_rsl_ip, tvb,
1090 + offset, len, val32);
1091 + break;
1092 + case NM_ATT_IPACC_DST_IP_PORT:
1093 + val16 = tvb_get_ntohs(tvb, offset);
1094 + proto_tree_add_uint(att_tree, hf_attr_ipa_rsl_port, tvb,
1095 + offset, len, val16);
1096 + break;
1097 + case NM_ATT_IPACC_LOCATION:
1098 + proto_tree_add_item(att_tree, hf_attr_ipa_location_name,
1099 + tvb, offset, len, TRUE);
1100 + break;
1101 + case NM_ATT_IPACC_UNIT_ID:
1102 + proto_tree_add_item(att_tree, hf_attr_ipa_unit_id,
1103 + tvb, offset, len, TRUE);
1104 + break;
1105 + case NM_ATT_IPACC_UNIT_NAME:
1106 + proto_tree_add_item(att_tree, hf_attr_ipa_unit_name,
1107 + tvb, offset, len, TRUE);
1108 + break;
1109 + case NM_ATT_IPACC_PRIM_OML_CFG_LIST:
1110 + proto_tree_add_item(att_tree, hf_attr_ipa_prim_oml_ip,
1111 + tvb, offset+1, 4, TRUE);
1112 + proto_tree_add_item(att_tree, hf_attr_ipa_prim_oml_port,
1113 + tvb, offset+1+4, 2, TRUE);
1114 + break;
1115 + case NM_ATT_IPACC_NV_FLAGS:
1117 + guint flags, mask;
1118 + flags = tvb_get_guint8(tvb, offset);
1119 + mask = tvb_get_guint8(tvb, offset+1);
1120 + flags |= tvb_get_guint8(tvb, offset+2) << 8;
1121 + mask |= tvb_get_guint8(tvb, offset+3) << 8;
1122 + proto_tree_add_uint(att_tree, hf_attr_ipa_nv_flags,
1123 + tvb, offset, 3, flags);
1124 + proto_tree_add_uint(att_tree, hf_attr_ipa_nv_mask,
1125 + tvb, offset+1, 3, mask);
1127 + break;
1128 + case NM_ATT_IPACC_RAC:
1129 + proto_tree_add_item(att_tree, hf_attr_ipa_rac,
1130 + tvb, offset, 1, TRUE);
1131 + break;
1132 + case NM_ATT_IPACC_NSEI:
1133 + val16 = tvb_get_ntohs(tvb, offset);
1134 + proto_tree_add_uint(att_tree, hf_attr_ipa_nsei,
1135 + tvb, offset, 2, val16);
1136 + break;
1137 + case NM_ATT_IPACC_NSVCI:
1138 + val16 = tvb_get_ntohs(tvb, offset);
1139 + proto_tree_add_uint(att_tree, hf_attr_ipa_nsvci,
1140 + tvb, offset, 2, val16);
1141 + break;
1142 + case NM_ATT_IPACC_BVCI:
1143 + val16 = tvb_get_ntohs(tvb, offset);
1144 + proto_tree_add_uint(att_tree, hf_attr_ipa_bvci,
1145 + tvb, offset, 2, val16);
1146 + break;
1147 + case NM_ATT_IPACC_NS_LINK_CFG:
1148 + val16 = tvb_get_ntohs(tvb, offset);
1149 + proto_tree_add_uint(att_tree, hf_attr_ipa_nsl_sport,
1150 + tvb, offset, 2, val16);
1151 + val32 = tvb_get_ipv4(tvb, offset+2);
1152 + proto_tree_add_ipv4(att_tree, hf_attr_ipa_nsl_daddr,
1153 + tvb, offset+2, 4, val32);
1154 + val16 = tvb_get_ntohs(tvb, offset+6);
1155 + proto_tree_add_uint(att_tree, hf_attr_ipa_nsl_dport,
1156 + tvb, offset+6, 2, val16);
1157 + break;
1159 + offset += len;
1161 + return offset;
1164 +static int
1165 +dissect_oml_fom(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
1166 + int offset, proto_item *top_ti)
1168 + guint8 msg_type, obj_class, bts_nr, trx_nr, ts_nr;
1169 + proto_item *ti;
1170 + proto_tree *fom_tree;
1172 + msg_type = tvb_get_guint8(tvb, offset);
1173 + obj_class = tvb_get_guint8(tvb, offset+1);
1174 + bts_nr = tvb_get_guint8(tvb, offset+2);
1175 + trx_nr = tvb_get_guint8(tvb, offset+3);
1176 + ts_nr = tvb_get_guint8(tvb, offset+4);
1177 + proto_item_append_text(top_ti, ", %s(%02x,%02x,%02x) %s ",
1178 + val_to_str(obj_class, oml_fom_objclass_vals, "%02x"),
1179 + bts_nr, trx_nr, ts_nr,
1180 + val_to_str_ext(msg_type, &oml_fom_msgtype_vse,
1181 + "unknown 0x%x"));
1182 + col_append_fstr(pinfo->cinfo, COL_INFO, "%s(%02x,%02x,%02x) %s ",
1183 + val_to_str(obj_class, oml_fom_objclass_vals, "%02x"),
1184 + bts_nr, trx_nr, ts_nr,
1185 + val_to_str_ext(msg_type, &oml_fom_msgtype_vse,
1186 + "unknown 0x%x"));
1187 + ti = proto_tree_add_item(tree, hf_oml_fom_msgtype, tvb, offset++, 1, FALSE);
1188 + fom_tree = proto_item_add_subtree(ti, ett_oml_fom);
1189 + proto_tree_add_item(fom_tree, hf_oml_fom_objclass, tvb, offset++, 1, FALSE);
1190 + proto_tree_add_item(fom_tree, hf_oml_fom_inst_bts, tvb, offset++, 1, FALSE);
1191 + proto_tree_add_item(fom_tree, hf_oml_fom_inst_trx, tvb, offset++, 1, FALSE);
1192 + proto_tree_add_item(fom_tree, hf_oml_fom_inst_ts, tvb, offset++, 1, FALSE);
1195 + /* dissect the TLV objects in the message body */
1196 + offset = dissect_oml_attrs(tvb, offset, pinfo, fom_tree);
1198 + return offset;
1201 +static const guint8 ipaccess_magic[] = "com.ipaccess";
1203 +static int
1204 +dissect_oml_manuf(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
1205 + int offset, proto_item *top_ti)
1207 + if (tvb_get_guint8(tvb, offset) != 0x0d ||
1208 + tvb_memeql(tvb, offset+1, ipaccess_magic, sizeof(ipaccess_magic)))
1209 + return offset;
1211 + offset += sizeof(ipaccess_magic) + 1;
1213 + return dissect_oml_fom(tvb, pinfo, tree, offset, top_ti);
1216 +static void
1217 +dissect_abis_oml(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
1219 + proto_item *ti;
1220 + proto_tree *oml_tree;
1222 + int offset = 0;
1224 + col_set_str(pinfo->cinfo, COL_PROTOCOL, "OML");
1226 + top_tree = tree;
1227 + if (tree) {
1228 + u_int8_t msg_disc = tvb_get_guint8(tvb, offset);
1230 + ti = proto_tree_add_item(tree, proto_abis_oml, tvb, 0, -1, FALSE);
1231 + oml_tree = proto_item_add_subtree(ti, ett_oml);
1233 + proto_tree_add_item(oml_tree, hf_oml_msg_disc, tvb, offset++,
1234 + 1, TRUE);
1235 + proto_tree_add_item(oml_tree, hf_oml_placement, tvb, offset++,
1236 + 1, TRUE);
1237 + proto_tree_add_item(oml_tree, hf_oml_sequence, tvb, offset++,
1238 + 1, TRUE);
1239 + proto_tree_add_item(oml_tree, hf_oml_length, tvb, offset++,
1240 + 1, TRUE);
1242 + switch (msg_disc) {
1243 + case ABIS_OM_MDISC_FOM:
1244 + offset = dissect_oml_fom(tvb, pinfo, oml_tree,
1245 + offset, ti);
1246 + break;
1247 + case ABIS_OM_MDISC_MANUF:
1248 + offset = dissect_oml_manuf(tvb, pinfo, oml_tree, offset, ti);
1249 + break;
1250 + case ABIS_OM_MDISC_MMI:
1251 + case ABIS_OM_MDISC_TRAU:
1252 + default:
1253 + break;
1258 +void
1259 +proto_reg_handoff_abis_oml(void);
1261 +void
1262 +proto_register_abis_oml(void)
1264 + static hf_register_info hf[] = {
1265 + { &hf_oml_msg_disc,
1266 + { "Message Discriminator", "oml.msg_dsc",
1267 + FT_UINT8, BASE_HEX, VALS(oml_msg_disc_vals), 0,
1268 + "GSM 12.21 Message Discriminator", HFILL }
1269 + },
1270 + { &hf_oml_placement,
1271 + { "Placement Indicator", "oml.placement",
1272 + FT_UINT8, BASE_HEX, VALS(oml_placement_vals), 0,
1273 + "GSM 12.21 Placement Indicator", HFILL }
1274 + },
1275 + { &hf_oml_sequence,
1276 + { "Sequence Number", "oml.sequence",
1277 + FT_UINT8, BASE_HEX, NULL, 0,
1278 + "Sequence Number (if multi-part msg)", HFILL }
1279 + },
1280 + { &hf_oml_length,
1281 + { "Length Indicator", "oml.length",
1282 + FT_UINT8, BASE_DEC, NULL, 0,
1283 + "Total length of payload", HFILL }
1284 + },
1285 + { &hf_oml_fom_msgtype,
1286 + { "FOM Message Type", "oml.fom.msg_type",
1287 + FT_UINT8, BASE_HEX|BASE_EXT_STRING, (&oml_fom_msgtype_vse), 0,
1288 + NULL, HFILL }
1289 + },
1290 + { &hf_oml_fom_objclass,
1291 + { "FOM Object Class", "oml.fom.obj_class",
1292 + FT_UINT8, BASE_HEX, VALS(oml_fom_objclass_vals), 0,
1293 + NULL, HFILL }
1294 + },
1295 + { &hf_oml_fom_inst_bts,
1296 + { "FOM Object Instance BTS", "oml.fom.obj_inst.bts",
1297 + FT_UINT8, BASE_DEC, NULL, 0,
1298 + NULL, HFILL }
1299 + },
1300 + { &hf_oml_fom_inst_trx,
1301 + { "FOM Object Instance TRX", "oml.fom.obj_inst.trx",
1302 + FT_UINT8, BASE_DEC, NULL, 0,
1303 + NULL, HFILL }
1304 + },
1305 + { &hf_oml_fom_inst_ts,
1306 + { "FOM Object Instance TS", "oml.fom.obj_inst.ts",
1307 + FT_UINT8, BASE_DEC, NULL, 0,
1308 + NULL, HFILL }
1309 + },
1310 + { &hf_oml_fom_attr_tag,
1311 + { "FOM Attribute ID", "oml.fom.attr_id",
1312 + FT_UINT8, BASE_HEX|BASE_EXT_STRING, (&oml_fom_attr_vse), 0,
1313 + NULL, HFILL }
1314 + },
1315 + { &hf_oml_fom_attr_len,
1316 + { "FOM Attribute Length", "oml.fom.attr_len",
1317 + FT_UINT16, BASE_DEC, NULL, 0,
1318 + NULL, HFILL }
1319 + },
1320 + { &hf_oml_fom_attr_val,
1321 + { "FOM Attribute Value", "oml.fom.attr_val",
1322 + FT_BYTES, BASE_NONE, NULL, 0,
1323 + NULL, HFILL }
1324 + },
1328 + /* OML Attributes */
1329 + { &hf_attr_adm_state,
1330 + { "Administrative State", "oml.fom.attr.adm_state",
1331 + FT_UINT8, BASE_HEX, VALS(oml_adm_state_vals), 0,
1332 + NULL, HFILL }
1333 + },
1334 + { &hf_attr_arfcn,
1335 + { "ARFCN", "oml.fom.attr.arfcn",
1336 + FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1337 + },
1338 + { &hf_attr_oper_state,
1339 + { "Operational State", "oml.fom.attr.oper_state",
1340 + FT_UINT8, BASE_HEX, VALS(oml_oper_state_vals), 0,
1341 + NULL, HFILL }
1342 + },
1343 + { &hf_attr_avail_state,
1344 + { "Availability Status", "oml.fom.attr.avail_state",
1345 + FT_UINT8, BASE_HEX, VALS(oml_avail_state_vals), 0,
1346 + NULL, HFILL }
1347 + },
1348 + { &hf_attr_event_type,
1349 + { "Event Type", "oml.fom.attr.event_type",
1350 + FT_UINT8, BASE_HEX, VALS(oml_event_type_vals), 0,
1351 + NULL, HFILL }
1352 + },
1353 + { &hf_attr_severity,
1354 + { "Severity", "oml.fom.attr.severity",
1355 + FT_UINT8, BASE_HEX, VALS(oml_severity_vals), 0,
1356 + NULL, HFILL }
1357 + },
1358 + { &hf_attr_bcch_arfcn,
1359 + { "BCCH ARFCN", "oml.fom.attr.bcch_arfcn",
1360 + FT_UINT16, BASE_DEC, NULL, 0,
1361 + "ARFCN of the BCCH", HFILL }
1362 + },
1363 + { &hf_attr_bsic,
1364 + { "BSIC", "oml.fom.attr.bsic",
1365 + FT_UINT16, BASE_HEX, NULL, 0,
1366 + "Base Station Identity Cdoe", HFILL }
1367 + },
1368 + { &hf_attr_test_no,
1369 + { "Test Number", "oml.fom.attr.test_no",
1370 + FT_UINT8, BASE_HEX, VALS(oml_test_no_vals), 0,
1371 + NULL, HFILL }
1372 + },
1373 + { &hf_attr_tsc,
1374 + { "TSC", "oml.fom.attr.tsc",
1375 + FT_UINT8, BASE_HEX, NULL, 0,
1376 + "Training Sequence Code", HFILL }
1377 + },
1378 + { &hf_attr_tei,
1379 + { "TEI", "oml.fom.attr.tei",
1380 + FT_UINT8, BASE_DEC, NULL, 0,
1381 + NULL, HFILL }
1382 + },
1383 + { &hf_attr_ach_btsp,
1384 + { "BTS E1 Port", "oml.fom.attr.abis_ch.bts_port",
1385 + FT_UINT8, BASE_DEC, NULL, 0,
1386 + NULL, HFILL }
1387 + },
1388 + { &hf_attr_ach_tslot,
1389 + { "E1 Timeslot", "oml.fom.attr.abis_ch.timeslot",
1390 + FT_UINT8, BASE_DEC, NULL, 0,
1391 + NULL, HFILL }
1392 + },
1393 + { &hf_attr_ach_sslot,
1394 + { "E1 Subslot", "oml.fom.attr.abis_ch.subslot",
1395 + FT_UINT8, BASE_DEC, NULL, 0,
1396 + NULL, HFILL }
1397 + },
1398 + { &hf_attr_gsm_time,
1399 + { "GSM Time", "oml.fom.attr.gsm_time",
1400 + FT_UINT16, BASE_DEC, NULL, 0,
1401 + "GSM Time", HFILL }
1402 + },
1403 + { &hf_attr_chan_comb,
1404 + { "Channel Combination", "oml.fom.attr.chan_comb",
1405 + FT_UINT8, BASE_HEX, VALS(oml_chan_comb_vals), 0,
1406 + NULL, HFILL }
1407 + },
1408 + { &hf_attr_hsn,
1409 + { "HSN", "oml.fom.attr.hsn",
1410 + FT_UINT8, BASE_DEC, NULL, 0,
1411 + "Hopping Sequence Number", HFILL }
1412 + },
1413 + { &hf_attr_maio,
1414 + { "MAIO", "oml.fom.attr.maio",
1415 + FT_UINT8, BASE_DEC, NULL, 0,
1416 + "Mobile Allocation Index Offset", HFILL }
1417 + },
1419 + /* IP Access */
1420 + { &hf_oml_ipa_tres_attr_tag,
1421 + { "IPA Test Result Embedded IE",
1422 + "oml.fom.testrep.ipa_tag",
1423 + FT_UINT8, BASE_HEX, VALS(ipacc_testres_ie_vals), 0,
1424 + "Information Element embedded into the Test Result "
1425 + "of ip.access BTS", HFILL },
1426 + },
1427 + { &hf_oml_ipa_tres_attr_len,
1428 + { "IPA Test Result Embedded IE Length",
1429 + "oml.fom.testrep.ipa_len",
1430 + FT_UINT16, BASE_DEC, NULL, 0,
1431 + "Length of ip.access Test Result Embedded IE", HFILL }
1432 + },
1433 + { &hf_attr_ipa_test_res,
1434 + { "IPA Test Result", "oml.fom.testrep.result",
1435 + FT_UINT8, BASE_DEC, VALS(ipacc_test_res_vals), 0,
1436 + NULL, HFILL }
1437 + },
1438 + { &hf_attr_ipa_tr_rxlev,
1439 + { "Rx Level", "oml.fom.testrep.ipa_rxlev",
1440 + FT_UINT16, BASE_DEC, NULL, 0xfc00, NULL, HFILL }
1441 + },
1442 + { &hf_attr_ipa_tr_b_rxlev,
1443 + { "Rx Level", "oml.fom.testrep.ipa_rxlev_b",
1444 + FT_UINT8, BASE_DEC, NULL, 0, NULL, HFILL }
1445 + },
1446 + { &hf_attr_ipa_tr_arfcn,
1447 + { "ARFCN", "oml.fom.testrep.ipa_arfcn",
1448 + FT_UINT16, BASE_DEC, NULL, 0x03ff, "ARFCN", HFILL }
1449 + },
1450 + { &hf_attr_ipa_tr_f_qual,
1451 + { "Frequency Quality", "oml.fom.testrep.ipa.freq_qual",
1452 + FT_UINT8, BASE_DEC, NULL, 0xfc, NULL, HFILL }
1453 + },
1454 + { &hf_attr_ipa_tr_f_err,
1455 + { "Frequency Error", "oml.fom.testrep.ipa.freq_err",
1456 + FT_INT16, BASE_DEC, NULL, 0, NULL, HFILL }
1457 + },
1458 + { &hf_attr_ipa_tr_rxqual,
1459 + { "Rx Quality", "oml.fom.testrep.ipa.rx_qual",
1460 + FT_UINT8, BASE_DEC, NULL, 0x7, NULL, HFILL }
1461 + },
1462 + { &hf_attr_ipa_tr_frame_offs,
1463 + { "Frame Offset", "oml.fom.testrep.ipa.frame_offset",
1464 + FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1465 + },
1466 + { &hf_attr_ipa_tr_framenr_offs,
1467 + { "Frame Number Offset",
1468 + "oml.fom.testrep.ipa.framenr_offset",
1469 + FT_UINT32, BASE_DEC, NULL, 0, NULL, HFILL }
1470 + },
1471 + { &hf_attr_ipa_tr_bsic,
1472 + { "BSIC", "oml.fom.testrep.ipa.bsic",
1473 + FT_UINT8, BASE_DEC, NULL, 0x3f,
1474 + "Base Station Identity Code", HFILL }
1475 + },
1476 + { &hf_attr_ipa_tr_cell_id,
1477 + { "Cell ID", "oml.fom.testrep.ipa.cell_id",
1478 + FT_UINT16, BASE_HEX, NULL, 0, NULL, HFILL }
1479 + },
1480 + { &hf_attr_ipa_rsl_ip,
1481 + { "BSC RSL IP Address", "oml.fom.attr.ipa.rsl_ip",
1482 + FT_IPv4, BASE_NONE, NULL, 0,
1483 + "IP Address to which the BTS establishes "
1484 + "the RSL link", HFILL }
1485 + },
1486 + { &hf_attr_ipa_rsl_port,
1487 + { "BSC RSL TCP Port", "oml.fom.attr.ipa.rsl_port",
1488 + FT_UINT16, BASE_DEC, NULL, 0,
1489 + "Port number to which the BST establishes "
1490 + "the RSL link", HFILL }
1491 + },
1492 + { &hf_attr_ipa_prim_oml_ip,
1493 + { "Primary OML IP Address",
1494 + "oml.fom.attr.ipa.prim_oml_ip",
1495 + FT_IPv4, BASE_NONE, NULL, 0,
1496 + "IP Address of the BSC for the primary OML link",
1497 + HFILL }
1498 + },
1499 + { &hf_attr_ipa_prim_oml_port,
1500 + { "Primary OML TCP Port",
1501 + "oml.fom.attr.ipa.prim_oml_port",
1502 + FT_UINT16, BASE_DEC, NULL, 0,
1503 + "TCP Port of the BSC for the primarly OML link",
1504 + HFILL }
1505 + },
1506 + { &hf_attr_ipa_location_name,
1507 + { "Location Name", "oml.fom.attr.ipa.loc_name",
1508 + FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL }
1509 + },
1510 + { &hf_attr_ipa_unit_name,
1511 + { "Unit Name", "oml.fom.attr.ipa.unit_name",
1512 + FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL }
1513 + },
1514 + { &hf_attr_ipa_unit_id,
1515 + { "Unit ID", "oml.fom.attr.ipa.unit_id",
1516 + FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL }
1517 + },
1518 + { &hf_attr_ipa_nv_flags,
1519 + { "NVRAM Config Flags", "oml.fom.attr.ipa.nv_flags",
1520 + FT_UINT16, BASE_HEX, NULL, 0xffff, NULL, HFILL }
1521 + },
1522 + { &hf_attr_ipa_nv_mask,
1523 + { "NVRAM Config Mask", "oml.fom.attr.ipa.nv_mask",
1524 + FT_UINT16, BASE_HEX, NULL, 0xffff, NULL, HFILL }
1525 + },
1526 + { &hf_attr_ipa_tr_si2,
1527 + { "System Information 2", "oml.fom.attr.ipa.si2",
1528 + FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL }
1529 + },
1530 + { &hf_attr_ipa_tr_si2bis,
1531 + { "System Information 2bis", "oml.fom.attr.ipa.si2bis",
1532 + FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL }
1533 + },
1534 + { &hf_attr_ipa_tr_si2ter,
1535 + { "System Information 2ter", "oml.fom.attr.ipa.si2ter",
1536 + FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL }
1537 + },
1538 + { &hf_attr_ipa_tr_chan_desc,
1539 + { "Cell Channel Description",
1540 + "oml.fom.attr.ipa.chan_desc",
1541 + FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL }
1542 + },
1543 + { &hf_attr_ipa_nsl_sport,
1544 + { "NS Link IP Source Port",
1545 + "oml.fom.attr.ipa.nsl_sport",
1546 + FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1547 + },
1548 + { &hf_attr_ipa_nsl_daddr,
1549 + { "NS Link IP Destination Addr",
1550 + "oml.fom.attr.ipa.nsl_daddr",
1551 + FT_IPv4, BASE_NONE, NULL, 0, NULL, HFILL }
1552 + },
1553 + { &hf_attr_ipa_nsl_dport,
1554 + { "NS Link IP Destination Port",
1555 + "oml.fom.attr.ipa.nsl_dport",
1556 + FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1557 + },
1558 + { &hf_attr_ipa_nsei,
1559 + { "NSEI", "oml.fom.attr.ipa.nsei",
1560 + FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1561 + },
1562 + { &hf_attr_ipa_nsvci,
1563 + { "NSVCI", "oml.fom.attr.ipa.nsvci",
1564 + FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1565 + },
1566 + { &hf_attr_ipa_bvci,
1567 + { "BVCI", "oml.fom.attr.ipa.bvci",
1568 + FT_UINT16, BASE_DEC, NULL, 0, NULL, HFILL }
1569 + },
1570 + { &hf_attr_ipa_rac,
1571 + { "RAC", "oml.fom.attr.ipa.rac",
1572 + FT_UINT8, BASE_HEX, NULL, 0,
1573 + "Routing Area Code", HFILL }
1574 + },
1575 + };
1576 + static gint *ett[] = {
1577 + &ett_oml,
1578 + &ett_oml_fom,
1579 + &ett_oml_fom_att,
1580 + };
1582 + module_t *oml_module;
1584 + /* assign our custom match functions */
1585 + oml_fom_msgtype_vse._vs_match = _match_oml_fom_msgtype;
1586 + oml_fom_attr_vse._vs_match = _match_oml_fom_attr;
1588 + proto_abis_oml = proto_register_protocol("GSM A-bis OML", "A-bis OML",
1589 + "gsm_abis_oml");
1591 + proto_register_field_array(proto_abis_oml, hf, array_length(hf));
1593 + proto_register_subtree_array(ett, array_length(ett));
1595 + register_dissector("gsm_abis_oml", dissect_abis_oml, proto_abis_oml);
1597 + oml_module = prefs_register_protocol(proto_abis_oml, proto_reg_handoff_abis_oml);
1598 + prefs_register_bool_preference(oml_module, "use_ipaccess_oml",
1599 + "Use nanoBTS definitions",
1600 + "Use ipaccess nanoBTS specific definitions for OML",
1601 + &global_oml_use_nano_bts);
1604 +/* This function is called once at startup and every time the user hits
1605 + * 'apply' in the preferences dialogue */
1606 +void
1607 +proto_reg_handoff_abis_oml(void)
1609 + static gboolean initialized = FALSE;
1611 + if (!initialized) {
1612 + dissector_handle_t abis_oml_handle;
1614 + abis_oml_handle = create_dissector_handle(dissect_abis_oml, proto_abis_oml);
1615 + dissector_add("lapd.gsm.sapi", LAPD_GSM_SAPI_OM_PROC, abis_oml_handle);
1617 + } else {
1618 + /* preferences have been changed */
1621 + if (global_oml_use_nano_bts == TRUE) {
1622 + /* initialize with nanobts definitions */
1623 + oml_fom_msgtype_vse._vs_p = _oml_fom_msgtype_vals_ipa;
1624 + oml_fom_msgtype_vse._vs_num_entries =
1625 + array_length(_oml_fom_msgtype_vals_ipa)-1;
1626 + oml_fom_attr_vse._vs_p = oml_fom_attr_vals_ipa;
1627 + oml_fom_attr_vse._vs_num_entries =
1628 + array_length(oml_fom_attr_vals_ipa)-1;
1629 + } else {
1630 + /* initialize with BS11 defaults */
1631 + oml_fom_msgtype_vse._vs_p = _oml_fom_msgtype_vals_bs11;
1632 + oml_fom_msgtype_vse._vs_num_entries =
1633 + array_length(_oml_fom_msgtype_vals_bs11)-1;
1634 + oml_fom_attr_vse._vs_p = oml_fom_attr_vals_bs11;
1635 + oml_fom_attr_vse._vs_num_entries =
1636 + array_length(oml_fom_attr_vals_bs11)-1;
1639 Index: wireshark/epan/dissectors/packet-gsm_abis_oml.h
1640 ===================================================================
1641 --- /dev/null
1642 +++ wireshark/epan/dissectors/packet-gsm_abis_oml.h
1643 @@ -0,0 +1,830 @@
1644 +/* GSM Network Management messages on the A-bis interface
1645 + * 3GPP TS 12.21 version 8.0.0 Release 1999 / ETSI TS 100 623 V8.0.0 */
1647 +/* (C) 2008-2009 by Harald Welte <laforge@gnumonks.org>
1648 + * All Rights Reserved
1650 + * This program is free software; you can redistribute it and/or modify
1651 + * it under the terms of the GNU General Public License as published by
1652 + * the Free Software Foundation; either version 2 of the License, or
1653 + * (at your option) any later version.
1655 + * This program is distributed in the hope that it will be useful,
1656 + * but WITHOUT ANY WARRANTY; without even the implied warranty of
1657 + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1658 + * GNU General Public License for more details.
1660 + * You should have received a copy of the GNU General Public License along
1661 + * with this program; if not, write to the Free Software Foundation, Inc.,
1662 + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
1664 + */
1666 +#ifndef __PACKET_ABIS_OML_H__
1667 +#define __PACKET_ABIS_OML_H__
1669 +#include <sys/types.h>
1671 +/* From openbsc/include/openbsc/abis_nm.h */
1673 +/* generic header in front of every OML message according to TS 08.59 */
1674 +struct abis_om_hdr {
1675 + guint8 mdisc;
1676 + guint8 placement;
1677 + guint8 sequence;
1678 + guint8 length;
1679 + guint8 data[0];
1680 +} __attribute__ ((packed));
1682 +#define ABIS_OM_MDISC_FOM 0x80
1683 +#define ABIS_OM_MDISC_MMI 0x40
1684 +#define ABIS_OM_MDISC_TRAU 0x20
1685 +#define ABIS_OM_MDISC_MANUF 0x10
1686 +#define ABIS_OM_PLACEMENT_ONLY 0x80
1687 +#define ABIS_OM_PLACEMENT_FIRST 0x40
1688 +#define ABIS_OM_PLACEMENT_MIDDLE 0x20
1689 +#define ABIS_OM_PLACEMENT_LAST 0x10
1691 +struct abis_om_obj_inst {
1692 + guint8 bts_nr;
1693 + guint8 trx_nr;
1694 + guint8 ts_nr;
1695 +} __attribute__ ((packed));
1697 +struct abis_om_fom_hdr {
1698 + guint8 msg_type;
1699 + guint8 obj_class;
1700 + struct abis_om_obj_inst obj_inst;
1701 + guint8 data[0];
1702 +} __attribute__ ((packed));
1704 +#define ABIS_OM_FOM_HDR_SIZE (sizeof(struct abis_om_hdr) + sizeof(struct abis_om_fom_hdr))
1706 +/* Section 9.1: Message Types */
1707 +enum abis_nm_msgtype {
1708 + /* SW Download Management Messages */
1709 + NM_MT_LOAD_INIT = 0x01,
1710 + NM_MT_LOAD_INIT_ACK,
1711 + NM_MT_LOAD_INIT_NACK,
1712 + NM_MT_LOAD_SEG,
1713 + NM_MT_LOAD_SEG_ACK,
1714 + NM_MT_LOAD_ABORT,
1715 + NM_MT_LOAD_END,
1716 + NM_MT_LOAD_END_ACK,
1717 + NM_MT_LOAD_END_NACK,
1718 + NM_MT_SW_ACT_REQ, /* BTS->BSC */
1719 + NM_MT_SW_ACT_REQ_ACK,
1720 + NM_MT_SW_ACT_REQ_NACK,
1721 + NM_MT_ACTIVATE_SW, /* BSC->BTS */
1722 + NM_MT_ACTIVATE_SW_ACK,
1723 + NM_MT_ACTIVATE_SW_NACK,
1724 + NM_MT_SW_ACTIVATED_REP, /* 0x10 */
1725 + /* A-bis Interface Management Messages */
1726 + NM_MT_ESTABLISH_TEI = 0x21,
1727 + NM_MT_ESTABLISH_TEI_ACK,
1728 + NM_MT_ESTABLISH_TEI_NACK,
1729 + NM_MT_CONN_TERR_SIGN,
1730 + NM_MT_CONN_TERR_SIGN_ACK,
1731 + NM_MT_CONN_TERR_SIGN_NACK,
1732 + NM_MT_DISC_TERR_SIGN,
1733 + NM_MT_DISC_TERR_SIGN_ACK,
1734 + NM_MT_DISC_TERR_SIGN_NACK,
1735 + NM_MT_CONN_TERR_TRAF,
1736 + NM_MT_CONN_TERR_TRAF_ACK,
1737 + NM_MT_CONN_TERR_TRAF_NACK,
1738 + NM_MT_DISC_TERR_TRAF,
1739 + NM_MT_DISC_TERR_TRAF_ACK,
1740 + NM_MT_DISC_TERR_TRAF_NACK,
1741 + /* Transmission Management Messages */
1742 + NM_MT_CONN_MDROP_LINK = 0x31,
1743 + NM_MT_CONN_MDROP_LINK_ACK,
1744 + NM_MT_CONN_MDROP_LINK_NACK,
1745 + NM_MT_DISC_MDROP_LINK,
1746 + NM_MT_DISC_MDROP_LINK_ACK,
1747 + NM_MT_DISC_MDROP_LINK_NACK,
1748 + /* Air Interface Management Messages */
1749 + NM_MT_SET_BTS_ATTR = 0x41,
1750 + NM_MT_SET_BTS_ATTR_ACK,
1751 + NM_MT_SET_BTS_ATTR_NACK,
1752 + NM_MT_SET_RADIO_ATTR,
1753 + NM_MT_SET_RADIO_ATTR_ACK,
1754 + NM_MT_SET_RADIO_ATTR_NACK,
1755 + NM_MT_SET_CHAN_ATTR,
1756 + NM_MT_SET_CHAN_ATTR_ACK,
1757 + NM_MT_SET_CHAN_ATTR_NACK,
1758 + /* Test Management Messages */
1759 + NM_MT_PERF_TEST = 0x51,
1760 + NM_MT_PERF_TEST_ACK,
1761 + NM_MT_PERF_TEST_NACK,
1762 + NM_MT_TEST_REP,
1763 + NM_MT_SEND_TEST_REP,
1764 + NM_MT_SEND_TEST_REP_ACK,
1765 + NM_MT_SEND_TEST_REP_NACK,
1766 + NM_MT_STOP_TEST,
1767 + NM_MT_STOP_TEST_ACK,
1768 + NM_MT_STOP_TEST_NACK,
1769 + /* State Management and Event Report Messages */
1770 + NM_MT_STATECHG_EVENT_REP = 0x61,
1771 + NM_MT_FAILURE_EVENT_REP,
1772 + NM_MT_STOP_EVENT_REP,
1773 + NM_MT_STOP_EVENT_REP_ACK,
1774 + NM_MT_STOP_EVENT_REP_NACK,
1775 + NM_MT_REST_EVENT_REP,
1776 + NM_MT_REST_EVENT_REP_ACK,
1777 + NM_MT_REST_EVENT_REP_NACK,
1778 + NM_MT_CHG_ADM_STATE,
1779 + NM_MT_CHG_ADM_STATE_ACK,
1780 + NM_MT_CHG_ADM_STATE_NACK,
1781 + NM_MT_CHG_ADM_STATE_REQ,
1782 + NM_MT_CHG_ADM_STATE_REQ_ACK,
1783 + NM_MT_CHG_ADM_STATE_REQ_NACK,
1784 + NM_MT_REP_OUTST_ALARMS = 0x93,
1785 + NM_MT_REP_OUTST_ALARMS_ACK,
1786 + NM_MT_REP_OUTST_ALARMS_NACK,
1787 + /* Equipment Management Messages */
1788 + NM_MT_CHANGEOVER = 0x71,
1789 + NM_MT_CHANGEOVER_ACK,
1790 + NM_MT_CHANGEOVER_NACK,
1791 + NM_MT_OPSTART,
1792 + NM_MT_OPSTART_ACK,
1793 + NM_MT_OPSTART_NACK,
1794 + NM_MT_REINIT,
1795 + NM_MT_REINIT_ACK,
1796 + NM_MT_REINIT_NACK,
1797 + NM_MT_SET_SITE_OUT, /* BS11: get alarm ?!? */
1798 + NM_MT_SET_SITE_OUT_ACK,
1799 + NM_MT_SET_SITE_OUT_NACK,
1800 + NM_MT_CHG_HW_CONF = 0x90,
1801 + NM_MT_CHG_HW_CONF_ACK,
1802 + NM_MT_CHG_HW_CONF_NACK,
1803 + /* Measurement Management Messages */
1804 + NM_MT_MEAS_RES_REQ = 0x8a,
1805 + NM_MT_MEAS_RES_RESP,
1806 + NM_MT_STOP_MEAS,
1807 + NM_MT_START_MEAS,
1808 + /* Other Messages */
1809 + NM_MT_GET_ATTR = 0x81,
1810 + NM_MT_GET_ATTR_RESP,
1811 + NM_MT_GET_ATTR_NACK,
1812 + NM_MT_SET_ALARM_THRES,
1813 + NM_MT_SET_ALARM_THRES_ACK,
1814 + NM_MT_SET_ALARM_THRES_NACK,
1816 + NM_MT_IPACC_RESTART = 0x87,
1817 + NM_MT_IPACC_RESTART_ACK,
1820 +enum abis_nm_msgtype_bs11 {
1821 + NM_MT_BS11_RESET_RESOURCE = 0x74,
1823 + NM_MT_BS11_BEGIN_DB_TX = 0xa3,
1824 + NM_MT_BS11_BEGIN_DB_TX_ACK,
1825 + NM_MT_BS11_BEGIN_DB_TX_NACK,
1826 + NM_MT_BS11_END_DB_TX = 0xa6,
1827 + NM_MT_BS11_END_DB_TX_ACK,
1828 + NM_MT_BS11_END_DB_TX_NACK,
1829 + NM_MT_BS11_CREATE_OBJ = 0xa9,
1830 + NM_MT_BS11_CREATE_OBJ_ACK,
1831 + NM_MT_BS11_CREATE_OBJ_NACK,
1832 + NM_MT_BS11_DELETE_OBJ = 0xac,
1833 + NM_MT_BS11_DELETE_OBJ_ACK,
1834 + NM_MT_BS11_DELETE_OBJ_NACK,
1836 + NM_MT_BS11_SET_ATTR = 0xd0,
1837 + NM_MT_BS11_SET_ATTR_ACK,
1838 + NM_MT_BS11_SET_ATTR_NACK,
1839 + NM_MT_BS11_LMT_SESSION = 0xdc,
1841 + NM_MT_BS11_GET_STATE = 0xe3,
1842 + NM_MT_BS11_GET_STATE_ACK,
1843 + NM_MT_BS11_LMT_LOGON = 0xe5,
1844 + NM_MT_BS11_LMT_LOGON_ACK,
1845 + NM_MT_BS11_RESTART = 0xe7,
1846 + NM_MT_BS11_RESTART_ACK,
1847 + NM_MT_BS11_DISCONNECT = 0xe9,
1848 + NM_MT_BS11_DISCONNECT_ACK,
1849 + NM_MT_BS11_LMT_LOGOFF = 0xec,
1850 + NM_MT_BS11_LMT_LOGOFF_ACK,
1851 + NM_MT_BS11_RECONNECT = 0xf1,
1852 + NM_MT_BS11_RECONNECT_ACK,
1855 +enum abis_nm_msgtype_ipacc {
1856 + NM_MT_IPACC_RSL_CONNECT = 0xe0,
1857 + NM_MT_IPACC_RSL_CONNECT_ACK,
1858 + NM_MT_IPACC_RSL_CONNECT_NACK,
1859 + NM_MT_IPACC_RSL_DISCONNECT = 0xe3,
1860 + NM_MT_IPACC_RSL_DISCONNECT_ACK,
1861 + NM_MT_IPACC_RSL_DISCONNECT_NACK,
1862 + NM_MT_IPACC_CONN_TRAF = 0xe6,
1863 + NM_MT_IPACC_CONN_TRAF_ACK,
1864 + NM_MT_IPACC_CONN_TRAF_NACK,
1865 + NM_MT_IPACC_DISC_TRAF = 0xe9,
1866 + NM_MT_IPACC_DISC_TRAF_ACK,
1867 + NM_MT_IPACC_DISC_TRAF_NACK,
1868 + NM_MT_IPACC_DEF_BOOT_SW = 0xec,
1869 + NM_MT_IPACC_DEF_BOOT_SW_ACK,
1870 + NM_MT_IPACC_DEF_BOOT_SW_NACK,
1871 + NM_MT_IPACC_SET_NVATTR = 0xef,
1872 + NM_MT_IPACC_SET_NVATTR_ACK,
1873 + NM_MT_IPACC_SET_NVATTR_NACK,
1874 + NM_MT_IPACC_GET_NVATTR = 0xf2,
1875 + NM_MT_IPACC_GET_NVATTR_ACK,
1876 + NM_MT_IPACC_GET_NVATTR_NACK,
1877 + NM_MT_IPACC_SET_ATTR = 0xf5,
1878 + NM_MT_IPACC_SET_ATTR_ACK,
1879 + NM_MT_IPACC_SET_ATTR_NACK,
1880 + NM_MT_IPACC_ATTR_CHG_EVT = 0xf8,
1881 + NM_MT_IPACC_SW_DEACT = 0xf9,
1882 + NM_MT_IPACC_SW_DEACT_ACK,
1883 + NM_MT_IPACC_SW_DEACT_NACK,
1884 + NM_MT_IPACC_MEAS_RES_REQ_NACK = 0xfc,
1885 + NM_MT_IPACC_START_MEAS_NACK,
1886 + NM_MT_IPACC_STOP_MEAS_NACK,
1889 +enum abis_nm_bs11_cell_alloc {
1890 + NM_BS11_CANR_GSM = 0x00,
1891 + NM_BS11_CANR_DCS1800 = 0x01,
1894 +/* Section 9.2: Object Class */
1895 +enum abis_nm_obj_class {
1896 + NM_OC_SITE_MANAGER = 0x00,
1897 + NM_OC_BTS,
1898 + NM_OC_RADIO_CARRIER,
1899 + NM_OC_CHANNEL,
1900 + NM_OC_BASEB_TRANSC,
1901 + /* RFU: 05-FE */
1902 + NM_OC_BS11_ADJC = 0xa0,
1903 + NM_OC_BS11_HANDOVER = 0xa1,
1904 + NM_OC_BS11_PWR_CTRL = 0xa2,
1905 + NM_OC_BS11_BTSE = 0xa3, /* LMT? */
1906 + NM_OC_BS11_RACK = 0xa4,
1907 + NM_OC_BS11 = 0xa5, /* 01: ALCO */
1908 + NM_OC_BS11_TEST = 0xa6,
1909 + NM_OC_BS11_ENVABTSE = 0xa8,
1910 + NM_OC_BS11_BPORT = 0xa9,
1912 + NM_OC_GPRS_NSE = 0xf0,
1913 + NM_OC_GPRS_CELL = 0xf1,
1914 + NM_OC_GPRS_NSVC0 = 0xf2,
1915 + NM_OC_GPRS_NSVC1 = 0xf3,
1917 + NM_OC_NULL = 0xff,
1920 +/* Section 9.4: Attributes */
1921 +enum abis_nm_attr {
1922 + NM_ATT_ABIS_CHANNEL = 0x01,
1923 + NM_ATT_ADD_INFO,
1924 + NM_ATT_ADD_TEXT,
1925 + NM_ATT_ADM_STATE,
1926 + NM_ATT_ARFCN_LIST,
1927 + NM_ATT_AUTON_REPORT,
1928 + NM_ATT_AVAIL_STATUS,
1929 + NM_ATT_BCCH_ARFCN,
1930 + NM_ATT_BSIC,
1931 + NM_ATT_BTS_AIR_TIMER,
1932 + NM_ATT_CCCH_L_I_P,
1933 + NM_ATT_CCCH_L_T,
1934 + NM_ATT_CHAN_COMB,
1935 + NM_ATT_CONN_FAIL_CRIT,
1936 + NM_ATT_DEST,
1937 + /* res */
1938 + NM_ATT_EVENT_TYPE = 0x11, /* BS11: file data ?!? */
1939 + NM_ATT_FILE_ID,
1940 + NM_ATT_FILE_VERSION,
1941 + NM_ATT_GSM_TIME,
1942 + NM_ATT_HSN,
1943 + NM_ATT_HW_CONFIG,
1944 + NM_ATT_HW_DESC,
1945 + NM_ATT_INTAVE_PARAM,
1946 + NM_ATT_INTERF_BOUND,
1947 + NM_ATT_LIST_REQ_ATTR,
1948 + NM_ATT_MAIO,
1949 + NM_ATT_MANUF_STATE,
1950 + NM_ATT_MANUF_THRESH,
1951 + NM_ATT_MANUF_ID,
1952 + NM_ATT_MAX_TA,
1953 + NM_ATT_MDROP_LINK, /* 0x20 */
1954 + NM_ATT_MDROP_NEXT,
1955 + NM_ATT_NACK_CAUSES,
1956 + NM_ATT_NY1,
1957 + NM_ATT_OPER_STATE,
1958 + NM_ATT_OVERL_PERIOD,
1959 + NM_ATT_PHYS_CONF,
1960 + NM_ATT_POWER_CLASS,
1961 + NM_ATT_POWER_THRESH,
1962 + NM_ATT_PROB_CAUSE,
1963 + NM_ATT_RACH_B_THRESH,
1964 + NM_ATT_LDAVG_SLOTS,
1965 + NM_ATT_RAD_SUBC,
1966 + NM_ATT_RF_MAXPOWR_R,
1967 + NM_ATT_SITE_INPUTS,
1968 + NM_ATT_SITE_OUTPUTS,
1969 + NM_ATT_SOURCE, /* 0x30 */
1970 + NM_ATT_SPEC_PROB,
1971 + NM_ATT_START_TIME,
1972 + NM_ATT_T200,
1973 + NM_ATT_TEI,
1974 + NM_ATT_TEST_DUR,
1975 + NM_ATT_TEST_NO,
1976 + NM_ATT_TEST_REPORT,
1977 + NM_ATT_VSWR_THRESH,
1978 + NM_ATT_WINDOW_SIZE,
1979 + /* Res */
1980 + NM_ATT_BS11_RSSI_OFFS = 0x3d,
1981 + NM_ATT_BS11_TXPWR = 0x3e,
1982 + NM_ATT_BS11_DIVERSITY = 0x3f,
1983 + /* Res */
1984 + NM_ATT_TSC = 0x40,
1985 + NM_ATT_SW_CONFIG,
1986 + NM_ATT_SW_DESCR,
1987 + NM_ATT_SEVERITY,
1988 + NM_ATT_GET_ARI,
1989 + NM_ATT_HW_CONF_CHG,
1990 + NM_ATT_OUTST_ALARM,
1991 + NM_ATT_FILE_DATA,
1992 + NM_ATT_MEAS_RES,
1993 + NM_ATT_MEAS_TYPE,
1996 +enum abis_nm_attr_bs11 {
1997 + NM_ATT_BS11_OM_LAPD_REL_TIMER = 0x02,
1998 + NM_ATT_BS11_EMERG_TIMER1 = 0x42,
1999 + NM_ATT_BS11_EMERG_TIMER2 = 0x44,
2000 + NM_ATT_BS11_ESN_FW_CODE_NO = 0x4c,
2001 + NM_ATT_BS11_ESN_HW_CODE_NO = 0x4f,
2003 + NM_ATT_BS11_FILE_DATA = NM_ATT_EVENT_TYPE,
2005 + NM_ATT_BS11_ESN_PCB_SERIAL = 0x55,
2006 + NM_ATT_BS11_EXCESSIVE_DISTANCE = 0x58,
2008 + NM_ATT_BS11_ALL_TEST_CATG = 0x60,
2009 + NM_ATT_BS11_BTSLS_HOPPING,
2010 + NM_ATT_BS11_CELL_ALLOC_NR,
2011 + NM_ATT_BS11_CELL_GLOBAL_ID,
2012 + NM_ATT_BS11_ENA_INTERF_CLASS = 0x66,
2013 + NM_ATT_BS11_ENA_INT_INTEC_HANDO = 0x67,
2014 + NM_ATT_BS11_ENA_INT_INTRC_HANDO = 0x68,
2015 + NM_ATT_BS11_ENA_MS_PWR_CTRL = 0x69,
2016 + NM_ATT_BS11_ENA_PWR_BDGT_HO = 0x6a,
2017 + NM_ATT_BS11_ENA_PWR_CTRL_RLFW = 0x6b,
2018 + NM_ATT_BS11_ENA_RXLEV_HO = 0x6c,
2019 + NM_ATT_BS11_ENA_RXQUAL_HO = 0x6d,
2020 + NM_ATT_BS11_FACCH_QUAL = 0x6e,
2022 + NM_ATT_BS11_RF_RES_IND_PER = 0x8f,
2024 + NM_ATT_BS11_RX_LEV_MIN_CELL = 0x90,
2025 + NM_ATT_BS11_ABIS_EXT_TIME = 0x91,
2026 + NM_ATT_BS11_TIMER_HO_REQUEST = 0x92,
2027 + NM_ATT_BS11_TIMER_NCELL = 0x93,
2028 + NM_ATT_BS11_TSYNC = 0x94,
2029 + NM_ATT_BS11_TTRAU = 0x95,
2030 + NM_ATT_BS11_EMRG_CFG_MEMBER = 0x9b,
2031 + NM_ATT_BS11_TRX_AREA = 0x9f,
2033 + NM_ATT_BS11_BCCH_RECONF = 0xd7,
2034 + NM_ATT_BS11_BIT_ERR_THESH = 0xa0,
2035 + NM_ATT_BS11_BOOT_SW_VERS = 0xa1,
2036 + NM_ATT_BS11_CCLK_ACCURACY = 0xa3,
2037 + NM_ATT_BS11_CCLK_TYPE = 0xa4,
2038 + NM_ATT_BS11_INP_IMPEDANCE = 0xaa,
2039 + NM_ATT_BS11_L1_PROT_TYPE = 0xab,
2040 + NM_ATT_BS11_LINE_CFG = 0xac,
2041 + NM_ATT_BS11_LI_PORT_1 = 0xad,
2042 + NM_ATT_BS11_LI_PORT_2 = 0xae,
2044 + NM_ATT_BS11_L1_REM_ALM_TYPE = 0xb0,
2045 + NM_ATT_BS11_SW_LOAD_INTENDED = 0xbb,
2046 + NM_ATT_BS11_SW_LOAD_SAFETY = 0xbc,
2047 + NM_ATT_BS11_SW_LOAD_STORED = 0xbd,
2049 + NM_ATT_BS11_VENDOR_NAME = 0xc1,
2050 + NM_ATT_BS11_HOPPING_MODE = 0xc5,
2051 + NM_ATT_BS11_LMT_LOGON_SESSION = 0xc6,
2052 + NM_ATT_BS11_LMT_LOGIN_TIME = 0xc7,
2053 + NM_ATT_BS11_LMT_USER_ACC_LEV = 0xc8,
2054 + NM_ATT_BS11_LMT_USER_NAME = 0xc9,
2056 + NM_ATT_BS11_L1_CONTROL_TS = 0xd8,
2057 + NM_ATT_BS11_RADIO_MEAS_GRAN = 0xdc, /* in SACCH multiframes */
2058 + NM_ATT_BS11_RADIO_MEAS_REP = 0xdd,
2060 + NM_ATT_BS11_SH_LAPD_INT_TIMER = 0xe8,
2062 + NM_ATT_BS11_BTS_STATE = 0xf0,
2063 + NM_ATT_BS11_E1_STATE = 0xf1,
2064 + NM_ATT_BS11_PLL = 0xf2,
2065 + NM_ATT_BS11_RX_OFFSET = 0xf3,
2066 + NM_ATT_BS11_ANT_TYPE = 0xf4,
2067 + NM_ATT_BS11_PLL_MODE = 0xfc,
2068 + NM_ATT_BS11_PASSWORD = 0xfd,
2071 +enum abis_nm_attr_ipa {
2072 + NM_ATT_IPACC_DST_IP = 0x80,
2073 + NM_ATT_IPACC_DST_IP_PORT = 0x81,
2074 + NM_ATT_IPACC_SSRC = 0x82, /* RTP Sync Source */
2075 + NM_ATT_IPACC_RTP_PAYLD_TYPE = 0x83,
2076 + NM_ATT_IPACC_BASEB_ID = 0x84,
2077 + NM_ATT_IPACC_STREAM_ID = 0x85,
2078 + NM_ATT_IPACC_NV_FLAGS = 0x86,
2079 + NM_ATT_IPACC_FREQ_CTRL = 0x87,
2080 + NM_ATT_IPACC_PRIM_OML_CFG = 0x88,
2081 + NM_ATT_IPACC_SEC_OML_CFG = 0x89,
2082 + NM_ATT_IPACC_IP_IF_CFG = 0x8a, /* IP interface */
2083 + NM_ATT_IPACC_IP_GW_CFG = 0x8b, /* IP gateway */
2084 + NM_ATT_IPACC_IN_SERV_TIME = 0x8c,
2085 + NM_ATT_IPACC_TRX_BTS_ASS = 0x8d,
2086 + NM_ATT_IPACC_LOCATION = 0x8e, /* string describing location */
2087 + NM_ATT_IPACC_PAGING_CFG = 0x8f,
2088 + NM_ATT_IPACC_FILE_DATA = 0x90,
2089 + NM_ATT_IPACC_UNIT_ID = 0x91, /* Site/BTS/TRX */
2090 + NM_ATT_IPACC_PARENT_UNIT_ID = 0x92,
2091 + NM_ATT_IPACC_UNIT_NAME = 0x93, /* default: nbts-<mac-as-string> */
2092 + NM_ATT_IPACC_SNMP_CFG = 0x94,
2093 + NM_ATT_IPACC_PRIM_OML_CFG_LIST = 0x95,
2094 + NM_ATT_IPACC_PRIM_OML_FB_TOUT = 0x96, /* fallback timeout */
2095 + NM_ATT_IPACC_CUR_SW_CFG = 0x97,
2096 + NM_ATT_IPACC_TIMING_BUS = 0x98,
2097 + NM_ATT_IPACC_CGI = 0x99, /* Cell Global ID */
2098 + NM_ATT_IPACC_RAC = 0x9a,
2099 + NM_ATT_IPACC_OBJ_VERSION = 0x9b,
2100 + NM_ATT_IPACC_GPRS_PAGING_CFG = 0x9c,
2101 + NM_ATT_IPACC_NSEI = 0x9d,
2102 + NM_ATT_IPACC_BVCI = 0x9e,
2103 + NM_ATT_IPACC_NSVCI = 0x9f,
2104 + NM_ATT_IPACC_NS_CFG = 0xa0,
2105 + NM_ATT_IPACC_BSSGP_CFG = 0xa1,
2106 + NM_ATT_IPACC_NS_LINK_CFG = 0xa2,
2107 + NM_ATT_IPACC_RLC_CFG = 0xa3,
2108 + NM_ATT_IPACC_ALM_THRESH_LIST = 0xa4,
2109 + NM_ATT_IPACC_MONIT_VAL_LIST = 0xa5,
2110 + NM_ATT_IPACC_TIB_CONTROL = 0xa6,
2111 + NM_ATT_IPACC_SUPP_FEATURES = 0xa7,
2112 + NM_ATT_IPACC_CODING_SCHEMES = 0xa8,
2113 + NM_ATT_IPACC_RLC_CFG_2 = 0xa9,
2114 + NM_ATT_IPACC_HEARTB_TOUT = 0xaa,
2115 + NM_ATT_IPACC_UPTIME = 0xab,
2116 + NM_ATT_IPACC_RLC_CFG_3 = 0xac,
2117 + NM_ATT_IPACC_SSL_CFG = 0xad,
2118 + NM_ATT_IPACC_SEC_POSSIBLE = 0xae,
2119 + NM_ATT_IPACC_IML_SSL_STATE = 0xaf,
2120 + NM_ATT_IPACC_REVOC_DATE = 0xb0,
2123 +/* Section 9.4.4: Administrative State */
2124 +enum abis_nm_adm_state {
2125 + NM_STATE_LOCKED = 0x01,
2126 + NM_STATE_UNLOCKED = 0x02,
2127 + NM_STATE_SHUTDOWN = 0x03,
2128 + NM_STATE_NULL = 0xff,
2131 +/* Section 9.4.13: Channel Combination */
2132 +enum abis_nm_chan_comb {
2133 + NM_CHANC_TCHFull = 0x00,
2134 + NM_CHANC_TCHHalf = 0x01,
2135 + NM_CHANC_TCHHalf2 = 0x02,
2136 + NM_CHANC_SDCCH = 0x03,
2137 + NM_CHANC_mainBCCH = 0x04,
2138 + NM_CHANC_BCCHComb = 0x05,
2139 + NM_CHANC_BCCH = 0x06,
2140 + NM_CHANC_BCCH_CBCH = 0x07,
2141 + NM_CHANC_SDCCH_CBCH = 0x08,
2144 +/* Section 9.4.16: Event Type */
2145 +enum abis_nm_event_type {
2146 + NM_EVT_COMM_FAIL = 0x00,
2147 + NM_EVT_QOS_FAIL = 0x01,
2148 + NM_EVT_PROC_FAIL = 0x02,
2149 + NM_EVT_EQUIP_FAIL = 0x03,
2150 + NM_EVT_ENV_FAIL = 0x04,
2153 +/* Section: 9.4.63: Perceived Severity */
2154 +enum abis_nm_severity {
2155 + NM_SEVER_CEASED = 0x00,
2156 + NM_SEVER_CRITICAL = 0x01,
2157 + NM_SEVER_MAJOR = 0x02,
2158 + NM_SEVER_MINOR = 0x03,
2159 + NM_SEVER_WARNING = 0x04,
2160 + NM_SEVER_INDETERMINATE = 0x05,
2163 +/* Section 9.4.43: Probable Cause Type */
2164 +enum abis_nm_pcause_type {
2165 + NM_PCAUSE_T_X721 = 0x01,
2166 + NM_PCAUSE_T_GSM = 0x02,
2167 + NM_PCAUSE_T_MANUF = 0x03,
2170 +/* Section 9.4.36: NACK Causes */
2171 +enum abis_nm_nack_cause {
2172 + /* General Nack Causes */
2173 + NM_NACK_INCORR_STRUCT = 0x01,
2174 + NM_NACK_MSGTYPE_INVAL = 0x02,
2175 + NM_NACK_OBJCLASS_INVAL = 0x05,
2176 + NM_NACK_OBJCLASS_NOTSUPP = 0x06,
2177 + NM_NACK_BTSNR_UNKN = 0x07,
2178 + NM_NACK_TRXNR_UNKN = 0x08,
2179 + NM_NACK_OBJINST_UNKN = 0x09,
2180 + NM_NACK_ATTRID_INVAL = 0x0c,
2181 + NM_NACK_ATTRID_NOTSUPP = 0x0d,
2182 + NM_NACK_PARAM_RANGE = 0x0e,
2183 + NM_NACK_ATTRLIST_INCONSISTENT = 0x0f,
2184 + NM_NACK_SPEC_IMPL_NOTSUPP = 0x10,
2185 + NM_NACK_CANT_PERFORM = 0x11,
2186 + /* Specific Nack Causes */
2187 + NM_NACK_RES_NOTIMPL = 0x19,
2188 + NM_NACK_RES_NOTAVAIL = 0x1a,
2189 + NM_NACK_FREQ_NOTAVAIL = 0x1b,
2190 + NM_NACK_TEST_NOTSUPP = 0x1c,
2191 + NM_NACK_CAPACITY_RESTR = 0x1d,
2192 + NM_NACK_PHYSCFG_NOTPERFORM = 0x1e,
2193 + NM_NACK_TEST_NOTINIT = 0x1f,
2194 + NM_NACK_PHYSCFG_NOTRESTORE = 0x20,
2195 + NM_NACK_TEST_NOSUCH = 0x21,
2196 + NM_NACK_TEST_NOSTOP = 0x22,
2197 + NM_NACK_MSGINCONSIST_PHYSCFG = 0x23,
2198 + NM_NACK_FILE_INCOMPLETE = 0x25,
2199 + NM_NACK_FILE_NOTAVAIL = 0x26,
2200 + NM_NACK_FILE_NOTACTIVATE = 0x27,
2201 + NM_NACK_REQ_NOT_GRANT = 0x28,
2202 + NM_NACK_WAIT = 0x29,
2203 + NM_NACK_NOTH_REPORT_EXIST = 0x2a,
2204 + NM_NACK_MEAS_NOTSUPP = 0x2b,
2205 + NM_NACK_MEAS_NOTSTART = 0x2c,
2208 +/* Section 9.4.1 */
2209 +struct abis_nm_channel {
2210 + guint8 attrib;
2211 + guint8 bts_port;
2212 + guint8 timeslot;
2213 + guint8 subslot;
2214 +} __attribute__ ((packed));
2216 +/* Siemens BS-11 specific objects in the SienemsHW (0xA5) object class */
2217 +enum abis_bs11_objtype {
2218 + BS11_OBJ_ALCO = 0x01,
2219 + BS11_OBJ_BBSIG = 0x02, /* obj_class: 0,1 */
2220 + BS11_OBJ_TRX1 = 0x03, /* only DEACTIVATE TRX1 */
2221 + BS11_OBJ_CCLK = 0x04,
2222 + BS11_OBJ_GPSU = 0x06,
2223 + BS11_OBJ_LI = 0x07,
2224 + BS11_OBJ_PA = 0x09, /* obj_class: 0, 1*/
2227 +enum abis_bs11_trx_power {
2228 + BS11_TRX_POWER_GSM_2W = 0x06,
2229 + BS11_TRX_POWER_GSM_250mW= 0x07,
2230 + BS11_TRX_POWER_GSM_80mW = 0x08,
2231 + BS11_TRX_POWER_GSM_30mW = 0x09,
2232 + BS11_TRX_POWER_DCS_3W = 0x0a,
2233 + BS11_TRX_POWER_DCS_1W6 = 0x0b,
2234 + BS11_TRX_POWER_DCS_500mW= 0x0c,
2235 + BS11_TRX_POWER_DCS_160mW= 0x0d,
2238 +enum abis_bs11_li_pll_mode {
2239 + BS11_LI_PLL_LOCKED = 2,
2240 + BS11_LI_PLL_STANDALONE = 3,
2243 +enum abis_bs11_phase {
2244 + BS11_STATE_SOFTWARE_RQD = 0x01,
2245 + BS11_STATE_LOAD_SMU_INTENDED = 0x11,
2246 + BS11_STATE_LOAD_SMU_SAFETY = 0x21,
2247 + BS11_STATE_LOAD_FAILED = 0x31,
2248 + BS11_STATE_LOAD_DIAGNOSTIC = 0x41,
2249 + BS11_STATE_WARM_UP = 0x51,
2250 + BS11_STATE_WARM_UP_2 = 0x52,
2251 + BS11_STATE_WAIT_MIN_CFG = 0x62,
2252 + BS11_STATE_MAINTENANCE = 0x72,
2253 + BS11_STATE_LOAD_MBCCU = 0x92,
2254 + BS11_STATE_WAIT_MIN_CFG_2 = 0xA2,
2255 + BS11_STATE_NORMAL = 0x03,
2256 + BS11_STATE_ABIS_LOAD = 0x13,
2259 +/* From openbsc/include/openbsc/tlv.h */
2260 +enum tlv_type {
2261 + TLV_TYPE_UNKNOWN,
2262 + TLV_TYPE_FIXED,
2263 + TLV_TYPE_T,
2264 + TLV_TYPE_TV,
2265 + TLV_TYPE_TLV,
2266 + TLV_TYPE_TL16V,
2267 + TLV_TYPE_TLV16,
2270 +struct tlv_def {
2271 + enum tlv_type type;
2272 + u_int8_t fixed_len;
2275 +struct tlv_definition {
2276 + struct tlv_def def[0xff];
2279 +enum abis_nm_ipacc_test_no {
2280 + NM_IPACC_TESTNO_RLOOP_ANT = 0x01,
2281 + NM_IPACC_TESTNO_RLOOP_XCVR = 0x02,
2282 + NM_IPACC_TESTNO_FUNC_OBJ = 0x03,
2283 + NM_IPACC_TESTNO_CHAN_USAGE = 0x40,
2284 + NM_IPACC_TESTNO_BCCH_CHAN_USAGE = 0x41,
2285 + NM_IPACC_TESTNO_FREQ_SYNC = 0x42,
2286 + NM_IPACC_TESTNO_BCCH_INFO = 0x43,
2287 + NM_IPACC_TESTNO_TX_BEACON = 0x44,
2288 + NM_IPACC_TESTNO_SYSINFO_MONITOR = 0x45,
2289 + NM_IPACC_TESTNO_BCCCH_MONITOR = 0x46,
2292 +/* first byte after length inside NM_ATT_TEST_REPORT */
2293 +enum abis_nm_ipacc_test_res {
2294 + NM_IPACC_TESTRES_SUCCESS = 0,
2295 + NM_IPACC_TESTRES_TIMEOUT = 1,
2296 + NM_IPACC_TESTRES_NO_CHANS = 2,
2297 + NM_IPACC_TESTRES_PARTIAL = 3,
2298 + NM_IPACC_TESTRES_STOPPED = 4,
2301 +/* internal IE inside NM_ATT_TEST_REPORT */
2302 +enum abis_nm_ipacc_testres_ie {
2303 + NM_IPACC_TR_IE_FREQ_ERR_LIST = 3,
2304 + NM_IPACC_TR_IE_CHAN_USAGE = 4,
2305 + NM_IPACC_TR_IE_BCCH_INFO = 6,
2306 + NM_IPACC_TR_IE_RESULT_DETAILS = 8,
2307 + NM_IPACC_TR_IE_FREQ_ERR = 18,
2310 +/* From openbsc/src/abis_nm.c */
2311 +static const struct tlv_definition nm_att_tlvdef_base = {
2312 + .def = {
2313 + [NM_ATT_ABIS_CHANNEL] = { TLV_TYPE_FIXED, 3 },
2314 + [NM_ATT_ADD_INFO] = { TLV_TYPE_TL16V, 0 },
2315 + [NM_ATT_ADD_TEXT] = { TLV_TYPE_TL16V, 0 },
2316 + [NM_ATT_ADM_STATE] = { TLV_TYPE_TV, 0 },
2317 + [NM_ATT_ARFCN_LIST]= { TLV_TYPE_TL16V, 0 },
2318 + [NM_ATT_AUTON_REPORT] = { TLV_TYPE_TV, 0 },
2319 + [NM_ATT_AVAIL_STATUS] = { TLV_TYPE_TL16V, 0 },
2320 + [NM_ATT_BCCH_ARFCN] = { TLV_TYPE_FIXED, 2 },
2321 + [NM_ATT_BSIC] = { TLV_TYPE_TV, 0 },
2322 + [NM_ATT_BTS_AIR_TIMER] = { TLV_TYPE_TV, 0 },
2323 + [NM_ATT_CCCH_L_I_P] = { TLV_TYPE_TV, 0 },
2324 + [NM_ATT_CCCH_L_T] = { TLV_TYPE_TV, 0 },
2325 + [NM_ATT_CHAN_COMB] = { TLV_TYPE_TV, 0 },
2326 + [NM_ATT_CONN_FAIL_CRIT] = { TLV_TYPE_TL16V, 0 },
2327 + [NM_ATT_DEST] = { TLV_TYPE_TL16V, 0 },
2328 + [NM_ATT_EVENT_TYPE] = { TLV_TYPE_TV, 0 },
2329 + [NM_ATT_FILE_ID] = { TLV_TYPE_TL16V, 0 },
2330 + [NM_ATT_FILE_VERSION] = { TLV_TYPE_TL16V, 0 },
2331 + [NM_ATT_GSM_TIME] = { TLV_TYPE_FIXED, 2 },
2332 + [NM_ATT_HSN] = { TLV_TYPE_TV, 0 },
2333 + [NM_ATT_HW_CONFIG] = { TLV_TYPE_TL16V, 0 },
2334 + [NM_ATT_HW_DESC] = { TLV_TYPE_TLV, 0 },
2335 + [NM_ATT_INTAVE_PARAM] = { TLV_TYPE_TV, 0 },
2336 + [NM_ATT_INTERF_BOUND] = { TLV_TYPE_FIXED, 6 },
2337 + [NM_ATT_LIST_REQ_ATTR] = { TLV_TYPE_TL16V, 0 },
2338 + [NM_ATT_MAIO] = { TLV_TYPE_TV, 0 },
2339 + [NM_ATT_MANUF_STATE] = { TLV_TYPE_TV, 0 },
2340 + [NM_ATT_MANUF_THRESH] = { TLV_TYPE_TL16V, 0 },
2341 + [NM_ATT_MANUF_ID] = { TLV_TYPE_TL16V, 0 },
2342 + [NM_ATT_MAX_TA] = { TLV_TYPE_TV, 0 },
2343 + [NM_ATT_MDROP_LINK] = { TLV_TYPE_FIXED, 2 },
2344 + [NM_ATT_MDROP_NEXT] = { TLV_TYPE_FIXED, 2 },
2345 + [NM_ATT_NACK_CAUSES] = { TLV_TYPE_TV, 0 },
2346 + [NM_ATT_NY1] = { TLV_TYPE_TV, 0 },
2347 + [NM_ATT_OPER_STATE] = { TLV_TYPE_TV, 0 },
2348 + [NM_ATT_OVERL_PERIOD] = { TLV_TYPE_TL16V, 0 },
2349 + [NM_ATT_PHYS_CONF] = { TLV_TYPE_TL16V, 0 },
2350 + [NM_ATT_POWER_CLASS] = { TLV_TYPE_TV, 0 },
2351 + [NM_ATT_POWER_THRESH] = { TLV_TYPE_FIXED, 3 },
2352 + [NM_ATT_PROB_CAUSE] = { TLV_TYPE_FIXED, 3 },
2353 + [NM_ATT_RACH_B_THRESH] = { TLV_TYPE_TV, 0 },
2354 + [NM_ATT_LDAVG_SLOTS] = { TLV_TYPE_FIXED, 2 },
2355 + [NM_ATT_RAD_SUBC] = { TLV_TYPE_TV, 0 },
2356 + [NM_ATT_RF_MAXPOWR_R] = { TLV_TYPE_TV, 0 },
2357 + [NM_ATT_SITE_INPUTS] = { TLV_TYPE_TL16V, 0 },
2358 + [NM_ATT_SITE_OUTPUTS] = { TLV_TYPE_TL16V, 0 },
2359 + [NM_ATT_SOURCE] = { TLV_TYPE_TL16V, 0 },
2360 + [NM_ATT_SPEC_PROB] = { TLV_TYPE_TV, 0 },
2361 + [NM_ATT_START_TIME] = { TLV_TYPE_FIXED, 2 },
2362 + [NM_ATT_T200] = { TLV_TYPE_FIXED, 7 },
2363 + [NM_ATT_TEI] = { TLV_TYPE_TV, 0 },
2364 + [NM_ATT_TEST_DUR] = { TLV_TYPE_FIXED, 2 },
2365 + [NM_ATT_TEST_NO] = { TLV_TYPE_TV, 0 },
2366 + [NM_ATT_TEST_REPORT] = { TLV_TYPE_TL16V, 0 },
2367 + [NM_ATT_VSWR_THRESH] = { TLV_TYPE_FIXED, 2 },
2368 + [NM_ATT_WINDOW_SIZE] = { TLV_TYPE_TV, 0 },
2369 + [NM_ATT_TSC] = { TLV_TYPE_TV, 0 },
2370 + [NM_ATT_SW_CONFIG] = { TLV_TYPE_TL16V, 0 },
2371 + [NM_ATT_SEVERITY] = { TLV_TYPE_TV, 0 },
2372 + [NM_ATT_GET_ARI] = { TLV_TYPE_TL16V, 0 },
2373 + [NM_ATT_HW_CONF_CHG] = { TLV_TYPE_TL16V, 0 },
2374 + [NM_ATT_OUTST_ALARM] = { TLV_TYPE_TV, 0 },
2375 + [NM_ATT_FILE_DATA] = { TLV_TYPE_TL16V, 0 },
2376 + [NM_ATT_MEAS_RES] = { TLV_TYPE_TL16V, 0 },
2378 + },
2381 +/* BS11 specifics */
2382 +static const struct tlv_definition nm_att_tlvdev_bs11 = {
2383 + .def = {
2384 + /* different stndard IEs */
2385 + [NM_ATT_OUTST_ALARM] = { TLV_TYPE_TLV, 0 },
2386 + [NM_ATT_HW_DESC] = { TLV_TYPE_TL16V, 0 },
2387 + [NM_ATT_ARFCN_LIST]= { TLV_TYPE_TLV16, 0 },
2389 + /* proprietary IEs */
2390 + [NM_ATT_BS11_ABIS_EXT_TIME] = { TLV_TYPE_TLV, 0 },
2391 + [NM_ATT_BS11_OM_LAPD_REL_TIMER]={ TLV_TYPE_FIXED, 2 },
2392 + [NM_ATT_BS11_SH_LAPD_INT_TIMER]={ TLV_TYPE_TLV, 0 },
2393 + [NM_ATT_BS11_EMERG_TIMER1] = { TLV_TYPE_TLV, 0 },
2394 + [NM_ATT_BS11_EMERG_TIMER2] = { TLV_TYPE_TLV, 0 },
2395 + [NM_ATT_BS11_BTSLS_HOPPING] = { TLV_TYPE_FIXED, 1 },
2396 + [NM_ATT_BS11_CELL_ALLOC_NR] = { TLV_TYPE_FIXED, 1 },
2397 + [NM_ATT_BS11_ENA_INTERF_CLASS]= { TLV_TYPE_FIXED, 1 },
2398 + [NM_ATT_BS11_FACCH_QUAL] = { TLV_TYPE_FIXED, 1 },
2399 + [NM_ATT_BS11_TSYNC] = { TLV_TYPE_FIXED, 2 },
2400 + [NM_ATT_BS11_TTRAU] = { TLV_TYPE_FIXED, 2 },
2401 + [NM_ATT_BS11_EXCESSIVE_DISTANCE] = { TLV_TYPE_TLV, 1 },
2402 + [NM_ATT_BS11_HOPPING_MODE] = { TLV_TYPE_TLV, 1 },
2403 + [NM_ATT_BS11_RF_RES_IND_PER] = { TLV_TYPE_FIXED, 1 },
2404 + [NM_ATT_BS11_RADIO_MEAS_GRAN] = { TLV_TYPE_TLV, 0 },
2405 + [NM_ATT_BS11_RADIO_MEAS_REP] = { TLV_TYPE_TLV, 0 },
2406 + [NM_ATT_BS11_EMRG_CFG_MEMBER] = { TLV_TYPE_TLV, 0 },
2407 + [NM_ATT_BS11_TRX_AREA] = { TLV_TYPE_TLV, 0 },
2408 + [NM_ATT_BS11_ESN_FW_CODE_NO] = { TLV_TYPE_TLV, 0 },
2409 + [NM_ATT_BS11_ESN_HW_CODE_NO] = { TLV_TYPE_TLV, 0 },
2410 + [NM_ATT_BS11_ESN_PCB_SERIAL] = { TLV_TYPE_TLV, 0 },
2411 + [NM_ATT_BS11_BOOT_SW_VERS] = { TLV_TYPE_TLV, 0 },
2412 + [0x59] = { TLV_TYPE_TLV, 0 },
2413 + [0xd5] = { TLV_TYPE_TLV, 0 },
2414 + [0xa8] = { TLV_TYPE_TLV, 0 },
2415 + [NM_ATT_BS11_PASSWORD] = { TLV_TYPE_TLV, 0 },
2416 + [NM_ATT_BS11_TXPWR] = { TLV_TYPE_TLV, 0 },
2417 + [NM_ATT_BS11_RSSI_OFFS] = { TLV_TYPE_TLV, 0 },
2418 + [NM_ATT_BS11_LINE_CFG] = { TLV_TYPE_TV, 0 },
2419 + [NM_ATT_BS11_L1_PROT_TYPE] = { TLV_TYPE_TV, 0 },
2420 + [NM_ATT_BS11_BIT_ERR_THESH] = { TLV_TYPE_FIXED, 2 },
2421 + [NM_ATT_BS11_DIVERSITY] = { TLV_TYPE_TLV, 0 },
2422 + [NM_ATT_BS11_LMT_LOGON_SESSION]={ TLV_TYPE_TLV, 0 },
2423 + [NM_ATT_BS11_LMT_LOGIN_TIME] = { TLV_TYPE_TLV, 0 },
2424 + [NM_ATT_BS11_LMT_USER_ACC_LEV] ={ TLV_TYPE_TLV, 0 },
2425 + [NM_ATT_BS11_LMT_USER_NAME] = { TLV_TYPE_TLV, 0 },
2426 + [NM_ATT_BS11_BTS_STATE] = { TLV_TYPE_TLV, 0 },
2427 + [NM_ATT_BS11_E1_STATE] = { TLV_TYPE_TLV, 0 },
2428 + [NM_ATT_BS11_PLL_MODE] = { TLV_TYPE_TLV, 0 },
2429 + [NM_ATT_BS11_PLL] = { TLV_TYPE_TLV, 0 },
2430 + [NM_ATT_BS11_CCLK_ACCURACY] = { TLV_TYPE_TV, 0 },
2431 + [NM_ATT_BS11_CCLK_TYPE] = { TLV_TYPE_TV, 0 },
2432 + },
2435 +/* ip.access specifics */
2436 +static const struct tlv_definition nm_att_tlvdef_ipa = {
2437 + .def = {
2438 + [NM_ATT_IPACC_DST_IP] = { TLV_TYPE_FIXED, 4 },
2439 + [NM_ATT_IPACC_DST_IP_PORT] = { TLV_TYPE_FIXED, 2 },
2440 + [NM_ATT_IPACC_PRIM_OML_CFG] = { TLV_TYPE_TL16V, 0 },
2441 + [NM_ATT_IPACC_NV_FLAGS] = { TLV_TYPE_TL16V, 0 },
2442 + [NM_ATT_IPACC_FREQ_CTRL] = { TLV_TYPE_FIXED, 2 },
2443 + [NM_ATT_IPACC_SEC_OML_CFG] = { TLV_TYPE_FIXED, 6 },
2444 + [NM_ATT_IPACC_IP_IF_CFG] = { TLV_TYPE_FIXED, 8 },
2445 + [NM_ATT_IPACC_IP_GW_CFG] = { TLV_TYPE_FIXED, 12 },
2446 + [NM_ATT_IPACC_LOCATION] = { TLV_TYPE_TL16V, 0 },
2447 + [NM_ATT_IPACC_UNIT_ID] = { TLV_TYPE_TL16V, 0 },
2448 + [NM_ATT_IPACC_UNIT_NAME] = { TLV_TYPE_TL16V, 0 },
2449 + [NM_ATT_IPACC_SNMP_CFG] = { TLV_TYPE_TL16V, 0 },
2450 + [NM_ATT_IPACC_ALM_THRESH_LIST]= { TLV_TYPE_TL16V, 0 },
2451 + [NM_ATT_IPACC_CUR_SW_CFG] = { TLV_TYPE_TL16V, 0 },
2452 + [NM_ATT_IPACC_STREAM_ID] = { TLV_TYPE_TV, 0 },
2453 + [NM_ATT_IPACC_RAC] = { TLV_TYPE_TL16V, 0 },
2454 + [NM_ATT_IPACC_OBJ_VERSION] = { TLV_TYPE_TL16V, 0 },
2455 + [NM_ATT_IPACC_GPRS_PAGING_CFG] ={ TLV_TYPE_TL16V, 0 },
2456 + [NM_ATT_IPACC_NSEI] = { TLV_TYPE_TL16V, 0 },
2457 + [NM_ATT_IPACC_BVCI] = { TLV_TYPE_TL16V, 0 },
2458 + [NM_ATT_IPACC_NSVCI] = { TLV_TYPE_TL16V, 0 },
2459 + [NM_ATT_IPACC_NS_CFG] = { TLV_TYPE_TL16V, 0 },
2460 + [NM_ATT_IPACC_BSSGP_CFG] = { TLV_TYPE_TL16V, 0 },
2461 + [NM_ATT_IPACC_NS_LINK_CFG] = { TLV_TYPE_TL16V, 0 },
2462 + [NM_ATT_IPACC_RLC_CFG] = { TLV_TYPE_TL16V, 0 },
2463 + [NM_ATT_IPACC_SUPP_FEATURES] = { TLV_TYPE_TL16V, 0 },
2464 + [NM_ATT_IPACC_CODING_SCHEMES] = { TLV_TYPE_TL16V, 0 },
2465 + [NM_ATT_IPACC_RLC_CFG_2] = { TLV_TYPE_TL16V, 0 },
2466 + [NM_ATT_IPACC_RLC_CFG_3] = { TLV_TYPE_TL16V, 0 },
2467 + [NM_ATT_IPACC_PAGING_CFG] = { TLV_TYPE_FIXED, 2 },
2468 + [NM_ATT_IPACC_FILE_DATA] = { TLV_TYPE_TL16V, 0 },
2469 + [NM_ATT_IPACC_CGI] = { TLV_TYPE_TL16V, 0 },
2470 + },
2473 +#endif /* _NM_H */