FreeCalypso > hg > ice1-trau-tester
annotate abis/dl_frames.c @ 36:e4a0b4a61649
top Makefile: add pcm-br
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Wed, 28 Aug 2024 05:02:29 +0000 |
parents | f0b026615f3b |
children |
rev | line source |
---|---|
30
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
1 /* |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
2 * In this module we generate canned TRAU-DL frames for FR and EFR, |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
3 * which will later be transmitted on Abis when individual subslots |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
4 * come alive. |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
5 */ |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
6 |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
7 #include <stdint.h> |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
8 #include <stdbool.h> |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
9 #include <stdio.h> |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
10 #include <stdlib.h> |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
11 #include <string.h> |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
12 |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
13 #include <osmocom/core/bits.h> |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
14 #include <osmocom/core/utils.h> |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
15 #include <osmocom/trau/trau_frame.h> |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
16 #include <osmocom/trau/trau_rtp.h> |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
17 |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
18 #include "dl_frames.h" |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
19 |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
20 ubit_t dl_frame_fr[DL_OUTPUT_BUFLEN]; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
21 ubit_t dl_frame_efr[DL_OUTPUT_BUFLEN]; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
22 |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
23 static const uint8_t gsmfr_silence_frame[33] = { |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
24 0xDA, 0xA7, 0xAA, 0xA5, 0x1A, |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
25 0x50, 0x20, 0x38, 0xE4, 0x6D, 0xB9, 0x1B, |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
26 0x50, 0x20, 0x38, 0xE4, 0x6D, 0xB9, 0x1B, |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
27 0x50, 0x20, 0x38, 0xE4, 0x6D, 0xB9, 0x1B, |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
28 0x50, 0x20, 0x38, 0xE4, 0x6D, 0xB9, 0x1B, |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
29 }; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
30 |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
31 static const uint8_t efr_dhf_rtp[31] = { |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
32 0xC0, 0x85, 0xEB, 0x49, 0x0F, 0xAA, 0xD6, 0x03, |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
33 0xE3, 0xA1, 0x86, 0x07, 0xB0, 0xC4, 0x2C, 0x08, |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
34 0x04, 0x80, 0x55, 0x80, 0x00, 0x00, 0x00, 0x00, |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
35 0x03, 0x6B, 0x00, 0x00, 0x00, 0x00, 0x00 |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
36 }; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
37 |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
38 static void gen_dl_fr(void) |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
39 { |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
40 struct osmo_trau_frame tf; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
41 struct osmo_trau2rtp_state st; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
42 int rc; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
43 |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
44 tf.dir = OSMO_TRAU_DIR_DL; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
45 st.type = OSMO_TRAU16_FT_FR; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
46 rc = osmo_rtp2trau(&tf, gsmfr_silence_frame, 33, &st); |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
47 OSMO_ASSERT(rc == 0); |
34
f0b026615f3b
abis: forgot to clear tf.dl_ta_usec
Mychaela Falconia <falcon@freecalypso.org>
parents:
30
diff
changeset
|
48 tf.dl_ta_usec = 0; |
30
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
49 rc = osmo_trau_frame_encode(dl_frame_fr, DL_OUTPUT_BUFLEN, &tf); |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
50 OSMO_ASSERT(rc == DL_OUTPUT_LEN); |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
51 } |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
52 |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
53 static void gen_dl_efr(void) |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
54 { |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
55 struct osmo_trau_frame tf; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
56 struct osmo_trau2rtp_state st; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
57 int rc; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
58 |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
59 tf.dir = OSMO_TRAU_DIR_DL; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
60 st.type = OSMO_TRAU16_FT_EFR; |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
61 rc = osmo_rtp2trau(&tf, efr_dhf_rtp, 31, &st); |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
62 OSMO_ASSERT(rc == 0); |
34
f0b026615f3b
abis: forgot to clear tf.dl_ta_usec
Mychaela Falconia <falcon@freecalypso.org>
parents:
30
diff
changeset
|
63 tf.dl_ta_usec = 0; |
30
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
64 rc = osmo_trau_frame_encode(dl_frame_efr, DL_OUTPUT_BUFLEN, &tf); |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
65 OSMO_ASSERT(rc == DL_OUTPUT_LEN); |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
66 } |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
67 |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
68 void init_canned_dl_frames(void) |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
69 { |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
70 gen_dl_fr(); |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
71 gen_dl_efr(); |
5dd30224b70a
abis: starting new program
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
72 } |