FreeCalypso > hg > ice1-trau-tester
annotate libhr/paramval_dec.c @ 40:e1eabf554a75
libhr: small subset of WIP libgsmhr1
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 30 Aug 2024 16:41:56 +0000 |
parents | |
children |
rev | line source |
---|---|
40
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
1 /* |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
2 * The function implemented in this module examines a frame of 22 int16_t words |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
3 * that corresponds to GSM-HR decoder input format, and checks if the unused |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
4 * upper bits of each int16_t word are cleared as they should be. |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
5 * This function should be used when reading from ETSI-format *.dec files, |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
6 * to guard against reading garbage or wrong endian. |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
7 */ |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
8 |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
9 #include <stdint.h> |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
10 #include "tw_gsmhr.h" |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
11 |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
12 int gsmhr_check_decoder_params(const int16_t *params) |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
13 { |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
14 if (params[18] < 0 || params[18] > 2) /* BFI */ |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
15 return -1; |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
16 if (params[19] < 0 || params[19] > 1) /* UFI */ |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
17 return -1; |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
18 if (params[20] < 0 || params[20] > 2) /* SID */ |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
19 return -1; |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
20 if (params[21] < 0 || params[21] > 1) /* TAF */ |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
21 return -1; |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
22 return gsmhr_check_common_params(params); |
e1eabf554a75
libhr: small subset of WIP libgsmhr1
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
23 } |