FreeCalypso > hg > gsm-codec-lib
annotate libtest/robewrite.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 | 14b627682458 |
| children |
| rev | line source |
|---|---|
|
11
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
1 /* |
|
153
14b627682458
gsmfr-decode-r utility put together
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
2 * Here we implement our PCM write helper function for "robe" format. |
|
11
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
3 */ |
|
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
4 |
|
153
14b627682458
gsmfr-decode-r utility put together
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
5 #include <stdio.h> |
|
11
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
6 #include <stdint.h> |
|
153
14b627682458
gsmfr-decode-r utility put together
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
7 #include "robewrite.h" |
|
11
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
8 |
|
153
14b627682458
gsmfr-decode-r utility put together
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
9 void write_pcm_to_robe(FILE *outf, const int16_t *pcm) |
|
11
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
10 { |
|
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
11 uint8_t bytes[320], *dp; |
|
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
12 int16_t samp; |
|
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
13 unsigned n; |
|
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
14 |
|
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
15 dp = bytes; |
|
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
16 for (n = 0; n < 160; n++) { |
|
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
17 samp = pcm[n]; |
|
153
14b627682458
gsmfr-decode-r utility put together
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
18 *dp++ = (samp >> 8) & 0xFF; |
|
11
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
19 *dp++ = samp & 0xFF; |
|
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
20 } |
|
153
14b627682458
gsmfr-decode-r utility put together
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
21 fwrite(bytes, 2, 160, outf); |
|
11
a3aa152c4653
libtest: pcmwrite helper function and module
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
22 } |
