/src/wireshark/epan/dissectors/packet-gsm_ipa.c
Line | Count | Source (jump to first uncovered line) |
1 | | /* packet-gsm_ipa.c |
2 | | * Routines for packet dissection of ip.access GSM A-bis over IP |
3 | | * Copyright 2009 by Harald Welte <laforge@gnumonks.org> |
4 | | * Copyright 2009, 2010 by Holger Hans Peter Freyther <zecke@selfish.org> |
5 | | * |
6 | | * Wireshark - Network traffic analyzer |
7 | | * By Gerald Combs <gerald@wireshark.org> |
8 | | * Copyright 1998 Gerald Combs |
9 | | * |
10 | | * SPDX-License-Identifier: GPL-2.0-or-later |
11 | | */ |
12 | | |
13 | | #include "config.h" |
14 | | |
15 | | #include <epan/packet.h> |
16 | | #include <epan/prefs.h> |
17 | | |
18 | | void proto_register_ipa(void); |
19 | | void proto_reg_handoff_gsm_ipa(void); |
20 | | |
21 | | /* |
22 | | * Protocol used by ip.access's nanoBTS/nanoGSM GSM picocells: |
23 | | * |
24 | | * http://www.ipaccess.com/en/nanoGSM-picocell |
25 | | * |
26 | | * to transport the GSM A-bis interface over TCP and UDP. |
27 | | * |
28 | | * See |
29 | | * |
30 | | * http://openbsc.osmocom.org/trac/wiki/nanoBTS |
31 | | * |
32 | | * for some information about this protocol determined by reverse- |
33 | | * engineering. |
34 | | */ |
35 | | |
36 | | /* |
37 | | * These ports are also registered for other protocols, as per |
38 | | * |
39 | | * http://www.iana.org/assignments/service-names-port-numbers/service-names-port-numbers.xml |
40 | | * |
41 | | * exlm-agent 3002 |
42 | | * cgms 3003 |
43 | | * ii-admin 3006 |
44 | | * vrml-multi-use 4200-4299 |
45 | | * commplex-main 5000 |
46 | | * |
47 | | * But, as that document says: |
48 | | * |
49 | | ************************************************************************ |
50 | | * PLEASE NOTE THE FOLLOWING: * |
51 | | * * |
52 | | * ASSIGNMENT OF A PORT NUMBER DOES NOT IN ANY WAY IMPLY AN * |
53 | | * ENDORSEMENT OF AN APPLICATION OR PRODUCT, AND THE FACT THAT NETWORK * |
54 | | * TRAFFIC IS FLOWING TO OR FROM A REGISTERED PORT DOES NOT MEAN THAT * |
55 | | * IT IS "GOOD" TRAFFIC, NOR THAT IT NECESSARILY CORRESPONDS TO THE * |
56 | | * ASSIGNED SERVICE. FIREWALL AND SYSTEM ADMINISTRATORS SHOULD * |
57 | | * CHOOSE HOW TO CONFIGURE THEIR SYSTEMS BASED ON THEIR KNOWLEDGE OF * |
58 | | * THE TRAFFIC IN QUESTION, NOT WHETHER THERE IS A PORT NUMBER * |
59 | | * REGISTERED OR NOT. * |
60 | | ************************************************************************ |
61 | | */ |
62 | 14 | #define IPA_TCP_PORTS "3002,3003,3006,4222,4249,4250,5000" |
63 | | |
64 | | static dissector_handle_t ipa_tcp_handle; |
65 | | static dissector_handle_t ipa_udp_handle; |
66 | | static bool global_ipa_in_root; |
67 | | static bool global_ipa_in_info; |
68 | | |
69 | | /* Initialize the protocol and registered fields */ |
70 | | static int proto_ipa; |
71 | | static int proto_ipaccess; |
72 | | |
73 | | static int hf_ipa_data_len; |
74 | | static int hf_ipa_protocol; |
75 | | static int hf_ipa_hsl_debug; |
76 | | static int hf_ipa_osmo_proto; |
77 | | static int hf_ipa_osmo_ctrl_data; |
78 | | |
79 | | static int hf_ipaccess_msgtype; |
80 | | static int hf_ipaccess_attr_tag; |
81 | | static int hf_ipaccess_attr_string; |
82 | | static int hf_ipaccess_attribute_unk; |
83 | | |
84 | | /* Initialize the subtree pointers */ |
85 | | static int ett_ipa; |
86 | | static int ett_ipaccess; |
87 | | |
88 | | enum { |
89 | | SUB_OML, |
90 | | SUB_RSL, |
91 | | SUB_SCCP, |
92 | | SUB_MGCP, |
93 | | /* SUB_IPACCESS, */ |
94 | | SUB_DATA, |
95 | | |
96 | | SUB_MAX |
97 | | }; |
98 | | |
99 | | static dissector_handle_t sub_handles[SUB_MAX]; |
100 | | static dissector_table_t osmo_dissector_table; |
101 | | |
102 | | |
103 | 4.08k | #define ABISIP_RSL_MAX 0x20 |
104 | 1 | #define HSL_DEBUG 0xdd |
105 | 316 | #define OSMO_EXT 0xee |
106 | 1 | #define IPA_MGCP 0xfc |
107 | 58 | #define AIP_SCCP 0xfd |
108 | 27 | #define ABISIP_IPACCESS 0xfe |
109 | 85 | #define ABISIP_OML 0xff |
110 | 314 | #define IPAC_PROTO_EXT_CTRL 0x00 |
111 | 315 | #define IPAC_PROTO_EXT_MGCP 0x01 |
112 | | #define IPAC_PROTO_EXT_LAC 0x02 |
113 | | #define IPAC_PROTO_EXT_SMSC 0x03 |
114 | | #define IPAC_PROTO_EXT_ORC 0x04 |
115 | | #define IPAC_PROTO_EXT_GSUP 0x05 |
116 | | #define IPAC_PROTO_EXT_OAP 0x06 |
117 | | |
118 | | static const value_string ipa_protocol_vals[] = { |
119 | | { 0x00, "RSL" }, |
120 | | { HSL_DEBUG, "HSL Debug" }, |
121 | | { OSMO_EXT, "OSMO EXT" }, |
122 | | { IPA_MGCP, "MGCP (old)" }, |
123 | | { AIP_SCCP, "SCCP" }, |
124 | | { ABISIP_IPACCESS, "IPA" }, |
125 | | { ABISIP_OML, "OML" }, |
126 | | { 0, NULL } |
127 | | }; |
128 | | |
129 | | static const value_string ipaccess_msgtype_vals[] = { |
130 | | { 0x00, "PING?" }, |
131 | | { 0x01, "PONG!" }, |
132 | | { 0x04, "IDENTITY REQUEST" }, |
133 | | { 0x05, "IDENTITY RESPONSE" }, |
134 | | { 0x06, "IDENTITY ACK" }, |
135 | | { 0x07, "IDENTITY NACK" }, |
136 | | { 0x08, "PROXY REQUEST" }, |
137 | | { 0x09, "PROXY ACK" }, |
138 | | { 0x0a, "PROXY NACK" }, |
139 | | { 0x0b, "SSL INFO" }, |
140 | | { 0, NULL } |
141 | | }; |
142 | | |
143 | | static const value_string ipaccess_idtag_vals[] = { |
144 | | { 0x00, "Serial Number" }, |
145 | | { 0x01, "Unit Name" }, |
146 | | { 0x02, "Location" }, |
147 | | { 0x03, "Unit Type" }, |
148 | | { 0x04, "Equipment Version" }, |
149 | | { 0x05, "Software Version" }, |
150 | | { 0x06, "IP Address" }, |
151 | | { 0x07, "MAC Address" }, |
152 | | { 0x08, "Unit ID" }, |
153 | | { 0x09, "User Name" }, |
154 | | { 0x0a, "Password" }, |
155 | | { 0x0b, "Access Class" }, |
156 | | { 0x0c, "Application Protocol Version" }, |
157 | | { 0, NULL } |
158 | | }; |
159 | | |
160 | | static const value_string ipa_osmo_proto_vals[] = { |
161 | | { 0x00, "CTRL" }, |
162 | | { 0x01, "MGCP" }, |
163 | | { 0x02, "LAC" }, |
164 | | { 0x03, "SMSC" }, |
165 | | { 0x04, "ORC" }, |
166 | | { 0x05, "GSUP" }, |
167 | | { 0x06, "OAP" }, |
168 | | { 0, NULL } |
169 | | }; |
170 | | |
171 | | |
172 | | static int |
173 | | dissect_ipa_attr(tvbuff_t *tvb, int base_offs, proto_tree *tree) |
174 | 14 | { |
175 | 14 | uint8_t len, attr_type; |
176 | | |
177 | 14 | int offset = base_offs; |
178 | | |
179 | 655 | while (tvb_reported_length_remaining(tvb, offset) > 0) { |
180 | 654 | attr_type = tvb_get_uint8(tvb, offset); |
181 | | |
182 | 654 | switch (attr_type) { |
183 | 234 | case 0x00: /* a string prefixed by its length */ |
184 | 234 | len = tvb_get_uint8(tvb, offset+1); |
185 | 234 | proto_tree_add_item(tree, hf_ipaccess_attr_tag, |
186 | 234 | tvb, offset+2, 1, ENC_BIG_ENDIAN); |
187 | 234 | proto_tree_add_item(tree, hf_ipaccess_attr_string, |
188 | 234 | tvb, offset+3, len-1, ENC_ASCII); |
189 | 234 | break; |
190 | 20 | case 0x01: /* a single-byte request for a certain attr */ |
191 | 20 | len = 0; |
192 | 20 | proto_tree_add_item(tree, hf_ipaccess_attr_tag, |
193 | 20 | tvb, offset+1, 1, ENC_BIG_ENDIAN); |
194 | 20 | break; |
195 | 396 | default: |
196 | 396 | len = 0; |
197 | 396 | proto_tree_add_uint(tree, hf_ipaccess_attribute_unk, tvb, offset+1, 1, |
198 | 396 | attr_type); |
199 | 396 | break; |
200 | 654 | }; |
201 | 641 | offset += len + 2; |
202 | 641 | }; |
203 | 1 | return offset; |
204 | 14 | } |
205 | | |
206 | | /* Dissect an ip.access specific message */ |
207 | | static int |
208 | | dissect_ipaccess(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) |
209 | 27 | { |
210 | 27 | proto_item *ti; |
211 | 27 | proto_tree *ipaccess_tree; |
212 | 27 | uint8_t msg_type; |
213 | | |
214 | 27 | msg_type = tvb_get_uint8(tvb, 0); |
215 | | |
216 | 27 | col_append_fstr(pinfo->cinfo, COL_INFO, "%s ", |
217 | 27 | val_to_str(msg_type, ipaccess_msgtype_vals, |
218 | 27 | "unknown 0x%02x")); |
219 | 27 | ti = proto_tree_add_item(tree, proto_ipaccess, tvb, 0, -1, ENC_NA); |
220 | 27 | ipaccess_tree = proto_item_add_subtree(ti, ett_ipaccess); |
221 | 27 | proto_tree_add_item(ipaccess_tree, hf_ipaccess_msgtype, |
222 | 27 | tvb, 0, 1, ENC_BIG_ENDIAN); |
223 | 27 | switch (msg_type) { |
224 | 13 | case 4: |
225 | 14 | case 5: |
226 | 14 | dissect_ipa_attr(tvb, 1, ipaccess_tree); |
227 | 14 | break; |
228 | 27 | } |
229 | | |
230 | 14 | return 1; |
231 | 27 | } |
232 | | |
233 | | /* Dissect the osmocom extension header */ |
234 | | static int |
235 | | dissect_osmo(tvbuff_t *tvb, packet_info *pinfo, proto_tree *ipatree, proto_tree *tree, proto_item *ipa_ti) |
236 | 316 | { |
237 | 316 | tvbuff_t *next_tvb; |
238 | 316 | uint8_t osmo_proto; |
239 | 316 | const char *name; |
240 | | |
241 | 316 | osmo_proto = tvb_get_uint8(tvb, 0); |
242 | 316 | name = val_to_str(osmo_proto, ipa_osmo_proto_vals, "unknown 0x%02x"); |
243 | 316 | col_append_fstr(pinfo->cinfo, COL_INFO, "%s ", name); |
244 | 316 | if (ipatree) { |
245 | 316 | proto_item_append_text(ipa_ti, " %s", name); |
246 | 316 | proto_tree_add_item(ipatree, hf_ipa_osmo_proto, |
247 | 316 | tvb, 0, 1, ENC_BIG_ENDIAN); |
248 | 316 | } |
249 | | |
250 | 316 | next_tvb = tvb_new_subset_remaining(tvb, 1); |
251 | | |
252 | | /* Call any subdissectors that registered for this protocol */ |
253 | 316 | if (dissector_try_uint(osmo_dissector_table, osmo_proto, next_tvb, pinfo, tree)) |
254 | 1 | return 1; |
255 | | |
256 | | /* Fallback to the standard MGCP dissector */ |
257 | 315 | if (osmo_proto == IPAC_PROTO_EXT_MGCP) { |
258 | 1 | call_dissector(sub_handles[SUB_MGCP], next_tvb, pinfo, tree); |
259 | 1 | return 1; |
260 | | /* Simply display the CTRL data as text */ |
261 | 314 | } else if (osmo_proto == IPAC_PROTO_EXT_CTRL) { |
262 | 1 | proto_tree_add_item(tree, hf_ipa_osmo_ctrl_data, next_tvb, 0, -1, ENC_ASCII); |
263 | 1 | return 1; |
264 | 1 | } |
265 | | |
266 | 313 | call_dissector(sub_handles[SUB_DATA], next_tvb, pinfo, tree); |
267 | | |
268 | 313 | return 1; |
269 | 315 | } |
270 | | |
271 | | |
272 | | |
273 | | /* Code to actually dissect the packets */ |
274 | | static bool |
275 | | dissect_ipa(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, bool is_udp) |
276 | 3.62k | { |
277 | 3.62k | int remaining; |
278 | 3.62k | int header_length = 3; |
279 | 3.62k | int offset = 0; |
280 | 3.62k | uint16_t len, msg_type; |
281 | | |
282 | 3.62k | if (tvb_reported_length(tvb) < 4) |
283 | 22 | return false; |
284 | | |
285 | | //sanity check the message type |
286 | 3.60k | msg_type = tvb_get_uint8(tvb, 2); |
287 | 3.60k | if ((try_val_to_str(msg_type, ipa_protocol_vals) == NULL) && |
288 | 3.60k | (msg_type >= ABISIP_RSL_MAX)) |
289 | 361 | return false; |
290 | | |
291 | 3.24k | col_set_str(pinfo->cinfo, COL_PROTOCOL, "IPA"); |
292 | 3.24k | col_clear(pinfo->cinfo, COL_INFO); |
293 | | |
294 | 4.48k | while ((remaining = tvb_reported_length_remaining(tvb, offset)) > 0) { |
295 | 3.66k | proto_item *ti; |
296 | 3.66k | proto_tree *ipa_tree = NULL; |
297 | 3.66k | tvbuff_t *next_tvb; |
298 | | |
299 | 3.66k | len = tvb_get_ntohs(tvb, offset); |
300 | 3.66k | msg_type = tvb_get_uint8(tvb, offset+2); |
301 | | |
302 | 3.66k | col_append_fstr(pinfo->cinfo, COL_INFO, "%s ", |
303 | 3.66k | val_to_str(msg_type, ipa_protocol_vals, |
304 | 3.66k | "unknown 0x%02x")); |
305 | | |
306 | | /* |
307 | | * The IPA header is different depending on the transport protocol. |
308 | | * With UDP there seems to be a fourth byte for the IPA header. |
309 | | * We attempt to detect this by checking if the length from the |
310 | | * header + four bytes of the IPA header equals the remaining size. |
311 | | */ |
312 | 3.66k | if (is_udp && (len + 4 == remaining)) { |
313 | 0 | header_length++; |
314 | 0 | } |
315 | | |
316 | 3.66k | ti = proto_tree_add_protocol_format(tree, proto_ipa, |
317 | 3.66k | tvb, offset, len+header_length, |
318 | 3.66k | "IPA protocol ip.access, type: %s", |
319 | 3.66k | val_to_str(msg_type, ipa_protocol_vals, |
320 | 3.66k | "unknown 0x%02x")); |
321 | 3.66k | ipa_tree = proto_item_add_subtree(ti, ett_ipa); |
322 | 3.66k | proto_tree_add_item(ipa_tree, hf_ipa_data_len, |
323 | 3.66k | tvb, offset, 2, ENC_BIG_ENDIAN); |
324 | 3.66k | proto_tree_add_item(ipa_tree, hf_ipa_protocol, |
325 | 3.66k | tvb, offset+2, 1, ENC_BIG_ENDIAN); |
326 | | |
327 | 3.66k | next_tvb = tvb_new_subset_length(tvb, offset+header_length, len); |
328 | | |
329 | 3.66k | switch (msg_type) { |
330 | 85 | case ABISIP_OML: |
331 | | /* hand this off to the standard A-bis OML dissector */ |
332 | 85 | if (sub_handles[SUB_OML]) |
333 | 85 | call_dissector(sub_handles[SUB_OML], next_tvb, |
334 | 85 | pinfo, tree); |
335 | 85 | break; |
336 | 27 | case ABISIP_IPACCESS: |
337 | 27 | dissect_ipaccess(next_tvb, pinfo, tree); |
338 | 27 | break; |
339 | 58 | case AIP_SCCP: |
340 | | /* hand this off to the standard SCCP dissector */ |
341 | 58 | call_dissector(sub_handles[SUB_SCCP], next_tvb, pinfo, tree); |
342 | 58 | break; |
343 | 1 | case IPA_MGCP: |
344 | | /* hand this off to the standard MGCP dissector */ |
345 | 1 | call_dissector(sub_handles[SUB_MGCP], next_tvb, pinfo, tree); |
346 | 1 | break; |
347 | 316 | case OSMO_EXT: |
348 | 316 | dissect_osmo(next_tvb, pinfo, ipa_tree, tree, ti); |
349 | 316 | break; |
350 | 1 | case HSL_DEBUG: |
351 | 1 | proto_tree_add_item(ipa_tree, hf_ipa_hsl_debug, |
352 | 1 | next_tvb, 0, len, ENC_ASCII); |
353 | 1 | if (global_ipa_in_root == true) |
354 | 0 | proto_tree_add_item(tree, hf_ipa_hsl_debug, |
355 | 0 | next_tvb, 0, len, ENC_ASCII); |
356 | 1 | if (global_ipa_in_info == true) |
357 | 0 | col_append_fstr(pinfo->cinfo, COL_INFO, "%s ", |
358 | 0 | tvb_get_stringz_enc(pinfo->pool, next_tvb, 0, NULL, ENC_ASCII)); |
359 | 1 | break; |
360 | 3.17k | default: |
361 | 3.17k | if (msg_type < ABISIP_RSL_MAX) { |
362 | | /* hand this off to the standard A-bis RSL dissector */ |
363 | 3.13k | call_dissector(sub_handles[SUB_RSL], next_tvb, pinfo, tree); |
364 | 3.13k | } |
365 | 3.17k | break; |
366 | 3.66k | } |
367 | 1.24k | offset += len + header_length; |
368 | 1.24k | } |
369 | | |
370 | 818 | return true; |
371 | 3.24k | } |
372 | | |
373 | | static int |
374 | | dissect_ipa_tcp(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data _U_) |
375 | 3.62k | { |
376 | 3.62k | if (!dissect_ipa(tvb, pinfo, tree, false)) |
377 | 383 | return 0; |
378 | 3.24k | return tvb_captured_length(tvb); |
379 | 3.62k | } |
380 | | |
381 | | static int |
382 | | dissect_ipa_udp(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data _U_) |
383 | 0 | { |
384 | 0 | if (!dissect_ipa(tvb, pinfo, tree, true)) |
385 | 0 | return 0; |
386 | | |
387 | 0 | return tvb_captured_length(tvb); |
388 | 0 | } |
389 | | |
390 | | void proto_register_ipa(void) |
391 | 14 | { |
392 | 14 | module_t *ipa_module; |
393 | | |
394 | 14 | static hf_register_info hf[] = { |
395 | 14 | {&hf_ipa_data_len, |
396 | 14 | {"DataLen", "gsm_ipa.data_len", |
397 | 14 | FT_UINT16, BASE_DEC, NULL, 0x0, |
398 | 14 | "The length of the data (in bytes)", HFILL} |
399 | 14 | }, |
400 | 14 | {&hf_ipa_protocol, |
401 | 14 | {"Protocol", "gsm_ipa.protocol", |
402 | 14 | FT_UINT8, BASE_HEX, VALS(ipa_protocol_vals), 0x0, |
403 | 14 | "The IPA Sub-Protocol", HFILL} |
404 | 14 | }, |
405 | 14 | {&hf_ipa_hsl_debug, |
406 | 14 | {"Debug Message", "gsm_ipa.hsl_debug", |
407 | 14 | FT_STRING, BASE_NONE, NULL, 0, |
408 | 14 | "Hay Systems Limited debug message", HFILL} |
409 | 14 | }, |
410 | 14 | {&hf_ipa_osmo_proto, |
411 | 14 | {"Osmo ext protocol", "gsm_ipa.osmo.protocol", |
412 | 14 | FT_UINT8, BASE_HEX, VALS(ipa_osmo_proto_vals), 0x0, |
413 | 14 | "The osmo extension protocol", HFILL} |
414 | 14 | }, |
415 | | |
416 | 14 | {&hf_ipa_osmo_ctrl_data, |
417 | 14 | {"CTRL data", "gsm_ipa.ctrl.data", |
418 | 14 | FT_STRING, BASE_NONE, NULL, 0x0, |
419 | 14 | "Control interface data", HFILL} |
420 | 14 | }, |
421 | | |
422 | 14 | }; |
423 | 14 | static hf_register_info hf_ipa[] = { |
424 | 14 | {&hf_ipaccess_msgtype, |
425 | 14 | {"MessageType", "ipaccess.msg_type", |
426 | 14 | FT_UINT8, BASE_HEX, VALS(ipaccess_msgtype_vals), 0x0, |
427 | 14 | "Type of ip.access message", HFILL} |
428 | 14 | }, |
429 | 14 | {&hf_ipaccess_attr_tag, |
430 | 14 | {"Tag", "ipaccess.attr_tag", |
431 | 14 | FT_UINT8, BASE_HEX, VALS(ipaccess_idtag_vals), 0x0, |
432 | 14 | "Attribute Tag", HFILL} |
433 | 14 | }, |
434 | 14 | {&hf_ipaccess_attr_string, |
435 | 14 | {"String", "ipaccess.attr_string", |
436 | 14 | FT_STRING, BASE_NONE, NULL, 0x0, |
437 | 14 | "String attribute", HFILL} |
438 | 14 | }, |
439 | 14 | {&hf_ipaccess_attribute_unk, |
440 | 14 | {"Unknown attribute type", "ipaccess.attr_unk", |
441 | 14 | FT_UINT8, BASE_HEX, NULL, 0x0, |
442 | 14 | NULL, HFILL} |
443 | 14 | }, |
444 | 14 | }; |
445 | | |
446 | 14 | static int *ett[] = { |
447 | 14 | &ett_ipa, |
448 | 14 | &ett_ipaccess, |
449 | 14 | }; |
450 | | |
451 | 14 | proto_ipa = proto_register_protocol("GSM over IP protocol as used by ip.access", "GSM over IP", "gsm_ipa"); |
452 | 14 | proto_ipaccess = proto_register_protocol("GSM over IP ip.access CCM sub-protocol", "IPA", "ipaccess"); |
453 | | |
454 | 14 | proto_register_field_array(proto_ipa, hf, array_length(hf)); |
455 | 14 | proto_register_field_array(proto_ipaccess, hf_ipa, array_length(hf_ipa)); |
456 | 14 | proto_register_subtree_array(ett, array_length(ett)); |
457 | | |
458 | | /* Register table for subdissectors */ |
459 | 14 | osmo_dissector_table = register_dissector_table("ipa.osmo.protocol", |
460 | 14 | "GSM over IP ip.access Protocol", proto_ipa, |
461 | 14 | FT_UINT8, BASE_DEC); |
462 | | |
463 | 14 | ipa_module = prefs_register_protocol(proto_ipa, NULL); |
464 | | |
465 | 14 | prefs_register_bool_preference(ipa_module, "hsl_debug_in_root_tree", |
466 | 14 | "HSL Debug messages in root protocol tree", |
467 | 14 | NULL, &global_ipa_in_root); |
468 | 14 | prefs_register_bool_preference(ipa_module, "hsl_debug_in_info", |
469 | 14 | "HSL Debug messages in INFO column", |
470 | 14 | NULL, &global_ipa_in_info); |
471 | | |
472 | 14 | ipa_tcp_handle = register_dissector("gsm_ipa.tcp", dissect_ipa_tcp, proto_ipa); |
473 | 14 | ipa_udp_handle = register_dissector("gsm_ipa.udp", dissect_ipa_udp, proto_ipa); |
474 | 14 | } |
475 | | |
476 | | void proto_reg_handoff_gsm_ipa(void) |
477 | 14 | { |
478 | 14 | sub_handles[SUB_RSL] = find_dissector_add_dependency("gsm_abis_rsl", proto_ipa); |
479 | 14 | sub_handles[SUB_OML] = find_dissector_add_dependency("gsm_abis_oml", proto_ipa); |
480 | 14 | sub_handles[SUB_SCCP] = find_dissector_add_dependency("sccp", proto_ipa); |
481 | 14 | sub_handles[SUB_MGCP] = find_dissector_add_dependency("mgcp", proto_ipa); |
482 | 14 | sub_handles[SUB_DATA] = find_dissector("data"); |
483 | | |
484 | 14 | dissector_add_uint_range_with_preference("tcp.port", IPA_TCP_PORTS, ipa_tcp_handle); |
485 | 14 | dissector_add_uint_range_with_preference("udp.port", "", ipa_udp_handle); |
486 | 14 | } |
487 | | |
488 | | /* |
489 | | * Editor modelines - https://www.wireshark.org/tools/modelines.html |
490 | | * |
491 | | * Local variables: |
492 | | * c-basic-offset: 8 |
493 | | * tab-width: 8 |
494 | | * indent-tabs-mode: t |
495 | | * End: |
496 | | * |
497 | | * vi: set shiftwidth=8 tabstop=8 noexpandtab: |
498 | | * :indentSize=8:tabSize=8:noTabs=false: |
499 | | */ |