FreeCalypso > hg > gsm-codec-lib
annotate libtwamr/dhf_check.c @ 477:4c9222d95647
libtwamr encoder: always emit frame->mode = mode;
In the original implementation of amr_encode_frame(), the 'mode' member
of the output struct was set to 0xFF if the output frame type is TX_NO_DATA.
This design was made to mimic the mode field (16-bit word) being set to
0xFFFF (or -1) in 3GPP test sequence format - but nothing actually depends
on this struct member being set in any way, and amr_frame_to_tseq()
generates the needed 0xFFFF on its own, based on frame->type being equal
to TX_NO_DATA.
It is simpler and more efficient to always set frame->mode to the actual
encoding mode in amr_encode_frame(), and this new behavior has already
been documented in doc/AMR-library-API description in anticipation of
the present change.
| author | Mychaela Falconia <falcon@freecalypso.org> |
|---|---|
| date | Sat, 18 May 2024 22:30:42 +0000 |
| parents | 9beb01439a90 |
| children |
| rev | line source |
|---|---|
|
355
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
1 /* |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
2 * This module implements the DHF checking function. |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
3 */ |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
4 |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
5 #include <stdint.h> |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
6 #include <string.h> |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
7 #include "tw_amr.h" |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
8 #include "typedef.h" |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
9 #include "namespace.h" |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
10 #include "bitno.h" |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
11 |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
12 static const Word16 * const dhf_per_mode[8] = { |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
13 amr_dhf_mr475, |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
14 amr_dhf_mr515, |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
15 amr_dhf_mr59, |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
16 amr_dhf_mr67, |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
17 amr_dhf_mr74, |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
18 amr_dhf_mr795, |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
19 amr_dhf_mr102, |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
20 amr_dhf_mr122 |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
21 }; |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
22 |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
23 int amr_check_dhf(const struct amr_param_frame *frame, int first_sub_only) |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
24 { |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
25 const Word16 *table; |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
26 Word16 nparam; |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
27 |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
28 if (frame->type != RX_SPEECH_GOOD) |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
29 return 0; |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
30 if ((frame->mode & 0x87) == 0x87) |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
31 table = amr_dhf_gsmefr; |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
32 else |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
33 table = dhf_per_mode[frame->mode & 7]; |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
34 if (first_sub_only) |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
35 nparam = prmnofsf[frame->mode & 7]; |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
36 else |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
37 nparam = prmno[frame->mode & 7]; |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
38 if (memcmp(frame->param, table, nparam * sizeof(int16_t))) |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
39 return 0; |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
40 else |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
41 return 1; |
|
9beb01439a90
libtwamr: implement DHF check function
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
42 } |
