libosmocoding
1.6.0
Osmocom GSM/GPRS/EGPRS L1 channel coding library
|
#include <stdint.h>
#include <osmocom/core/defs.h>
#include <osmocom/core/bits.h>
Go to the source code of this file.
|
enum | gsm0503_amr_dtx_frames {
AMR_OTHER,
AFS_SID_FIRST,
AFS_SID_UPDATE,
AFS_SID_UPDATE_CN,
AFS_ONSET,
AHS_SID_UPDATE,
AHS_SID_UPDATE_CN,
AHS_SID_FIRST_P1,
AHS_SID_FIRST_P2,
AHS_ONSET,
AHS_SID_FIRST_INH,
AHS_SID_UPDATE_INH
} |
|
void gsm0503_xcch_deinterleave(sbit_t *cB, const sbit_t *iB)
De-Interleave burst bits according to TS 05.03 4.1.4.
Definition: gsm0503_interleaving.c:86
static void tch_fr_disassemble(ubit_t *b_bits, const uint8_t *tch_data, int net_order)
Definition: gsm0503_coding.c:1552
#define OSMO_BYTES_FOR_BITS(BITS)
const struct osmo_conv_code gsm0503_mcs5_dl_hdr
@ EGPRS_MCS8
Definition: gsm0503_coding.h:28
void gsm0503_mcs5_dl_burst_map(const ubit_t *di, ubit_t *eB, const ubit_t *hi, const ubit_t *up, int B)
Definition: gsm0503_mapping.c:100
static int egprs_type1_unmap(const sbit_t *bursts, sbit_t *hc, sbit_t *c1, sbit_t *c2, int msc)
Definition: gsm0503_coding.c:723
static int egprs_type3_map(ubit_t *bursts, const ubit_t *hc, const ubit_t *dc, int usf)
Definition: gsm0503_coding.c:1174
const uint8_t gsm0503_tch_hr_interleaving[228][2]
Definition: gsm0503_tables.c:1698
const uint8_t gsm0503_puncture_mcs3_p1[948]
Definition: gsm0503_tables.c:291
void gsm0503_mcs8_ul_deinterleave(sbit_t *hc, sbit_t *c1, sbit_t *c2, const sbit_t *hi, const sbit_t *di)
De-Interleave MCS8 UL burst bits according to TS 05.03 5.1.12.2.4.
Definition: gsm0503_interleaving.c:516
uint8_t hdr_len
Length of header (bits)
Definition: gsm0503_coding.c:158
const struct osmo_conv_code gsm0503_tch_ahs_6_7
const struct osmo_conv_code gsm0503_tch_ahs_7_4
const uint8_t gsm0503_puncture_mcs1_p1[588]
Definition: gsm0503_tables.c:173
const uint8_t gsm0503_puncture_mcs5_p1[1404]
Definition: gsm0503_tables.c:582
static void tch_amr_unmerge(ubit_t *d, ubit_t *p, const ubit_t *u, int len, int prot)
Definition: gsm0503_coding.c:1827
static bool detect_afs_id_marker(int *n_errors, int *n_bits_total, const ubit_t *ubits, uint8_t offset, uint8_t count, const ubit_t *id_marker, uint8_t id_marker_len)
Definition: gsm0503_amr_dtx.c:63
static void tch_efr_reassemble(uint8_t *tch_data, const ubit_t *b_bits)
Definition: gsm0503_coding.c:1601
int gsm0503_sch_encode(ubit_t *burst, const uint8_t *sb_info)
Encode the SCH according to TS 05.03.
Definition: gsm0503_coding.c:3202
const uint8_t gsm0503_puncture_mcs7_dl_hdr[135]
Definition: gsm0503_tables.c:822
static const ubit_t id_marker_0[]
Definition: gsm0503_amr_dtx.c:39
const struct osmo_crc8gen_code gsm0503_mcs_crc8_hdr
EDGE MCS header parity.
Definition: gsm0503_parity.c:65
const uint16_t gsm620_voiced_bitorder[]
static void tch_efr_disassemble(ubit_t *b_bits, const uint8_t *tch_data)
Definition: gsm0503_coding.c:1612
#define EGPRS_DATA_C2
Definition: gsm0503_coding.c:133
static void tch_hr_b_to_d(ubit_t *d_bits, const ubit_t *b_bits)
Definition: gsm0503_coding.c:1707
@ AHS_SID_FIRST_INH
Definition: gsm0503_amr_dtx.h:27
const sbit_t gsm0503_ahs_ic_sbit[4][4]
Definition: gsm0503_tables.c:1691
#define EGPRS_DATA_U_MAX
Definition: gsm0503_coding.c:123
const uint8_t gsm0503_puncture_mcs7_ul_hdr[162]
Definition: gsm0503_tables.c:839
const ubit_t gsm0503_pdtch_edge_hl_hn_ubit[3][8]
Definition: gsm0503_tables.c:47
#define GSM0503_EGPRS_BURSTS_NBITS
Definition: gsm0503_coding.h:17
static int osmo_conv_decode_ber(const struct osmo_conv_code *code, const sbit_t *input, ubit_t *output, int *n_errors, int *n_bits_total)
Convolutional Decode + compute BER for non-punctured codes.
Definition: gsm0503_coding.c:579
const struct osmo_crc8gen_code gsm0503_tch_fr_crc3
GSM TCH FR/HR/EFR parity.
Definition: gsm0503_parity.c:108
static size_t len(const char *str)
const uint8_t gsm0503_puncture_mcs9_p3[1836]
Definition: gsm0503_tables.c:1462
void gsm0503_mcs5_dl_interleave(const ubit_t *hc, const ubit_t *dc, ubit_t *hi, ubit_t *di)
Interleave MCS5 DL burst bits according to TS 05.03 5.1.9.1.5.
Definition: gsm0503_interleaving.c:312
@ AHS_SID_UPDATE_INH
Definition: gsm0503_amr_dtx.h:28
int gsm0503_pdtch_decode(uint8_t *l2_data, const sbit_t *bursts, uint8_t *usf_p, int *n_errors, int *n_bits_total)
Decode GPRS PDTCH.
Definition: gsm0503_coding.c:1022
@ EGPRS_MCS4
Definition: gsm0503_coding.h:24
void gsm0503_xcch_burst_map(const ubit_t *iB, ubit_t *eB, const ubit_t *hl, const ubit_t *hn)
Definition: gsm0503_mapping.c:53
struct gprs_rlc_dl_header_egprs_2 type2
Definition: gsm0503_coding.c:145
static void tch_fr_unreorder(ubit_t *d, ubit_t *p, const ubit_t *u)
Definition: gsm0503_coding.c:1748
int gsm0503_tch_ahs_encode(ubit_t *bursts, const uint8_t *tch_data, int len, int codec_mode_req, uint8_t *codec, int codecs, uint8_t ft, uint8_t cmr)
Perform channel encoding on a TCH/AHS channel according to TS 05.03.
Definition: gsm0503_coding.c:2872
static bool detect_ahs_sid_update(int *n_errors, int *n_bits_total, const ubit_t *ubits)
Definition: gsm0503_amr_dtx.c:203
const struct osmo_conv_code gsm0503_rach
void gsm0503_mcs1_ul_deinterleave(sbit_t *hc, sbit_t *dc, const sbit_t *iB)
Interleave MCS1 UL burst bits according to TS 05.03 5.1.5.2.4.
Definition: gsm0503_interleaving.c:194
const uint8_t gsm0503_puncture_mcs2_p2[732]
Definition: gsm0503_tables.c:263
void gsm0503_tch_fr_interleave(const ubit_t *cB, ubit_t *iB)
GSM TCH FR/EFR/AFS Interleaving and burst mapping.
Definition: gsm0503_interleaving.c:646
const struct osmo_conv_code gsm0503_mcs7_dl_hdr
static bool detect_ahs_sid_first_p1(int *n_errors, int *n_bits_total, const ubit_t *ubits)
Definition: gsm0503_amr_dtx.c:209
const struct osmo_conv_code gsm0503_xcch
uint16_t data_code_len
length of data convolutional code
Definition: gsm0503_coding.c:172
const uint8_t * data_punc[3]
data puncturing sequences
Definition: gsm0503_coding.c:178
int gsm0503_rach_ext_decode(uint16_t *ra, const sbit_t *burst, uint8_t bsic) OSMO_DEPRECATED("Use gsm0503_rach_ext_decode_ber() instead")
Decode the Extended (11-bit) RACH according to 3GPP TS 45.003.
Definition: gsm0503_coding.c:3070
const uint8_t gsm0503_puncture_mcs1_dl_hdr[108]
Definition: gsm0503_tables.c:153
void gsm0503_mcs5_ul_burst_map(const ubit_t *di, ubit_t *eB, const ubit_t *hi, int B)
Definition: gsm0503_mapping.c:142
int gsm0503_rach_ext_decode_ber(uint16_t *ra, const sbit_t *burst, uint8_t bsic, int *n_errors, int *n_bits_total)
Decode the Extended (11-bit) RACH according to 3GPP TS 45.003.
Definition: gsm0503_coding.c:3104
int gsm0503_rach_ext_encode(ubit_t *burst, uint16_t ra, uint8_t bsic, bool is_11bit)
Encode the Extended (11-bit) or regular (8-bit) RACH according to 3GPP TS 45.003.
Definition: gsm0503_coding.c:3151
void gsm0503_mcs5_ul_deinterleave(sbit_t *hc, sbit_t *dc, const sbit_t *hi, const sbit_t *di)
De-Interleave MCS5 UL burst bits according to TS 05.03 5.1.9.2.4.
Definition: gsm0503_interleaving.c:285
union osmo_sub_auth_data::@105 u
#define EGPRS_DATA_C_MAX
Definition: gsm0503_coding.c:126
const struct osmo_conv_code gsm0503_tch_afs_6_7
void gsm0503_mcs1_dl_deinterleave(sbit_t *u, sbit_t *hc, sbit_t *dc, const sbit_t *iB)
De-Interleave MCS1 DL burst bits according to TS 05.03 5.1.5.1.5.
Definition: gsm0503_interleaving.c:116
@ AMR_OTHER
Definition: gsm0503_amr_dtx.h:17
const struct osmo_conv_code gsm0503_mcs1_ul_hdr
void gsm0503_mcs8_ul_interleave(const ubit_t *hc, const ubit_t *c1, const ubit_t *c2, ubit_t *hi, ubit_t *di)
Interleave MCS8 UL burst bits according to TS 05.03 5.1.12.2.4.
Definition: gsm0503_interleaving.c:486
static bool detect_afs_onset(int *n_errors, int *n_bits_total, const ubit_t *ubits)
Definition: gsm0503_amr_dtx.c:179
const struct osmo_crc16gen_code gsm0503_sch_crc10
GSM SCH parity.
Definition: gsm0503_parity.c:97
static int egprs_parse_ul_cps(struct egprs_cps *cps, union gprs_rlc_ul_hdr_egprs *hdr, int type)
Definition: gsm0503_coding.c:837
void gsm0503_tch_hr_deinterleave(sbit_t *cB, const sbit_t *iB)
GSM TCH HR/AHS De-Interleaving and burst mapping.
Definition: gsm0503_interleaving.c:660
static bool detect_ahs_sid_first_inh(int *n_errors, int *n_bits_total, const ubit_t *ubits)
Definition: gsm0503_amr_dtx.c:263
const struct osmo_conv_code gsm0503_tch_afs_4_75
const uint8_t gsm0503_puncture_mcs8_p2[1692]
Definition: gsm0503_tables.c:1152
@ EGPRS_MCS7
Definition: gsm0503_coding.h:27
const struct osmo_conv_code gsm0503_sch
int osmo_conv_encode(const struct osmo_conv_code *code, const ubit_t *input, ubit_t *output)
uint16_t data_len
length of data (bits)
Definition: gsm0503_coding.c:170
const uint8_t gsm0503_puncture_mcs3_p3[948]
Definition: gsm0503_tables.c:403
struct gprs_rlc_dl_header_egprs_3 type3
Definition: gsm0503_coding.c:146
void gsm0503_mcs7_ul_burst_map(const ubit_t *di, ubit_t *eB, const ubit_t *hi, int B)
Definition: gsm0503_mapping.c:216
const ubit_t gsm0503_mcs5_usf_precode_table[8][36]
Definition: gsm0503_tables.c:1742
const uint8_t gsm0503_puncture_mcs4_p3[1116]
Definition: gsm0503_tables.c:541
@ AFS_SID_FIRST
Definition: gsm0503_amr_dtx.h:18
const uint8_t gsm0503_puncture_mcs9_p1[1836]
Definition: gsm0503_tables.c:1252
const struct osmo_conv_code gsm0503_tch_afs_5_15
#define GSM0503_GPRS_BURSTS_NBITS
Definition: gsm0503_coding.h:16
const uint8_t gsm0503_puncture_mcs5_p2[1404]
Definition: gsm0503_tables.c:637
const uint16_t gsm0503_interleave_mcs5[1248]
Definition: gsm0503_tables.c:1567
#define EGPRS_HDR_UPP_MAX
Definition: gsm0503_coding.c:114
const uint8_t gsm0503_puncture_mcs3_p2[948]
Definition: gsm0503_tables.c:347
const uint8_t gsm0503_puncture_cs3[676]
Definition: gsm0503_tables.c:127
static void tch_efr_reorder(ubit_t *w, const ubit_t *s, const ubit_t *p)
Definition: gsm0503_coding.c:1786
static int _xcch_encode_cB(ubit_t *cB, const uint8_t *l2_data)
convenience wrapper for encoding to coded bits
Definition: gsm0503_coding.c:616
void gsm0503_tch_fr_deinterleave(sbit_t *cB, const sbit_t *iB)
GSM TCH FR/EFR/AFS De-Interleaving and burst mapping.
Definition: gsm0503_interleaving.c:632
const uint8_t gsm0503_puncture_mcs8_p3[1692]
Definition: gsm0503_tables.c:1202
int gsm0503_tch_hr_decode(uint8_t *tch_data, const sbit_t *bursts, int odd, int *n_errors, int *n_bits_total)
Perform channel decoding of a HR(v1) channel according TS 05.03.
Definition: gsm0503_coding.c:1991
const uint8_t gsm0503_gsm_efr_protected_bits[65]
Definition: gsm0503_tables.c:1659
void gsm0503_mcs5_dl_burst_unmap(sbit_t *di, const sbit_t *eB, sbit_t *hi, sbit_t *up, int B)
Definition: gsm0503_mapping.c:122
@ EGPRS_MCS2
Definition: gsm0503_coding.h:22
#define EGPRS_HDR_C_MAX
Definition: gsm0503_coding.c:117
uint16_t data_punc_len
length of data code puncturing sequence
Definition: gsm0503_coding.c:174
@ EGPRS_MCS6
Definition: gsm0503_coding.h:26
static int egprs_decode_hdr(union gprs_rlc_ul_hdr_egprs *hdr, const sbit_t *bursts, uint16_t nbits)
Definition: gsm0503_coding.c:801
const ubit_t gsm0503_ahs_ic_ubit[4][4]
Definition: gsm0503_tables.c:1684
const struct osmo_conv_code gsm0503_mcs9
const uint8_t gsm0503_puncture_mcs6_p2[1836]
Definition: gsm0503_tables.c:757
static int egprs_encode_data(ubit_t *c, const uint8_t *l2_data, int mcs, int p, int blk)
Definition: gsm0503_coding.c:1265
const uint8_t gsm0503_puncture_mcs6_p1[1836]
Definition: gsm0503_tables.c:692
union across the three different EGPRS Downlink header types
Definition: gsm0503_coding.c:143
@ AHS_SID_FIRST_P1
Definition: gsm0503_amr_dtx.h:24
const struct osmo_conv_code gsm0503_tch_afs_12_2
const struct osmo_conv_code gsm0503_tch_hr
int gsm0503_sch_decode(uint8_t *sb_info, const sbit_t *burst)
Decode the SCH according to TS 05.03.
Definition: gsm0503_coding.c:3182
const sbit_t gsm0503_usf2twelve_sbit[8][12]
Definition: gsm0503_tables.c:94
uint8_t usf_len
Length of Uplink Stealing Flag (USF) in bits.
Definition: gsm0503_coding.c:154
void osmo_crc8gen_set_bits(const struct osmo_crc8gen_code *code, const ubit_t *in, int len, ubit_t *crc_bits)
static void tch_efr_w_to_d(ubit_t *d_bits, const ubit_t *b_bits)
Definition: gsm0503_coding.c:1731
static void extract_afs_sid_update(sbit_t *sid_update, const sbit_t *sbits)
Definition: gsm0503_coding.c:1654
const struct osmo_conv_code gsm0503_tch_axs_sid_update
const struct osmo_crc8gen_code gsm0503_rach_crc6
GSM RACH parity.
Definition: gsm0503_parity.c:86
static void tch_hr_reorder(ubit_t *u, const ubit_t *d, const ubit_t *p)
Definition: gsm0503_coding.c:1780
int gsm0503_pdtch_encode(ubit_t *bursts, const uint8_t *l2_data, uint8_t l2_len)
GPRS DL message encoding.
Definition: gsm0503_coding.c:1432
void gsm0503_xcch_interleave(const ubit_t *cB, ubit_t *iB)
Interleave burst bits according to TS 05.03 4.1.4.
Definition: gsm0503_interleaving.c:100
Structure describing a Modulation and Coding Scheme.
Definition: gsm0503_coding.c:150
struct gprs_rlc_ul_header_egprs_3 type3
Definition: gsm0503_coding.c:139
static void tch_amr_reassemble(uint8_t *tch_data, const ubit_t *d_bits, int len)
Definition: gsm0503_coding.c:1621
@ AHS_SID_FIRST_P2
Definition: gsm0503_amr_dtx.h:25
const struct osmo_conv_code gsm0503_mcs1
static int egprs_type1_map(ubit_t *bursts, const ubit_t *hc, const ubit_t *c1, const ubit_t *c2, int usf, int mcs)
Definition: gsm0503_coding.c:1208
const struct osmo_conv_code gsm0503_mcs7_ul_hdr
void gsm0503_mcs5_burst_swap(sbit_t *eB)
Definition: gsm0503_mapping.c:250
static void tch_efr_protected(const ubit_t *s_bits, ubit_t *b_bits)
Definition: gsm0503_coding.c:1740
const struct osmo_conv_code gsm0503_cs2_np
static void tch_amr_merge(ubit_t *u, const ubit_t *d, const ubit_t *p, int len, int prot)
Definition: gsm0503_coding.c:1820
struct gprs_rlc_dl_header_egprs_1 type1
Definition: gsm0503_coding.c:144
static void tch_fr_reassemble(uint8_t *tch_data, const ubit_t *b_bits, int net_order)
assemble a FR codec frame in format as used inside RTP
Definition: gsm0503_coding.c:1520
gsm0503_amr_dtx_frames
Definition: gsm0503_amr_dtx.h:16
static int osmo_conv_decode_ber_punctured(const struct osmo_conv_code *code, const sbit_t *input, ubit_t *output, int *n_errors, int *n_bits_total, const uint8_t *data_punc)
Convolutional Decode + compute BER for punctured codes.
Definition: gsm0503_coding.c:540
const uint8_t gsm0503_puncture_mcs4_p1[1116]
Definition: gsm0503_tables.c:459
static void rach_apply_bsic(ubit_t *d, uint8_t bsic, uint8_t start)
Definition: gsm0503_coding.c:3035
int gsm0503_tch_fr_encode(ubit_t *bursts, const uint8_t *tch_data, int len, int net_order)
Perform channel encoding on a TCH/FS channel according to TS 05.03.
Definition: gsm0503_coding.c:1926
const struct osmo_conv_code gsm0503_tch_fr
static int _xcch_decode_cB(uint8_t *l2_data, const sbit_t *cB, int *n_errors, int *n_bits_total)
convenience wrapper for decoding coded bits
Definition: gsm0503_coding.c:593
enum gsm0503_amr_dtx_frames gsm0503_detect_ahs_dtx_frame(int *n_errors, int *n_bits_total, const ubit_t *ubits)
Detect HR AMR DTX frame in unmapped, deinterleaved frame bits.
Definition: gsm0503_amr_dtx.c:298
const struct osmo_conv_code gsm0503_tch_afs_7_4
void gsm0503_mcs7_dl_interleave(const ubit_t *hc, const ubit_t *c1, const ubit_t *c2, ubit_t *hi, ubit_t *di)
Interleave MCS7 DL burst bits according to TS 05.03 5.1.11.1.5.
Definition: gsm0503_interleaving.c:362
const struct osmo_conv_code * data_conv
data convolutional code
Definition: gsm0503_coding.c:176
const struct osmo_crc8gen_code gsm0503_amr_crc6
GSM AMR parity.
Definition: gsm0503_parity.c:130
const struct osmo_crc8gen_code gsm0503_tch_efr_crc8
GSM TCH EFR parity.
Definition: gsm0503_parity.c:119
@ AHS_ONSET
Definition: gsm0503_amr_dtx.h:26
void osmo_sbit2ubit(ubit_t *out, const sbit_t *in, unsigned int num_bits)
int gsm0503_pdtch_egprs_decode(uint8_t *l2_data, const sbit_t *bursts, uint16_t nbits, uint8_t *usf_p, int *n_errors, int *n_bits_total)
Decode EGPRS UL message.
Definition: gsm0503_coding.c:933
const struct gsm0503_mcs_code gsm0503_mcs_dl_codes[EGPRS_NUM_MCS]
Definition: gsm0503_coding.c:355
struct gprs_rlc_ul_header_egprs_2 type2
Definition: gsm0503_coding.c:138
const struct osmo_conv_code gsm0503_tch_ahs_5_15
const ubit_t gsm0503_afs_ic_ubit[4][8]
Definition: gsm0503_tables.c:1670
static int egprs_type2_map(ubit_t *bursts, const ubit_t *hc, const ubit_t *dc, int usf)
Definition: gsm0503_coding.c:1190
static bool detect_ahs_sid_update_inh(int *n_errors, int *n_bits_total, const ubit_t *ubits)
Definition: gsm0503_amr_dtx.c:269
int osmo_crc8gen_check_bits(const struct osmo_crc8gen_code *code, const ubit_t *in, int len, const ubit_t *crc_bits)
const struct osmo_conv_code gsm0503_mcs4
struct abis_rsl_common_hdr c
static const ubit_t id_marker_1[]
Definition: gsm0503_amr_dtx.c:36
int osmo_conv_decode(const struct osmo_conv_code *code, const sbit_t *input, ubit_t *output)
int gsm48_generate_mid_from_tmsi *(uint8_t *buf, uint32_t tmsi) OSMO_DEPRECATED_OUTSIDE("Instead u l))
int gsm0503_tch_ahs_decode_dtx(uint8_t *tch_data, const sbit_t *bursts, int odd, int codec_mode_req, uint8_t *codec, int codecs, uint8_t *ft, uint8_t *cmr, int *n_errors, int *n_bits_total, uint8_t *dtx)
Perform channel decoding of a TCH/AFS channel according TS 05.03.
Definition: gsm0503_coding.c:2609
const uint8_t gsm0503_puncture_mcs2_p1[732]
Definition: gsm0503_tables.c:235
int gsm0503_xcch_decode(uint8_t *l2_data, const sbit_t *bursts, int *n_errors, int *n_bits_total)
Decoding of xCCH data from bursts to L2 frame.
Definition: gsm0503_coding.c:639
const uint8_t gsm0503_puncture_mcs1_p2[588]
Definition: gsm0503_tables.c:204
static void tch_efr_unreorder(ubit_t *s, ubit_t *p, const ubit_t *w)
Definition: gsm0503_coding.c:1800
const struct osmo_conv_code gsm0503_cs3_np
int egprs_get_cps(struct egprs_cps *cps, uint8_t type, uint8_t bits)
@ EGPRS_MCS9
Definition: gsm0503_coding.h:29
static void tch_hr_d_to_b(ubit_t *b_bits, const ubit_t *d_bits)
Definition: gsm0503_coding.c:1691
int gsm0503_pdtch_egprs_encode(ubit_t *bursts, const uint8_t *l2_data, uint8_t l2_len)
EGPRS DL message encoding.
Definition: gsm0503_coding.c:1337
void gsm0503_mcs5_ul_burst_unmap(sbit_t *di, const sbit_t *eB, sbit_t *hi, int B)
Definition: gsm0503_mapping.c:159
const struct osmo_conv_code gsm0503_rach_ext
enum gsm0503_amr_dtx_frames gsm0503_detect_afs_dtx_frame(int *n_errors, int *n_bits_total, const ubit_t *ubits)
Detect FR AMR DTX frame in unmapped, deinterleaved frame bits.
Definition: gsm0503_amr_dtx.c:279
static bool detect_ahs_sid_first_p2(int *n_errors, int *n_bits_total, const ubit_t *ubits)
Definition: gsm0503_amr_dtx.c:215
void gsm0503_tch_burst_unmap(sbit_t *iB, const sbit_t *eB, sbit_t *h, int odd)
Definition: gsm0503_mapping.c:65
void gsm0503_tch_burst_map(const ubit_t *iB, ubit_t *eB, const ubit_t *h, int odd)
Definition: gsm0503_mapping.c:85
void gsm0503_mcs1_ul_interleave(const ubit_t *hc, const ubit_t *dc, ubit_t *iB)
Interleave MCS1 DL burst bits according to TS 05.03 5.1.5.2.4.
Definition: gsm0503_interleaving.c:228
const ubit_t gsm0503_usf2twelve_ubit[8][12]
Definition: gsm0503_tables.c:83
const struct osmo_conv_code gsm0503_mcs7
const struct osmo_conv_code gsm0503_mcs1_dl_hdr
void gsm0503_mcs7_ul_deinterleave(sbit_t *hc, sbit_t *c1, sbit_t *c2, const sbit_t *hi, const sbit_t *di)
De-Interleave MCS7 UL burst bits according to TS 05.03 5.1.11.2.4.
Definition: gsm0503_interleaving.c:453
static void tch_amr_sid_update_append(ubit_t *sid_update, uint8_t sti, uint8_t mi)
Definition: gsm0503_coding.c:1641
int gsm0503_rach_decode_ber(uint8_t *ra, const sbit_t *burst, uint8_t bsic, int *n_errors, int *n_bits_total)
Decode the (8-bit) RACH according to TS 05.03.
Definition: gsm0503_coding.c:3122
const uint8_t gsm0503_puncture_mcs9_p2[1836]
Definition: gsm0503_tables.c:1357
const struct osmo_conv_code gsm0503_tch_afs_7_95
int gsm0503_tch_afs_decode_dtx(uint8_t *tch_data, const sbit_t *bursts, int codec_mode_req, uint8_t *codec, int codecs, uint8_t *ft, uint8_t *cmr, int *n_errors, int *n_bits_total, uint8_t *dtx)
Perform channel decoding of a TCH/AFS channel according TS 05.03.
Definition: gsm0503_coding.c:2157
const uint16_t gsm610_bitorder[]
const uint8_t gsm0503_puncture_mcs8_p1[1692]
Definition: gsm0503_tables.c:1102
const struct osmo_crc16gen_code gsm0503_mcs_crc12
EDGE MCS data parity.
Definition: gsm0503_parity.c:75
@ AHS_SID_UPDATE
Definition: gsm0503_amr_dtx.h:22
const uint8_t * hdr_punc
header puncturing sequence
Definition: gsm0503_coding.c:166
const sbit_t gsm0503_afs_ic_sbit[4][8]
Definition: gsm0503_tables.c:1677
@ AHS_SID_UPDATE_CN
Definition: gsm0503_amr_dtx.h:23
static void tch_fr_reorder(ubit_t *u, const ubit_t *d, const ubit_t *p)
Definition: gsm0503_coding.c:1761
const struct osmo_conv_code gsm0503_tch_afs_5_9
@ EGPRS_MCS1
Definition: gsm0503_coding.h:21
static int egprs_type2_unmap(const sbit_t *bursts, sbit_t *hc, sbit_t *dc)
Definition: gsm0503_coding.c:700
const struct osmo_conv_code * hdr_conv
header convolutional code
Definition: gsm0503_coding.c:164
static const ubit_t codec_mode_4_sid[]
Definition: gsm0503_amr_dtx.c:45
#define EGPRS_DATA_C1
Definition: gsm0503_coding.c:132
const struct value_string gsm0503_amr_dtx_frame_names[]
Definition: gsm0503_amr_dtx.c:47
static void tch_hr_unreorder(ubit_t *d, ubit_t *p, const ubit_t *u)
Definition: gsm0503_coding.c:1774
static void tch_fr_b_to_d(ubit_t *d_bits, const ubit_t *b_bits)
Definition: gsm0503_coding.c:1682
const uint8_t gsm0503_gsm_fr_map[76]
Definition: gsm0503_tables.c:1650
const struct osmo_crc64gen_code gsm0503_fire_crc40
GSM (SACCH) parity (FIRE code)
Definition: gsm0503_parity.c:44
static int egprs_decode_data(uint8_t *l2_data, const sbit_t *c, int mcs, int p, int blk, int *n_errors, int *n_bits_total)
Definition: gsm0503_coding.c:867
const uint8_t gsm0503_puncture_mcs4_p2[1116]
Definition: gsm0503_tables.c:500
static int egprs_parse_dl_cps(struct egprs_cps *cps, const union gprs_rlc_dl_hdr_egprs *hdr, int type)
Definition: gsm0503_coding.c:1310
const struct osmo_conv_code gsm0503_mcs3
void gsm0503_mcs7_ul_interleave(const ubit_t *hc, const ubit_t *c1, const ubit_t *c2, ubit_t *hi, ubit_t *di)
Interleave MCS7 UL burst bits according to TS 05.03 5.1.11.2.4.
Definition: gsm0503_interleaving.c:424
enum osmo_sub_auth_type type
const struct osmo_conv_code gsm0503_tch_ahs_5_9
static void tch_efr_d_to_w(ubit_t *b_bits, const ubit_t *d_bits)
Definition: gsm0503_coding.c:1722
@ EGPRS_MCS5
Definition: gsm0503_coding.h:25
int gsm0503_xcch_encode(ubit_t *bursts, const uint8_t *l2_data)
Encoding of xCCH data from L2 frame to bursts.
Definition: gsm0503_coding.c:658
const uint8_t gsm0503_puncture_mcs7_p1[1404]
Definition: gsm0503_tables.c:859
static void tch_hr_disassemble(ubit_t *b_bits, const uint8_t *tch_data)
Definition: gsm0503_coding.c:1592
int gsm0503_tch_afs_decode(uint8_t *tch_data, const sbit_t *bursts, int codec_mode_req, uint8_t *codec, int codecs, uint8_t *ft, uint8_t *cmr, int *n_errors, int *n_bits_total)
Perform channel decoding of a TCH/AFS channel according TS 05.03.
Definition: gsm0503_coding.c:2134
@ AFS_ONSET
Definition: gsm0503_amr_dtx.h:21
const struct osmo_crc16gen_code gsm0503_cs234_crc16
GSM PDTCH CS-2, CS-3, CS-4 parity.
Definition: gsm0503_parity.c:55
static int egprs_type3_unmap(const sbit_t *bursts, sbit_t *hc, sbit_t *dc)
Definition: gsm0503_coding.c:681
uint8_t hdr_code_len
Length of header convolutional code.
Definition: gsm0503_coding.c:160
const ubit_t gsm0503_pdtch_hl_hn_ubit[4][8]
Definition: gsm0503_tables.c:40
const struct osmo_conv_code gsm0503_mcs8
static bool detect_interleaved_ahs_id_marker(int *n_errors, int *n_bits_total, const ubit_t *ubits, uint8_t offset, uint8_t n_bits, const ubit_t *id_marker, uint8_t id_marker_len)
Definition: gsm0503_amr_dtx.c:129
const struct osmo_conv_code gsm0503_mcs6
void gsm0503_mcs8_dl_deinterleave(sbit_t *hc, sbit_t *c1, sbit_t *c2, const sbit_t *hi, const sbit_t *di)
De-Interleave MCS8 DL burst bits according to TS 05.03 5.1.12.1.5.
Definition: gsm0503_interleaving.c:578
static void tch_hr_reassemble(uint8_t *tch_data, const ubit_t *b_bits)
Definition: gsm0503_coding.c:1581
void gsm0503_mcs8_dl_interleave(const ubit_t *hc, const ubit_t *c1, const ubit_t *c2, ubit_t *hi, ubit_t *di)
Interleave MCS8 DL burst bits according to TS 05.03 5.1.12.1.5.
Definition: gsm0503_interleaving.c:549
const sbit_t gsm0503_pdtch_edge_hl_hn_sbit[3][8]
Definition: gsm0503_tables.c:60
void gsm0503_mcs7_dl_burst_unmap(sbit_t *di, const sbit_t *eB, sbit_t *hi, sbit_t *up, int B)
Definition: gsm0503_mapping.c:196
static bool detect_afs_sid_update(int *n_errors, int *n_bits_total, const ubit_t *ubits)
Definition: gsm0503_amr_dtx.c:173
const uint16_t gsm660_bitorder[]
static const ubit_t codec_mode_2_sid[]
Definition: gsm0503_amr_dtx.c:43
const struct osmo_conv_code gsm0503_mcs5
void gsm0503_mcs7_ul_burst_unmap(sbit_t *di, const sbit_t *eB, sbit_t *hi, int B)
Definition: gsm0503_mapping.c:234
static void tch_fr_d_to_b(ubit_t *b_bits, const ubit_t *d_bits)
Definition: gsm0503_coding.c:1673
const uint16_t gsm620_unvoiced_bitorder[]
const sbit_t gsm0503_pdtch_hl_hn_sbit[4][8]
Definition: gsm0503_tables.c:53
static bool detect_ahs_onset(int *n_errors, int *n_bits_total, const ubit_t *ubits)
Definition: gsm0503_amr_dtx.c:239
void gsm0503_mcs1_dl_interleave(const ubit_t *up, const ubit_t *hc, const ubit_t *dc, ubit_t *iB)
Interleave MCS1 DL burst bits according to TS 05.03 5.1.5.1.5.
Definition: gsm0503_interleaving.c:157
const struct osmo_conv_code gsm0503_tch_afs_10_2
static int _egprs_decode_hdr(const sbit_t *hc, int mcs, union gprs_rlc_ul_hdr_egprs *hdr)
Definition: gsm0503_coding.c:753
static int16_t rach_decode_ber(const sbit_t *burst, uint8_t bsic, bool is_11bit, int *n_errors, int *n_bits_total)
Definition: gsm0503_coding.c:3044
void gsm0503_mcs7_dl_burst_map(const ubit_t *di, ubit_t *eB, const ubit_t *hi, const ubit_t *up, int B)
Definition: gsm0503_mapping.c:174
int gsm0503_rach_decode(uint8_t *ra, const sbit_t *burst, uint8_t bsic) OSMO_DEPRECATED("Use gsm0503_rach_decode_ber() instead")
Decode the (8-bit) RACH according to TS 05.03.
Definition: gsm0503_coding.c:3087
uint8_t k[OSMO_A5_MAX_KEY_LEN_BYTES]
@ EGPRS_MCS0
Definition: gsm0503_coding.h:20
int gsm0503_tch_afs_encode(ubit_t *bursts, const uint8_t *tch_data, int len, int codec_mode_req, uint8_t *codec, int codecs, uint8_t ft, uint8_t cmr)
Perform channel encoding on a TCH/AFS channel according to TS 05.03.
Definition: gsm0503_coding.c:2411
const uint8_t gsm0503_puncture_mcs7_p2[1404]
Definition: gsm0503_tables.c:940
@ AFS_SID_UPDATE_CN
Definition: gsm0503_amr_dtx.h:20
int osmo_pbit2ubit_ext(ubit_t *out, unsigned int out_ofs, const pbit_t *in, unsigned int in_ofs, unsigned int num_bits, int lsb_mode)
static int egprs_encode_hdr(ubit_t *hc, const uint8_t *l2_data, int mcs)
Definition: gsm0503_coding.c:1231
const uint8_t gsm0503_puncture_mcs7_p3[1404]
Definition: gsm0503_tables.c:1021
#define EGPRS_HDR_HC_MAX
Definition: gsm0503_coding.c:120
const uint8_t gsm0503_puncture_cs2[588]
Definition: gsm0503_tables.c:105
int gsm0503_rach_encode(ubit_t *burst, const uint8_t *ra, uint8_t bsic) OSMO_DEPRECATED("Use gsm0503_rach_ext_encode() instead")
Encode the (8-bit) RACH according to TS 05.03.
Definition: gsm0503_coding.c:3140
int osmo_ubit2pbit_ext(pbit_t *out, unsigned int out_ofs, const ubit_t *in, unsigned int in_ofs, unsigned int num_bits, int lsb_mode)
void osmo_crc64gen_set_bits(const struct osmo_crc64gen_code *code, const ubit_t *in, int len, ubit_t *crc_bits)
void gsm0503_tch_hr_interleave(const ubit_t *cB, ubit_t *iB)
GSM TCH HR/AHS Interleaving and burst mapping.
Definition: gsm0503_interleaving.c:674
const struct osmo_conv_code gsm0503_tch_ahs_7_95
void osmo_crc16gen_set_bits(const struct osmo_crc16gen_code *code, const ubit_t *in, int len, ubit_t *crc_bits)
static bool detect_afs_sid_first(int *n_errors, int *n_bits_total, const ubit_t *ubits)
Definition: gsm0503_amr_dtx.c:167
void gsm0503_mcs5_ul_interleave(const ubit_t *hc, const ubit_t *dc, ubit_t *hi, ubit_t *di)
Interleave MCS5 UL burst bits according to TS 05.03 5.1.9.2.4.
Definition: gsm0503_interleaving.c:263
union across the three different EGPRS Uplink header types
Definition: gsm0503_coding.c:136
#define EGPRS_DATA_DC_MAX
Definition: gsm0503_coding.c:129
void gsm0503_mcs7_dl_deinterleave(sbit_t *hc, sbit_t *c1, sbit_t *c2, const sbit_t *hi, const sbit_t *di)
De-Interleave MCS7 DL burst bits according to TS 05.03 5.1.11.1.5.
Definition: gsm0503_interleaving.c:391
const struct osmo_conv_code gsm0503_tch_ahs_4_75
const uint8_t gsm0503_puncture_mcs1_ul_hdr[117]
Definition: gsm0503_tables.c:160
const struct gsm0503_mcs_code gsm0503_mcs_ul_codes[EGPRS_NUM_MCS]
Definition: gsm0503_coding.c:184
const ubit_t gsm0503_usf2six[8][6]
Definition: gsm0503_tables.c:69
@ EGPRS_MCS3
Definition: gsm0503_coding.h:23
const struct osmo_crc16gen_code gsm0503_amr_crc14
GSM AMR parity (SID_UPDATE)
Definition: gsm0503_parity.c:141
uint8_t hdr_punc_len
Length of header code puncturing sequence.
Definition: gsm0503_coding.c:162
int osmo_crc64gen_check_bits(const struct osmo_crc64gen_code *code, const ubit_t *in, int len, const ubit_t *crc_bits)
int gsm0503_tch_fr_decode(uint8_t *tch_data, const sbit_t *bursts, int net_order, int efr, int *n_errors, int *n_bits_total)
Perform channel decoding of a FR/EFR channel according TS 05.03.
Definition: gsm0503_coding.c:1842
const struct osmo_conv_code gsm0503_mcs5_ul_hdr
int gsm0503_tch_ahs_decode(uint8_t *tch_data, const sbit_t *bursts, int odd, int codec_mode_req, uint8_t *codec, int codecs, uint8_t *ft, uint8_t *cmr, int *n_errors, int *n_bits_total)
Perform channel decoding of a TCH/AFS channel according TS 05.03.
Definition: gsm0503_coding.c:2585
static const ubit_t codec_mode_3_sid[]
Definition: gsm0503_amr_dtx.c:44
struct gprs_rlc_ul_header_egprs_1 type1
Definition: gsm0503_coding.c:137
@ AFS_SID_UPDATE
Definition: gsm0503_amr_dtx.h:19
const struct osmo_conv_code gsm0503_mcs2
static bool detect_ahs_id_marker(int *n_errors, int *n_bits_total, const ubit_t *ubits, const ubit_t *id_marker)
Definition: gsm0503_amr_dtx.c:95
uint8_t mcs
Modulation and Coding Scheme (MSC) number.
Definition: gsm0503_coding.c:152
void gsm0503_xcch_burst_unmap(sbit_t *iB, const sbit_t *eB, sbit_t *hl, sbit_t *hn)
Definition: gsm0503_mapping.c:40
static void tch_amr_disassemble(ubit_t *d_bits, const uint8_t *tch_data, int len)
Definition: gsm0503_coding.c:1631
void gsm0503_mcs5_dl_deinterleave(sbit_t *hc, sbit_t *dc, const sbit_t *hi, const sbit_t *di)
De-Interleave MCS5 UL burst bits according to TS 05.03 5.1.9.1.5.
Definition: gsm0503_interleaving.c:334
static const ubit_t codec_mode_1_sid[]
Definition: gsm0503_amr_dtx.c:42
int osmo_crc16gen_check_bits(const struct osmo_crc16gen_code *code, const ubit_t *in, int len, const ubit_t *crc_bits)
int gsm0503_tch_hr_encode(ubit_t *bursts, const uint8_t *tch_data, int len)
Perform channel encoding on a TCH/HS channel according to TS 05.03.
Definition: gsm0503_coding.c:2066
@ EGPRS_NUM_MCS
Definition: gsm0503_coding.h:30