FreeCalypso > hg > fc-tourmaline
view src/cs/layer1/gtt_include/ctm/diag_interleaver.h @ 275:79cfefc1e2b4
audio mode load: gracefully handle mode files of wrong AEC version
Unfortunately our change of enabling L1_NEW_AEC (which is necessary
in order to bring our Calypso ARM fw into match with the underlying
DSP reality) brings along a change in the audio mode file binary
format and file size - all those new tunable AEC parameters do need
to be stored somewhere, after all. But we already have existing
mode files in the old format, and setting AEC config to garbage when
loading old audio modes (which is what would happen without the
present change) is not an appealing proposition.
The solution implemented in the present change is as follows: the
audio mode loading code checks the file size, and if it differs
from the active version of T_AUDIO_MODE, the T_AUDIO_AEC_CFG structure
is cleared - set to the default (disabled AEC) for the compiled type
of AEC. We got lucky in that this varying T_AUDIO_AEC_CFG structure
sits at the end of T_AUDIO_MODE!
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 30 Jul 2021 02:55:48 +0000 |
parents | 4e78acac3d88 |
children |
line wrap: on
line source
/* ******************************************************************************* * * COPYRIGHT (C) 2000 BY ERICSSON EUROLAB DEUTSCHLAND GmbH * 90411 NUERNBERG, GERMANY, Tel Int + 49 911 5217 100 * * The program(s) may be used and/or copied only with the * written permission from Ericsson or in accordance * with the terms and conditions stipulated in the agreement or * contract under which the program(s) have been supplied. * ******************************************************************************* * * File : diag_interleaver.h * Purpose : diagonal (chain) interleaver routine * ******************************************************************************* */ #ifndef diag_interleaver_h #define diag_interleaver_h "$Id: $" /* ******************************************************************************* * INCLUDE FILES ******************************************************************************* */ #include "init_interleaver.h" /* ******************************************************************************* * DECLARATION OF PROTOTYPES ******************************************************************************* */ /* ---------------------------------------------------------------------- */ /* diag_interleaver: */ /* Diagonal (chain) interleaver, based on block-by-block processing. */ /* An arbitrary number of bits can be interleaved, depending of the */ /* value num_bits. The vector "out", which must have the same */ /* length than "in", contains the interleaved samples. */ /* All states (memory etc.) of the interleaver are stored in the variable */ /* *intl_state. Therefore, a pointer to this variable must be handled to */ /* this function. This variable initially has to be initialized by the */ /* function init_interleaver, which offers also the possibility to */ /* specify the dimensions of the interleaver matrix. */ /* ---------------------------------------------------------------------- */ void diag_interleaver(WORD16 *out, WORD16 *in, WORD16 num_bits, interleaver_state_t *intl_state); /* ---------------------------------------------------------------------- */ /* diag_interleaver_flush: */ /* Execution of the diagonal (chain) interleaver without writing in new */ /* samples. The number of calculated output samples is returned via the */ /* value *num_bits. */ /* ---------------------------------------------------------------------- */ void diag_interleaver_flush(WORD16 *out, WORD16 *num_bits, interleaver_state_t *intl_state); #endif