view src/cs/layer1/gtt_include/ctm/tonemod.h @ 287:3dee79757ae4

UI fw: load handheld audio mode on boot We have now reached the point where use of audio mode config files should be considered mandatory. In ACI usage we can tell users that they need to perform an AT@AUL of some appropriate audio mode, but in UI-enabled fw we really need to have the firmware load audio modes on its own, so that correct audio config gets established when the handset or development board runs on its own, without a connected host computer. Once have FC Venus with both main and headset audio channels and headset plug insertion detection, our fw will need to automatically load the handheld mode or the headset mode depending on the plug insertion state. For now we load only the handheld mode, which has been tuned for FC-HDS4 on FC Luna.
author Mychaela Falconia <falcon@freecalypso.org>
date Sat, 13 Nov 2021 03:20:57 +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.
*
*      Changes since October 13, 2000:
*      - The type mod_state_t includes a new member txbits_fifo_state now.
*
*******************************************************************************
*
*      File             : tonemod.h
*      Purpose          : header file for tonemod.c
*
*******************************************************************************
*/

#ifndef tonemod_h
#define tonemod_h "$Id: $"

/*
*******************************************************************************
*                         INCLUDE FILES
*******************************************************************************
*/

#include <fifo.h>

/*
*******************************************************************************
*                         DECLARATION OF PROTOTYPES
*******************************************************************************
*/


/* Define a type for the state variable of the function tonemod()     */

typedef struct {
  WORD16      cntModulatedSamples;
  WORD16      actualBits[2];
  fifo_state_t  txbits_fifo_state;
} mod_state_t;


/* ---------------------------------------------------------------------- */
/* Function init_tonemod()                                                */
/* ***********************                                                */
/* This function has to be executed before tonemod() can be used.         */
/* ---------------------------------------------------------------------- */

void init_tonemod(mod_state_t  *mod_state);


/* ---------------------------------------------------------------------- */
/* Function tonemod()                                                     */
/* ******************                                                     */
/* Modulator of the Cellular Text Telephone Modem.                        */
/* The input vector bits_in must contain the bits that have to be         */
/* transmitted. The length of bits_in must be even because always two     */
/* bits are coded in parallel.                                            */
/* Bits are either unipolar (i.e. {0, 1}) or bipolar (i.e. {-1, +1)}.     */
/* The length of the output vector tones_out must be 20 times longer than */
/* the length of bits_in, since each pair of two bits is coded within a   */
/* frame of 40 audio samples.                                             */
/* ---------------------------------------------------------------------- */

void tonemod(WORD16    *tones_out,
             WORD16    *bits_in,
             WORD16     num_samples_tones_out,
             WORD16     num_bits_in,
             mod_state_t *mod_state);

#endif