FreeCalypso > hg > ice1-trau-tester
annotate abis/dl_frames.c @ 31:cd7448724d74
top Makefile: add abis program subdir
| author | Mychaela Falconia <falcon@freecalypso.org> | 
|---|---|
| date | Tue, 13 Aug 2024 21:44:30 +0000 | 
| parents | 5dd30224b70a | 
| children | f0b026615f3b | 
| 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); | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 48 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 | 49 OSMO_ASSERT(rc == DL_OUTPUT_LEN); | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 50 } | 
| 
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 static void gen_dl_efr(void) | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 53 { | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 54 struct osmo_trau_frame tf; | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 55 struct osmo_trau2rtp_state st; | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 56 int rc; | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 57 | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 58 tf.dir = OSMO_TRAU_DIR_DL; | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 59 st.type = OSMO_TRAU16_FT_EFR; | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 60 rc = osmo_rtp2trau(&tf, efr_dhf_rtp, 31, &st); | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 61 OSMO_ASSERT(rc == 0); | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 62 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 | 63 OSMO_ASSERT(rc == DL_OUTPUT_LEN); | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 64 } | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 65 | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 66 void init_canned_dl_frames(void) | 
| 
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 gen_dl_fr(); | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 69 gen_dl_efr(); | 
| 
5dd30224b70a
abis: starting new program
 Mychaela Falconia <falcon@freecalypso.org> parents: diff
changeset | 70 } | 
