FreeCalypso > hg > tcs211-l1-reconst
changeset 267:8d577190e377
l1audio_sync.c: passes compilation
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 13 Mar 2017 04:48:37 +0000 (2017-03-13) |
parents | 35e8e0637eba |
children | 67b777cee725 |
files | chipsetsw/layer1/audio_cfile/l1audio_sync.c |
diffstat | 1 files changed, 55 insertions(+), 190 deletions(-) [+] |
line wrap: on
line diff
--- a/chipsetsw/layer1/audio_cfile/l1audio_sync.c Mon Mar 13 04:10:04 2017 +0000 +++ b/chipsetsw/layer1/audio_cfile/l1audio_sync.c Mon Mar 13 04:48:37 2017 +0000 @@ -159,12 +159,14 @@ #include "l1audio_macro.h" #include "l1_trace.h" - #if (CODE_VERSION != SIMULATION) + +#if (CHIPSET == 15) && (CODE_VERSION != SIMULATION) #include "bspTwl3029.h" #include "bspTwl3029_I2c.h" #include "bspTwl3029_Aud_Map.h" #include "bspTwl3029_Int_Map.h" #endif + /**************************************/ /* Prototypes for L1 SYNCH manager */ /**************************************/ @@ -202,10 +204,10 @@ void l1s_sr_processing_manager(void); void l1s_sr_speech_manager (void); #endif - #if (L1_AEC == 1) + #if (AEC == 1) void l1s_aec_manager (void); #endif - #if (L1_AEC == 2) + #if (AEC == 2) void l1s_aec_manager (void); #endif #if (FIR) @@ -500,7 +502,7 @@ l1_audio_it_com = TRUE; } #endif - #if (L1_AEC == 1) + #if (AEC == 1) // the AEC is activated? if ((l1a_l1s_com.aec_task.command.start) || (l1s.audio_state[L1S_AEC_STATE] != 0)) @@ -511,19 +513,18 @@ // already requested by the modem } #endif - #if (L1_AEC == 2) + #if (AEC == 2) // the AEC is activated? if ((l1a_l1s_com.aec_task.command.start) || (l1s.audio_state[L1S_AEC_STATE] != 0)) { l1s_aec_manager(); - l1_audio_it_com = TRUE; + l1_audio_it_com = TRUE; } #endif #if (FIR) // the FIR is activated? -if ((l1a_l1s_com.fir_task.command.start) || - (l1s.audio_state[L1S_FIR_STATE] !=0 )) + if (l1a_l1s_com.fir_task.command.start) { l1s_fir_manager(); l1_audio_it_com = TRUE; @@ -762,12 +763,14 @@ } #endif +#if 0 /* FreeCalypso: LoCosto-ism not present in TCS211 */ // the audio It task is activated? if (l1a_l1s_com.audioIt_task.command.start) { l1s_audio_it_manager(); l1_audio_it_com = TRUE; } +#endif #if (L1_MIDI == 1) if ((l1a_l1s_com.midi_task.command.start) || @@ -778,9 +781,11 @@ } #endif // L1_MIDI +#if 0 /* FreeCalypso: LoCosto-ism not present in TCS211 */ // The audio IT shall be foprwarded to the DSP in case the L1S is forcing the audio if (l1a_l1s_com.audio_forced_by_l1s == TRUE) l1_audio_it_com = TRUE; +#endif l1s.l1_audio_it_com = l1_audio_it_com; } @@ -3500,30 +3505,6 @@ else // The DSP needs a new block ? { - if (l1a_l1s_com.voicememo_amr_task.play.command.pause) - { - // Stop the DSP voice memorization playing task - *(l1s.voicememo_amr.play.a_du_x) =*(l1s.voicememo_amr.play.a_du_x) | B_BLOCK_READY; - l1_vm_amr_in_pause= TRUE; - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_VM_AMR_PAUSE_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - // *state =WAIT_DSP_REQUEST; - - } - if (l1a_l1s_com.voicememo_amr_task.play.command.resume) - { - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_VM_AMR_RESUME_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - } // Determine which a_du buffer is currently used l1s.voicememo_amr.play.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_1; if (l1a_l1s_com.dedic_set.aset != NULL) @@ -4828,7 +4809,7 @@ } #endif // SPEECH_RECO - #if (L1_AEC == 1) + #if (AEC == 1) /*-------------------------------------------------------*/ /* l1s_aec_manager() */ /*-------------------------------------------------------*/ @@ -5028,7 +5009,7 @@ } #endif // AEC - #if(L1_AEC == 2) + #if(AEC == 2) /*-------------------------------------------------------*/ /* l1s_aec_manager() */ @@ -5193,105 +5174,7 @@ void l1s_fir_manager(void) { - enum states - { - IDLE, - WAIT_AUDIO_ON, - FIR_LOOP_ON - }; - - UWORD8 *state = &l1s.audio_state[L1S_FIR_STATE]; xSignalHeaderRec *conf_msg; - - - - switch (*state) - { - case IDLE: - { - if (l1a_l1s_com.fir_task.parameters.fir_loop == 0) - { - l1s_fir_set_params(); - // Send the FIR confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AUDIO_FIR_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - // Reset the start command - l1a_l1s_com.fir_task.command.start = FALSE; - } - else { - //enable UL and DL - l1s.audio_on_off_ctl.l1_audio_switch_on_ul_request++; - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request++; - *state = WAIT_AUDIO_ON; - } - } - break; - - case WAIT_AUDIO_ON: - { - if((l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE] == L1_AUDIO_DL_ON) && - (l1s.audio_state[L1S_AUDIO_UL_ONOFF_STATE] == L1_AUDIO_UL_ON)) - { - l1s_fir_set_params(); - // Send the FIR confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AUDIO_FIR_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - // Reset the start command - l1a_l1s_com.fir_task.command.start = FALSE; - //set the Loop on the DSP side - l1s_dsp_com.dsp_ndb_ptr->d_audio_init |= B_FIR_LOOP; - *state = FIR_LOOP_ON; - } - - } - break; - - case FIR_LOOP_ON: - { - if (l1a_l1s_com.fir_task.command.start == TRUE) - { - if (l1a_l1s_com.fir_task.parameters.fir_loop == 0) - { - //disable UL and DL - l1s.audio_on_off_ctl.l1_audio_switch_on_ul_request--; - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request--; - - l1s_dsp_com.dsp_ndb_ptr->d_audio_init &= ~(B_FIR_LOOP); - *state = IDLE; - } - - // Reset the start command - l1a_l1s_com.fir_task.command.start = FALSE; - //download parameters - l1s_fir_set_params(); - // Send the FIR confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AUDIO_FIR_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } - break; - } // end switch - - } - - void l1s_fir_set_params(void) - { - UWORD8 i; // Update the DL FIR? @@ -5300,73 +5183,54 @@ // Download the DL FIR coefficients to the melody a_fir31_downlink for (i=0; i<MAX_FIR_COEF; i++) { - #if ((DSP == 33) || (DSP == 34) || (DSP == 35) || (DSP == 36) || (DSP == 37) || (DSP == 38) || (DSP == 39)) // For this DSP code the FIR coefficients are in API param memory - l1s_dsp_com.dsp_param_ptr->a_fir31_downlink[i] = *l1a_l1s_com.fir_task.parameters.fir_dl_coefficient; + #if (DSP >= 33) // For this DSP code the FIR coefficients are in API param memory + l1s_dsp_com.dsp_param_ptr->a_fir31_downlink[i] = *l1a_l1s_com.fir_task.parameters.fir_dl_coefficient++; #else - l1s_dsp_com.dsp_ndb_ptr->a_fir31_downlink[i] = *l1a_l1s_com.fir_task.parameters.fir_dl_coefficient; + l1s_dsp_com.dsp_ndb_ptr->a_fir31_downlink[i] = *l1a_l1s_com.fir_task.parameters.fir_dl_coefficient++; #endif - l1a_l1s_com.fir_task.parameters.fir_dl_coefficient++; } } - // Update the UL FIR? if (l1a_l1s_com.fir_task.parameters.update_fir & UL_FIR) { - if ((l1s_dsp_com.dsp_ndb_ptr->d_audio_status & B_FIR_LOOP) == 1) // loop mode --> do not invert coef - { - // Download the UL FIR coefficients to the melody a_fir31_uplink - for (i=0; i<MAX_FIR_COEF; i++) - { - #if (DSP == 33) || (DSP == 34) || (DSP == 35) // For this DSP code the FIR coefficients are in API param memory - l1s_dsp_com.dsp_param_ptr->a_fir31_uplink[i] = *l1a_l1s_com.fir_task.parameters.fir_ul_coefficient; - #elif ((DSP == 36) || (DSP == 37) || (DSP == 38) || (DSP == 39)) // CQ #28839 - l1s_dsp_com.dsp_param_ptr->a_fir31_uplink[MAX_FIR_COEF-i-1] = *l1a_l1s_com.fir_task.parameters.fir_ul_coefficient; - #else - l1s_dsp_com.dsp_ndb_ptr->a_fir31_uplink[i] = *l1a_l1s_com.fir_task.parameters.fir_ul_coefficient; - #endif - l1a_l1s_com.fir_task.parameters.fir_ul_coefficient++; - } - } - else // normal mode --> invert coeff - { - // Download the UL FIR coefficients to the melody a_fir31_uplink - for (i=0; i<MAX_FIR_COEF; i++) - { - // In UL, coefs are inversed - #if ((DSP == 33) || (DSP == 34) || (DSP == 35) || (DSP == 36) || (DSP == 37) || (DSP == 38) || (DSP == 39))// For this DSP code the FIR coefficients are in API param memory - l1s_dsp_com.dsp_param_ptr->a_fir31_uplink[MAX_FIR_COEF-i-1] = *l1a_l1s_com.fir_task.parameters.fir_ul_coefficient; - #else - l1s_dsp_com.dsp_ndb_ptr->a_fir31_uplink[MAX_FIR_COEF-i-1] = *l1a_l1s_com.fir_task.parameters.fir_ul_coefficient; - #endif - l1a_l1s_com.fir_task.parameters.fir_ul_coefficient++; - } + // Download the UL FIR coefficients to the melody a_fir31_uplink + for (i=0; i<MAX_FIR_COEF; i++) + { + #if (DSP >= 33) // For this DSP code the FIR coefficients are in API param memory + l1s_dsp_com.dsp_param_ptr->a_fir31_uplink[i] = *l1a_l1s_com.fir_task.parameters.fir_ul_coefficient++; + #else + l1s_dsp_com.dsp_ndb_ptr->a_fir31_uplink[i] = *l1a_l1s_com.fir_task.parameters.fir_ul_coefficient++; + #endif } } - else // no UL update - { - if (((l1s_dsp_com.dsp_ndb_ptr->d_audio_status & B_FIR_LOOP) && (l1a_l1s_com.fir_task.parameters.fir_loop == FALSE)) - || ((!(l1s_dsp_com.dsp_ndb_ptr->d_audio_status & B_FIR_LOOP)) && (l1a_l1s_com.fir_task.parameters.fir_loop == TRUE))) // changing mode - { - // we are changing mode, normal to loop or loop to normal - // so we have to invert the coefficients in the API - UWORD16 temp_coeff; - - for (i=0; i<(MAX_FIR_COEF/2); i++) - { - #if ((DSP == 33) || (DSP == 34) || (DSP == 35) || (DSP == 36) || (DSP == 37) || (DSP == 38) || (DSP == 39)) // For this DSP code the FIR coefficients are in API param memory - temp_coeff = l1s_dsp_com.dsp_param_ptr->a_fir31_uplink[i]; - l1s_dsp_com.dsp_param_ptr->a_fir31_uplink[i] = l1s_dsp_com.dsp_param_ptr->a_fir31_uplink[MAX_FIR_COEF-i-1]; - l1s_dsp_com.dsp_param_ptr->a_fir31_uplink[MAX_FIR_COEF-i-1] = temp_coeff; - #else - temp_coeff = l1s_dsp_com.dsp_ndb_ptr->a_fir31_uplink[i]; - l1s_dsp_com.dsp_ndb_ptr->a_fir31_uplink[i] = l1s_dsp_com.dsp_ndb_ptr->a_fir31_uplink[MAX_FIR_COEF-i-1]; - l1s_dsp_com.dsp_ndb_ptr->a_fir31_uplink[MAX_FIR_COEF-i-1] = temp_coeff; - #endif - } - } + + // Set the FIR loop back: + if (l1a_l1s_com.fir_task.parameters.fir_loop) + { + #if (DSP == 17) || (DSP == 32) + l1s_dsp_com.dsp_ndb_ptr->d_audio_init &= ~(B_FIR_START); + #endif + l1s_dsp_com.dsp_ndb_ptr->d_audio_init |= B_FIR_LOOP; } - - + else + { + #if (DSP == 17) || (DSP == 32) + l1s_dsp_com.dsp_ndb_ptr->d_audio_init |= B_FIR_START; + #endif + l1s_dsp_com.dsp_ndb_ptr->d_audio_init &= ~(B_FIR_LOOP); + } + + // Send the FIR confirmation message + // Allocate confirmation message... + conf_msg = os_alloc_sig(0); + DEBUGMSG(status,NU_ALLOC_ERR) + conf_msg->SignalCode = L1_AUDIO_FIR_CON; + // Send confirmation message... + os_send_sig(conf_msg, L1C1_QUEUE); + DEBUGMSG(status,NU_SEND_QUEUE_ERR) + + // Reset the start command + l1a_l1s_com.fir_task.command.start = FALSE; } #endif // FIR #if (AUDIO_MODE) @@ -6202,6 +6066,7 @@ } #endif // L1_CPORT == 1 + #if 0 /* FreeCalypso: function not present in TCS211 */ /*-------------------------------------------------------*/ /* l1s_audio_it_manager() */ /*-------------------------------------------------------*/ @@ -6222,7 +6087,7 @@ // audio IT to DSP in case another sw entity has changed // something in the API } - + #endif #if (L1_EXTERNAL_AUDIO_VOICE_ONOFF == 1) /*-------------------------------------------------------*/