FreeCalypso > hg > gsm-codec-lib
view libgsmfr2/prng.c @ 604:54f0f1b74c25
libgsmhr1 TFO: require BFI=0 and SID=0 for homing
In order for a received frame to be recognized as DHF, we need
not only the correct bit pattern, but also BFI=0 and SID=0.
The BFI=0 requirement should be obvious, while the SID=0 requirement
is needed only for HR codec. With FR and EFR, SID classification
comes from the payload bits and no separate check is needed -
but in HR we get an out-of-band SID ternary flag. When SID=1,
no payload bits are used at all; when SID=2, we use only the first
33 bits of the payload. Therefore, it is proper to conditionalize
DHF acceptance on SID=0.
We already implemented this logic in the just finished full decoder;
now bring TFO code into agreement.
| author | Mychaela Falconia <falcon@freecalypso.org> |
|---|---|
| date | Thu, 04 Dec 2025 19:40:35 +0000 |
| parents | 573afa985df6 |
| children |
line wrap: on
line source
/* * We use a pseudorandom sequence generator function in two places: * when generating comfort noise (GSM 06.12 section 6.1), and when * randomizing grid position parameters as part of speech muting * during error handling (GSM 06.11 section 6). * * Our PRNG is a copy of the pseudonoise() function from ETSI EFR code, * where it is used for similar purposes. */ #include <stdint.h> #include "tw_gsmfr.h" #include "pp_state.h" #include "pp_internal.h" uint16_t gsmfr_preproc_prng(struct gsmfr_preproc_state *st, uint16_t no_bits) { uint16_t noise_bits, Sn, i; noise_bits = 0; for (i = 0; i < no_bits; i++) { /* State n == 31 */ if ((st->cn_random_lfsr & 0x00000001L) != 0) { Sn = 1; } else { Sn = 0; } /* State n == 3 */ if ((st->cn_random_lfsr & 0x10000000L) != 0) { Sn = Sn ^ 1; } else { Sn = Sn ^ 0; } noise_bits = noise_bits << 1; noise_bits = noise_bits | st->cn_random_lfsr & 1; st->cn_random_lfsr >>= 1; if (Sn & 1) { st->cn_random_lfsr |= 0x40000000L; } } return noise_bits; }
