blob: b0dad7d8a465f9b3507bf861efc5f9b7dcf7adf8 [file] [log] [blame]
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +01001/*
2 * (C) 2012 by Holger Hans Peter Freyther
3 * All Rights Reserved
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 */
20
21#include <osmocom/gsm/gsm0808.h>
Philipp Maier22401432017-03-24 17:59:26 +010022#include <osmocom/gsm/gsm0808_utils.h>
23#include <osmocom/gsm/protocol/gsm_08_08.h>
Philipp Maier3d48ec02017-03-29 17:37:55 +020024#include <osmocom/gsm/protocol/gsm_08_58.h>
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +010025
26#include <stdio.h>
27#include <stdlib.h>
Philipp Maier22401432017-03-24 17:59:26 +010028#include <sys/socket.h>
29#include <netinet/in.h>
30#include <arpa/inet.h>
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +010031
32#define VERIFY(msg, data, len) \
33 if (msgb_l3len(msg) != len) { \
34 printf("%s:%d Length don't match: %d vs. %d. %s\n", \
Holger Hans Peter Freytherfdb46672015-11-09 16:32:43 +000035 __func__, __LINE__, msgb_l3len(msg), (int) len, \
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +010036 osmo_hexdump(msg->l3h, msgb_l3len(msg))); \
37 abort(); \
38 } else if (memcmp(msg->l3h, data, len) != 0) { \
39 printf("%s:%d didn't match: got: %s\n", \
40 __func__, __LINE__, \
41 osmo_hexdump(msg->l3h, msgb_l3len(msg))); \
42 abort(); \
43 }
44
Philipp Maierfa896ab2017-03-27 16:55:32 +020045/* Setup a fake codec list for testing */
46static void setup_codec_list(struct gsm0808_speech_codec_list *scl)
47{
48 memset(scl, 0, sizeof(*scl));
49
50 scl->codec[0].pi = true;
51 scl->codec[0].tf = true;
52 scl->codec[0].type = 0xab;
53 scl->codec[0].type_extended = true;
54 scl->codec[0].cfg_present = true;
55 scl->codec[0].cfg = 0xcdef;
56
57 scl->codec[1].fi = true;
58 scl->codec[1].pt = true;
59 scl->codec[1].type = 0x05;
60
61 scl->codec[2].fi = true;
62 scl->codec[2].tf = true;
63 scl->codec[2].type = 0xf2;
64 scl->codec[2].type_extended = true;
65
66 scl->len = 3;
67}
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +010068
69static void test_create_layer3(void)
70{
71 static const uint8_t res[] = {
72 0x00, 0x0e, 0x57, 0x05, 0x08, 0x00, 0x77, 0x62,
73 0x83, 0x33, 0x66, 0x44, 0x88, 0x17, 0x01, 0x23 };
74 struct msgb *msg, *in_msg;
75 printf("Testing creating Layer3\n");
76
77 in_msg = msgb_alloc_headroom(512, 128, "foo");
78 in_msg->l3h = in_msg->data;
79 msgb_v_put(in_msg, 0x23);
80
81 msg = gsm0808_create_layer3(in_msg, 0x1122, 0x2244, 0x3366, 0x4488);
82 VERIFY(msg, res, ARRAY_SIZE(res));
83 msgb_free(msg);
84 msgb_free(in_msg);
85}
86
Philipp Maierfa896ab2017-03-27 16:55:32 +020087static void test_create_layer3_aoip()
88{
89 static const uint8_t res[] = {
90 0x00, 0x17, 0x57, 0x05, 0x08, 0x00, 0x77, 0x62,
91 0x83, 0x33, 0x66, 0x44, 0x88, 0x17, 0x01, 0x23,
92 GSM0808_IE_SPEECH_CODEC_LIST, 0x07, 0x5f, 0xab, 0xcd, 0xef,
93 0xa5, 0x9f, 0xf2
94 };
95
96 struct msgb *msg, *in_msg;
97 struct gsm0808_speech_codec_list sc_list;
98 printf("Testing creating Layer3 (AoIP)\n");
99
100 setup_codec_list(&sc_list);
101
102 in_msg = msgb_alloc_headroom(512, 128, "foo");
103 in_msg->l3h = in_msg->data;
104 msgb_v_put(in_msg, 0x23);
105
106 msg =
107 gsm0808_create_layer3_aoip(in_msg, 0x1122, 0x2244, 0x3366, 0x4488,
108 &sc_list);
109 VERIFY(msg, res, ARRAY_SIZE(res));
110
111 msgb_free(msg);
112 msgb_free(in_msg);
113}
114
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100115static void test_create_reset()
116{
117 static const uint8_t res[] = { 0x00, 0x04, 0x30, 0x04, 0x01, 0x20 };
118 struct msgb *msg;
119
120 printf("Testing creating Reset\n");
121 msg = gsm0808_create_reset();
122 VERIFY(msg, res, ARRAY_SIZE(res));
123 msgb_free(msg);
124}
125
126static void test_create_clear_command()
127{
128 static const uint8_t res[] = { 0x20, 0x04, 0x01, 0x23 };
129 struct msgb *msg;
130
131 printf("Testing creating Clear Command\n");
132 msg = gsm0808_create_clear_command(0x23);
133 VERIFY(msg, res, ARRAY_SIZE(res));
134 msgb_free(msg);
135}
136
137static void test_create_clear_complete()
138{
139 static const uint8_t res[] = { 0x00, 0x01, 0x21 };
140 struct msgb *msg;
141
142 printf("Testing creating Clear Complete\n");
143 msg = gsm0808_create_clear_complete();
144 VERIFY(msg, res, ARRAY_SIZE(res));
145 msgb_free(msg);
146}
147
Philipp Maierb478dd32017-03-29 15:50:05 +0200148static void test_create_cipher()
149{
150 static const uint8_t res[] =
151 { 0x00, 0x0c, 0x53, 0x0a, 0x09, 0x03, 0xaa,
152 0xbb, 0xcc, 0xdd, 0xee, 0xff, 0x23, 0x42 };
153 static const uint8_t res2[] =
154 { 0x00, 0x0e, 0x53, 0x0a, 0x09, 0x03, 0xaa,
155 0xbb, 0xcc, 0xdd, 0xee, 0xff, 0x23, 0x42,
156 GSM0808_IE_CIPHER_RESPONSE_MODE, 0x01 };
157 struct msgb *msg;
158 struct gsm0808_encrypt_info ei;
159 uint8_t include_imeisv;
160
161 memset(&ei, 0, sizeof(ei));
162 ei.perm_algo[0] = GSM0808_ALG_ID_A5_0;
163 ei.perm_algo[1] = GSM0808_ALG_ID_A5_1;
164 ei.perm_algo_len = 2;
165 ei.key[0] = 0xaa;
166 ei.key[1] = 0xbb;
167 ei.key[2] = 0xcc;
168 ei.key[3] = 0xdd;
169 ei.key[4] = 0xee;
170 ei.key[5] = 0xff;
171 ei.key[6] = 0x23;
172 ei.key[7] = 0x42;
173 ei.key_len = 8;
174 include_imeisv = 1;
175
176 printf("Testing creating Chipher Mode Command\n");
177 msg = gsm0808_create_cipher(&ei, NULL);
178 OSMO_ASSERT(msg);
179 VERIFY(msg, res, ARRAY_SIZE(res));
180 msgb_free(msg);
181
182 msg = gsm0808_create_cipher(&ei, &include_imeisv);
183 OSMO_ASSERT(msg);
184 VERIFY(msg, res2, ARRAY_SIZE(res2));
185 msgb_free(msg);
186}
187
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100188static void test_create_cipher_complete()
189{
190 static const uint8_t res1[] = {
191 0x00, 0x08, 0x55, 0x20, 0x03, 0x23, 0x42, 0x21, 0x2c, 0x04 };
192 static const uint8_t res2[] = { 0x00, 0x03, 0x55, 0x2c, 0x04};
193 struct msgb *l3, *msg;
194
195 printf("Testing creating Cipher Complete\n");
196 l3 = msgb_alloc_headroom(512, 128, "l3h");
197 l3->l3h = l3->data;
198 msgb_v_put(l3, 0x23);
199 msgb_v_put(l3, 0x42);
200 msgb_v_put(l3, 0x21);
201
202 /* with l3 data */
203 msg = gsm0808_create_cipher_complete(l3, 4);
204 VERIFY(msg, res1, ARRAY_SIZE(res1));
205 msgb_free(msg);
206
207 /* with l3 data but short */
208 l3->len -= 1;
209 l3->tail -= 1;
210 msg = gsm0808_create_cipher_complete(l3, 4);
211 VERIFY(msg, res2, ARRAY_SIZE(res2));
212 msgb_free(msg);
213
214 /* without l3 data */
215 msg = gsm0808_create_cipher_complete(NULL, 4);
216 VERIFY(msg, res2, ARRAY_SIZE(res2));
217 msgb_free(msg);
218
219
220 msgb_free(l3);
221}
222
223static void test_create_cipher_reject()
224{
225 static const uint8_t res[] = { 0x00, 0x02, 0x59, 0x23 };
226 struct msgb *msg;
227
228 printf("Testing creating Cipher Reject\n");
229 msg = gsm0808_create_cipher_reject(0x23);
230 VERIFY(msg, res, ARRAY_SIZE(res));
231 msgb_free(msg);
232}
233
234static void test_create_cm_u()
235{
Harald Welte07b625d2012-01-23 10:02:58 +0100236 static const uint8_t res[] = {
237 0x00, 0x07, 0x54, 0x12, 0x01, 0x23, 0x13, 0x01, 0x42 };
238 static const uint8_t res2o[] = {
239 0x00, 0x04, 0x54, 0x12, 0x01, 0x23 };
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100240 struct msgb *msg;
Harald Welte07b625d2012-01-23 10:02:58 +0100241 const uint8_t cm2 = 0x23;
242 const uint8_t cm3 = 0x42;
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100243
244 printf("Testing creating CM U\n");
Harald Welte07b625d2012-01-23 10:02:58 +0100245 msg = gsm0808_create_classmark_update(&cm2, 1, &cm3, 1);
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100246 VERIFY(msg, res, ARRAY_SIZE(res));
Harald Welte07b625d2012-01-23 10:02:58 +0100247
248 msg = gsm0808_create_classmark_update(&cm2, 1, NULL, 0);
249 VERIFY(msg, res2o, ARRAY_SIZE(res2o));
250
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100251 msgb_free(msg);
252}
253
254static void test_create_sapi_reject()
255{
256 static const uint8_t res[] = { 0x00, 0x03, 0x25, 0x03, 0x25 };
257 struct msgb *msg;
258
259 printf("Testing creating SAPI Reject\n");
260 msg = gsm0808_create_sapi_reject(3);
261 VERIFY(msg, res, ARRAY_SIZE(res));
262 msgb_free(msg);
263}
264
265static void test_create_ass_compl()
266{
267 static const uint8_t res1[] = {
268 0x00, 0x09, 0x02, 0x15, 0x23, 0x21, 0x42, 0x2c,
269 0x11, 0x40, 0x22 };
270 static const uint8_t res2[] = {
271 0x00, 0x07, 0x02, 0x15, 0x23, 0x21, 0x42, 0x2c, 0x11};
272 struct msgb *msg;
273
274 printf("Testing creating Assignment Complete\n");
275 msg = gsm0808_create_assignment_completed(0x23, 0x42, 0x11, 0x22);
276 VERIFY(msg, res1, ARRAY_SIZE(res1));
277 msgb_free(msg);
278
279 msg = gsm0808_create_assignment_completed(0x23, 0x42, 0x11, 0);
280 VERIFY(msg, res2, ARRAY_SIZE(res2));
281 msgb_free(msg);
282}
283
Philipp Maierfa896ab2017-03-27 16:55:32 +0200284static void test_create_ass_compl_aoip()
285{
286 struct sockaddr_storage ss;
287 struct sockaddr_in sin;
288 struct gsm0808_speech_codec sc;
289 struct gsm0808_speech_codec_list sc_list;
290 static const uint8_t res[] =
291 { 0x00, 0x1d, 0x02, 0x15, 0x23, 0x21, 0x42, 0x2c, 0x11, 0x40, 0x22,
292 GSM0808_IE_AOIP_TRASP_ADDR, 0x06, 0xc0, 0xa8, 0x64, 0x17, 0x04,
293 0xd2, GSM0808_IE_SPEECH_CODEC, 0x01, 0x9a,
294 GSM0808_IE_SPEECH_CODEC_LIST, 0x07, 0x5f, 0xab, 0xcd, 0xef, 0xa5,
295 0x9f, 0xf2 };
296 struct msgb *msg;
297
298 memset(&sin, 0, sizeof(sin));
299 sin.sin_family = AF_INET;
300 sin.sin_port = htons(1234);
301 inet_aton("192.168.100.23", &sin.sin_addr);
302
303 memset(&ss, 0, sizeof(ss));
304 memcpy(&ss, &sin, sizeof(sin));
305
306 memset(&sc, 0, sizeof(sc));
307 sc.fi = true;
308 sc.tf = true;
309 sc.type = 0x0a;
310
311 setup_codec_list(&sc_list);
312
313 printf("Testing creating Assignment Complete (AoIP)\n");
314 msg = gsm0808_create_ass_compl(0x23, 0x42, 0x11, 0x22,
315 &ss, &sc, &sc_list);
316 VERIFY(msg, res, ARRAY_SIZE(res));
317 msgb_free(msg);
318}
319
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100320static void test_create_ass_fail()
321{
322 static const uint8_t res1[] = { 0x00, 0x04, 0x03, 0x04, 0x01, 0x23 };
323 static const uint8_t res2[] = {
324 0x00, 0x06, 0x03, 0x04, 0x01, 0x23, 0x15, 0x02};
325 uint8_t rr_res = 2;
326 struct msgb *msg;
327
328 printf("Testing creating Assignment Failure\n");
329 msg = gsm0808_create_assignment_failure(0x23, NULL);
330 VERIFY(msg, res1, ARRAY_SIZE(res1));
331 msgb_free(msg);
332
333 msg = gsm0808_create_assignment_failure(0x23, &rr_res);
334 VERIFY(msg, res2, ARRAY_SIZE(res2));
335 msgb_free(msg);
336}
337
Philipp Maierfa896ab2017-03-27 16:55:32 +0200338static void test_create_ass_fail_aoip()
339{
340 static const uint8_t res1[] =
341 { 0x00, 0x0d, 0x03, 0x04, 0x01, 0x23, GSM0808_IE_SPEECH_CODEC_LIST,
342 0x07, 0x5f, 0xab, 0xcd, 0xef, 0xa5, 0x9f, 0xf2 };
343 static const uint8_t res2[] =
344 { 0x00, 0x0f, 0x03, 0x04, 0x01, 0x23, 0x15, 0x02,
345 GSM0808_IE_SPEECH_CODEC_LIST, 0x07, 0x5f, 0xab,
346 0xcd, 0xef, 0xa5, 0x9f, 0xf2 };
347 uint8_t rr_res = 2;
348 struct msgb *msg;
349 struct gsm0808_speech_codec_list sc_list;
350
351 setup_codec_list(&sc_list);
352
353 printf("Testing creating Assignment Failure (AoIP)\n");
354 msg = gsm0808_create_ass_fail(0x23, NULL, &sc_list);
355 VERIFY(msg, res1, ARRAY_SIZE(res1));
356 msgb_free(msg);
357
358 msg = gsm0808_create_ass_fail(0x23, &rr_res, &sc_list);
359 VERIFY(msg, res2, ARRAY_SIZE(res2));
360 msgb_free(msg);
361}
362
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100363static void test_create_clear_rqst()
364{
365 static const uint8_t res[] = { 0x00, 0x04, 0x22, 0x04, 0x01, 0x23 };
366 struct msgb *msg;
367
368 printf("Testing creating Clear Request\n");
369 msg = gsm0808_create_clear_rqst(0x23);
370 VERIFY(msg, res, ARRAY_SIZE(res));
371 msgb_free(msg);
372}
373
Philipp Maier3d48ec02017-03-29 17:37:55 +0200374static void test_create_paging()
375{
376 static const uint8_t res[] =
377 { 0x00, 0x10, 0x52, 0x08, 0x08, 0x09, 0x10, 0x10, 0x00, 0x00, 0x00,
378 0x21, 0x43, 0x1a, 0x03, 0x05, 0x23, 0x42 };
379 static const uint8_t res2[] =
380 { 0x00, 0x16, 0x52, 0x08, 0x08, 0x09, 0x10, 0x10, 0x00, 0x00, 0x00,
381 0x21, 0x43, GSM0808_IE_TMSI, 0x04, 0x12, 0x34, 0x56, 0x78, 0x1a,
382 0x03, 0x05, 0x23, 0x42 };
383 static const uint8_t res3[] =
384 { 0x00, 0x18, 0x52, 0x08, 0x08, 0x09, 0x10, 0x10, 0x00, 0x00, 0x00,
385 0x21, 0x43, GSM0808_IE_TMSI, 0x04, 0x12, 0x34, 0x56, 0x78, 0x1a,
386 0x03, 0x05, 0x23, 0x42, GSM0808_IE_CHANNEL_NEEDED,
387 RSL_CHANNEED_TCH_ForH };
388
389 struct msgb *msg;
390 struct gsm0808_cell_id_list cil;
391 uint32_t tmsi = 0x12345678;
392 uint8_t chan_needed = RSL_CHANNEED_TCH_ForH;
393
394 char imsi[] = "001010000001234";
395
396 cil.id_discr = CELL_IDENT_LAC;
397 cil.id_list_lac[0] = 0x2342;
398 cil.id_list_len = 1;
399
400 printf("Testing creating Paging Request\n");
401 msg = gsm0808_create_paging(imsi, NULL, &cil, NULL);
402 VERIFY(msg, res, ARRAY_SIZE(res));
403 msgb_free(msg);
404
405 msg = gsm0808_create_paging(imsi, &tmsi, &cil, NULL);
406 VERIFY(msg, res2, ARRAY_SIZE(res2));
407 msgb_free(msg);
408
409 msg = gsm0808_create_paging(imsi, &tmsi, &cil, &chan_needed);
410 VERIFY(msg, res3, ARRAY_SIZE(res3));
411 msgb_free(msg);
412}
413
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100414static void test_create_dtap()
415{
416 static const uint8_t res[] = { 0x01, 0x03, 0x02, 0x23, 0x42 };
417 struct msgb *msg, *l3;
418
419 printf("Testing creating DTAP\n");
420 l3 = msgb_alloc_headroom(512, 128, "test");
421 l3->l3h = l3->data;
422 msgb_v_put(l3, 0x23);
423 msgb_v_put(l3, 0x42);
424
425 msg = gsm0808_create_dtap(l3, 0x3);
426 VERIFY(msg, res, ARRAY_SIZE(res));
427 msgb_free(msg);
428 msgb_free(l3);
429}
430
431static void test_prepend_dtap()
432{
433 static const uint8_t res[] = { 0x01, 0x03, 0x02, 0x23, 0x42 };
434 struct msgb *in_msg;
435
436 printf("Testing prepend DTAP\n");
437
438 in_msg = msgb_alloc_headroom(512, 128, "test");
439 msgb_v_put(in_msg, 0x23);
440 msgb_v_put(in_msg, 0x42);
441
442 gsm0808_prepend_dtap_header(in_msg, 0x3);
443 in_msg->l3h = in_msg->data;
444 VERIFY(in_msg, res, ARRAY_SIZE(res));
445 msgb_free(in_msg);
446}
447
Philipp Maier22401432017-03-24 17:59:26 +0100448static void test_enc_dec_aoip_trasp_addr_v4()
449{
450 struct sockaddr_storage enc_addr;
451 struct sockaddr_storage dec_addr;
452 struct sockaddr_in enc_addr_in;
453 struct msgb *msg;
454 uint8_t rc_enc;
455 int rc_dec;
456
457 memset(&enc_addr_in, 0, sizeof(enc_addr_in));
458 enc_addr_in.sin_family = AF_INET;
459 enc_addr_in.sin_port = htons(1234);
460 inet_aton("255.0.255.255", &enc_addr_in.sin_addr);
461
462 memset(&enc_addr, 0, sizeof(enc_addr));
463 memcpy(&enc_addr, &enc_addr_in, sizeof(enc_addr_in));
464
465 msg = msgb_alloc(1024, "output buffer");
466 rc_enc = gsm0808_enc_aoip_trasp_addr(msg, &enc_addr);
467 OSMO_ASSERT(rc_enc == 8);
468 rc_dec =
469 gsm0808_dec_aoip_trasp_addr(&dec_addr, msg->data + 2, msg->len - 2);
470 OSMO_ASSERT(rc_dec == 6);
471 OSMO_ASSERT(memcmp(&enc_addr, &dec_addr, sizeof(enc_addr)) == 0);
472
473 msgb_free(msg);
474}
475
476static void test_enc_dec_aoip_trasp_addr_v6()
477{
478 struct sockaddr_storage enc_addr;
479 struct sockaddr_storage dec_addr;
480 struct sockaddr_in6 enc_addr_in;
481 struct msgb *msg;
482 uint8_t rc_enc;
483 int rc_dec;
484
485 memset(&enc_addr_in, 0, sizeof(enc_addr_in));
486 enc_addr_in.sin6_family = AF_INET6;
487 enc_addr_in.sin6_port = htons(4567);
488 inet_pton(AF_INET6, "2001:0db8:85a3:08d3:1319:8a2e:0370:7344",
489 &enc_addr_in.sin6_addr);
490
491 memset(&enc_addr, 0, sizeof(enc_addr));
492 memcpy(&enc_addr, &enc_addr_in, sizeof(enc_addr_in));
493
494 msg = msgb_alloc(1024, "output buffer");
495 rc_enc = gsm0808_enc_aoip_trasp_addr(msg, &enc_addr);
496 OSMO_ASSERT(rc_enc == 20);
497 rc_dec =
498 gsm0808_dec_aoip_trasp_addr(&dec_addr, msg->data + 2, msg->len - 2);
499 OSMO_ASSERT(rc_dec == 18);
500 OSMO_ASSERT(memcmp(&enc_addr, &dec_addr, sizeof(enc_addr)) == 0);
501
502 msgb_free(msg);
503}
504
Philipp Maier6f725d62017-03-24 18:03:17 +0100505static void test_gsm0808_enc_dec_speech_codec()
506{
507 struct gsm0808_speech_codec enc_sc;
508 struct gsm0808_speech_codec dec_sc;
509 struct msgb *msg;
510 uint8_t rc_enc;
511 int rc_dec;
512
513 memset(&enc_sc, 0, sizeof(enc_sc));
514 enc_sc.fi = true;
515 enc_sc.pt = true;
516 enc_sc.type = 0x05;
517
518 msg = msgb_alloc(1024, "output buffer");
519 rc_enc = gsm0808_enc_speech_codec(msg, &enc_sc);
520 OSMO_ASSERT(rc_enc == 3);
521
522 rc_dec = gsm0808_dec_speech_codec(&dec_sc, msg->data + 2, msg->len - 2);
523 OSMO_ASSERT(rc_dec == 1);
524
525 OSMO_ASSERT(memcmp(&enc_sc, &dec_sc, sizeof(enc_sc)) == 0);
526
527 msgb_free(msg);
528}
529
530
531static void test_gsm0808_enc_dec_speech_codec_ext_with_cfg()
532{
533 struct gsm0808_speech_codec enc_sc;
534 struct gsm0808_speech_codec dec_sc;
535 struct msgb *msg;
536 uint8_t rc_enc;
537 int rc_dec;
538
539 enc_sc.pi = true;
540 enc_sc.tf = true;
541 enc_sc.type = 0xab;
542 enc_sc.type_extended = true;
543 enc_sc.cfg_present = true;
544 enc_sc.cfg = 0xcdef;
545
546 msg = msgb_alloc(1024, "output buffer");
547 rc_enc = gsm0808_enc_speech_codec(msg, &enc_sc);
548 OSMO_ASSERT(rc_enc == 6);
549
550 rc_dec = gsm0808_dec_speech_codec(&dec_sc, msg->data + 2, msg->len - 2);
551 OSMO_ASSERT(rc_dec == 4);
552
553 OSMO_ASSERT(memcmp(&enc_sc, &dec_sc, sizeof(enc_sc)) == 0);
554
555 msgb_free(msg);
556}
557
558static void test_gsm0808_enc_dec_speech_codec_ext()
559{
560 struct gsm0808_speech_codec enc_sc;
561 struct gsm0808_speech_codec dec_sc;
562 struct msgb *msg;
563 uint8_t rc_enc;
564 int rc_dec;
565
566 enc_sc.fi = true;
567 enc_sc.tf = true;
568 enc_sc.type = 0xf2;
569 enc_sc.type_extended = true;
570 enc_sc.cfg_present = false;
571 enc_sc.cfg = 0x0000;
572
573 msg = msgb_alloc(1024, "output buffer");
574 rc_enc = gsm0808_enc_speech_codec(msg, &enc_sc);
575 OSMO_ASSERT(rc_enc == 4);
576
577 rc_dec = gsm0808_dec_speech_codec(&dec_sc, msg->data + 2, msg->len - 2);
578 OSMO_ASSERT(rc_dec == 2);
579
580 OSMO_ASSERT(memcmp(&enc_sc, &dec_sc, sizeof(enc_sc)) == 0);
581
582 msgb_free(msg);
583}
584
585static void test_gsm0808_enc_dec_speech_codec_list()
586{
587 struct gsm0808_speech_codec_list enc_scl;
588 struct gsm0808_speech_codec_list dec_scl;
589 struct msgb *msg;
590 uint8_t rc_enc;
591 int rc_dec;
592
593 memset(&enc_scl, 0, sizeof(enc_scl));
594
595 enc_scl.codec[0].pi = true;
596 enc_scl.codec[0].tf = true;
597 enc_scl.codec[0].type = 0xab;
598 enc_scl.codec[0].type_extended = true;
599 enc_scl.codec[0].cfg_present = true;
600 enc_scl.codec[0].cfg = 0xcdef;
601
602 enc_scl.codec[1].fi = true;
603 enc_scl.codec[1].pt = true;
604 enc_scl.codec[1].type = 0x05;
605
606 enc_scl.codec[2].fi = true;
607 enc_scl.codec[2].tf = true;
608 enc_scl.codec[2].type = 0xf2;
609 enc_scl.codec[2].type_extended = true;
610
611 enc_scl.len = 3;
612
613 msg = msgb_alloc(1024, "output buffer");
614 rc_enc = gsm0808_enc_speech_codec_list(msg, &enc_scl);
615 OSMO_ASSERT(rc_enc == 9);
616
617 rc_dec = gsm0808_dec_speech_codec_list(&dec_scl, msg->data + 2, msg->len - 2);
618 OSMO_ASSERT(rc_dec == 7);
619
620 OSMO_ASSERT(memcmp(&enc_scl, &dec_scl, sizeof(enc_scl)) == 0);
621
622 msgb_free(msg);
623}
624
Philipp Maiere0c65302017-03-28 17:05:40 +0200625static void test_gsm0808_enc_dec_channel_type()
626{
627 struct gsm0808_channel_type enc_ct;
628 struct gsm0808_channel_type dec_ct;
629 struct msgb *msg;
630 uint8_t ct_enc_expected[] = { GSM0808_IE_CHANNEL_TYPE,
631 0x04, 0x01, 0x0b, 0xa1, 0x25
632 };
633 uint8_t rc_enc;
634 int rc_dec;
635
636 memset(&enc_ct, 0, sizeof(enc_ct));
637 enc_ct.ch_indctr = GSM0808_CHAN_SPEECH;
638 enc_ct.ch_rate_type = GSM0808_SPEECH_HALF_PREF;
639 enc_ct.perm_spch[0] = GSM0808_PERM_FR3;
640 enc_ct.perm_spch[1] = GSM0808_PERM_HR3;
641 enc_ct.perm_spch_len = 2;
642
643 msg = msgb_alloc(1024, "output buffer");
644 rc_enc = gsm0808_enc_channel_type(msg, &enc_ct);
645 OSMO_ASSERT(rc_enc == 6);
646 OSMO_ASSERT(memcmp(ct_enc_expected, msg->data, msg->len) == 0);
647
648 rc_dec = gsm0808_dec_channel_type(&dec_ct, msg->data + 2, msg->len - 2);
649 OSMO_ASSERT(rc_dec == 4);
650 OSMO_ASSERT(memcmp(&enc_ct, &dec_ct, sizeof(enc_ct)) == 0);
651
652 msgb_free(msg);
653}
654
Philipp Maier14e76b92017-03-28 18:36:52 +0200655static void test_gsm0808_enc_dec_encrypt_info()
656{
657 struct gsm0808_encrypt_info enc_ei;
658 struct gsm0808_encrypt_info dec_ei;
659 struct msgb *msg;
660 uint8_t ei_enc_expected[] =
661 { GSM0808_IE_ENCRYPTION_INFORMATION, 0x09, 0x03, 0xaa, 0xbb,
662 0xcc, 0xdd, 0xee, 0xff, 0x23, 0x42
663 };
664 uint8_t rc_enc;
665 int rc_dec;
666
667 memset(&enc_ei, 0, sizeof(enc_ei));
668 enc_ei.perm_algo[0] = GSM0808_ALG_ID_A5_0;
669 enc_ei.perm_algo[1] = GSM0808_ALG_ID_A5_1;
670 enc_ei.perm_algo_len = 2;
671 enc_ei.key[0] = 0xaa;
672 enc_ei.key[1] = 0xbb;
673 enc_ei.key[2] = 0xcc;
674 enc_ei.key[3] = 0xdd;
675 enc_ei.key[4] = 0xee;
676 enc_ei.key[5] = 0xff;
677 enc_ei.key[6] = 0x23;
678 enc_ei.key[7] = 0x42;
679 enc_ei.key_len = 8;
680
681 msg = msgb_alloc(1024, "output buffer");
682 rc_enc = gsm0808_enc_encrypt_info(msg, &enc_ei);
683 OSMO_ASSERT(rc_enc == 11);
684 OSMO_ASSERT(memcmp(ei_enc_expected, msg->data, msg->len) == 0);
685
686 rc_dec = gsm0808_dec_encrypt_info(&dec_ei, msg->data + 2, msg->len - 2);
687 OSMO_ASSERT(rc_dec == 9);
688
689 OSMO_ASSERT(memcmp(&enc_ei, &dec_ei, sizeof(enc_ei)) == 0);
690
691 msgb_free(msg);
692}
693
Philipp Maier783047e2017-03-29 11:35:50 +0200694static void test_gsm0808_enc_dec_cell_id_list_lac()
695{
696 struct gsm0808_cell_id_list enc_cil;
697 struct gsm0808_cell_id_list dec_cil;
698 struct msgb *msg;
699 uint8_t rc_enc;
700 int rc_dec;
701
702 memset(&enc_cil, 0, sizeof(enc_cil));
703 enc_cil.id_discr = CELL_IDENT_LAC;
704 enc_cil.id_list_lac[0] = 0x0124;
705 enc_cil.id_list_lac[1] = 0xABCD;
706 enc_cil.id_list_lac[2] = 0x5678;
707 enc_cil.id_list_len = 3;
708
709 msg = msgb_alloc(1024, "output buffer");
710 rc_enc = gsm0808_enc_cell_id_list(msg, &enc_cil);
711 OSMO_ASSERT(rc_enc == 9);
712
713 rc_dec = gsm0808_dec_cell_id_list(&dec_cil, msg->data + 2,
714 msg->len - 2);
715 OSMO_ASSERT(rc_dec == 7);
716
717 OSMO_ASSERT(memcmp(&enc_cil, &dec_cil, sizeof(enc_cil)) == 0);
718
719 msgb_free(msg);
720}
721
722static void test_gsm0808_enc_dec_cell_id_list_single_lac()
723{
724 struct gsm0808_cell_id_list enc_cil;
725 struct gsm0808_cell_id_list dec_cil;
726 struct msgb *msg;
727 uint8_t cil_enc_expected[] = { GSM0808_IE_CELL_IDENTIFIER_LIST, 0x03,
728 0x05, 0x23, 0x42
729 };
730 uint8_t rc_enc;
731 int rc_dec;
732
733 memset(&enc_cil, 0, sizeof(enc_cil));
734 enc_cil.id_discr = CELL_IDENT_LAC;
735 enc_cil.id_list_lac[0] = 0x2342;
736 enc_cil.id_list_len = 1;
737
738 msg = msgb_alloc(1024, "output buffer");
739 rc_enc = gsm0808_enc_cell_id_list(msg, &enc_cil);
740 OSMO_ASSERT(rc_enc == 5);
741 OSMO_ASSERT(memcmp(cil_enc_expected, msg->data, msg->len) == 0);
742
743 rc_dec = gsm0808_dec_cell_id_list(&dec_cil, msg->data + 2,
744 msg->len - 2);
745 OSMO_ASSERT(rc_dec == 3);
746
747 OSMO_ASSERT(memcmp(&enc_cil, &dec_cil, sizeof(enc_cil)) == 0);
748
749 msgb_free(msg);
750}
751
752static void test_gsm0808_enc_dec_cell_id_list_bss()
753{
754 struct gsm0808_cell_id_list enc_cil;
755 struct gsm0808_cell_id_list dec_cil;
756 struct msgb *msg;
757 uint8_t rc_enc;
758 int rc_dec;
759
760 memset(&enc_cil, 0, sizeof(enc_cil));
761 enc_cil.id_discr = CELL_IDENT_LAC;
762
763 msg = msgb_alloc(1024, "output buffer");
764 rc_enc = gsm0808_enc_cell_id_list(msg, &enc_cil);
765 OSMO_ASSERT(rc_enc == 3);
766
767 rc_dec = gsm0808_dec_cell_id_list(&dec_cil, msg->data + 2,
768 msg->len - 2);
769 OSMO_ASSERT(rc_dec == 1);
770
771 OSMO_ASSERT(memcmp(&enc_cil, &dec_cil, sizeof(enc_cil)) == 0);
772
773 msgb_free(msg);
774}
775
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100776int main(int argc, char **argv)
777{
778 printf("Testing generation of GSM0808 messages\n");
779 test_create_layer3();
Philipp Maierfa896ab2017-03-27 16:55:32 +0200780 test_create_layer3_aoip();
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100781 test_create_reset();
782 test_create_clear_command();
783 test_create_clear_complete();
Philipp Maierb478dd32017-03-29 15:50:05 +0200784 test_create_cipher();
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100785 test_create_cipher_complete();
786 test_create_cipher_reject();
787 test_create_cm_u();
788 test_create_sapi_reject();
789 test_create_ass_compl();
Philipp Maierfa896ab2017-03-27 16:55:32 +0200790 test_create_ass_compl_aoip();
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100791 test_create_ass_fail();
Philipp Maierfa896ab2017-03-27 16:55:32 +0200792 test_create_ass_fail_aoip();
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100793 test_create_clear_rqst();
Philipp Maier3d48ec02017-03-29 17:37:55 +0200794 test_create_paging();
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100795 test_create_dtap();
796 test_prepend_dtap();
Philipp Maier22401432017-03-24 17:59:26 +0100797 test_enc_dec_aoip_trasp_addr_v4();
798 test_enc_dec_aoip_trasp_addr_v6();
Philipp Maier6f725d62017-03-24 18:03:17 +0100799 test_gsm0808_enc_dec_speech_codec();
800 test_gsm0808_enc_dec_speech_codec_ext();
801 test_gsm0808_enc_dec_speech_codec_ext_with_cfg();
802 test_gsm0808_enc_dec_speech_codec_list();
Philipp Maiere0c65302017-03-28 17:05:40 +0200803 test_gsm0808_enc_dec_channel_type();
Philipp Maier14e76b92017-03-28 18:36:52 +0200804 test_gsm0808_enc_dec_encrypt_info();
Philipp Maier783047e2017-03-29 11:35:50 +0200805 test_gsm0808_enc_dec_cell_id_list_lac();
806 test_gsm0808_enc_dec_cell_id_list_single_lac();
807 test_gsm0808_enc_dec_cell_id_list_bss();
Holger Hans Peter Freyther97510812012-01-22 13:36:52 +0100808
809 printf("Done\n");
810 return EXIT_SUCCESS;
811}