FreeCalypso > hg > freecalypso-citrine
changeset 13:a2723de00e06
L1/audio_cfile: untouched LoCosto source modules removed
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 10 Jun 2016 06:21:21 +0000 (2016-06-10) |
parents | 88bca1eff64a |
children | bb29929d4b3d |
files | L1/audio_cfile/l1audio_afunc.c L1/audio_cfile/l1audio_async.c L1/audio_cfile/l1audio_back.c L1/audio_cfile/l1audio_func.c L1/audio_cfile/l1audio_stereo.c L1/audio_cfile/l1audio_sync.c |
diffstat | 6 files changed, 0 insertions(+), 22411 deletions(-) [+] |
line wrap: on
line diff
--- a/L1/audio_cfile/l1audio_afunc.c Fri Jun 10 06:07:27 2016 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,1032 +0,0 @@ -/************* Revision Controle System Header ************* - * GSM Layer 1 software - * L1AUDIO_AFUNC.C - * - * Filename l1audio_afunc.c - * Copyright 2003 (C) Texas Instruments - * - ************* Revision Controle System Header *************/ - -/************************************/ -/* Include files... */ -/************************************/ - -#include "l1_macro.h" -#include "l1_confg.h" - -#if (AUDIO_TASK == 1) - - #include "l1_types.h" - #include "sys_types.h" - - #if (CODE_VERSION == SIMULATION) && (AUDIO_SIMULATION) - - - #include <stdlib.h> - #include <string.h> - - #include "iq.h" // Debug / Init hardware ("eva3.lib") - #include "l1_ver.h" - #include "l1_const.h" - #include "l1_signa.h" - - #if TESTMODE - #include "l1tm_defty.h" - #endif - - #include "l1audio_const.h" - #include "l1audio_cust.h" - #include "l1audio_signa.h" - #include "l1audio_defty.h" - #include "l1audio_msgty.h" - - #if (L1_GTT == 1) - #include "l1gtt_const.h" - #include "l1gtt_defty.h" - #endif -//added from e-sample for AAC - #if (L1_DYN_DSP_DWNLD == 1) - #include "l1_dyn_dwl_const.h" - #include "l1_dyn_dwl_defty.h" - #endif - #if (L1_MP3 == 1) - #include "l1mp3_defty.h" - #endif - - #if (L1_MIDI == 1) - #include "l1midi_defty.h" - #endif -//added from e-sample for AAC - #if (L1_AAC == 1) - #include "l1aac_defty.h" - #endif - - #include "l1_defty.h" - #include "cust_os.h" - #include "l1_msgty.h" - #include "l1_varex.h" - - #include "l1_mftab.h" - #include "l1_tabs.h" - #include "l1_ctl.h" - - #include "l1_time.h" - #include "l1_scen.h" - - #include "l1audio_proto.h" - - #else - // Layer1 and debug include files. - - #include <ctype.h> - #include <math.h> - #include "l1_ver.h" - #include "l1_const.h" - #include "l1_signa.h" - #include "cust_os.h" - - #if TESTMODE - #include "l1tm_defty.h" - #endif - - #include "l1audio_const.h" - #include "l1audio_cust.h" - #include "l1audio_signa.h" - #include "l1audio_defty.h" - #include "l1audio_msgty.h" - #include "l1audio_proto.h" - - #if (L1_GTT == 1) - #include "l1gtt_const.h" - #include "l1gtt_defty.h" - #endif -//added from e-sample for AAC - #if (L1_DYN_DSP_DWNLD == 1) - #include "l1_dyn_dwl_const.h" - #include "l1_dyn_dwl_defty.h" - #endif - #if (L1_MP3 == 1) - #include "l1mp3_defty.h" - #endif - - #if (L1_MIDI == 1) - #include "l1midi_defty.h" - #endif -//added from e-smaple for AAC - #if (L1_AAC == 1) - #include "l1aac_defty.h" - #endif -#if (RF_FAM == 61) -#include "l1_rf61.h" -#endif - - #include "l1_defty.h" - #include "l1_msgty.h" - #include "tpudrv.h" // TPU drivers. ("eva3.lib") - #include "l1_varex.h" - - #include "l1_proto.h" - #include "l1_mftab.h" - #include "l1_tabs.h" - #include "mem.h" - #include "armio.h" - #include "timer.h" - #include "timer1.h" - #include "dma.h" - #include "inth.h" - #include "ulpd.h" - #include "rhea_arm.h" - #include "clkm.h" // Clockm ("eva3.lib") - #include "l1_ctl.h" - - #include "l1_time.h" - #if L2_L3_SIMUL - #include "l1_scen.h" - #endif - - #if (OP_RIV_AUDIO == 1) - #include "rv_general.h" - #include "audio_api.h" - #include "audio_structs_i.h" - #include "audio_var_i.h" - #include "audio_macro_i.h" - #include "audio_const_i.h" - #endif - #endif -// #include "audio_api.h" //Thukaram Test -#if (OP_L1_STANDALONE == 0) - - #include "typedefs.h" - #include "vsi.h" - #include "os_const.h" - #include "os.h" - #include "frm_glob.h" - - #include "typedefs.h" - #include "vsi.h" - #include "os_const.h" - #include "os.h" - #include "frm_glob.h" - - extern T_HANDLE mm_ext_data_pool_handle; - extern T_HANDLE mm_int_data_pool_handle; - #endif - UWORD8 dma_src_port; - // This macro avoids to duplicate the code. - #if (OP_RIV_AUDIO == 1) - #define AUDIO_MSG (p_message) - #else - #define AUDIO_MSG (msg->SigP) - #endif - - /*-------------------------------------------------------*/ - /* l1a_audio_send_confirmation() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : Signal Code ofthe message */ - /* */ - /* Return : */ - /* */ - /* Description : Send a confirmation message to the MMI */ - /* for an audio task. */ - /* */ - /*-------------------------------------------------------*/ - void l1a_audio_send_confirmation(UWORD32 SignalCode) - { - #if (OP_RIV_AUDIO == 1) - - void *p_message; - T_RVF_MB_STATUS mb_status; //omaps00090550 - - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_RV_HDR), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - /* fill the message id */ - ((T_RV_HDR *)p_message)->msg_id = SignalCode; - - /* send the messsage to the audio entity */ - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - - #else // OP_RIV_AUDIO - - xSignalHeaderRec *msg; - - msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - msg->SignalCode = SignalCode; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(msg); - #endif - - os_send_sig(msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - #endif // OP_RIV_AUDIO - } - -/*-------------------------------------------------------*/ -/* l1a_audio_send_result() */ -/*-------------------------------------------------------*/ -/* Parameters : */ -/* Return : */ -/* Functionality : Send a result message to the MMI. */ -/*-------------------------------------------------------*/ -void l1a_audio_send_result(UWORD32 SignalCode, xSignalHeaderRec *msg, UWORD8 queue) -{ -#if (OP_RIV_AUDIO == 1) - - void *p_message = NULL; //omaps00090550 - T_RVF_MB_STATUS mb_status; //omaps00090550 - - switch (SignalCode) - { - #if (L1_AUDIO_DRIVER == 1) - case AUDIO_DRIVER_NOTIFICATION_MSG: - { - T_AUDIO_DRIVER_SESSION *p_session; - T_RV_RETURN *return_path; - UINT8 channel_id; - - /* get driver session */ - channel_id = ((T_L1_AUDIO_DRIVER_IND *)msg->SigP)->channel_id; - p_session = &(p_audio_gbl_var->audio_driver_session[channel_id]); - return_path = &(p_session->session_req.return_path); - - /* Translate the l1 message into the Riviera compliant message */ - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_AUDIO_DRIVER_NOTIFICATION), - (T_RVF_BUFFER **) (&p_message)); - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for driver notification",RV_TRACE_LEVEL_ERROR); - return; - } - - /* Fill the message ID + parameters */ - ((T_AUDIO_DRIVER_NOTIFICATION *)p_message)->header.msg_id = SignalCode; - ((T_AUDIO_DRIVER_NOTIFICATION *)p_message)->channel_id = channel_id; - ((T_AUDIO_DRIVER_NOTIFICATION *)p_message)->p_buffer = ((T_L1_AUDIO_DRIVER_IND *)(msg->SigP))->p_buffer; - - /* send answer */ - if (return_path->callback_func == NULL) - rvf_send_msg (return_path->addr_id, p_message); - else - { - (*return_path->callback_func)((void *)(p_message)); - rvf_free_buf((T_RVF_BUFFER *)p_message); - } - - // This return is important because there is another rvf_send_msg at the end of the switch - return; - } -//omaps00090550 break; - #endif - #if (L1_VOICE_MEMO_AMR) - case MMI_VM_AMR_RECORD_STOP_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_VM_AMR_RECORD_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for MMI_VM_AMR_RECORD_STOP_CON",RV_TRACE_LEVEL_ERROR); - return; - } - - // recorded size includes the end mask - ((T_MMI_VM_AMR_RECORD_CON *)p_message)->recorded_size = ((T_L1_VM_AMR_RECORD_CON *)(msg->SigP))->recorded_size; - } - break; - #endif - #if (VOICE_MEMO) - case MMI_VM_RECORD_STOP_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_VM_RECORD_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - ((T_MMI_VM_RECORD_CON *)p_message)->recorded_size = - ((T_L1_VM_RECORD_CON *)(msg->SigP))->recorded_size; - - break; - } - #endif - #if (L1_PCM_EXTRACTION) - case MMI_PCM_UPLOAD_STOP_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_PCM_UPLOAD_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - ((T_MMI_PCM_UPLOAD_STOP_CON *)p_message)->uploaded_size = - ((T_L1_PCM_UPLOAD_STOP_CON *)(msg->SigP))->uploaded_size; - - break; - } - #endif /* L1_PCM_EXTRACTION */ - - #if (SPEECH_RECO) - case MMI_SR_ENROLL_STOP_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_ENROLL_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - /* Fill the message parameter */ - ((T_MMI_SR_ENROLL_STOP_CON *)(p_message))->error_id = - ((T_L1_SR_ENROLL_STOP_CON *)(msg->SigP))->error_id; - - break; - } - case MMI_SR_UPDATE_STOP_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - /* Fill the message parameter */ - ((T_MMI_SR_UPDATE_STOP_CON *)(p_message))->error_id = - ((T_L1_SR_UPDATE_STOP_CON *)(msg->SigP))->error_id; - - break; - } - case MMI_SR_RECO_STOP_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_RECO_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - /* Fill the message parameter */ - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->error_id = - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->error_id; - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->best_word_index = - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_index; - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->best_word_score = - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_score; - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->second_best_word_index = - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->second_best_word_index; - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->second_best_word_score = - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->second_best_word_score; - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->third_best_word_index = - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->third_best_word_index; - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->third_best_word_score = - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->third_best_word_score; - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->fourth_best_word_index = - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->fourth_best_word_index; - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->fourth_best_word_score = - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->fourth_best_word_score; - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->d_sr_model_size = - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->d_sr_model_size; - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->d_sr_db_level = - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->d_sr_db_level; - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->d_sr_db_noise = - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->d_sr_db_noise; - - break; - } - - case MMI_SR_UPDATE_CHECK_STOP_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_CHECK_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - /* Fill the message parameter */ - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->error_id = - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(msg->SigP))->error_id; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->best_word_index = - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(msg->SigP))->best_word_index; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->best_word_score = - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(msg->SigP))->best_word_score; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->second_best_word_index = - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(msg->SigP))->second_best_word_index; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->second_best_word_score = - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(msg->SigP))->second_best_word_score; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->third_best_word_index = - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(msg->SigP))->third_best_word_index; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->third_best_word_score = - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(msg->SigP))->third_best_word_score; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->fourth_best_word_index = - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(msg->SigP))->fourth_best_word_index; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->fourth_best_word_score = - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(msg->SigP))->fourth_best_word_score; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->d_sr_model_size = - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(msg->SigP))->d_sr_model_size; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->d_sr_db_level = - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(msg->SigP))->d_sr_db_level; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->d_sr_db_noise = - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(msg->SigP))->d_sr_db_noise; - - break; - } - - #endif /* SPEECH_RECO */ - - - #if (L1_CPORT == 1) - case MMI_CPORT_CONFIGURE_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_CPORT_CONFIGURE_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for MMI_CPORT_CONFIGURE_CON",RV_TRACE_LEVEL_ERROR); - return; - } - - // recorded size includes the end mask - ((T_MMI_CPORT_CONFIGURE_CON *)p_message)->register_id = ((T_L1_CPORT_CONFIGURE_CON *)(msg->SigP))->register_id; - ((T_MMI_CPORT_CONFIGURE_CON *)p_message)->register_value = ((T_L1_CPORT_CONFIGURE_CON *)(msg->SigP))->register_value; - } - break; - #endif - - #if(L1_ANR == 2) - case MMI_AQI_ANR_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_AQI_ANR_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for MMI_AQI_ANR_CON",RV_TRACE_LEVEL_ERROR); - return; - } - - // recorded size includes the end mask - ((T_MMI_AQI_ANR_CON *)p_message)->anr_ul_action = ((T_L1_AQI_ANR_CON *)(msg->SigP))->anr_ul_action; - } - break; - #endif - - #if(L1_IIR == 2) - case MMI_AQI_IIR_DL_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_AQI_IIR_DL_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for MMI_AQI_IIR_DL_CON",RV_TRACE_LEVEL_ERROR); - return; - } - - // recorded size includes the end mask - ((T_MMI_AQI_IIR_DL_CON *)p_message)->iir_dl_action = ((T_L1_AQI_IIR_DL_CON *)(msg->SigP))->iir_dl_action; - } - break; - #endif - - #if(L1_AGC_UL == 1) - case MMI_AQI_AGC_UL_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_AQI_AGC_UL_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for MMI_AQI_AGC_UL_CON",RV_TRACE_LEVEL_ERROR); - return; - } - - // recorded size includes the end mask - ((T_MMI_AQI_AGC_UL_CON *)p_message)->agc_ul_action = ((T_L1_AQI_AGC_UL_CON *)(msg->SigP))->agc_ul_action; - } - break; - #endif - - #if(L1_AGC_DL == 1) - case MMI_AQI_AGC_DL_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_AQI_AGC_DL_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for MMI_AQI_AGC_DL_CON",RV_TRACE_LEVEL_ERROR); - return; - } - - // recorded size includes the end mask - ((T_MMI_AQI_AGC_DL_CON *)p_message)->agc_dl_action = ((T_L1_AQI_AGC_DL_CON *)(msg->SigP))->agc_dl_action; - } - break; - #endif - - #if(L1_WCM == 1) - case MMI_AQI_WCM_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_AQI_WCM_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for MMI_AQI_WCM_CON",RV_TRACE_LEVEL_ERROR); - return; - } - - // recorded size includes the end mask - ((T_MMI_AQI_WCM_CON *)p_message)->wcm_action = ((T_L1_AQI_WCM_CON *)(msg->SigP))->wcm_action; - } - break; - #endif - - - #if(L1_DRC == 1) - case MMI_AQI_DRC_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_AQI_DRC_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for MMI_AQI_DRC_CON",RV_TRACE_LEVEL_ERROR); - return; - } - - // recorded size includes the end mask - ((T_MMI_AQI_DRC_CON *)p_message)->drc_dl_action = ((T_L1_AQI_DRC_CON *)(msg->SigP))->drc_dl_action; - } - break; - #endif - - #if(L1_AEC == 2) - case MMI_AQI_AEC_CON: - { - /* Translate the l1 message into the Riviera compliant message */ - /* Allocate the Riviera buffer */ - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_AQI_AEC_CON), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for MMI_AQI_AEC_CON",RV_TRACE_LEVEL_ERROR); - return; - } - - // recorded size includes the end mask - ((T_MMI_AQI_AEC_CON *)p_message)->aec_action = ((T_L1_AQI_AEC_CON *)(msg->SigP))->aec_action; - } - break; - #endif - - -default: - { - AUDIO_SEND_TRACE("AUDIO entity: wrong L1 confirmation message",RV_TRACE_LEVEL_ERROR); - break; - } - } - - if(p_message != NULL) -{ - /* Fill the message ID */ - ((T_RV_HDR *)p_message)->msg_id = SignalCode; -} - /* send the messsage to the audio entity */ - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - -#else // OP_RIV_AUDIO - - // Set flag to avoid the FREE(msg) in L1ASYNC. - l1a.l1_msg_forwarded = TRUE; - - msg->SignalCode = SignalCode; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(msg); - #endif - - os_send_sig(msg, queue); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - -#endif // OP_RIV_AUDIO -} - -#if (SPEECH_RECO) - /*-------------------------------------------------------*/ - /* l1_send_sr_background_msg() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : Signal Code ofthe message */ - /* */ - /* Return : */ - /* */ - /* Description : Send a message to the SR background */ - /* task. */ - /* */ - /*-------------------------------------------------------*/ - void l1_send_sr_background_msg(UWORD32 SignalCode) - { - #if (OP_RIV_AUDIO == 1) - void *p_message; - T_RVF_MB_STATUS mb_status; //omaps00090550 - #else - xSignalHeaderRec *msg; - #endif - - switch (SignalCode) - { - case L1_SRBACK_SAVE_DATA_REQ: - { - // Allocate the partition - #if (OP_RIV_AUDIO == 1) - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_L1_SRBACK_SAVE_DATA_REQ), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - #else // OP_RIV_AUDIO - msg = os_alloc_sig(sizeof(T_L1_SRBACK_SAVE_DATA_REQ)); - DEBUGMSG(status,NU_ALLOC_ERR) - #endif // OP_RIV_AUDIO - - // Fill the message - ((T_L1_SRBACK_SAVE_DATA_REQ *)(AUDIO_MSG))->database_id = l1a_l1s_com.speechreco_task.parameters.database_id; - ((T_L1_SRBACK_SAVE_DATA_REQ *)(AUDIO_MSG))->model_index = l1a_l1s_com.speechreco_task.parameters.word_index; - ((T_L1_SRBACK_SAVE_DATA_REQ *)(AUDIO_MSG))->model_RAM_address = l1a_l1s_com.speechreco_task.parameters.model_address; - ((T_L1_SRBACK_SAVE_DATA_REQ *)(AUDIO_MSG))->speech = l1a_l1s_com.speechreco_task.parameters.speech; - ((T_L1_SRBACK_SAVE_DATA_REQ *)(AUDIO_MSG))->start_buffer = l1a_l1s_com.speechreco_task.parameters.speech_address; - ((T_L1_SRBACK_SAVE_DATA_REQ *)(AUDIO_MSG))->stop_buffer = l1a_l1s_com.speechreco_task.parameters.speech_address + SC_SR_MMI_2_L1_SPEECH_SIZE; - ((T_L1_SRBACK_SAVE_DATA_REQ *)(AUDIO_MSG))->start_address = l1a_l1s_com.speechreco_task.parameters.start_address; - ((T_L1_SRBACK_SAVE_DATA_REQ *)(AUDIO_MSG))->stop_address = l1a_l1s_com.speechreco_task.parameters.stop_address; - } - break; - - case L1_SRBACK_LOAD_MODEL_REQ: - { - // Allocate the partition - #if (OP_RIV_AUDIO == 1) - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_L1_SRBACK_LOAD_MODEL_REQ), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - #else // OP_RIV_AUDIO - msg = os_alloc_sig(sizeof(T_L1_SRBACK_LOAD_MODEL_REQ)); - DEBUGMSG(status,NU_ALLOC_ERR) - #endif // OP_RIV_AUDIO - - // Fill the message - ((T_L1_SRBACK_LOAD_MODEL_REQ *)(AUDIO_MSG))->database_id = l1a_l1s_com.speechreco_task.parameters.database_id; - ((T_L1_SRBACK_LOAD_MODEL_REQ *)(AUDIO_MSG))->model_index = l1a_l1s_com.speechreco_task.parameters.word_index; - ((T_L1_SRBACK_LOAD_MODEL_REQ *)(AUDIO_MSG))->model_RAM_address = l1a_l1s_com.speechreco_task.parameters.model_address; - ((T_L1_SRBACK_LOAD_MODEL_REQ *)(AUDIO_MSG))->CTO_enable = l1a_l1s_com.speechreco_task.parameters.CTO_algorithm; - } - break; - - case L1_SRBACK_TEMP_SAVE_DATA_REQ: - { - // Allocate the partition - #if (OP_RIV_AUDIO == 1) - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_L1_SRBACK_TEMP_SAVE_DATA_REQ), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - #else // OP_RIV_AUDIO - msg = os_alloc_sig(sizeof(T_L1_SRBACK_TEMP_SAVE_DATA_REQ)); - DEBUGMSG(status,NU_ALLOC_ERR) - #endif // OP_RIV_AUDIO - - // Fill the message - ((T_L1_SRBACK_TEMP_SAVE_DATA_REQ *)(AUDIO_MSG))->model_RAM_address_input = l1a_l1s_com.speechreco_task.parameters.model_address; - ((T_L1_SRBACK_TEMP_SAVE_DATA_REQ *)(AUDIO_MSG))->model_RAM_address_output = l1a_l1s_com.speechreco_task.parameters.model_temp_address; - } - break; - } - - #if (OP_RIV_AUDIO == 1) - /* fill the message id */ - ((T_RV_HDR *)p_message)->msg_id = SignalCode; - - /* send the messsage to the audio entity */ - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - msg->SignalCode = SignalCode; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(msg); - #endif - - os_send_sig(msg, SRBACK_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - } -#endif -#if (MELODY_E2) - /*-------------------------------------------------------*/ - /* l1_send_melody_e2_background_msg() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : Signal Code of the message */ - /* melody ID (0 or 1) */ - /* */ - /* Return : */ - /* */ - /* Description : Send a message to the audio background */ - /* for the melody E2 feature. */ - /* */ - /*-------------------------------------------------------*/ - void l1_send_melody_e2_background_msg(UWORD32 SignalCode, UWORD8 melody_id) - { - #if (OP_RIV_AUDIO == 1) - void *p_message; - T_RVF_MB_STATUS mb_status; //omaps00090550 - #else - xSignalHeaderRec *msg; - #endif - - UWORD8 i; - - if ( SignalCode == L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ ) - { - // Allocate the partition - #if (OP_RIV_AUDIO == 1) - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - #else // OP_RIV_AUDIO - msg = os_alloc_sig(sizeof(T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ)); - DEBUGMSG(status,NU_ALLOC_ERR) - #endif // OP_RIV_AUDIO - - ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(AUDIO_MSG))->melody_id = - melody_id; - - if (melody_id == 0) - { - // Load instrument for the melody 0 - // Fill the message - ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(AUDIO_MSG))->number_of_instrument = - l1a_l1s_com.melody0_e2_task.parameters.number_of_instrument; - for(i=0; i<SC_AUDIO_MELODY_E2_MAX_NUMBER_OF_INSTRUMENT; i++) - { - ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(AUDIO_MSG))->waves_table_id[i] = - l1a_l1s_com.melody0_e2_task.parameters.waves_table_id[i]; - } - } - if (melody_id == 1) - { - // Load instrument for the melody 1 - // Fill the message - ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(AUDIO_MSG))->number_of_instrument = - l1a_l1s_com.melody1_e2_task.parameters.number_of_instrument; - for(i=0; i<SC_AUDIO_MELODY_E2_MAX_NUMBER_OF_INSTRUMENT; i++) - { - ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(AUDIO_MSG))->waves_table_id[i] = - l1a_l1s_com.melody1_e2_task.parameters.waves_table_id[i]; - } - } - } - else - if (SignalCode == L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ) - { - // Allocate the partition - #if (OP_RIV_AUDIO == 1) - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ), - (T_RVF_BUFFER **) (&p_message)); - - /* If insufficient resources, then report a memory error and abort. */ - if (mb_status == RVF_RED) - { - /* the memory is insufficient to continue the non regression test */ - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - #else // OP_RIV_AUDIO - msg = os_alloc_sig(sizeof(T_L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ)); - DEBUGMSG(status,NU_ALLOC_ERR) - #endif // OP_RIV_AUDIO - - ((T_L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ *)(AUDIO_MSG))->melody_id = - melody_id; - - if (melody_id == 0) - { - ((T_L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ *)(AUDIO_MSG))->number_of_instrument = - l1a_l1s_com.melody0_e2_task.parameters.number_of_instrument; - } - else - if (melody_id == 1) - { - ((T_L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ *)(AUDIO_MSG))->number_of_instrument = - l1a_l1s_com.melody1_e2_task.parameters.number_of_instrument; - } - } - - #if (OP_RIV_AUDIO == 1) - ((T_RV_HDR *)p_message)->msg_id = SignalCode; - - /* send the messsage to the audio entity */ - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - msg->SignalCode = SignalCode; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(msg); - #endif - - os_send_sig(msg, SRBACK_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - } -#endif // MELODY_E2 - -#if (OP_L1_STANDALONE == 0) -void *mem_Allocate(UWORD16 size) -{ - -void* p_buffer; - - T_HANDLE hTask; - - hTask = e_running[os_MyHandle()]; - - if(os_AllocateMemory( hTask , (T_VOID_STRUCT **)&p_buffer,size,OS_NO_SUSPEND, mm_int_data_pool_handle) != 0) - { - if(os_AllocateMemory ( hTask, (T_VOID_STRUCT**)&p_buffer,size,OS_NO_SUSPEND, mm_ext_data_pool_handle) != 0) - return NULL; - else - { - dma_src_port =AUDIO_SP_SOURCE_EMIF; - return p_buffer; - } - } - else - { - dma_src_port =AUDIO_SP_SOURCE_IMIF; - return p_buffer; - } - - -} - - -void mem_Deallocate(void *memoryBlock) -{ - T_HANDLE hTask; - - hTask = e_running[os_MyHandle()]; - - if (memoryBlock) - { - os_DeallocateMemory(hTask, (T_VOID_STRUCT *) memoryBlock); - } - } -#endif//op_l1_standalone=0 -#endif // AUDIO_TASK
--- a/L1/audio_cfile/l1audio_async.c Fri Jun 10 06:07:27 2016 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,10690 +0,0 @@ -/************* Revision Controle System Header ************* - * GSM Layer 1 software - * L1AUDIO_ASYNC.C - * - * Filename l1audio_async.c - * Copyright 2003 (C) Texas Instruments - * - ************* Revision Controle System Header *************/ - -/************************************/ -/* Include files... */ -/************************************/ - -#include "l1_macro.h" -#include "l1_confg.h" - -#if (AUDIO_TASK == 1) - - #include "l1_types.h" - #include "sys_types.h" - - #if (CODE_VERSION == SIMULATION) && (AUDIO_SIMULATION) - - #include <stdlib.h> - #include <string.h> - - #include "iq.h" // Debug / Init hardware ("eva3.lib") - #include "l1_ver.h" - #include "l1_const.h" - #include "l1_signa.h" - #include "cust_os.h" - - #if TESTMODE - #include "l1tm_defty.h" - #endif - - #include "l1audio_const.h" - #include "l1audio_cust.h" - #include "l1audio_signa.h" - #include "l1audio_defty.h" - #include "l1audio_msgty.h" - #include "l1audio_varex.h" - #include "l1audio_proto.h" - - #if (L1_GTT == 1) - #include "l1gtt_const.h" - #include "l1gtt_defty.h" - #endif - - #if (L1_MIDI == 1) - #include "l1midi_defty.h" - #endif - - - #if (L1_MP3 == 1) - #include "l1mp3_defty.h" - #endif - - #if (L1_AAC == 1) - #include "l1aac_defty.h" - #endif - #if (L1_DYN_DSP_DWNLD==1) - #include "l1_dyn_dwl_defty.h" - #include "l1_dyn_dwl_const.h" - #include "l1_dyn_dwl_signa.h" - #endif - - #include "l1_defty.h" - #include "l1_msgty.h" - #include "l1_varex.h" - - #include "l1_mftab.h" - #include "l1_tabs.h" - #include "l1_ctl.h" - - - #include "l1_time.h" - #include "l1_scen.h" - - #else - - // Layer1 and debug include files. - #include <ctype.h> - #include <math.h> - #include "l1_ver.h" - #include "l1_const.h" - #include "l1_signa.h" - #include "cust_os.h" - - #if TESTMODE - #include "l1tm_defty.h" - #endif - - #include "l1audio_const.h" - #include "l1audio_cust.h" - #include "l1audio_signa.h" - #include "l1audio_defty.h" - #include "l1audio_msgty.h" - #include "l1audio_varex.h" - #include "l1audio_proto.h" - - #if (L1_GTT == 1) - #include "l1gtt_const.h" - #include "l1gtt_defty.h" - #endif - - #if (L1_MP3 == 1) - #include "l1mp3_defty.h" - #endif - - #if (L1_MIDI == 1) - #include "l1midi_defty.h" - #endif - - #if (L1_AAC == 1) - #include "l1aac_defty.h" - #endif - - #if (L1_DYN_DSP_DWNLD==1) - #include "l1_dyn_dwl_defty.h" - #include "l1_dyn_dwl_const.h" - #include "l1_dyn_dwl_signa.h" - #endif - -#if (RF_FAM == 61) -#include "l1_rf61.h" -#endif - - #include "l1_defty.h" - #include "l1_msgty.h" - #include "tpudrv.h" // TPU drivers. ("eva3.lib") - #include "l1_varex.h" - - #include "l1_proto.h" - #include "l1_mftab.h" - #include "l1_tabs.h" - #include "mem.h" - #include "armio.h" - #include "timer.h" - #include "timer1.h" - #include "dma.h" - #include "inth.h" - #include "ulpd.h" - #include "rhea_arm.h" - #include "clkm.h" // Clockm ("eva3.lib") - #include "l1_ctl.h" - - #include "l1_time.h" - - #if L2_L3_SIMUL - #include "l1_scen.h" - #endif - - #if (OP_RIV_AUDIO == 1) - #include "rv_general.h" - #include "audio_api.h" - #include "audio_structs_i.h" - #include "audio_var_i.h" - #include "audio_macro_i.h" - #include "audio_const_i.h" - #endif - #endif - - #include "l1audio_macro.h" - - #if(L1_DYN_DSP_DWNLD == 1) - #if (TRACE_TYPE == 1) ||(TRACE_TYPE == 4) || (TRACE_TYPE == 5) || (TRACE_TYPE == 7) || (TESTMODE) - #include "l1_trace.h" - #endif - #if(CODE_VERSION == SIMULATION) - extern void trace_fct_simu_dyn_dwnld(CHAR *fct_name); - #endif - #endif - -#if 0 - #if (L1_MP3) - extern T_MP3_MCU_DSP *mp3_ndb;//Mp3-FR - #endif -//#pragma DUPLICATE_FOR_INTERNAL_RAM_END - -#endif -#if ( L1_AAC) -extern UWORD16 a_aac_dma_input_buffer[2][C_AAC_OUTPUT_BUFFER_SIZE]; -extern UWORD8 d_aac_dma_current_buffer_id; - -#endif - -#if (L1_MP3) -extern T_MP3_MCU_DSP *mp3_ndb;//Mp3-FR -#endif - /**************************************/ - /* Prototypes for L1 ASYNCH task */ - /**************************************/ - #if (OP_RIV_AUDIO == 1) - #if (L1_AUDIO_DRIVER == 1) - void l1a_audio_driver_process (xSignalHeaderRec *msg); - #endif - #endif - #if (KEYBEEP) - void l1a_mmi_keybeep_process (xSignalHeaderRec *msg); - #endif - #if (TONE) - void l1a_mmi_tone_process (xSignalHeaderRec *msg); - #endif - #if (L1_CPORT == 1) - void l1a_mmi_cport_process (xSignalHeaderRec *msg); - #endif - #if (MELODY_E1) - void l1a_mmi_melody0_process (xSignalHeaderRec *msg); - void l1a_mmi_melody1_process (xSignalHeaderRec *msg); - #endif - #if (VOICE_MEMO) - void l1a_mmi_vm_playing_proccess (xSignalHeaderRec *msg); - void l1a_mmi_vm_recording_process (xSignalHeaderRec *msg); - #endif - #if (L1_PCM_EXTRACTION) - void l1a_mmi_pcm_download_process (xSignalHeaderRec *msg); - void l1a_mmi_pcm_upload_process (xSignalHeaderRec *msg); - #endif - #if (L1_VOICE_MEMO_AMR) - void l1a_mmi_vm_amr_playing_proccess (xSignalHeaderRec *msg); - void l1a_mmi_vm_amr_recording_process(xSignalHeaderRec *msg); - #endif - #if (SPEECH_RECO) - void l1a_mmi_sr_enroll_process (xSignalHeaderRec *msg); - void l1a_mmi_sr_update_process (xSignalHeaderRec *msg); - void l1a_mmi_sr_reco_process (xSignalHeaderRec *msg); - void l1a_mmi_sr_update_check_process(xSignalHeaderRec *msg); - #endif - #if (L1_AEC == 1) - void l1a_mmi_aec_process (xSignalHeaderRec *msg); - #endif - #if (L1_AEC == 2) - void l1a_mmi_aec_process (xSignalHeaderRec *msg); - #endif - #if (FIR) - void l1a_mmi_fir_process (xSignalHeaderRec *msg); - #endif - #if (AUDIO_MODE) - void l1a_mmi_audio_mode_process (xSignalHeaderRec *msg); - #endif - #if (MELODY_E2) - void l1a_mmi_melody0_e2_process (xSignalHeaderRec *msg); - void l1a_mmi_melody1_e2_process (xSignalHeaderRec *msg); - #endif - #if (L1_EXTERNAL_AUDIO_VOICE_ONOFF == 1) - void l1a_mmi_audio_onoff_process (xSignalHeaderRec *msg); - #endif - #if (L1_EXT_AUDIO_MGT == 1) - void l1a_mmi_ext_audio_mgt_process (xSignalHeaderRec *msg); - #endif - #if (L1_ANR == 1 || L1_ANR == 2) - void l1a_mmi_anr_process (xSignalHeaderRec *msg); - #endif - #if (L1_AGC_UL == 1) - void l1a_mmi_agc_ul_process (xSignalHeaderRec *msg); - #endif - #if (L1_AGC_DL == 1) - void l1a_mmi_agc_dl_process (xSignalHeaderRec *msg); - #endif - #if (L1_IIR == 1 || L1_IIR == 2) - void l1a_mmi_iir_process (xSignalHeaderRec *msg); - #endif - #if (L1_WCM == 1) - void l1a_mmi_wcm_process (xSignalHeaderRec *msg); - #endif -#if (L1_DRC == 1) - void l1a_mmi_drc_process (xSignalHeaderRec *msg); - #endif - #if (L1_LIMITER == 1) - void l1a_mmi_limiter_process (xSignalHeaderRec *msg); - #endif - #if (L1_ES == 1) - void l1a_mmi_es_process (xSignalHeaderRec *msg); - #endif - #if (L1_DYN_DSP_DWNLD == 1) - void l1a_mmi_vocoder_cfg_process(xSignalHeaderRec *msg); - #endif -#if(L1_BT_AUDIO==1) - void l1a_mmi_bt_process(xSignalHeaderRec *msg); -#endif - /**************************************/ - /* External prototypes */ - /**************************************/ - extern UWORD8 copy_data_from_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD16 **ptr_buf, UWORD16 data_size, API *ptr_dst); - extern UWORD8 copy_data_to_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD16 **ptr_buf, UWORD16 data_size, API *ptr_src); - extern UWORD8 Cust_get_pointer (UWORD16 **ptr, UWORD16 *buffer_size, UWORD8 session_id); - #if (MELODY_E2) - extern UWORD8 copy_byte_data_from_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, UWORD8 *ptr_dst); - extern UWORD8 copy_byte_data_to_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, UWORD8 *ptr_src); - #endif - #if (L1_EXT_AUDIO_MGT == 1) - T_MIDI_DMA_PARAM midi_buf; - #if (CODE_VERSION == NOT_SIMULATION) -#pragma DATA_SECTION(midi_buf,".l1s_global") -#endif - extern void l1_ext_audio_mgt_dma_handler(SYS_UWORD16 dma_status); - #endif - #if(L1_BT_AUDIO ==1) - BOOL midi_task_running; - extern T_L1_BT_AUDIO bt_audio; - extern void l1_audio_bt_init(UINT16 media_buf_size); - #endif - - #if (OP_RIV_AUDIO == 1) - #if (L1_AUDIO_DRIVER == 1) - void l1a_audio_driver_process(xSignalHeaderRec *msg) - { - UWORD32 SignalCode = msg->SignalCode; - - if (SignalCode == L1_AUDIO_DRIVER_IND) - l1a_audio_send_result(AUDIO_DRIVER_NOTIFICATION_MSG, msg, MMI_QUEUE); - } - #endif - #endif - - #if (KEYBEEP) - /*-------------------------------------------------------*/ - /* l1a_mmi_keybeep_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* keybeep feature. */ - /* */ - /* Starting messages: MMI_KEYBEEP_START_REQ */ - /* */ - /* Result messages (input): L1_KEYBEEP_START_CON */ - /* */ - /* Result messages (output): MMI_KEYBEEP_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_KEYBEEP_STOP_REQ */ - /* L1_KEYBEEP_STOP_CON */ - /* */ - /* Stop message (output): MMI_KEYBEEP_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_keybeep_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_START_CON = 2, - WAIT_STOP = 3 - }; - - UWORD8 *state = &l1a.state[L1A_KEYBEEP_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.keybeep_task.command.start = FALSE; - l1a_l1s_com.keybeep_task.command.stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_KEYBEEP_START_REQ) - { - // Download the keybeep description in the NDB. - l1s_dsp_com.dsp_ndb_ptr->d_k_x1_kt0= ((T_MMI_KEYBEEP_REQ *)(msg->SigP))->d_k_x1_kt0; - l1s_dsp_com.dsp_ndb_ptr->d_k_x1_kt1= ((T_MMI_KEYBEEP_REQ *)(msg->SigP))->d_k_x1_kt1; - l1s_dsp_com.dsp_ndb_ptr->d_dur_kb = ((T_MMI_KEYBEEP_REQ *)(msg->SigP))->d_dur_kb; - - // Start the L1S keybeep task - l1a_l1s_com.keybeep_task.command.start = TRUE; - - *state = WAIT_START_CON; - } - - // End process - return; - } - // OMPAS00090550 break; - - case WAIT_START_CON: - { - if (SignalCode == L1_KEYBEEP_START_CON) - { - // Disable the start command - l1a_l1s_com.keybeep_task.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_KEYBEEP_START_CON); - - *state = WAIT_STOP; - } - - // End process - return; - } - // ompas00090550 break; - - case WAIT_STOP: - { - if (SignalCode == MMI_KEYBEEP_STOP_REQ) - { - // Stop the L1S keybeep task - l1a_l1s_com.keybeep_task.command.stop = TRUE; - - // End process - return; - } - else - if (SignalCode == L1_KEYBEEP_STOP_CON) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_KEYBEEP_STOP_CON); - - *state = RESET; - } - else - { - // End process - return; - } - } - // omaps00090550 break; - } // switch - } // while(1) - } - #endif // KEYBEEP - - #if (TONE) - /*-------------------------------------------------------*/ - /* l1a_mmi_tone_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* tone feature. */ - /* */ - /* Starting messages: MMI_TONE_START_REQ */ - /* */ - /* Result messages (input): L1_TONE_START_CON */ - /* */ - /* Result messages (output): MMI_TONE_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_TONE_STOP_REQ */ - /* L1_TONE_STOP_CON */ - /* */ - /* Stop message (output): MMI_TONE_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_tone_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_START_CON = 2, - WAIT_STOP = 3 - }; - - UWORD8 *state = &l1a.state[L1A_TONE_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.tone_task.command.start = FALSE; - l1a_l1s_com.tone_task.command.stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_TONE_START_REQ) - { - // Download the tone description in the NDB. - l1s_dsp_com.dsp_ndb_ptr->d_k_x1_t0 = ((T_MMI_TONE_REQ *)(msg->SigP))->d_k_x1_t0; - l1s_dsp_com.dsp_ndb_ptr->d_k_x1_t1 = ((T_MMI_TONE_REQ *)(msg->SigP))->d_k_x1_t1; - l1s_dsp_com.dsp_ndb_ptr->d_k_x1_t2 = ((T_MMI_TONE_REQ *)(msg->SigP))->d_k_x1_t2; - l1s_dsp_com.dsp_ndb_ptr->d_pe_rep = ((T_MMI_TONE_REQ *)(msg->SigP))->d_pe_rep; - l1s_dsp_com.dsp_ndb_ptr->d_pe_off = ((T_MMI_TONE_REQ *)(msg->SigP))->d_pe_off; - l1s_dsp_com.dsp_ndb_ptr->d_se_off = ((T_MMI_TONE_REQ *)(msg->SigP))->d_se_off; - l1s_dsp_com.dsp_ndb_ptr->d_bu_off = ((T_MMI_TONE_REQ *)(msg->SigP))->d_bu_off; - l1s_dsp_com.dsp_ndb_ptr->d_t0_on = ((T_MMI_TONE_REQ *)(msg->SigP))->d_t0_on; - l1s_dsp_com.dsp_ndb_ptr->d_t0_off = ((T_MMI_TONE_REQ *)(msg->SigP))->d_t0_off; - l1s_dsp_com.dsp_ndb_ptr->d_t1_on = ((T_MMI_TONE_REQ *)(msg->SigP))->d_t1_on; - l1s_dsp_com.dsp_ndb_ptr->d_t1_off = ((T_MMI_TONE_REQ *)(msg->SigP))->d_t1_off; - l1s_dsp_com.dsp_ndb_ptr->d_t2_on = ((T_MMI_TONE_REQ *)(msg->SigP))->d_t2_on; - l1s_dsp_com.dsp_ndb_ptr->d_t2_off = ((T_MMI_TONE_REQ *)(msg->SigP))->d_t2_off; - - - // Start the L1S tone task - l1a_l1s_com.tone_task.command.start = TRUE; - - *state = WAIT_START_CON; - } - - // End process - return; - } - //omaps00090550 break; - - case WAIT_START_CON: - { - if (SignalCode == L1_TONE_START_CON) - { - // Disable the start command - l1a_l1s_com.tone_task.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_TONE_START_CON); - - *state = WAIT_STOP; - } - - // End process - return; - } - // omaps00090550 break; - - case WAIT_STOP: - { - if (SignalCode == MMI_TONE_STOP_REQ) - { - // Stop the L1S tone task - l1a_l1s_com.tone_task.command.stop = TRUE; - - // End process - return; - } - else - if (SignalCode == L1_TONE_STOP_CON) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_TONE_STOP_CON); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - #endif // TONE - - - - - - #if (MELODY_E1) - /*-------------------------------------------------------*/ - /* l1a_mmi_melody0_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* melody 0 feature. */ - /* */ - /* Starting messages: MMI_MELODY0_START_REQ */ - /* */ - /* Result messages (input): L1_MELODY0_START_CON */ - /* */ - /* Result messages (output): MMI_MELODY0_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_MELDOY0_STOP_REQ */ - /* L1_MELODY0_STOP_CON */ - /* */ - /* Stop message (output): MMI_MELODY0_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_melody0_process(xSignalHeaderRec *msg) - { - enum states - { - M0_RESET = 0, - M0_WAIT_START_REQ = 1, - M0_WAIT_START_CON = 2, - M0_WAIT_STOP = 3 - }; - - UWORD8 *state = &l1a.state[L1A_MELODY0_STATE]; - UWORD32 SignalCode = msg->SignalCode; - UWORD8 melody_osc, used_osc; - - while(1) - { - switch(*state) - { - case M0_RESET: - { - // Reset the commands: - l1a_l1s_com.melody0_task.command.start = FALSE; - l1a_l1s_com.melody0_task.command.stop = FALSE; - - // Initialize the translation table - for (melody_osc=0; melody_osc<SC_NUMBER_OSCILLATOR; melody_osc++) - l1a_l1s_com.melody0_task.parameters.melody_to_oscillator[melody_osc] = SC_NUMBER_OSCILLATOR; - - *state = M0_WAIT_START_REQ; - } - break; - - case M0_WAIT_START_REQ: - { - if (SignalCode == MMI_MELODY0_START_REQ) - { - // Download the parameters from the message: - l1a_l1s_com.melody0_task.parameters.session_id = ((T_MMI_MELODY_REQ *)(msg->SigP))->session_id; - l1a_l1s_com.melody0_task.parameters.loopback = ((T_MMI_MELODY_REQ *)(msg->SigP))->loopback; - l1a_l1s_com.melody0_task.parameters.oscillator_used_bitmap = ((T_MMI_MELODY_REQ *)(msg->SigP))->oscillator_used_bitmap; - - // Initialize the buffer parameters - l1a_l1s_com.melody0_task.parameters.ptr_buf = NULL; - l1a_l1s_com.melody0_task.parameters.buffer_size = 0; - l1a_l1s_com.melody0_task.parameters.error_id = Cust_get_pointer((UWORD16 **)&l1a_l1s_com.melody0_task.parameters.ptr_buf, - &l1a_l1s_com.melody0_task.parameters.buffer_size, - l1a_l1s_com.melody0_task.parameters.session_id); - - // Read the Header of the melody description to have the melody bitmap - l1a_l1s_com.melody0_task.parameters.error_id = copy_data_from_buffer (l1a_l1s_com.melody0_task.parameters.session_id, - &l1a_l1s_com.melody0_task.parameters.buffer_size, - (UWORD16 **)&l1a_l1s_com.melody0_task.parameters.ptr_buf, - 1, - &l1a_l1s_com.melody0_task.parameters.oscillator_melody_bitmap); - - l1a_l1s_com.melody0_task.parameters.oscillator_melody_bitmap = Field(l1a_l1s_com.melody0_task.parameters.oscillator_melody_bitmap, SC_MELO_OSCILLATOR_USED_MASK, SC_MELO_OSCILLATOR_USED_SHIFT); - - // Build the array of translation between the melody mapping and the oscillators used - used_osc = 0; - melody_osc = 0; - while ( (melody_osc < SC_NUMBER_OSCILLATOR) && (used_osc < SC_NUMBER_OSCILLATOR) ) - { - // find the next oscillator available in the melody - while( ((l1a_l1s_com.melody0_task.parameters.oscillator_melody_bitmap & (0x1<<melody_osc)) == 0) && (melody_osc < SC_NUMBER_OSCILLATOR) ) - melody_osc++; - - // find the next oscillator available in the oscillator used - while( ((l1a_l1s_com.melody0_task.parameters.oscillator_used_bitmap & (0x1<<used_osc)) == 0) && (melody_osc < SC_NUMBER_OSCILLATOR) ) - used_osc++; - - // Fill the translation table - if ( (melody_osc < SC_NUMBER_OSCILLATOR) && (used_osc < SC_NUMBER_OSCILLATOR) ) - l1a_l1s_com.melody0_task.parameters.melody_to_oscillator[melody_osc] = used_osc; - melody_osc++; - used_osc++; - } - - // Start the melody 0 L1S task: - l1a_l1s_com.melody0_task.command.start = TRUE; - - *state = M0_WAIT_START_CON; - } - - // End process - return; - } - // omaps00090550 break; - - case M0_WAIT_START_CON: - { - if (SignalCode == L1_MELODY0_START_CON) - { - // Disable the start command - l1a_l1s_com.melody0_task.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_MELODY0_START_CON); - - *state = M0_WAIT_STOP; - } - - // End process - return; - } - // omaps00090550 break; - - case M0_WAIT_STOP: - { - if (SignalCode == L1_MELODY0_STOP_CON) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_MELODY0_STOP_CON); - - *state = M0_RESET; - } - else - if (SignalCode == MMI_MELODY0_STOP_REQ) - { - // Stop the melody 0 L1S task: - l1a_l1s_com.melody0_task.command.stop = TRUE; - - // End process - return; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - - /*-------------------------------------------------------*/ - /* l1a_mmi_melody1_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* melody 1 feature. */ - /* */ - /* Starting messages: MMI_MELODY1_START_REQ */ - /* */ - /* Result messages (input): L1_MELODY1_START_CON */ - /* */ - /* Result messages (output): MMI_MELODY1_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_MELDOY1_STOP_REQ */ - /* L1_MELODY1_STOP_CON */ - /* */ - /* Stop message (output): MMI_MELODY1_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_melody1_process(xSignalHeaderRec *msg) - { - enum states - { - M1_RESET = 0, - M1_WAIT_START_REQ = 1, - M1_WAIT_START_CON = 2, - M1_WAIT_STOP = 3 - }; - - UWORD8 *state = &l1a.state[L1A_MELODY1_STATE]; - UWORD32 SignalCode = msg->SignalCode; - UWORD8 melody_osc, used_osc; - - while(1) - { - switch(*state) - { - case M1_RESET: - { - // Reset the commands: - l1a_l1s_com.melody1_task.command.start = FALSE; - l1a_l1s_com.melody1_task.command.stop = FALSE; - - // Initialize the translation table - for (melody_osc=0; melody_osc<SC_NUMBER_OSCILLATOR; melody_osc++) - l1a_l1s_com.melody1_task.parameters.melody_to_oscillator[melody_osc] = SC_NUMBER_OSCILLATOR; - - - *state = M1_WAIT_START_REQ; - } - break; - - case M1_WAIT_START_REQ: - { - if (SignalCode == MMI_MELODY1_START_REQ) - { - // Download the parameters from the message: - l1a_l1s_com.melody1_task.parameters.session_id = ((T_MMI_MELODY_REQ *)(msg->SigP))->session_id; - l1a_l1s_com.melody1_task.parameters.loopback = ((T_MMI_MELODY_REQ *)(msg->SigP))->loopback; - l1a_l1s_com.melody1_task.parameters.oscillator_used_bitmap = ((T_MMI_MELODY_REQ *)(msg->SigP))->oscillator_used_bitmap; - - // Initialize the buffer parameters - l1a_l1s_com.melody1_task.parameters.ptr_buf = NULL; - l1a_l1s_com.melody1_task.parameters.buffer_size = 0; - l1a_l1s_com.melody1_task.parameters.error_id = Cust_get_pointer((UWORD16 **)&l1a_l1s_com.melody1_task.parameters.ptr_buf, - &l1a_l1s_com.melody1_task.parameters.buffer_size, - l1a_l1s_com.melody1_task.parameters.session_id); - - // Read the Header of the melody description to have the melody bitmap - l1a_l1s_com.melody1_task.parameters.error_id = copy_data_from_buffer (l1a_l1s_com.melody1_task.parameters.session_id, - &l1a_l1s_com.melody1_task.parameters.buffer_size, - (UWORD16 **)&l1a_l1s_com.melody1_task.parameters.ptr_buf, - 1, - &l1a_l1s_com.melody1_task.parameters.oscillator_melody_bitmap); - - l1a_l1s_com.melody1_task.parameters.oscillator_melody_bitmap = Field(l1a_l1s_com.melody1_task.parameters.oscillator_melody_bitmap, SC_MELO_OSCILLATOR_USED_MASK, SC_MELO_OSCILLATOR_USED_SHIFT); - // Build the array of translation between the melody maaping and the oscillators used - used_osc = 0; - melody_osc = 0; - while ( (melody_osc < SC_NUMBER_OSCILLATOR) && (used_osc < SC_NUMBER_OSCILLATOR) ) - { - // find the next oscillator available in the melody - while( ((l1a_l1s_com.melody1_task.parameters.oscillator_melody_bitmap & (0x1<<melody_osc)) == 0) && (melody_osc < SC_NUMBER_OSCILLATOR) ) - melody_osc++; - - // find the next oscillator available in the oscillator used - while( ((l1a_l1s_com.melody1_task.parameters.oscillator_used_bitmap & (0x1<<used_osc)) == 0) && (melody_osc < SC_NUMBER_OSCILLATOR) ) - used_osc++; - - // Fill the translation table - if ( (melody_osc < SC_NUMBER_OSCILLATOR) && (used_osc < SC_NUMBER_OSCILLATOR) ) - l1a_l1s_com.melody1_task.parameters.melody_to_oscillator[melody_osc] = used_osc; - melody_osc++; - used_osc++; - } - - // Start the melody 1 L1S task: - l1a_l1s_com.melody1_task.command.start = TRUE; - - *state = M1_WAIT_START_CON; - } - - // End process - return; - } - // omaps00090550 break; - - case M1_WAIT_START_CON: - { - if (SignalCode == L1_MELODY1_START_CON) - { - // Disable the start command - l1a_l1s_com.melody1_task.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_MELODY1_START_CON); - - *state = M1_WAIT_STOP; - } - - // End process - return; - } - // omaps00090550 break; - case M1_WAIT_STOP: - { - if (SignalCode == L1_MELODY1_STOP_CON) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_MELODY1_STOP_CON); - - *state = M1_RESET; - } - else - if (SignalCode == MMI_MELODY1_STOP_REQ) - { - // Stop the melody 0 L1S task: - l1a_l1s_com.melody1_task.command.stop = TRUE; - - // End process - return; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - #endif // MELODY_E1 - -#if (VOICE_MEMO) - /*-------------------------------------------------------*/ - /* l1a_mmi_vm_playing_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* voice memorization playing feature. */ - /* */ - /* Starting messages: MMI_VM_PLAY_START_REQ */ - /* */ - /* Result messages (input): L1_VM_PLAY_START_CON */ - /* */ - /* Result messages (output): MMI_VM_PLAY_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_VM_PLAY_STOP_REQ */ - /* L1_VM_PLAY_STOP_CON */ - /* */ - /* Stop message (output): MMI_VM_PLAY_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_vm_playing_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_START_CON = 2, - WAIT_STOP = 3 - }; - - UWORD8 *state = &l1a.state[L1A_VM_PLAY_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.voicememo_task.play.command.start = FALSE; - l1a_l1s_com.voicememo_task.play.command.stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_VM_PLAY_START_REQ) - { - // Download the parameters of the message to the l1a_l1s_com structure. - l1a_l1s_com.voicememo_task.play.parameters.session_id = ((T_MMI_VM_PLAY_REQ *)(msg->SigP))->session_id; - - // Start the L1S voice memo playing task - l1a_l1s_com.voicememo_task.play.command.start = TRUE; - - *state = WAIT_START_CON; - } - - // End process - return; - } - // omaps00090550 break; - - case WAIT_START_CON: - { - if (SignalCode == L1_VM_PLAY_START_CON) - { - // Reset the start command - l1a_l1s_com.voicememo_task.play.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_VM_PLAY_START_CON); - - *state = WAIT_STOP; - } - - // End process - return; - } - // omaps00090550 break; - - case WAIT_STOP: - { - if (SignalCode == MMI_VM_PLAY_STOP_REQ) - { - // Stop the L1S voice memo playing task - l1a_l1s_com.voicememo_task.play.command.stop = TRUE; - - // End process - return; - } - else - if (SignalCode == L1_VM_PLAY_STOP_CON) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_VM_PLAY_STOP_CON); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - - /*-------------------------------------------------------*/ - /* l1a_mmi_vm_recording_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* voice memorization recording feature. */ - /* */ - /* Starting messages: MMI_VM_RECORD_START_REQ */ - /* */ - /* Result messages (input): L1_VM_RECORD_START_CON */ - /* */ - /* Result messages (output): MMI_VM_RECORD_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_VM_RECORD_STOP_REQ */ - /* L1_VM_RECORD_STOP_CON */ - /* */ - /* Stop message (output): MMI_VM_RECORD_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_vm_recording_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_START_CON = 2, - WAIT_STOP = 3 - }; - - UWORD8 *state = &l1a.state[L1A_VM_RECORD_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.voicememo_task.record.command.start = FALSE; - l1a_l1s_com.voicememo_task.record.command.stop = FALSE; - l1a_l1s_com.voicememo_task.record.tone_ul.start = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_VM_RECORD_START_REQ) - { - // Download the parameters of the message to the l1a_l1s_com structure. - l1a_l1s_com.voicememo_task.record.parameters.session_id = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->session_id; - l1a_l1s_com.voicememo_task.record.parameters.maximum_size = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->maximum_size; - l1a_l1s_com.voicememo_task.record.parameters.dtx = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->dtx_used; - - // Download UL/DL audio gain to the NDB - l1s_dsp_com.dsp_ndb_ptr->d_shiftul = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->record_coeff_ul; - l1s_dsp_com.dsp_ndb_ptr->d_shiftdl = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->record_coeff_dl; - - // Download the tone description in the NDB. - l1s_dsp_com.dsp_ndb_ptr->d_k_x1_t0 = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->d_k_x1_t0; - l1s_dsp_com.dsp_ndb_ptr->d_k_x1_t1 = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->d_k_x1_t1; - l1s_dsp_com.dsp_ndb_ptr->d_k_x1_t2 = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->d_k_x1_t2; - l1s_dsp_com.dsp_ndb_ptr->d_pe_rep = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->d_pe_rep; - l1s_dsp_com.dsp_ndb_ptr->d_pe_off = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->d_pe_off; - l1s_dsp_com.dsp_ndb_ptr->d_se_off = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->d_se_off; - l1s_dsp_com.dsp_ndb_ptr->d_bu_off = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->d_bu_off; - l1s_dsp_com.dsp_ndb_ptr->d_t0_on = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->d_t0_on; - l1s_dsp_com.dsp_ndb_ptr->d_t0_off = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->d_t0_off; - l1s_dsp_com.dsp_ndb_ptr->d_t1_on = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->d_t1_on; - l1s_dsp_com.dsp_ndb_ptr->d_t1_off = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->d_t1_off; - l1s_dsp_com.dsp_ndb_ptr->d_t2_on = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->d_t2_on; - l1s_dsp_com.dsp_ndb_ptr->d_t2_off = ((T_MMI_VM_RECORD_REQ *)(msg->SigP))->d_t2_off; - - // Start the L1S voice memo recording task - l1a_l1s_com.voicememo_task.record.command.start = TRUE; - - // Start the L1S voice memo tone uplink task - l1a_l1s_com.voicememo_task.record.tone_ul.start = TRUE; - - *state = WAIT_START_CON; - } - - // End process - return; - } - // omaps00090550 break; - - case WAIT_START_CON: - { - if (SignalCode == L1_VM_RECORD_START_CON) - { - // Reset the start command - l1a_l1s_com.voicememo_task.record.tone_ul.start = FALSE; - - // Reset the start command - l1a_l1s_com.voicememo_task.record.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_VM_RECORD_START_CON); - - *state = WAIT_STOP; - } - - // End process - return; - } - // omaps00090550 break; - - case WAIT_STOP: - { - if (SignalCode == MMI_VM_RECORD_STOP_REQ) - { - // Stop the L1S voice memo recording task - l1a_l1s_com.voicememo_task.record.command.stop = TRUE; - - // End process - return; - } - else - if (SignalCode == L1_VM_RECORD_STOP_CON) - { - // Forward the stop confirmation message - l1a_audio_send_result(MMI_VM_RECORD_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - #endif // VOICE_MEMO - - #if (L1_PCM_EXTRACTION) - #if (L1_DYN_DSP_DWNLD == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_pcm_download_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* PCM download feature. */ - /* */ - /* Starting messages: MMI_PCM_DOWNLOAD_START_REQ */ - /* */ - /* Result messages (input): L1_PCM_DOWNLOAD_START_CON */ - /* */ - /* Result messages (output): MMI_PCM_DOWNLOAD_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_PCM_DOWNLOAD_STOP_REQ */ - /* L1_PCM_DOWNLOAD_STOP_CON */ - /* */ - /* Stop message (output): MMI_PCM_DOWNLOAD_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_pcm_download_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_START_CON = 3, - WAIT_STOP = 4 - }; - - UWORD8 *state = &l1a.state[L1A_PCM_DOWNLOAD_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - BOOL end_process = 0; - - while(!end_process) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.pcm_task.download.command.start = FALSE; - l1a_l1s_com.pcm_task.download.command.stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_PCM_DOWNLOAD_START_REQ) - { - // Download the parameters of the message to the l1a_l1s_com structure. - l1a_l1s_com.pcm_task.download.parameters.session_id = ((T_MMI_PCM_DOWNLOAD_START_REQ *)(msg->SigP))->session_id; - l1a_l1s_com.pcm_task.download.parameters.maximum_size = ((T_MMI_PCM_DOWNLOAD_START_REQ *)(msg->SigP))->maximum_size; - - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_download = ((((T_MMI_PCM_DOWNLOAD_START_REQ *)(msg->SigP))->download_ul_gain) << 1); - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_download |= - ((((T_MMI_PCM_DOWNLOAD_START_REQ *)(msg->SigP))->download_dl_gain) << 8); - - if (l1a.dyn_dwnld.semaphore_vect[PCM_EXTRACTION_STATE_MACHINE]==GREEN) - { - // Start the L1S PCM download task - l1a_l1s_com.pcm_task.download.command.start = TRUE; - *state = WAIT_START_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"PCM Extraction SM blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - - // End process - end_process = 1; - } - break; - - case WAIT_DYN_DWNLD: - { - if((SignalCode==API_L1_DYN_DWNLD_FINISHED) && (l1a.dyn_dwnld.semaphore_vect[PCM_EXTRACTION_STATE_MACHINE] == GREEN)) - { - // Start the L1S PCM download task - l1a_l1s_com.pcm_task.download.command.start = TRUE; - *state = WAIT_START_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[32]; - sprintf(str,"PCM Extraction SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - // End process - end_process = 1; - } - break; - - case WAIT_START_CON: - { - if (SignalCode == L1_PCM_DOWNLOAD_START_CON) - { - // Reset the start command - l1a_l1s_com.pcm_task.download.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_PCM_DOWNLOAD_START_CON); - - *state = WAIT_STOP; - } - - // End process - end_process = 1; - } - break; - - case WAIT_STOP: - { - - UWORD32 maximum_size; - - if (SignalCode == MMI_PCM_DOWNLOAD_STOP_REQ) - { - maximum_size = ((T_MMI_PCM_DOWNLOAD_STOP_REQ *)(msg->SigP))->maximum_size; - if(maximum_size == 0) - { - // Stop the L1S PCM download task - l1a_l1s_com.pcm_task.download.command.stop = TRUE; - } - else - { - l1a_l1s_com.pcm_task.download.parameters.maximum_size = maximum_size; - - } - - // End process - return; - } - else - if (SignalCode == L1_PCM_DOWNLOAD_STOP_CON) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_PCM_DOWNLOAD_STOP_CON); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(!end_process) - } - - /*-------------------------------------------------------*/ - /* l1a_mmi_pcm_upload_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* PCM upload feature. */ - /* */ - /* Starting messages: MMI_PCM_UPLOAD_START_REQ */ - /* */ - /* Result messages (input): L1_PCM_UPLOAD_START_CON */ - /* */ - /* Result messages (output): MMI_PCM_UPLOAD_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_PCM_UPLOAD_STOP_REQ */ - /* L1_PCM_UPLOAD_STOP_CON */ - /* */ - /* Stop message (output): MMI_PCM_UPLOAD_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_pcm_upload_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_START_CON = 3, - WAIT_STOP = 4 - }; - - UWORD8 *state = &l1a.state[L1A_PCM_UPLOAD_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - BOOL end_process = 0; - - while(!end_process) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.pcm_task.upload.command.start = FALSE; - l1a_l1s_com.pcm_task.upload.command.stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_PCM_UPLOAD_START_REQ) - { - // Download the parameters of the message to the l1a_l1s_com structure. - l1a_l1s_com.pcm_task.upload.parameters.session_id = ((T_MMI_PCM_UPLOAD_START_REQ *)(msg->SigP))->session_id; - l1a_l1s_com.pcm_task.upload.parameters.maximum_size = ((T_MMI_PCM_UPLOAD_START_REQ *)(msg->SigP))->maximum_size; - - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_upload = ((((T_MMI_PCM_UPLOAD_START_REQ *)(msg->SigP))->upload_ul_gain) << 1); - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_upload |= ((((T_MMI_PCM_UPLOAD_START_REQ *)(msg->SigP))->upload_dl_gain) << 8); - - if (l1a.dyn_dwnld.semaphore_vect[PCM_EXTRACTION_STATE_MACHINE]==GREEN) - { - // Start the L1S PCM upload task - l1a_l1s_com.pcm_task.upload.command.start = TRUE; - *state = WAIT_START_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"PCM Extraction SM blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - - - } - - // End process - end_process = 1; - } - break; - - case WAIT_DYN_DWNLD: - { - if((SignalCode==API_L1_DYN_DWNLD_FINISHED) && (l1a.dyn_dwnld.semaphore_vect[PCM_EXTRACTION_STATE_MACHINE] == GREEN)) - { - // Start the L1S PCM upload task - l1a_l1s_com.pcm_task.upload.command.start = TRUE; - *state = WAIT_START_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[32]; - sprintf(str,"PCM Extraction SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - // End process - end_process = 1; - } - break; - - case WAIT_START_CON: - { - if (SignalCode == L1_PCM_UPLOAD_START_CON) - { - // Reset the start command - l1a_l1s_com.pcm_task.upload.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_PCM_UPLOAD_START_CON); - - *state = WAIT_STOP; - } - - // End process - end_process = 1; - } - break; - - case WAIT_STOP: - { - if (SignalCode == MMI_PCM_UPLOAD_STOP_REQ) - { - // Stop the L1S PCM recording task - l1a_l1s_com.pcm_task.upload.command.stop = TRUE; - - // End process - return; - } - else - if (SignalCode == L1_PCM_UPLOAD_STOP_CON) - { - // Forward the stop confirmation message - l1a_audio_send_result(MMI_PCM_UPLOAD_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(!end_process) - } - -#else /*L1_DYN_DSP_DWNLD == 0 - -// l1a_mmi_pcm_download_process() -// Description: -// This function is a state machine which handles the */ -// PCM download feature. - // Starting messages: MMI_PCM_DOWNLOAD_START_REQ -// Result messages (input): L1_PCM_DOWNLOAD_START_CON - // Result messages (output): MMI_PCM_DOWNLOAD_START_CON -// Reset messages (input): none - // Stop message (input): MMI_PCM_DOWNLOAD_STOP_REQ - //L1_PCM_DOWNLOAD_STOP_CON -// Stop message (output): MMI_PCM_DOWNLOAD_STOP_CON */ - //Rem: */ - - void l1a_mmi_pcm_download_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_START_CON = 2, - WAIT_STOP = 3 - }; - - UWORD8 *state = &l1a.state[L1A_PCM_DOWNLOAD_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - BOOL end_process = 0; - - while(!end_process) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.pcm_task.download.command.start = FALSE; - l1a_l1s_com.pcm_task.download.command.stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_PCM_DOWNLOAD_START_REQ) - { - // Download the parameters of the message to the l1a_l1s_com structure. - l1a_l1s_com.pcm_task.download.parameters.session_id = ((T_MMI_PCM_DOWNLOAD_START_REQ *)(msg->SigP))->session_id; - l1a_l1s_com.pcm_task.download.parameters.maximum_size = ((T_MMI_PCM_DOWNLOAD_START_REQ *)(msg->SigP))->maximum_size; - - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_download = ((((T_MMI_PCM_DOWNLOAD_START_REQ *)(msg->SigP))->download_ul_gain) << 1); - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_download |= - ((((T_MMI_PCM_DOWNLOAD_START_REQ *)(msg->SigP))->download_dl_gain) << 8); - // Start the L1S PCM download task - l1a_l1s_com.pcm_task.download.command.start = TRUE; - - *state = WAIT_START_CON; - } - - // End process - end_process = 1; - } - break; - - case WAIT_START_CON: - { - if (SignalCode == L1_PCM_DOWNLOAD_START_CON) - { - // Reset the start command - l1a_l1s_com.pcm_task.download.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_PCM_DOWNLOAD_START_CON); - - *state = WAIT_STOP; - } - - // End process - end_process = 1; - } - break; - - case WAIT_STOP: - { - - UWORD32 maximum_size; - - if (SignalCode == MMI_PCM_DOWNLOAD_STOP_REQ) - { - maximum_size = ((T_MMI_PCM_DOWNLOAD_STOP_REQ *)(msg->SigP))->maximum_size; - if(maximum_size == 0) - { - // Stop the L1S PCM download task - l1a_l1s_com.pcm_task.download.command.stop = TRUE; - } - else - { - l1a_l1s_com.pcm_task.download.parameters.maximum_size = maximum_size; - - } - - // End process - return; - } - else - if (SignalCode == L1_PCM_DOWNLOAD_STOP_CON) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_PCM_DOWNLOAD_STOP_CON); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(!end_process) - } - - /*-------------------------------------------------------*/ - /* l1a_mmi_pcm_upload_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* PCM upload feature. */ - /* */ - /* Starting messages: MMI_PCM_UPLOAD_START_REQ */ - /* */ - /* Result messages (input): L1_PCM_UPLOAD_START_CON */ - /* */ - /* Result messages (output): MMI_PCM_UPLOAD_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_PCM_UPLOAD_STOP_REQ */ - /* L1_PCM_UPLOAD_STOP_CON */ - /* */ - /* Stop message (output): MMI_PCM_UPLOAD_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_pcm_upload_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_START_CON = 2, - WAIT_STOP = 3 - }; - - UWORD8 *state = &l1a.state[L1A_PCM_UPLOAD_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - BOOL end_process = 0; - - while(!end_process) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.pcm_task.upload.command.start = FALSE; - l1a_l1s_com.pcm_task.upload.command.stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_PCM_UPLOAD_START_REQ) - { - // Download the parameters of the message to the l1a_l1s_com structure. - l1a_l1s_com.pcm_task.upload.parameters.session_id = ((T_MMI_PCM_UPLOAD_START_REQ *)(msg->SigP))->session_id; - l1a_l1s_com.pcm_task.upload.parameters.maximum_size = ((T_MMI_PCM_UPLOAD_START_REQ *)(msg->SigP))->maximum_size; - - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_upload = ((((T_MMI_PCM_UPLOAD_START_REQ *)(msg->SigP))->upload_ul_gain) << 1); - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_upload |= ((((T_MMI_PCM_UPLOAD_START_REQ *)(msg->SigP))->upload_dl_gain) << 8); - - // Start the L1S voice memo recording task - l1a_l1s_com.pcm_task.upload.command.start = TRUE; - - - *state = WAIT_START_CON; - } - - // End process - end_process = 1; - } - break; - - case WAIT_START_CON: - { - if (SignalCode == L1_PCM_UPLOAD_START_CON) - { - // Reset the start command - l1a_l1s_com.pcm_task.upload.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_PCM_UPLOAD_START_CON); - - *state = WAIT_STOP; - } - - // End process - end_process = 1; - } - break; - - case WAIT_STOP: - { - if (SignalCode == MMI_PCM_UPLOAD_STOP_REQ) - { - // Stop the L1S PCM recording task - l1a_l1s_com.pcm_task.upload.command.stop = TRUE; - - // End process - return; - } - else - if (SignalCode == L1_PCM_UPLOAD_STOP_CON) - { - // Forward the stop confirmation message - l1a_audio_send_result(MMI_PCM_UPLOAD_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(!end_process) - } - #endif /* L1_DYN_DSP_DWNLD */ - - #endif /* L1_PCM_EXTRACTION */ - - #if (L1_VOICE_MEMO_AMR) - - #if (L1_DYN_DSP_DWNLD==1) - /*-------------------------------------------------------*/ - /* l1a_mmi_vm_amr_playing_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* voice memorization playing feature. */ - /* */ - /* Starting messages: MMI_VM_AMR_PLAY_START_REQ */ - /* */ - /* Result messages (input): L1_VM_AMR_PLAY_START_CON */ - /* */ - /* Result messages (output): MMI_VM_AMR_PLAY_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_VM_AMR_PLAY_STOP_REQ */ - /* L1_VM_AMR_PLAY_STOP_CON */ - /* */ - /* Stop message (output): MMI_VM_AMR_PLAY_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_vm_amr_playing_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_START_CON = 3, - WAIT_STOP = 4, - VM_AMR_PLAY = 5, - VM_AMR_PAUSE = 6, - VM_AMR_PAUSE_CON = 7, - WAIT_RESUME_CON = 8 - - - }; - - UWORD8 *state = &l1a.state[L1A_VM_AMR_PLAY_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.voicememo_amr_task.play.command.start = FALSE; - l1a_l1s_com.voicememo_amr_task.play.command.stop = FALSE; - l1a_l1s_com.voicememo_amr_task.play.command.pause = FALSE; - l1a_l1s_com.voicememo_amr_task.play.command.resume = FALSE; - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if(SignalCode == MMI_VM_AMR_PLAY_START_REQ) - { - // Download the parameters of the message to the l1a_l1s_com structure. - l1a_l1s_com.voicememo_amr_task.play.parameters.session_id = ((T_MMI_VM_AMR_PLAY_REQ *)(msg->SigP))->session_id; - - if (l1a.dyn_dwnld.semaphore_vect[VM_STATE_MACHINE]==GREEN) - { - // WARNING: code below must be duplicated in WAIT_DYN_DWNLD state - // Start the L1S voice memo playing task - l1a_l1s_com.voicememo_amr_task.play.command.start = TRUE; - *state = WAIT_START_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"VOICE PLAY AMR SM blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - // End process - return; - } -// omaps00090550 break; - case WAIT_DYN_DWNLD: - { - if((SignalCode==API_L1_DYN_DWNLD_FINISHED) && (l1a.dyn_dwnld.semaphore_vect[VM_STATE_MACHINE] == GREEN)) - { - // Start the L1S voice memo playing task - l1a_l1s_com.voicememo_amr_task.play.command.start = TRUE; - *state = WAIT_START_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[32]; - sprintf(str,"VOICE PLAY AMR SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - // omaps00090550 break; - case WAIT_START_CON: - { - if (SignalCode == L1_VM_AMR_PLAY_START_CON) - { - // Reset the start command - l1a_l1s_com.voicememo_amr_task.play.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_VM_AMR_PLAY_START_CON); - - *state = VM_AMR_PLAY ; - } - - // End process - return; - } - // omaps00090550 break; - - case WAIT_STOP: - { - if (SignalCode == L1_VM_AMR_PLAY_STOP_CON) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_VM_AMR_PLAY_STOP_CON); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - case VM_AMR_PLAY: - { - switch (SignalCode) - { - case MMI_VM_AMR_PAUSE_REQ: - { - // Stop the L1S voice memo playing task - l1a_l1s_com.voicememo_amr_task.play.command.pause= TRUE; - *state = VM_AMR_PAUSE_CON; - - } - break; - case MMI_VM_AMR_PLAY_STOP_REQ: - { - // Stop the L1S voice memo playing task - l1a_l1s_com.voicememo_amr_task.play.command.stop = TRUE; - *state=WAIT_STOP; - - } - break; - case L1_VM_AMR_PLAY_STOP_CON: - { - l1a_audio_send_confirmation(MMI_VM_AMR_PLAY_STOP_CON); - - *state = RESET; - } - break; - } - return; - } - - case VM_AMR_PAUSE_CON: - { - if(SignalCode==L1_VM_AMR_PAUSE_CON) - { - // Send confirmation to upper layers - l1a_audio_send_confirmation(MMI_VM_AMR_PAUSE_CON); - - // Change state - *state=VM_AMR_PAUSE; - } - else if(SignalCode== L1_VM_AMR_PLAY_STOP_CON) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_VM_AMR_PLAY_STOP_CON); - - *state = RESET; - } - return; - } // case WAIT_PAUSE_CON - // ************* - // * VM_AMR_PAUSE * - // ************* - case VM_AMR_PAUSE: - { - switch(SignalCode) - { - // * MMI requests VM_AMR resume * - case MMI_VM_AMR_RESUME_REQ: - { - l1a_l1s_com.voicememo_amr_task.play.command.pause= FALSE; - l1a_l1s_com.voicememo_amr_task.play.command.resume=TRUE; - - // Change state - *state=WAIT_RESUME_CON; - - } - break; - // *-----------------------* - // * MMI requests VM_AMR stop * - // *-----------------------* - case MMI_VM_AMR_PLAY_STOP_REQ: - { - // Store stop request in L1A/HISR interface - l1a_l1s_com.voicememo_amr_task.play.command.stop=TRUE; - - // Change state - *state=WAIT_STOP; - - } - break; - case L1_VM_AMR_PLAY_STOP_CON: - { - l1a_audio_send_confirmation(MMI_VM_AMR_PLAY_STOP_CON); - - *state = RESET; - } - break; - } - return; - } - // case VM_AMR_PAUSE - // ******************* - // * WAIT_RESUME_CON * - // ******************* - case WAIT_RESUME_CON: - { - if(SignalCode==L1_VM_AMR_RESUME_CON) - { - l1a_l1s_com.voicememo_amr_task.play.command.resume=FALSE; - // Send confirmation to upper layers - l1a_audio_send_confirmation(MMI_VM_AMR_RESUME_CON); - - // Change state - *state=VM_AMR_PLAY; - } - return; - } // case WAIT_RESUME_CON - } // switch - } // while(1) - } - - /*-------------------------------------------------------*/ - /* l1a_mmi_vm_amr_recording_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* voice memorization recording feature. */ - /* */ - /* Starting messages: MMI_VM_AMR_RECORD_START_REQ */ - /* */ - /* Result messages (input): L1_VM_AMR_RECORD_START_CON */ - /* */ - /* Result messages (output): MMI_VM_AMR_RECORD_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_VM_AMR_RECORD_STOP_REQ */ - /* L1_VM_AMR_RECORD_STOP_CON */ - /* */ - /* Stop message (output): MMI_VM_AMR_RECORD_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_vm_amr_recording_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_START_CON = 3, - WAIT_STOP = 4 - }; - - UWORD8 *state = &l1a.state[L1A_VM_AMR_RECORD_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.voicememo_amr_task.record.command.start = FALSE; - l1a_l1s_com.voicememo_amr_task.record.command.stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_VM_AMR_RECORD_START_REQ) - { - // Download the parameters of the message to the l1a_l1s_com structure. - l1a_l1s_com.voicememo_amr_task.record.parameters.session_id = ((T_MMI_VM_AMR_RECORD_REQ *)(msg->SigP))->session_id; - l1a_l1s_com.voicememo_amr_task.record.parameters.maximum_size = ((T_MMI_VM_AMR_RECORD_REQ *)(msg->SigP))->maximum_size; - l1a_l1s_com.voicememo_amr_task.record.parameters.dtx = ((T_MMI_VM_AMR_RECORD_REQ *)(msg->SigP))->dtx_used; - l1a_l1s_com.voicememo_amr_task.record.parameters.amr_vocoder = ((T_MMI_VM_AMR_RECORD_REQ *)(msg->SigP))->amr_vocoder; - - // Download UL/DL audio gain to the NDB - l1s_dsp_com.dsp_ndb_ptr->d_shiftul = ((T_MMI_VM_AMR_RECORD_REQ *)(msg->SigP))->record_coeff_ul; - - if(l1a.dyn_dwnld.semaphore_vect[VM_STATE_MACHINE]==GREEN) - { - // WARNING: code below must be duplicated in WAIT_DYN_DWNLD state - // Start the L1S voice memo recording task - l1a_l1s_com.voicememo_amr_task.record.command.start = TRUE; - - *state = WAIT_START_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"VOICE MEMO AMR SM blocked \r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - // End process - return; - } - // omaps00090550 break; - case WAIT_DYN_DWNLD: - { - if((SignalCode == API_L1_DYN_DWNLD_FINISHED) && (l1a.dyn_dwnld.semaphore_vect[VM_STATE_MACHINE] == GREEN)) - { - // Start the L1S voice memo recording task - l1a_l1s_com.voicememo_amr_task.record.command.start = TRUE; - *state = WAIT_START_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[32]; - sprintf(str,"VOICE MEMO AMR SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - // omaps00090550 break; - case WAIT_START_CON: - { - if (SignalCode == L1_VM_AMR_RECORD_START_CON) - { - // Reset the start command - l1a_l1s_com.voicememo_amr_task.record.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_VM_AMR_RECORD_START_CON); - - *state = WAIT_STOP; - } - - // End process - return; - } - // omaps00090550 break; - - case WAIT_STOP: - { - if (SignalCode == MMI_VM_AMR_RECORD_STOP_REQ) - { - // Stop the L1S voice memo recording task - l1a_l1s_com.voicememo_amr_task.record.command.stop = TRUE; - - // End process - return; - } - else - if (SignalCode == L1_VM_AMR_RECORD_STOP_CON) - { - // Forward the stop confirmation message - l1a_audio_send_result(MMI_VM_AMR_RECORD_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - -#else // L1_DYN_DSP_DWNLD = 0 - - /*-------------------------------------------------------*/ - /* l1a_mmi_vm_amr_playing_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* voice memorization playing feature. */ - /* */ - /* Starting messages: MMI_VM_AMR_PLAY_START_REQ */ - /* */ - /* Result messages (input): L1_VM_AMR_PLAY_START_CON */ - /* */ - /* Result messages (output): MMI_VM_AMR_PLAY_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_VM_AMR_PLAY_STOP_REQ */ - /* L1_VM_AMR_PLAY_STOP_CON */ - /* */ - /* Stop message (output): MMI_VM_AMR_PLAY_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - - void l1a_mmi_vm_amr_playing_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_START_CON = 2, - WAIT_STOP = 3, - VM_AMR_PLAY = 4, - VM_AMR_PAUSE = 5, - VM_AMR_PAUSE_CON = 6, - WAIT_RESUME_CON = 7 - - }; - - UWORD8 *state = &l1a.state[L1A_VM_AMR_PLAY_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.voicememo_amr_task.play.command.start = FALSE; - l1a_l1s_com.voicememo_amr_task.play.command.stop = FALSE; - l1a_l1s_com.voicememo_amr_task.play.command.pause = FALSE; - l1a_l1s_com.voicememo_amr_task.play.command.resume = FALSE; - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_VM_AMR_PLAY_START_REQ) - { - // Download the parameters of the message to the l1a_l1s_com structure. - l1a_l1s_com.voicememo_amr_task.play.parameters.session_id = ((T_MMI_VM_AMR_PLAY_REQ *)(msg->SigP))->session_id; - - // Start the L1S voice memo playing task - l1a_l1s_com.voicememo_amr_task.play.command.start = TRUE; - - *state = WAIT_START_CON; - } - - // End process - return; - } - break; - - case WAIT_START_CON: - { - if (SignalCode == L1_VM_AMR_PLAY_START_CON) - { - // Reset the start command - l1a_l1s_com.voicememo_amr_task.play.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_VM_AMR_PLAY_START_CON); - - *state = VM_AMR_PLAY ; - } - - // End process - return; - } - break; - - case WAIT_STOP: - { - if (SignalCode == L1_VM_AMR_PLAY_STOP_CON) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_VM_AMR_PLAY_STOP_CON); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - case VM_AMR_PLAY: - { - switch (SignalCode) - { - case MMI_VM_AMR_PAUSE_REQ: - { - // Stop the L1S voice memo playing task - l1a_l1s_com.voicememo_amr_task.play.command.pause= TRUE; - *state = VM_AMR_PAUSE_CON; - - } - break; - case MMI_VM_AMR_PLAY_STOP_REQ: - { - // Stop the L1S voice memo playing task - l1a_l1s_com.voicememo_amr_task.play.command.stop = TRUE; - *state=WAIT_STOP; - - } - break; - case L1_VM_AMR_PLAY_STOP_CON: - { - l1a_audio_send_confirmation(MMI_VM_AMR_PLAY_STOP_CON); - - *state = RESET; - } - break; - } - return; - } - - case VM_AMR_PAUSE_CON: - { - if(SignalCode==L1_VM_AMR_PAUSE_CON) - { - // Send confirmation to upper layers - l1a_audio_send_confirmation(MMI_VM_AMR_PAUSE_CON); - - // Change state - *state=VM_AMR_PAUSE; - } - else if(SignalCode== L1_VM_AMR_PLAY_STOP_CON) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_VM_AMR_PLAY_STOP_CON); - - *state = RESET; - } - return; - } // case WAIT_PAUSE_CON - // ************* - // * VM_AMR_PAUSE * - // ************* - case VM_AMR_PAUSE: - { - switch(SignalCode) - { - // * MMI requests VM_AMR resume * - case MMI_VM_AMR_RESUME_REQ: - { - l1a_l1s_com.voicememo_amr_task.play.command.pause= FALSE; - l1a_l1s_com.voicememo_amr_task.play.command.resume=TRUE; - - // Change state - *state=WAIT_RESUME_CON; - - } - break; - // *-----------------------* - // * MMI requests VM_AMR stop * - // *-----------------------* - case MMI_VM_AMR_PLAY_STOP_REQ: - { - // Store stop request in L1A/HISR interface - l1a_l1s_com.voicememo_amr_task.play.command.stop=TRUE; - - // Change state - *state=WAIT_STOP; - - } - break; - case L1_VM_AMR_PLAY_STOP_CON: - { - l1a_audio_send_confirmation(MMI_VM_AMR_PLAY_STOP_CON); - - *state = RESET; - } - break; - } - return; - } - // case VM_AMR_PAUSE - // ******************* - // * WAIT_RESUME_CON * - // ******************* - case WAIT_RESUME_CON: - { - if(SignalCode==L1_VM_AMR_RESUME_CON) - { - l1a_l1s_com.voicememo_amr_task.play.command.resume=FALSE; - // Send confirmation to upper layers - l1a_audio_send_confirmation(MMI_VM_AMR_RESUME_CON); - - // Change state - *state=VM_AMR_PLAY; - } - return; - } // case WAIT_RESUME_CON - } // switch - } // while(1) - } - - /*-------------------------------------------------------*/ - /* l1a_mmi_vm_amr_recording_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* voice memorization recording feature. */ - /* */ - /* Starting messages: MMI_VM_AMR_RECORD_START_REQ */ - /* */ - /* Result messages (input): L1_VM_AMR_RECORD_START_CON */ - /* */ - /* Result messages (output): MMI_VM_AMR_RECORD_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_VM_AMR_RECORD_STOP_REQ */ - /* L1_VM_AMR_RECORD_STOP_CON */ - /* */ - /* Stop message (output): MMI_VM_AMR_RECORD_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - - void l1a_mmi_vm_amr_recording_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_START_CON = 2, - WAIT_STOP = 3 - }; - - UWORD8 *state = &l1a.state[L1A_VM_AMR_RECORD_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.voicememo_amr_task.record.command.start = FALSE; - l1a_l1s_com.voicememo_amr_task.record.command.stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_VM_AMR_RECORD_START_REQ) - { - // Download the parameters of the message to the l1a_l1s_com structure. - l1a_l1s_com.voicememo_amr_task.record.parameters.session_id = ((T_MMI_VM_AMR_RECORD_REQ *)(msg->SigP))->session_id; - l1a_l1s_com.voicememo_amr_task.record.parameters.maximum_size = ((T_MMI_VM_AMR_RECORD_REQ *)(msg->SigP))->maximum_size; - l1a_l1s_com.voicememo_amr_task.record.parameters.dtx = ((T_MMI_VM_AMR_RECORD_REQ *)(msg->SigP))->dtx_used; - l1a_l1s_com.voicememo_amr_task.record.parameters.amr_vocoder = ((T_MMI_VM_AMR_RECORD_REQ *)(msg->SigP))->amr_vocoder; - - // Download UL/DL audio gain to the NDB - l1s_dsp_com.dsp_ndb_ptr->d_shiftul = ((T_MMI_VM_AMR_RECORD_REQ *)(msg->SigP))->record_coeff_ul; - - // Start the L1S voice memo recording task - l1a_l1s_com.voicememo_amr_task.record.command.start = TRUE; - - *state = WAIT_START_CON; - } - - // End process - return; - } - break; - - case WAIT_START_CON: - { - if (SignalCode == L1_VM_AMR_RECORD_START_CON) - { - // Reset the start command - l1a_l1s_com.voicememo_amr_task.record.command.start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_VM_AMR_RECORD_START_CON); - - *state = WAIT_STOP; - } - - // End process - return; - } - break; - - case WAIT_STOP: - { - if (SignalCode == MMI_VM_AMR_RECORD_STOP_REQ) - { - // Stop the L1S voice memo recording task - l1a_l1s_com.voicememo_amr_task.record.command.stop = TRUE; - - // End process - return; - } - else - if (SignalCode == L1_VM_AMR_RECORD_STOP_CON) - { - // Forward the stop confirmation message - l1a_audio_send_result(MMI_VM_AMR_RECORD_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - #endif // L1_DYN_DSP_DWNLD - #endif // L1_VOICE_MEMO_AMR - - #if (SPEECH_RECO) - #if(L1_DYN_DSP_DWNLD == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_sr_enroll_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* speech recognition enrollment feature. */ - /* */ - /* Starting messages: MMI_SR_ENROLL_START_REQ */ - /* */ - /* Result messages (input): L1_SR_ENROLL_START_CON */ - /* */ - /* Result messages (output): MMI_SR_ENROLL_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_SR_ENROLL_STOP_REQ */ - /* L1_SR_ENROLL_STOP_CON */ - /* */ - /* Stop message (output): MMI_SR_ENROLL_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_sr_enroll_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_START_CON = 3, - WAIT_STOP = 4, - WAIT_BACK_TASK_DONE = 5, - WAIT_L1S_STOP = 6, - WAIT_BACK_STOP = 7 - }; - - UWORD8 *state = &l1a.state[L1A_SR_ENROLL_STATE]; - UWORD32 SignalCode = msg->SignalCode; - #if (OP_RIV_AUDIO == 1) - void *p_message; - T_RVF_MB_STATUS mb_status; - #else - xSignalHeaderRec *conf_msg; - #endif - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.enroll_start = FALSE; - l1a_l1s_com.speechreco_task.command.enroll_stop = FALSE; - l1a_l1s_com.speechreco_task.command.speech_start = FALSE; - l1a_l1s_com.speechreco_task.command.speech_stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_SR_ENROLL_START_REQ) - { - // Download the message parameters to the parameters memory - l1a_l1s_com.speechreco_task.parameters.database_id = ((T_MMI_SR_ENROLL_REQ *)(msg->SigP))->database_id; - l1a_l1s_com.speechreco_task.parameters.word_index = ((T_MMI_SR_ENROLL_REQ *)(msg->SigP))->word_index; - l1a_l1s_com.speechreco_task.parameters.model_address = l1s_dsp_com.dsp_ndb_ptr->a_model; - l1a_l1s_com.speechreco_task.parameters.speech = ((T_MMI_SR_ENROLL_REQ *)(msg->SigP))->speech; - l1a_l1s_com.speechreco_task.parameters.speech_address = ((T_MMI_SR_ENROLL_REQ *)(msg->SigP))->speech_address; - - if(l1a.dyn_dwnld.semaphore_vect[SR_STATE_MACHINE]==GREEN) - { - - // WARNING: code below must be duplicated in WAIT_DYN_DWNLD state - // Set the start command of the speech recording task - l1a_l1s_com.speechreco_task.command.speech_start = l1a_l1s_com.speechreco_task.parameters.speech; - - // Start the speech recognition enrollment task - l1a_l1s_com.speechreco_task.command.enroll_start = TRUE; - - *state = WAIT_START_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"SPEECH RECO SM blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - - // End process - return; - } - break; - case WAIT_DYN_DWNLD: - { - if((SignalCode == API_L1_DYN_DWNLD_FINISHED) && (l1a.dyn_dwnld.semaphore_vect[SR_STATE_MACHINE] == GREEN)) - { - // Set the start command of the speech recording task - l1a_l1s_com.speechreco_task.command.speech_start = l1a_l1s_com.speechreco_task.parameters.speech; - - // Start the speech recognition enrollment task - l1a_l1s_com.speechreco_task.command.enroll_start = TRUE; - *state = WAIT_START_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"SPEECH RECO SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - break; - case WAIT_START_CON: - { - if (SignalCode == L1_SR_ENROLL_START_CON) - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.enroll_start = FALSE; - l1a_l1s_com.speechreco_task.command.speech_start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_SR_ENROLL_START_CON); - - *state = WAIT_STOP; - } - - // End process - return; - } - break; - - case WAIT_STOP: - { - if (SignalCode == MMI_SR_ENROLL_STOP_REQ) - { - // Stop the speech recognition enroll task - l1a_l1s_com.speechreco_task.command.enroll_stop = TRUE; - - // Stop the speech recording task (if present) - l1a_l1s_com.speechreco_task.command.speech_stop = l1a_l1s_com.speechreco_task.parameters.speech; - - *state = WAIT_L1S_STOP; - - // End process - return; - } - else - if (SignalCode == L1_SR_ENROLL_STOP_CON) - { - // There is an error during the acquisition task? - if ( ((T_L1_SR_ENROLL_STOP_CON *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - // Reset the background task emergency stop - l1_srback_com.emergency_stop = FALSE; - - // Send the message L1_SRBACK_SAVE_DATA_REQ to the background task - l1_send_sr_background_msg(L1_SRBACK_SAVE_DATA_REQ); - - *state = WAIT_BACK_TASK_DONE; - - // End process - return; - } - else - // There is an error - { - // Forward the stop confirmation message - l1a_audio_send_result(MMI_SR_ENROLL_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - } - else - { - // End process - return; - } - } - break; - - case WAIT_BACK_TASK_DONE: - { - if (SignalCode == L1_SRBACK_SAVE_DATA_CON) - { - // Send the stop confirmation message with no error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_ENROLL_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_ENROLL_STOP_CON *)(p_message))->header.msg_id = MMI_SR_ENROLL_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_ENROLL_STOP_CON *)(p_message))->error_id = SC_NO_ERROR; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig( sizeof(T_MMI_SR_ENROLL_STOP_CON) ); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_ENROLL_STOP_CON; - - //Fill the message - ((T_MMI_SR_ENROLL_STOP_CON *)(conf_msg->SigP))->error_id = SC_NO_ERROR; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - - } - else - if (SignalCode == MMI_SR_ENROLL_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - - // End process - return; - } - else - { - // End process - return; - } - } - break; - - case WAIT_BACK_STOP: - { - if (SignalCode == L1_SRBACK_SAVE_DATA_CON) - { - // Send the message MMI_SR_ENROLL_STOP_CON with an acquisition error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_ENROLL_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_ENROLL_STOP_CON *)(p_message))->header.msg_id = MMI_SR_ENROLL_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_ENROLL_STOP_CON *)(p_message))->error_id = SC_BAD_ACQUISITION; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_ENROLL_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_ENROLL_STOP_CON; - - //Fill the message - ((T_MMI_SR_ENROLL_STOP_CON *)(conf_msg->SigP))->error_id = SC_BAD_ACQUISITION; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - - case WAIT_L1S_STOP: - { - if (SignalCode == L1_SR_ENROLL_STOP_CON) - { - // Send the message MMI_SR_ENROLL_STOP_CON with an acquisition error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_ENROLL_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_ENROLL_STOP_CON *)(p_message))->header.msg_id = MMI_SR_ENROLL_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_ENROLL_STOP_CON *)(p_message))->error_id = SC_BAD_ACQUISITION; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_ENROLL_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_ENROLL_STOP_CON; - - //Fill the message - ((T_MMI_SR_ENROLL_STOP_CON *)(conf_msg->SigP))->error_id = SC_BAD_ACQUISITION; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - - /*-------------------------------------------------------*/ - /* l1a_mmi_sr_update_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* speech recognition update feature. */ - /* */ - /* Starting messages: MMI_SR_UPDATE_START_REQ */ - /* */ - /* Result messages (input): L1_SR_UPDATE_START_CON */ - /* */ - /* Result messages (output): MMI_SR_UPDATE_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_SR_UPDATE_STOP_REQ */ - /* L1_SR_UPDATE_STOP_CON */ - /* */ - /* Stop message (output): MMI_SR_UPDATE_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_sr_update_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_MODEL_LOADED = 3, - WAIT_START_CON = 4, - WAIT_STOP = 5, - WAIT_BACK_TASK_DONE = 6, - WAIT_L1S_STOP = 7, - WAIT_BACK_STOP = 8 - }; - - UWORD8 *state = &l1a.state[L1A_SR_UPDATE_STATE]; - UWORD32 SignalCode = msg->SignalCode; - #if (OP_RIV_AUDIO == 1) - void *p_message; - T_RVF_MB_STATUS mb_status; - #else - xSignalHeaderRec *conf_msg; - #endif - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.update_start = FALSE; - l1a_l1s_com.speechreco_task.command.update_stop = FALSE; - l1a_l1s_com.speechreco_task.command.speech_start = FALSE; - l1a_l1s_com.speechreco_task.command.speech_stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_SR_UPDATE_START_REQ) - { - // Download the message parameters to the parameters memory - l1a_l1s_com.speechreco_task.parameters.database_id = ((T_MMI_SR_UPDATE_REQ *)(msg->SigP))->database_id; - l1a_l1s_com.speechreco_task.parameters.word_index = ((T_MMI_SR_UPDATE_REQ *)(msg->SigP))->word_index; - l1a_l1s_com.speechreco_task.parameters.model_address = l1s_dsp_com.dsp_ndb_ptr->a_model; - l1a_l1s_com.speechreco_task.parameters.speech = ((T_MMI_SR_UPDATE_REQ *)(msg->SigP))->speech; - l1a_l1s_com.speechreco_task.parameters.speech_address = ((T_MMI_SR_UPDATE_REQ *)(msg->SigP))->speech_address; - - // Reset the background task emergency stop - l1_srback_com.emergency_stop = FALSE; - - l1a_l1s_com.speechreco_task.parameters.CTO_algorithm = FALSE; - - if(l1a.dyn_dwnld.semaphore_vect[SR_STATE_MACHINE] == GREEN) - { - - // WARNING: code below must be duplicated in WAIT_DYN_DWNLD state - // Start to download the model to the API - l1_send_sr_background_msg(L1_SRBACK_LOAD_MODEL_REQ); - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_SR_UPDATE_START_CON); - - *state = WAIT_MODEL_LOADED; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"SPEECH RECO SM blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - - // End process - return; - } - break; - case WAIT_DYN_DWNLD: - { - if((SignalCode == API_L1_DYN_DWNLD_FINISHED) && (l1a.dyn_dwnld.semaphore_vect[SR_STATE_MACHINE] == GREEN)) - { - // Start to download the model to the API - l1_send_sr_background_msg(L1_SRBACK_LOAD_MODEL_REQ); - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_SR_UPDATE_START_CON); - - *state = WAIT_MODEL_LOADED; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"SPEECH RECO SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - - } - return; - } - break; - case WAIT_MODEL_LOADED: - { - if (SignalCode == MMI_SR_UPDATE_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - } - else - if (SignalCode == L1_SRBACK_LOAD_MODEL_CON) - { - // Set the start command of the speech recording task - l1a_l1s_com.speechreco_task.command.speech_start = l1a_l1s_com.speechreco_task.parameters.speech; - - // Start the speech recognition update task - l1a_l1s_com.speechreco_task.command.update_start = TRUE; - - *state = WAIT_START_CON; - } - - // End process - return; - } - break; - - case WAIT_START_CON: - { - if (SignalCode == MMI_SR_UPDATE_STOP_REQ) - { - // Stop the speech recognition update task - l1a_l1s_com.speechreco_task.command.update_stop = TRUE; - - // Stop the speech recording task (if present) - l1a_l1s_com.speechreco_task.command.speech_stop = l1a_l1s_com.speechreco_task.parameters.speech; - - *state = WAIT_L1S_STOP; - } - else - if (SignalCode == L1_SR_UPDATE_START_CON) - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.update_start = FALSE; - l1a_l1s_com.speechreco_task.command.speech_start = FALSE; - - *state = WAIT_STOP; - } - - // End process - return; - } - break; - - case WAIT_STOP: - { - if (SignalCode == MMI_SR_UPDATE_STOP_REQ) - { - // Stop the speech recognition update task - l1a_l1s_com.speechreco_task.command.update_stop = TRUE; - - // Stop the speech recording task (if present) - l1a_l1s_com.speechreco_task.command.speech_stop = l1a_l1s_com.speechreco_task.parameters.speech; - - *state = WAIT_L1S_STOP; - - // End process - return; - } - else - if (SignalCode == L1_SR_UPDATE_STOP_CON) - { - // There is an error during the update task? - if ( ((T_L1_SR_UPDATE_STOP_CON *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - // Reset the background task emergency stop - l1_srback_com.emergency_stop = FALSE; - - // Send the message L1_SRBACK_SAVE_DATA_REQ to the background task - l1_send_sr_background_msg(L1_SRBACK_SAVE_DATA_REQ); - - *state = WAIT_BACK_TASK_DONE; - - // End process - return; - } - else - { - // Forward the stop confirmation message - l1a_audio_send_result(MMI_SR_UPDATE_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - } - else - { - // End process - return; - } - } - break; - - case WAIT_BACK_TASK_DONE: - { - if (SignalCode == MMI_SR_UPDATE_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - } - else - if (SignalCode == L1_SRBACK_SAVE_DATA_CON) - { - // Send the message MMI_SR_UPDATE_STOP_CON with an acquisition error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_UPDATE_STOP_CON *)(p_message))->error_id = SC_NO_ERROR; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_STOP_CON; - - //Fill the message - ((T_MMI_SR_UPDATE_STOP_CON *)(conf_msg->SigP))->error_id = SC_NO_ERROR; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - - case WAIT_BACK_STOP: - { - if ( (SignalCode == L1_SRBACK_SAVE_DATA_CON) || - (SignalCode == L1_SRBACK_LOAD_MODEL_CON) ) - { - // Send the message MMI_SR_UPDATE_STOP_CON with an update error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_UPDATE_STOP_CON *)(p_message))->error_id = SC_BAD_UPDATE; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_STOP_CON; - - //Fill the message - ((T_MMI_SR_UPDATE_STOP_CON *)(conf_msg->SigP))->error_id = SC_BAD_UPDATE; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - - case WAIT_L1S_STOP: - { - if (SignalCode == L1_SR_UPDATE_STOP_CON) - { - // Send the message MMI_SR_UPDATE_STOP_CON with an update error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_UPDATE_STOP_CON *)(p_message))->error_id = SC_BAD_UPDATE; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_STOP_CON; - - //Fill the message - ((T_MMI_SR_UPDATE_STOP_CON *)(conf_msg->SigP))->error_id = SC_BAD_UPDATE; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - - /*-------------------------------------------------------*/ - /* l1a_mmi_sr_reco_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* speech recognition reco feature. */ - /* */ - /* Starting messages: MMI_SR_RECO_START_REQ */ - /* */ - /* Result messages (input): L1_SR_RECO_START_CON */ - /* */ - /* Result messages (output): MMI_SR_RECO_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_SR_RECO_STOP_REQ */ - /* L1_SR_RECO_STOP_IND */ - /* */ - /* Stop message (output): MMI_SR_RECO_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_sr_reco_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_RECO_START = 3, - WAIT_RECO_STOP = 4, - LOAD_MODEL = 5, - WAIT_MODEL_LOADED = 6, - WAIT_PROCESSING_STOP = 7, - WAIT_L1S_STOP = 8, - WAIT_BACK_STOP = 9 - }; - - UWORD8 *state = &l1a.state[L1A_SR_RECO_STATE]; - UWORD32 SignalCode = msg->SignalCode; - #if (OP_RIV_AUDIO == 1) - void *p_message; - T_RVF_MB_STATUS mb_status; - #else - xSignalHeaderRec *conf_msg; - #endif - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.reco_start = FALSE; - l1a_l1s_com.speechreco_task.command.reco_stop = FALSE; - l1a_l1s_com.speechreco_task.command.processing_start = FALSE; - l1a_l1s_com.speechreco_task.command.processing_stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_SR_RECO_START_REQ) - { - // Reset the index counter - l1a_l1s_com.speechreco_task.parameters.index_counter = 0; - - // Download the parameters to the l1a_l1s_com.speechreco_task.parameters memory - l1a_l1s_com.speechreco_task.parameters.database_id = ((T_MMI_SR_RECO_REQ *)(msg->SigP))->database_id; - l1a_l1s_com.speechreco_task.parameters.vocabulary_size = ((T_MMI_SR_RECO_REQ *)(msg->SigP))->vocabulary_size; - l1a_l1s_com.speechreco_task.parameters.model_address = l1s_dsp_com.dsp_ndb_ptr->a_model; - - // The CTO algorithm must be used? - if (l1a_l1s_com.speechreco_task.parameters.vocabulary_size <= SC_SR_MAX_WORDS_FOR_CTO) - { - // Enable the CTO algorithm - l1a_l1s_com.speechreco_task.parameters.CTO_algorithm = TRUE; - - // Double the vocabulary size - l1a_l1s_com.speechreco_task.parameters.vocabulary_size <<= 1; - } - else - { - // Disable the CTO algorithm - l1a_l1s_com.speechreco_task.parameters.CTO_algorithm = FALSE; - } - - if (l1a.dyn_dwnld.semaphore_vect[SR_STATE_MACHINE] == GREEN) - { - - // WARNING: code below must be duplicated in WAIT_DYN_DWNLD state - // Start the speech recognition reco task - l1a_l1s_com.speechreco_task.command.reco_start = TRUE; - - *state = WAIT_RECO_START; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"SPEECH RECO SM blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - // End process - return; - } - break; - - case WAIT_DYN_DWNLD: - { - if((SignalCode == API_L1_DYN_DWNLD_FINISHED) && (l1a.dyn_dwnld.semaphore_vect[SR_STATE_MACHINE] == GREEN)) - { - // Start the speech recognition reco task - l1a_l1s_com.speechreco_task.command.reco_start = TRUE; - *state = WAIT_RECO_START; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"SPEECH RECO SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - - } - return; - } - break; - case WAIT_RECO_START: - { - if (SignalCode == L1_SR_RECO_START_CON) - { - // Reset the start command - l1a_l1s_com.speechreco_task.command.reco_start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_SR_RECO_START_CON); - - *state = WAIT_RECO_STOP; - } - // End process - return; - } - break; - - case WAIT_RECO_STOP: - { - if (SignalCode == L1_SR_RECO_STOP_CON) - { - // The acqusition is good or not? - if ( ((T_L1_SR_RECO_STOP_CON *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - *state = LOAD_MODEL; - } - else - { - // Send the message MMI_SR_RECO_STOP_CON with an error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_RECO_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->header.msg_id = MMI_SR_RECO_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->error_id = - ((T_L1_SR_RECO_STOP_CON *)(msg->SigP))->error_id; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_RECO_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_RECO_STOP_CON; - // File the message - ((T_MMI_SR_RECO_STOP_CON *)(conf_msg->SigP))->error_id = ((T_L1_SR_RECO_STOP_CON *)(msg->SigP))->error_id; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - } - else - if(SignalCode == MMI_SR_RECO_STOP_REQ) - { - // Stop the speech recognition task - l1a_l1s_com.speechreco_task.command.reco_stop = TRUE; - - *state = WAIT_L1S_STOP; - - // End process - return; - } - else - { - // End process - return; - } - } - break; - - case LOAD_MODEL: - { - // Initialize the background task stop command - l1_srback_com.emergency_stop = FALSE; - - // Start to load the model to the API - l1a_l1s_com.speechreco_task.parameters.word_index = l1a_l1s_com.speechreco_task.parameters.index_counter; - l1_send_sr_background_msg(L1_SRBACK_LOAD_MODEL_REQ); - - // Increase the index counter - l1a_l1s_com.speechreco_task.parameters.index_counter++; - - *state = WAIT_MODEL_LOADED; - - // End process - return; - } - break; - - case WAIT_MODEL_LOADED: - { - if (SignalCode == L1_SRBACK_LOAD_MODEL_CON) - { - // Start the DSP processing task - l1a_l1s_com.speechreco_task.command.processing_start = TRUE; - - *state = WAIT_PROCESSING_STOP; - } - else - if (SignalCode == MMI_SR_RECO_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - } - - // End process - return; - } - break; - - case WAIT_PROCESSING_STOP: - { - if (SignalCode == L1_SR_PROCESSING_STOP_CON) - { - // The processing phase is good or not? - if ( ((T_L1_SR_PROCESSING_STOP_CON *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - *state = LOAD_MODEL; - } - else - { - // Send the MMI_SR_RECO_STOP_CON message with an error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_RECO_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->header.msg_id = MMI_SR_RECO_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->error_id = - ((T_L1_SR_PROCESSING_STOP_CON *)(msg->SigP))->error_id; - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_RECO_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_RECO_STOP_CON; - // File the message - ((T_MMI_SR_RECO_STOP_CON *)(conf_msg->SigP))->error_id = ((T_L1_SR_PROCESSING_STOP_CON *)(msg->SigP))->error_id; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - } - else - if (SignalCode == L1_SR_RECO_STOP_IND) - { - // The CTO algorithm is used? - if (l1a_l1s_com.speechreco_task.parameters.CTO_algorithm) - { - // There is an error during the recognition? - if ( ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - // The best word is odd? - if ( ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_index & 0x01 ) - { - // Change the error to tSC_CTO_WORD - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->error_id = SC_CTO_WORD; - } - else - { - // Devided by 2 the 4 indexes of the best words in the message - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_index >>= 1; - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->second_best_word_index >>= 1; - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->third_best_word_index >>= 1; - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->fourth_best_word_index >>= 1; - } - } - } - // Forward the message in the MMI_SR_RECO_STOP_CON - l1a_audio_send_result(MMI_SR_RECO_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - else - if (SignalCode == MMI_SR_RECO_STOP_REQ) - { - // Stop the L1S processing task - l1a_l1s_com.speechreco_task.command.processing_stop = TRUE; - - *state = WAIT_L1S_STOP; - - // end process - return; - } - else - { - // end process - return; - } - } - break; - - case WAIT_L1S_STOP: - { - if ( (SignalCode == L1_SR_PROCESSING_STOP_CON) || - (SignalCode == L1_SR_RECO_STOP_CON) || - (SignalCode == L1_SR_RECO_STOP_IND) ) - { - // Send the message MMI_SR_RECO_STOP_CON with a bad recognition error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_RECO_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->header.msg_id = MMI_SR_RECO_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->error_id = SC_BAD_RECOGNITION; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_RECO_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_RECO_STOP_CON; - // File the message - ((T_MMI_SR_RECO_STOP_CON *)(conf_msg->SigP))->error_id = SC_BAD_RECOGNITION; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - - case WAIT_BACK_STOP: - { - if (SignalCode == L1_SRBACK_LOAD_MODEL_CON) - { - // Send the MMI_SR_RECO_STOP_CON with an bad recognition error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_RECO_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->header.msg_id = MMI_SR_RECO_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->error_id = SC_BAD_RECOGNITION; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_RECO_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_RECO_STOP_CON; - // Fill the message - ((T_MMI_SR_RECO_STOP_CON *)(conf_msg->SigP))->error_id = SC_BAD_RECOGNITION; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - - /*---------------------------------------------------------*/ - /* l1a_mmi_sr_update_check_process() */ - /*---------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* speech recognition update check feature. */ - /* */ - /* Starting messages: MMI_SR_UPDATE_CHECK_START_REQ */ - /* */ - /* Result messages (input): L1_SR_UPDATE_START_CON */ - /* */ - /* Result messages (output): MMI_SR_UPDATE_CHECK_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_SR_UPDATE_CHECK_STOP_REQ */ - /* L1_SR_RECO_STOP_IND */ - /* */ - /* Stop message (output): MMI_SR_UPDATE_CHECK_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*---------------------------------------------------------*/ - void l1a_mmi_sr_update_check_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_MODEL = 3, - WAIT_UPDATE_START = 4, - WAIT_UPDATE_STOP = 5, - WAIT_TEMP_SAVE_DONE = 6, - LOAD_MODEL = 7, - WAIT_MODEL_LOADED = 8, - WAIT_PROCESSING_STOP = 9, - WAIT_SAVE_DONE = 10, - WAIT_L1S_STOP = 11, - WAIT_BACK_STOP = 12 - }; - - UWORD8 *state = &l1a.state[L1A_SR_UPDATE_CHECK_STATE]; - UWORD32 SignalCode = msg->SignalCode; - #if (OP_RIV_AUDIO == 1) - void *p_message; - T_RVF_MB_STATUS mb_status; - #define AUDIO_MSG (p_message) - #else - xSignalHeaderRec *conf_msg; - #define AUDIO_MSG (conf_msg->SigP) - #endif - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.update_start = FALSE; - l1a_l1s_com.speechreco_task.command.update_stop = FALSE; - l1a_l1s_com.speechreco_task.command.speech_start = FALSE; - l1a_l1s_com.speechreco_task.command.speech_stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if(SignalCode == MMI_SR_UPDATE_CHECK_START_REQ) - { - // Download the message parameters to the parameters memory - l1a_l1s_com.speechreco_task.parameters.database_id = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->database_id; - l1a_l1s_com.speechreco_task.parameters.word_index = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->word_index; - l1a_l1s_com.speechreco_task.parameters.word_to_check = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->word_index; - l1a_l1s_com.speechreco_task.parameters.model_address = l1s_dsp_com.dsp_ndb_ptr->a_model; - l1a_l1s_com.speechreco_task.parameters.model_temp_address = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->model_address; - l1a_l1s_com.speechreco_task.parameters.speech = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->speech; - l1a_l1s_com.speechreco_task.parameters.speech_address = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->speech_address; - l1a_l1s_com.speechreco_task.parameters.vocabulary_size = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->vocabulary_size; - - // Reset the background task emergency stop - l1_srback_com.emergency_stop = FALSE; - - l1a_l1s_com.speechreco_task.parameters.CTO_algorithm = FALSE; - - if (l1a.dyn_dwnld.semaphore_vect[SR_STATE_MACHINE] == GREEN) - { - - // WARNING: code below must be duplicated in WAIT_DYN_DWNLD state - // Start to download the model to the API - l1_send_sr_background_msg(L1_SRBACK_LOAD_MODEL_REQ); - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_SR_UPDATE_CHECK_START_CON); - - *state = WAIT_MODEL; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"SPEECH RECO SM blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - - // End process - return; - } - break; - case WAIT_DYN_DWNLD: - { - if((SignalCode == API_L1_DYN_DWNLD_FINISHED) && (l1a.dyn_dwnld.semaphore_vect[SR_STATE_MACHINE] == GREEN)) - { - - // Start to download the model to the API - l1_send_sr_background_msg(L1_SRBACK_LOAD_MODEL_REQ); - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_SR_UPDATE_CHECK_START_CON); - - *state = WAIT_MODEL; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"SPEECH RECO SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - - } - return; - } - break; - case WAIT_MODEL: - { - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - } - else - if (SignalCode == L1_SRBACK_LOAD_MODEL_CON) - { - // Set the start command of the speech recording task - l1a_l1s_com.speechreco_task.command.speech_start = l1a_l1s_com.speechreco_task.parameters.speech; - - // Start the speech recognition update task - l1a_l1s_com.speechreco_task.command.update_start = TRUE; - - *state = WAIT_UPDATE_START; - } - - // End process - return; - } - break; - - case WAIT_UPDATE_START: - { - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop the speech recognition update task - l1a_l1s_com.speechreco_task.command.update_stop = TRUE; - - // Stop the speech recording task (if present) - l1a_l1s_com.speechreco_task.command.speech_stop = l1a_l1s_com.speechreco_task.parameters.speech; - - *state = WAIT_L1S_STOP; - } - else - if (SignalCode == L1_SR_UPDATE_START_CON) - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.update_start = FALSE; - l1a_l1s_com.speechreco_task.command.speech_start = FALSE; - - *state = WAIT_UPDATE_STOP; - } - - // End process - return; - } - break; - - case WAIT_UPDATE_STOP: - { - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop the speech recognition update task - l1a_l1s_com.speechreco_task.command.update_stop = TRUE; - - // Stop the speech recording task (if present) - l1a_l1s_com.speechreco_task.command.speech_stop = l1a_l1s_com.speechreco_task.parameters.speech; - - *state = WAIT_L1S_STOP; - - // End process - return; - } - else - if (SignalCode == L1_SR_UPDATE_STOP_CON) - { - // There is an error during the update task? - if ( ((T_L1_SR_UPDATE_STOP_CON *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - // Reset the background task emergency stop - l1_srback_com.emergency_stop = FALSE; - - // Send the message L1_SRBACK_SAVE_DATA_REQ to the background task - l1_send_sr_background_msg(L1_SRBACK_TEMP_SAVE_DATA_REQ); - - *state = WAIT_TEMP_SAVE_DONE; - - // End process - return; - } - else - { - // Forward the stop confirmation message - l1a_audio_send_result(MMI_SR_UPDATE_CHECK_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - } - else - { - // End process - return; - } - } - break; - - case WAIT_TEMP_SAVE_DONE: - { - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - - // End process - return; - } - else - if (SignalCode == L1_SRBACK_TEMP_SAVE_DATA_CON) - { - // Reset the command - l1a_l1s_com.speechreco_task.command.processing_start = FALSE; - l1a_l1s_com.speechreco_task.command.processing_stop = FALSE; - - // Reset the index counter - l1a_l1s_com.speechreco_task.parameters.index_counter = 0; - - // The CTO algorithm must be used? - if (l1a_l1s_com.speechreco_task.parameters.vocabulary_size <= SC_SR_MAX_WORDS_FOR_CTO) - { - // Enable the CTO algorithm - l1a_l1s_com.speechreco_task.parameters.CTO_algorithm = TRUE; - - // Double the vocabulary size - l1a_l1s_com.speechreco_task.parameters.vocabulary_size <<= 1; - } - else - { - // Disable the CTO algorithm - l1a_l1s_com.speechreco_task.parameters.CTO_algorithm = FALSE; - } - - *state = LOAD_MODEL; - } - else - { - // End process - return; - } - } - break; - - case LOAD_MODEL: - { - // Initialize the background task stop command - l1_srback_com.emergency_stop = FALSE; - - // Start to load the model to the API - l1a_l1s_com.speechreco_task.parameters.word_index = l1a_l1s_com.speechreco_task.parameters.index_counter; - l1_send_sr_background_msg(L1_SRBACK_LOAD_MODEL_REQ); - - // Increase the index counter - l1a_l1s_com.speechreco_task.parameters.index_counter++; - - *state = WAIT_MODEL_LOADED; - - // End process - return; - } - break; - - case WAIT_MODEL_LOADED: - { - if (SignalCode == L1_SRBACK_LOAD_MODEL_CON) - { - // Start the DSP processing task - l1a_l1s_com.speechreco_task.command.processing_start = TRUE; - - *state = WAIT_PROCESSING_STOP; - } - else - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - } - - // End process - return; - } - break; - - case WAIT_PROCESSING_STOP: - { - if (SignalCode == L1_SR_PROCESSING_STOP_CON) - { - // The processing phase is good or not? - if ( ((T_L1_SR_PROCESSING_STOP_CON *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - *state = LOAD_MODEL; - } - else - { - // Send the MMI_SR_UPDATE_CHECK_STOP_CON message with an error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_CHECK_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_CHECK_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->error_id = - ((T_L1_SR_PROCESSING_STOP_CON *)(msg->SigP))->error_id; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_CHECK_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_CHECK_STOP_CON; - // File the message - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(conf_msg->SigP))->error_id = ((T_L1_SR_PROCESSING_STOP_CON *)(msg->SigP))->error_id; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - } - else - if (SignalCode == L1_SR_RECO_STOP_IND) - { - // There is an error during the recognition? - if ( ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - // The CTO algorithm is used? - if (l1a_l1s_com.speechreco_task.parameters.CTO_algorithm) - { - // The best word is odd? - if ( ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_index & 0x01 ) - { - // Change the error to SC_CTO_WORD - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->error_id = SC_CTO_WORD; - - // Forward the message in the MMI_SR_RECO_STOP_CON - l1a_audio_send_result(MMI_SR_UPDATE_CHECK_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - - // End process - return; - } - else - { - // Devided by 2 the 4 indexes of the best words in the message - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_index >>= 1; - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->second_best_word_index >>= 1; - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->third_best_word_index >>= 1; - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->fourth_best_word_index >>= 1; - } - } - // Is it the good word? - if ( ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_index == - l1a_l1s_com.speechreco_task.parameters.word_to_check ) - { - // Save the message informations in the l1a_l1s_com memory - l1a_l1s_com.speechreco_task.parameters.best_word_index = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_index; - l1a_l1s_com.speechreco_task.parameters.best_word_score = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_score; - l1a_l1s_com.speechreco_task.parameters.second_best_word_index = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->second_best_word_index; - l1a_l1s_com.speechreco_task.parameters.second_best_word_score = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->second_best_word_score; - l1a_l1s_com.speechreco_task.parameters.third_best_word_index = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->third_best_word_index; - l1a_l1s_com.speechreco_task.parameters.third_best_word_score = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->third_best_word_score; - l1a_l1s_com.speechreco_task.parameters.fourth_best_word_index = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->fourth_best_word_index; - l1a_l1s_com.speechreco_task.parameters.fourth_best_word_score = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->fourth_best_word_score; - l1a_l1s_com.speechreco_task.parameters.d_sr_db_level = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->d_sr_db_level; - l1a_l1s_com.speechreco_task.parameters.d_sr_db_noise = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->d_sr_db_noise; - l1a_l1s_com.speechreco_task.parameters.d_sr_model_size = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->d_sr_model_size; - - // Reset the stop background task - l1_srback_com.emergency_stop = FALSE; - - // Start the background task to save the model in the database - l1a_l1s_com.speechreco_task.parameters.word_index = l1a_l1s_com.speechreco_task.parameters.word_to_check; - l1a_l1s_com.speechreco_task.parameters.model_address = l1a_l1s_com.speechreco_task.parameters.model_temp_address; - l1_send_sr_background_msg(L1_SRBACK_SAVE_DATA_REQ); - - *state = WAIT_SAVE_DONE; - - // End process - return; - } - else - { - // Change the error to SC_CHECK_ERROR - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->error_id = SC_CHECK_ERROR; - } - } - // Forward the message in the MMI_SR_RECO_STOP_CON - l1a_audio_send_result(MMI_SR_UPDATE_CHECK_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - else - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop the L1S processing task - l1a_l1s_com.speechreco_task.command.processing_stop = TRUE; - - *state = WAIT_L1S_STOP; - - // end process - return; - } - else - { - // end process - return; - } - } - break; - - case WAIT_SAVE_DONE: - { - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - - // End process - return; - } - else - if (SignalCode == L1_SRBACK_SAVE_DATA_CON) - { - // Send the MMI_SR_UPDATE_CHECK_STOP_CON message with an error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_CHECK_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_CHECK_STOP_CON; - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_CHECK_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_CHECK_STOP_CON; - #endif // OP_RIV_AUDIO - - // Fill the message parameter - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->error_id = SC_NO_ERROR; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->best_word_index = l1a_l1s_com.speechreco_task.parameters.best_word_index; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->best_word_score = l1a_l1s_com.speechreco_task.parameters.best_word_score; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->second_best_word_index = l1a_l1s_com.speechreco_task.parameters.second_best_word_index; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->second_best_word_score = l1a_l1s_com.speechreco_task.parameters.second_best_word_score; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->third_best_word_index = l1a_l1s_com.speechreco_task.parameters.third_best_word_index; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->third_best_word_score = l1a_l1s_com.speechreco_task.parameters.third_best_word_score; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->fourth_best_word_index = l1a_l1s_com.speechreco_task.parameters.fourth_best_word_index; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->fourth_best_word_score = l1a_l1s_com.speechreco_task.parameters.fourth_best_word_score; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->d_sr_db_level = l1a_l1s_com.speechreco_task.parameters.d_sr_db_level; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->d_sr_db_noise = l1a_l1s_com.speechreco_task.parameters.d_sr_db_noise; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->d_sr_model_size = l1a_l1s_com.speechreco_task.parameters.d_sr_model_size; - - #if (OP_RIV_AUDIO == 1) - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - - case WAIT_BACK_STOP: - { - if ( (SignalCode == L1_SRBACK_SAVE_DATA_CON) || - (SignalCode == L1_SRBACK_LOAD_MODEL_CON) || - (SignalCode == L1_SRBACK_TEMP_SAVE_DATA_CON) ) - { - // Send the message MMI_SR_UPDATE_STOP_CON with an update error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_CHECK_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_CHECK_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->error_id = SC_CHECK_ERROR; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_CHECK_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_CHECK_STOP_CON; - - //Fill the message - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(conf_msg->SigP))->error_id = SC_CHECK_ERROR; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - - case WAIT_L1S_STOP: - { - if ( (SignalCode == L1_SR_UPDATE_STOP_CON) || - (SignalCode == L1_SR_PROCESSING_STOP_CON) || - (SignalCode == L1_SR_RECO_STOP_CON) || - (SignalCode == L1_SR_RECO_STOP_IND) ) - { - // Send the message MMI_SR_UPDATE_CHECK_STOP_CON with an update error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_CHECK_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_CHECK_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->error_id = SC_CHECK_ERROR; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_CHECK_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_CHECK_STOP_CON; - - //Fill the message - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(conf_msg->SigP))->error_id = SC_CHECK_ERROR; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - - // Undefine message pointer macro. - #undef MSG_AUDIO - - } - #else // L1_DYN_DSP_DWNLD = 0 - /*-------------------------------------------------------*/ - /* l1a_mmi_sr_enroll_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* speech recognition enrollment feature. */ - /* */ - /* Starting messages: MMI_SR_ENROLL_START_REQ */ - /* */ - /* Result messages (input): L1_SR_ENROLL_START_CON */ - /* */ - /* Result messages (output): MMI_SR_ENROLL_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_SR_ENROLL_STOP_REQ */ - /* L1_SR_ENROLL_STOP_CON */ - /* */ - /* Stop message (output): MMI_SR_ENROLL_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_sr_enroll_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_START_CON = 2, - WAIT_STOP = 3, - WAIT_BACK_TASK_DONE = 4, - WAIT_L1S_STOP = 5, - WAIT_BACK_STOP = 6 - }; - - UWORD8 *state = &l1a.state[L1A_SR_ENROLL_STATE]; - UWORD32 SignalCode = msg->SignalCode; - #if (OP_RIV_AUDIO == 1) - void *p_message; - T_RVF_MB_STATUS mb_status; - #else - xSignalHeaderRec *conf_msg; - #endif - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.enroll_start = FALSE; - l1a_l1s_com.speechreco_task.command.enroll_stop = FALSE; - l1a_l1s_com.speechreco_task.command.speech_start = FALSE; - l1a_l1s_com.speechreco_task.command.speech_stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_SR_ENROLL_START_REQ) - { - // Download the message parameters to the parameters memory - l1a_l1s_com.speechreco_task.parameters.database_id = ((T_MMI_SR_ENROLL_REQ *)(msg->SigP))->database_id; - l1a_l1s_com.speechreco_task.parameters.word_index = ((T_MMI_SR_ENROLL_REQ *)(msg->SigP))->word_index; - l1a_l1s_com.speechreco_task.parameters.model_address = l1s_dsp_com.dsp_ndb_ptr->a_model; - l1a_l1s_com.speechreco_task.parameters.speech = ((T_MMI_SR_ENROLL_REQ *)(msg->SigP))->speech; - l1a_l1s_com.speechreco_task.parameters.speech_address = ((T_MMI_SR_ENROLL_REQ *)(msg->SigP))->speech_address; - - // Set the start command of the speech recording task - l1a_l1s_com.speechreco_task.command.speech_start = l1a_l1s_com.speechreco_task.parameters.speech; - - // Start the speech recognition enrollment task - l1a_l1s_com.speechreco_task.command.enroll_start = TRUE; - - *state = WAIT_START_CON; - } - - // End process - return; - } - break; - - case WAIT_START_CON: - { - if (SignalCode == L1_SR_ENROLL_START_CON) - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.enroll_start = FALSE; - l1a_l1s_com.speechreco_task.command.speech_start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_SR_ENROLL_START_CON); - - *state = WAIT_STOP; - } - - // End process - return; - } - break; - - case WAIT_STOP: - { - if (SignalCode == MMI_SR_ENROLL_STOP_REQ) - { - // Stop the speech recognition enroll task - l1a_l1s_com.speechreco_task.command.enroll_stop = TRUE; - - // Stop the speech recording task (if present) - l1a_l1s_com.speechreco_task.command.speech_stop = l1a_l1s_com.speechreco_task.parameters.speech; - - *state = WAIT_L1S_STOP; - - // End process - return; - } - else - if (SignalCode == L1_SR_ENROLL_STOP_CON) - { - // There is an error during the acquisition task? - if ( ((T_L1_SR_ENROLL_STOP_CON *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - // Reset the background task emergency stop - l1_srback_com.emergency_stop = FALSE; - - // Send the message L1_SRBACK_SAVE_DATA_REQ to the background task - l1_send_sr_background_msg(L1_SRBACK_SAVE_DATA_REQ); - - *state = WAIT_BACK_TASK_DONE; - - // End process - return; - } - else - // There is an error - { - // Forward the stop confirmation message - l1a_audio_send_result(MMI_SR_ENROLL_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - } - else - { - // End process - return; - } - } - break; - - case WAIT_BACK_TASK_DONE: - { - if (SignalCode == L1_SRBACK_SAVE_DATA_CON) - { - // Send the stop confirmation message with no error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_ENROLL_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_ENROLL_STOP_CON *)(p_message))->header.msg_id = MMI_SR_ENROLL_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_ENROLL_STOP_CON *)(p_message))->error_id = SC_NO_ERROR; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig( sizeof(T_MMI_SR_ENROLL_STOP_CON) ); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_ENROLL_STOP_CON; - - //Fill the message - ((T_MMI_SR_ENROLL_STOP_CON *)(conf_msg->SigP))->error_id = SC_NO_ERROR; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - - } - else - if (SignalCode == MMI_SR_ENROLL_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - - // End process - return; - } - else - { - // End process - return; - } - } - break; - - case WAIT_BACK_STOP: - { - if (SignalCode == L1_SRBACK_SAVE_DATA_CON) - { - // Send the message MMI_SR_ENROLL_STOP_CON with an acquisition error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_ENROLL_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_ENROLL_STOP_CON *)(p_message))->header.msg_id = MMI_SR_ENROLL_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_ENROLL_STOP_CON *)(p_message))->error_id = SC_BAD_ACQUISITION; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_ENROLL_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_ENROLL_STOP_CON; - - //Fill the message - ((T_MMI_SR_ENROLL_STOP_CON *)(conf_msg->SigP))->error_id = SC_BAD_ACQUISITION; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - - case WAIT_L1S_STOP: - { - if (SignalCode == L1_SR_ENROLL_STOP_CON) - { - // Send the message MMI_SR_ENROLL_STOP_CON with an acquisition error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_ENROLL_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_ENROLL_STOP_CON *)(p_message))->header.msg_id = MMI_SR_ENROLL_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_ENROLL_STOP_CON *)(p_message))->error_id = SC_BAD_ACQUISITION; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_ENROLL_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_ENROLL_STOP_CON; - - //Fill the message - ((T_MMI_SR_ENROLL_STOP_CON *)(conf_msg->SigP))->error_id = SC_BAD_ACQUISITION; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - - /*-------------------------------------------------------*/ - /* l1a_mmi_sr_update_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* speech recognition update feature. */ - /* */ - /* Starting messages: MMI_SR_UPDATE_START_REQ */ - /* */ - /* Result messages (input): L1_SR_UPDATE_START_CON */ - /* */ - /* Result messages (output): MMI_SR_UPDATE_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_SR_UPDATE_STOP_REQ */ - /* L1_SR_UPDATE_STOP_CON */ - /* */ - /* Stop message (output): MMI_SR_UPDATE_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_sr_update_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_MODEL_LOADED = 2, - WAIT_START_CON = 3, - WAIT_STOP = 4, - WAIT_BACK_TASK_DONE = 5, - WAIT_L1S_STOP = 6, - WAIT_BACK_STOP = 7 - }; - - UWORD8 *state = &l1a.state[L1A_SR_UPDATE_STATE]; - UWORD32 SignalCode = msg->SignalCode; - #if (OP_RIV_AUDIO == 1) - void *p_message; - T_RVF_MB_STATUS mb_status; - #else - xSignalHeaderRec *conf_msg; - #endif - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.update_start = FALSE; - l1a_l1s_com.speechreco_task.command.update_stop = FALSE; - l1a_l1s_com.speechreco_task.command.speech_start = FALSE; - l1a_l1s_com.speechreco_task.command.speech_stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_SR_UPDATE_START_REQ) - { - // Download the message parameters to the parameters memory - l1a_l1s_com.speechreco_task.parameters.database_id = ((T_MMI_SR_UPDATE_REQ *)(msg->SigP))->database_id; - l1a_l1s_com.speechreco_task.parameters.word_index = ((T_MMI_SR_UPDATE_REQ *)(msg->SigP))->word_index; - l1a_l1s_com.speechreco_task.parameters.model_address = l1s_dsp_com.dsp_ndb_ptr->a_model; - l1a_l1s_com.speechreco_task.parameters.speech = ((T_MMI_SR_UPDATE_REQ *)(msg->SigP))->speech; - l1a_l1s_com.speechreco_task.parameters.speech_address = ((T_MMI_SR_UPDATE_REQ *)(msg->SigP))->speech_address; - - // Reset the background task emergency stop - l1_srback_com.emergency_stop = FALSE; - - // Start to download the model to the API - l1a_l1s_com.speechreco_task.parameters.CTO_algorithm = FALSE; - l1_send_sr_background_msg(L1_SRBACK_LOAD_MODEL_REQ); - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_SR_UPDATE_START_CON); - - *state = WAIT_MODEL_LOADED; - } - - // End process - return; - } - break; - - case WAIT_MODEL_LOADED: - { - if (SignalCode == MMI_SR_UPDATE_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - } - else - if (SignalCode == L1_SRBACK_LOAD_MODEL_CON) - { - // Set the start command of the speech recording task - l1a_l1s_com.speechreco_task.command.speech_start = l1a_l1s_com.speechreco_task.parameters.speech; - - // Start the speech recognition update task - l1a_l1s_com.speechreco_task.command.update_start = TRUE; - - *state = WAIT_START_CON; - } - - // End process - return; - } - break; - - case WAIT_START_CON: - { - if (SignalCode == MMI_SR_UPDATE_STOP_REQ) - { - // Stop the speech recognition update task - l1a_l1s_com.speechreco_task.command.update_stop = TRUE; - - // Stop the speech recording task (if present) - l1a_l1s_com.speechreco_task.command.speech_stop = l1a_l1s_com.speechreco_task.parameters.speech; - - *state = WAIT_L1S_STOP; - } - else - if (SignalCode == L1_SR_UPDATE_START_CON) - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.update_start = FALSE; - l1a_l1s_com.speechreco_task.command.speech_start = FALSE; - - *state = WAIT_STOP; - } - - // End process - return; - } - break; - - case WAIT_STOP: - { - if (SignalCode == MMI_SR_UPDATE_STOP_REQ) - { - // Stop the speech recognition update task - l1a_l1s_com.speechreco_task.command.update_stop = TRUE; - - // Stop the speech recording task (if present) - l1a_l1s_com.speechreco_task.command.speech_stop = l1a_l1s_com.speechreco_task.parameters.speech; - - *state = WAIT_L1S_STOP; - - // End process - return; - } - else - if (SignalCode == L1_SR_UPDATE_STOP_CON) - { - // There is an error during the update task? - if ( ((T_L1_SR_UPDATE_STOP_CON *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - // Reset the background task emergency stop - l1_srback_com.emergency_stop = FALSE; - - // Send the message L1_SRBACK_SAVE_DATA_REQ to the background task - l1_send_sr_background_msg(L1_SRBACK_SAVE_DATA_REQ); - - *state = WAIT_BACK_TASK_DONE; - - // End process - return; - } - else - { - // Forward the stop confirmation message - l1a_audio_send_result(MMI_SR_UPDATE_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - } - else - { - // End process - return; - } - } - break; - - case WAIT_BACK_TASK_DONE: - { - if (SignalCode == MMI_SR_UPDATE_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - } - else - if (SignalCode == L1_SRBACK_SAVE_DATA_CON) - { - // Send the message MMI_SR_UPDATE_STOP_CON with an acquisition error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_UPDATE_STOP_CON *)(p_message))->error_id = SC_NO_ERROR; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_STOP_CON; - - //Fill the message - ((T_MMI_SR_UPDATE_STOP_CON *)(conf_msg->SigP))->error_id = SC_NO_ERROR; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - - case WAIT_BACK_STOP: - { - if ( (SignalCode == L1_SRBACK_SAVE_DATA_CON) || - (SignalCode == L1_SRBACK_LOAD_MODEL_CON) ) - { - // Send the message MMI_SR_UPDATE_STOP_CON with an update error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_UPDATE_STOP_CON *)(p_message))->error_id = SC_BAD_UPDATE; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_STOP_CON; - - //Fill the message - ((T_MMI_SR_UPDATE_STOP_CON *)(conf_msg->SigP))->error_id = SC_BAD_UPDATE; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - - case WAIT_L1S_STOP: - { - if (SignalCode == L1_SR_UPDATE_STOP_CON) - { - // Send the message MMI_SR_UPDATE_STOP_CON with an update error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_UPDATE_STOP_CON *)(p_message))->error_id = SC_BAD_UPDATE; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_STOP_CON; - - //Fill the message - ((T_MMI_SR_UPDATE_STOP_CON *)(conf_msg->SigP))->error_id = SC_BAD_UPDATE; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - - /*-------------------------------------------------------*/ - /* l1a_mmi_sr_reco_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* speech recognition reco feature. */ - /* */ - /* Starting messages: MMI_SR_RECO_START_REQ */ - /* */ - /* Result messages (input): L1_SR_RECO_START_CON */ - /* */ - /* Result messages (output): MMI_SR_RECO_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_SR_RECO_STOP_REQ */ - /* L1_SR_RECO_STOP_IND */ - /* */ - /* Stop message (output): MMI_SR_RECO_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_sr_reco_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_RECO_START = 2, - WAIT_RECO_STOP = 3, - LOAD_MODEL = 4, - WAIT_MODEL_LOADED = 5, - WAIT_PROCESSING_STOP = 6, - WAIT_L1S_STOP = 7, - WAIT_BACK_STOP = 8 - }; - - UWORD8 *state = &l1a.state[L1A_SR_RECO_STATE]; - UWORD32 SignalCode = msg->SignalCode; - #if (OP_RIV_AUDIO == 1) - void *p_message; - T_RVF_MB_STATUS mb_status; - #else - xSignalHeaderRec *conf_msg; - #endif - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.reco_start = FALSE; - l1a_l1s_com.speechreco_task.command.reco_stop = FALSE; - l1a_l1s_com.speechreco_task.command.processing_start = FALSE; - l1a_l1s_com.speechreco_task.command.processing_stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_SR_RECO_START_REQ) - { - - // Reset the index counter - l1a_l1s_com.speechreco_task.parameters.index_counter = 0; - - // Download the parameters to the l1a_l1s_com.speechreco_task.parameters memory - l1a_l1s_com.speechreco_task.parameters.database_id = ((T_MMI_SR_RECO_REQ *)(msg->SigP))->database_id; - l1a_l1s_com.speechreco_task.parameters.vocabulary_size = ((T_MMI_SR_RECO_REQ *)(msg->SigP))->vocabulary_size; - l1a_l1s_com.speechreco_task.parameters.model_address = l1s_dsp_com.dsp_ndb_ptr->a_model; - - // The CTO algorithm must be used? - if (l1a_l1s_com.speechreco_task.parameters.vocabulary_size <= SC_SR_MAX_WORDS_FOR_CTO) - { - // Enable the CTO algorithm - l1a_l1s_com.speechreco_task.parameters.CTO_algorithm = TRUE; - - // Double the vocabulary size - l1a_l1s_com.speechreco_task.parameters.vocabulary_size <<= 1; - } - else - { - // Disable the CTO algorithm - l1a_l1s_com.speechreco_task.parameters.CTO_algorithm = FALSE; - } - - // Start the speech recognition reco task - l1a_l1s_com.speechreco_task.command.reco_start = TRUE; - - *state = WAIT_RECO_START; - } - - // End process - return; - } - break; - - - case WAIT_RECO_START: - { - if (SignalCode == L1_SR_RECO_START_CON) - { - // Reset the start command - l1a_l1s_com.speechreco_task.command.reco_start = FALSE; - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_SR_RECO_START_CON); - - *state = WAIT_RECO_STOP; - } - // End process - return; - } - break; - - case WAIT_RECO_STOP: - { - if (SignalCode == L1_SR_RECO_STOP_CON) - { - // The acqusition is good or not? - if ( ((T_L1_SR_RECO_STOP_CON *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - *state = LOAD_MODEL; - } - else - { - // Send the message MMI_SR_RECO_STOP_CON with an error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_RECO_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->header.msg_id = MMI_SR_RECO_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->error_id = - ((T_L1_SR_RECO_STOP_CON *)(msg->SigP))->error_id; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_RECO_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_RECO_STOP_CON; - // File the message - ((T_MMI_SR_RECO_STOP_CON *)(conf_msg->SigP))->error_id = ((T_L1_SR_RECO_STOP_CON *)(msg->SigP))->error_id; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - } - else - if(SignalCode == MMI_SR_RECO_STOP_REQ) - { - // Stop the speech recognition task - l1a_l1s_com.speechreco_task.command.reco_stop = TRUE; - - *state = WAIT_L1S_STOP; - - // End process - return; - } - else - { - // End process - return; - } - } - break; - - case LOAD_MODEL: - { - // Initialize the background task stop command - l1_srback_com.emergency_stop = FALSE; - - // Start to load the model to the API - l1a_l1s_com.speechreco_task.parameters.word_index = l1a_l1s_com.speechreco_task.parameters.index_counter; - l1_send_sr_background_msg(L1_SRBACK_LOAD_MODEL_REQ); - - // Increase the index counter - l1a_l1s_com.speechreco_task.parameters.index_counter++; - - *state = WAIT_MODEL_LOADED; - - // End process - return; - } - break; - - case WAIT_MODEL_LOADED: - { - if (SignalCode == L1_SRBACK_LOAD_MODEL_CON) - { - // Start the DSP processing task - l1a_l1s_com.speechreco_task.command.processing_start = TRUE; - - *state = WAIT_PROCESSING_STOP; - } - else - if (SignalCode == MMI_SR_RECO_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - } - - // End process - return; - } - break; - - case WAIT_PROCESSING_STOP: - { - if (SignalCode == L1_SR_PROCESSING_STOP_CON) - { - // The processing phase is good or not? - if ( ((T_L1_SR_PROCESSING_STOP_CON *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - *state = LOAD_MODEL; - } - else - { - // Send the MMI_SR_RECO_STOP_CON message with an error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_RECO_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->header.msg_id = MMI_SR_RECO_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->error_id = - ((T_L1_SR_PROCESSING_STOP_CON *)(msg->SigP))->error_id; - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_RECO_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_RECO_STOP_CON; - // File the message - ((T_MMI_SR_RECO_STOP_CON *)(conf_msg->SigP))->error_id = ((T_L1_SR_PROCESSING_STOP_CON *)(msg->SigP))->error_id; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - } - else - if (SignalCode == L1_SR_RECO_STOP_IND) - { - // The CTO algorithm is used? - if (l1a_l1s_com.speechreco_task.parameters.CTO_algorithm) - { - // There is an error during the recognition? - if ( ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - // The best word is odd? - if ( ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_index & 0x01 ) - { - // Change the error to tSC_CTO_WORD - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->error_id = SC_CTO_WORD; - } - else - { - // Devided by 2 the 4 indexes of the best words in the message - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_index >>= 1; - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->second_best_word_index >>= 1; - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->third_best_word_index >>= 1; - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->fourth_best_word_index >>= 1; - } - } - } - // Forward the message in the MMI_SR_RECO_STOP_CON - l1a_audio_send_result(MMI_SR_RECO_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - else - if (SignalCode == MMI_SR_RECO_STOP_REQ) - { - // Stop the L1S processing task - l1a_l1s_com.speechreco_task.command.processing_stop = TRUE; - - *state = WAIT_L1S_STOP; - - // end process - return; - } - else - { - // end process - return; - } - } - break; - - case WAIT_L1S_STOP: - { - if ( (SignalCode == L1_SR_PROCESSING_STOP_CON) || - (SignalCode == L1_SR_RECO_STOP_CON) || - (SignalCode == L1_SR_RECO_STOP_IND) ) - { - // Send the message MMI_SR_RECO_STOP_CON with a bad recognition error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_RECO_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->header.msg_id = MMI_SR_RECO_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->error_id = SC_BAD_RECOGNITION; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_RECO_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_RECO_STOP_CON; - // File the message - ((T_MMI_SR_RECO_STOP_CON *)(conf_msg->SigP))->error_id = SC_BAD_RECOGNITION; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - - case WAIT_BACK_STOP: - { - if (SignalCode == L1_SRBACK_LOAD_MODEL_CON) - { - // Send the MMI_SR_RECO_STOP_CON with an bad recognition error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_RECO_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->header.msg_id = MMI_SR_RECO_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_RECO_STOP_CON *)(p_message))->error_id = SC_BAD_RECOGNITION; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_RECO_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_RECO_STOP_CON; - // Fill the message - ((T_MMI_SR_RECO_STOP_CON *)(conf_msg->SigP))->error_id = SC_BAD_RECOGNITION; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - - /*---------------------------------------------------------*/ - /* l1a_mmi_sr_update_check_process() */ - /*---------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* speech recognition update check feature. */ - /* */ - /* Starting messages: MMI_SR_UPDATE_CHECK_START_REQ */ - /* */ - /* Result messages (input): L1_SR_UPDATE_START_CON */ - /* */ - /* Result messages (output): MMI_SR_UPDATE_CHECK_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_SR_UPDATE_CHECK_STOP_REQ */ - /* L1_SR_RECO_STOP_IND */ - /* */ - /* Stop message (output): MMI_SR_UPDATE_CHECK_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*---------------------------------------------------------*/ - void l1a_mmi_sr_update_check_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_MODEL = 2, - WAIT_UPDATE_START = 3, - WAIT_UPDATE_STOP = 4, - WAIT_TEMP_SAVE_DONE = 5, - LOAD_MODEL = 6, - WAIT_MODEL_LOADED = 7, - WAIT_PROCESSING_STOP = 8, - WAIT_SAVE_DONE = 9, - WAIT_L1S_STOP = 10, - WAIT_BACK_STOP = 11 - }; - - UWORD8 *state = &l1a.state[L1A_SR_UPDATE_CHECK_STATE]; - UWORD32 SignalCode = msg->SignalCode; - #if (OP_RIV_AUDIO == 1) - void *p_message; - T_RVF_MB_STATUS mb_status; - #define AUDIO_MSG (p_message) - #else - xSignalHeaderRec *conf_msg; - #define AUDIO_MSG (conf_msg->SigP) - #endif - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.update_start = FALSE; - l1a_l1s_com.speechreco_task.command.update_stop = FALSE; - l1a_l1s_com.speechreco_task.command.speech_start = FALSE; - l1a_l1s_com.speechreco_task.command.speech_stop = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_SR_UPDATE_CHECK_START_REQ) - { - // Download the message parameters to the parameters memory - l1a_l1s_com.speechreco_task.parameters.database_id = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->database_id; - l1a_l1s_com.speechreco_task.parameters.word_index = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->word_index; - l1a_l1s_com.speechreco_task.parameters.word_to_check = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->word_index; - l1a_l1s_com.speechreco_task.parameters.model_address = l1s_dsp_com.dsp_ndb_ptr->a_model; - l1a_l1s_com.speechreco_task.parameters.model_temp_address = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->model_address; - l1a_l1s_com.speechreco_task.parameters.speech = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->speech; - l1a_l1s_com.speechreco_task.parameters.speech_address = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->speech_address; - l1a_l1s_com.speechreco_task.parameters.vocabulary_size = ((T_MMI_SR_UPDATE_CHECK_REQ *)(msg->SigP))->vocabulary_size; - - // Reset the background task emergency stop - l1_srback_com.emergency_stop = FALSE; - - // Start to download the model to the API - l1a_l1s_com.speechreco_task.parameters.CTO_algorithm = FALSE; - l1_send_sr_background_msg(L1_SRBACK_LOAD_MODEL_REQ); - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_SR_UPDATE_CHECK_START_CON); - - *state = WAIT_MODEL; - } - - // End process - return; - } - break; - - case WAIT_MODEL: - { - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - } - else - if (SignalCode == L1_SRBACK_LOAD_MODEL_CON) - { - // Set the start command of the speech recording task - l1a_l1s_com.speechreco_task.command.speech_start = l1a_l1s_com.speechreco_task.parameters.speech; - - // Start the speech recognition update task - l1a_l1s_com.speechreco_task.command.update_start = TRUE; - - *state = WAIT_UPDATE_START; - } - - // End process - return; - } - break; - - case WAIT_UPDATE_START: - { - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop the speech recognition update task - l1a_l1s_com.speechreco_task.command.update_stop = TRUE; - - // Stop the speech recording task (if present) - l1a_l1s_com.speechreco_task.command.speech_stop = l1a_l1s_com.speechreco_task.parameters.speech; - - *state = WAIT_L1S_STOP; - } - else - if (SignalCode == L1_SR_UPDATE_START_CON) - { - // Reset the commands - l1a_l1s_com.speechreco_task.command.update_start = FALSE; - l1a_l1s_com.speechreco_task.command.speech_start = FALSE; - - *state = WAIT_UPDATE_STOP; - } - - // End process - return; - } - break; - - case WAIT_UPDATE_STOP: - { - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop the speech recognition update task - l1a_l1s_com.speechreco_task.command.update_stop = TRUE; - - // Stop the speech recording task (if present) - l1a_l1s_com.speechreco_task.command.speech_stop = l1a_l1s_com.speechreco_task.parameters.speech; - - *state = WAIT_L1S_STOP; - - // End process - return; - } - else - if (SignalCode == L1_SR_UPDATE_STOP_CON) - { - // There is an error during the update task? - if ( ((T_L1_SR_UPDATE_STOP_CON *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - // Reset the background task emergency stop - l1_srback_com.emergency_stop = FALSE; - - // Send the message L1_SRBACK_SAVE_DATA_REQ to the background task - l1_send_sr_background_msg(L1_SRBACK_TEMP_SAVE_DATA_REQ); - - *state = WAIT_TEMP_SAVE_DONE; - - // End process - return; - } - else - { - // Forward the stop confirmation message - l1a_audio_send_result(MMI_SR_UPDATE_CHECK_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - } - else - { - // End process - return; - } - } - break; - - case WAIT_TEMP_SAVE_DONE: - { - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - - // End process - return; - } - else - if (SignalCode == L1_SRBACK_TEMP_SAVE_DATA_CON) - { - // Reset the command - l1a_l1s_com.speechreco_task.command.processing_start = FALSE; - l1a_l1s_com.speechreco_task.command.processing_stop = FALSE; - - // Reset the index counter - l1a_l1s_com.speechreco_task.parameters.index_counter = 0; - - // The CTO algorithm must be used? - if (l1a_l1s_com.speechreco_task.parameters.vocabulary_size <= SC_SR_MAX_WORDS_FOR_CTO) - { - // Enable the CTO algorithm - l1a_l1s_com.speechreco_task.parameters.CTO_algorithm = TRUE; - - // Double the vocabulary size - l1a_l1s_com.speechreco_task.parameters.vocabulary_size <<= 1; - } - else - { - // Disable the CTO algorithm - l1a_l1s_com.speechreco_task.parameters.CTO_algorithm = FALSE; - } - - *state = LOAD_MODEL; - } - else - { - // End process - return; - } - } - break; - - case LOAD_MODEL: - { - // Initialize the background task stop command - l1_srback_com.emergency_stop = FALSE; - - // Start to load the model to the API - l1a_l1s_com.speechreco_task.parameters.word_index = l1a_l1s_com.speechreco_task.parameters.index_counter; - l1_send_sr_background_msg(L1_SRBACK_LOAD_MODEL_REQ); - - // Increase the index counter - l1a_l1s_com.speechreco_task.parameters.index_counter++; - - *state = WAIT_MODEL_LOADED; - - // End process - return; - } - break; - - case WAIT_MODEL_LOADED: - { - if (SignalCode == L1_SRBACK_LOAD_MODEL_CON) - { - // Start the DSP processing task - l1a_l1s_com.speechreco_task.command.processing_start = TRUE; - - *state = WAIT_PROCESSING_STOP; - } - else - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - } - - // End process - return; - } - break; - - case WAIT_PROCESSING_STOP: - { - if (SignalCode == L1_SR_PROCESSING_STOP_CON) - { - // The processing phase is good or not? - if ( ((T_L1_SR_PROCESSING_STOP_CON *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - *state = LOAD_MODEL; - } - else - { - // Send the MMI_SR_UPDATE_CHECK_STOP_CON message with an error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_CHECK_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_CHECK_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->error_id = - ((T_L1_SR_PROCESSING_STOP_CON *)(msg->SigP))->error_id; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_CHECK_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_CHECK_STOP_CON; - // File the message - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(conf_msg->SigP))->error_id = ((T_L1_SR_PROCESSING_STOP_CON *)(msg->SigP))->error_id; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - } - else - if (SignalCode == L1_SR_RECO_STOP_IND) - { - // There is an error during the recognition? - if ( ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->error_id == SC_NO_ERROR ) - { - // The CTO algorithm is used? - if (l1a_l1s_com.speechreco_task.parameters.CTO_algorithm) - { - // The best word is odd? - if ( ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_index & 0x01 ) - { - // Change the error to SC_CTO_WORD - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->error_id = SC_CTO_WORD; - - // Forward the message in the MMI_SR_RECO_STOP_CON - l1a_audio_send_result(MMI_SR_UPDATE_CHECK_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - - // End process - return; - } - else - { - // Devided by 2 the 4 indexes of the best words in the message - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_index >>= 1; - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->second_best_word_index >>= 1; - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->third_best_word_index >>= 1; - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->fourth_best_word_index >>= 1; - } - } - // Is it the good word? - if ( ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_index == - l1a_l1s_com.speechreco_task.parameters.word_to_check ) - { - // Save the message informations in the l1a_l1s_com memory - l1a_l1s_com.speechreco_task.parameters.best_word_index = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_index; - l1a_l1s_com.speechreco_task.parameters.best_word_score = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->best_word_score; - l1a_l1s_com.speechreco_task.parameters.second_best_word_index = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->second_best_word_index; - l1a_l1s_com.speechreco_task.parameters.second_best_word_score = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->second_best_word_score; - l1a_l1s_com.speechreco_task.parameters.third_best_word_index = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->third_best_word_index; - l1a_l1s_com.speechreco_task.parameters.third_best_word_score = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->third_best_word_score; - l1a_l1s_com.speechreco_task.parameters.fourth_best_word_index = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->fourth_best_word_index; - l1a_l1s_com.speechreco_task.parameters.fourth_best_word_score = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->fourth_best_word_score; - l1a_l1s_com.speechreco_task.parameters.d_sr_db_level = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->d_sr_db_level; - l1a_l1s_com.speechreco_task.parameters.d_sr_db_noise = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->d_sr_db_noise; - l1a_l1s_com.speechreco_task.parameters.d_sr_model_size = ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->d_sr_model_size; - - // Reset the stop background task - l1_srback_com.emergency_stop = FALSE; - - // Start the background task to save the model in the database - l1a_l1s_com.speechreco_task.parameters.word_index = l1a_l1s_com.speechreco_task.parameters.word_to_check; - l1a_l1s_com.speechreco_task.parameters.model_address = l1a_l1s_com.speechreco_task.parameters.model_temp_address; - l1_send_sr_background_msg(L1_SRBACK_SAVE_DATA_REQ); - - *state = WAIT_SAVE_DONE; - - // End process - return; - } - else - { - // Change the error to SC_CHECK_ERROR - ((T_L1_SR_RECO_STOP_IND *)(msg->SigP))->error_id = SC_CHECK_ERROR; - } - } - // Forward the message in the MMI_SR_RECO_STOP_CON - l1a_audio_send_result(MMI_SR_UPDATE_CHECK_STOP_CON, msg, MMI_QUEUE); - - *state = RESET; - } - else - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop the L1S processing task - l1a_l1s_com.speechreco_task.command.processing_stop = TRUE; - - *state = WAIT_L1S_STOP; - - // end process - return; - } - else - { - // end process - return; - } - } - break; - - case WAIT_SAVE_DONE: - { - if (SignalCode == MMI_SR_UPDATE_CHECK_STOP_REQ) - { - // Stop immediatly the background task - l1_srback_com.emergency_stop = TRUE; - - *state = WAIT_BACK_STOP; - - // End process - return; - } - else - if (SignalCode == L1_SRBACK_SAVE_DATA_CON) - { - // Send the MMI_SR_UPDATE_CHECK_STOP_CON message with an error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_CHECK_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_CHECK_STOP_CON; - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_CHECK_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_CHECK_STOP_CON; - #endif // OP_RIV_AUDIO - - // Fill the message parameter - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->error_id = SC_NO_ERROR; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->best_word_index = l1a_l1s_com.speechreco_task.parameters.best_word_index; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->best_word_score = l1a_l1s_com.speechreco_task.parameters.best_word_score; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->second_best_word_index = l1a_l1s_com.speechreco_task.parameters.second_best_word_index; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->second_best_word_score = l1a_l1s_com.speechreco_task.parameters.second_best_word_score; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->third_best_word_index = l1a_l1s_com.speechreco_task.parameters.third_best_word_index; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->third_best_word_score = l1a_l1s_com.speechreco_task.parameters.third_best_word_score; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->fourth_best_word_index = l1a_l1s_com.speechreco_task.parameters.fourth_best_word_index; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->fourth_best_word_score = l1a_l1s_com.speechreco_task.parameters.fourth_best_word_score; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->d_sr_db_level = l1a_l1s_com.speechreco_task.parameters.d_sr_db_level; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->d_sr_db_noise = l1a_l1s_com.speechreco_task.parameters.d_sr_db_noise; - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(AUDIO_MSG))->d_sr_model_size = l1a_l1s_com.speechreco_task.parameters.d_sr_model_size; - - #if (OP_RIV_AUDIO == 1) - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - - case WAIT_BACK_STOP: - { - if ( (SignalCode == L1_SRBACK_SAVE_DATA_CON) || - (SignalCode == L1_SRBACK_LOAD_MODEL_CON) || - (SignalCode == L1_SRBACK_TEMP_SAVE_DATA_CON) ) - { - // Send the message MMI_SR_UPDATE_STOP_CON with an update error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_CHECK_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_CHECK_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->error_id = SC_CHECK_ERROR; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_CHECK_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_CHECK_STOP_CON; - - //Fill the message - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(conf_msg->SigP))->error_id = SC_CHECK_ERROR; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - - case WAIT_L1S_STOP: - { - if ( (SignalCode == L1_SR_UPDATE_STOP_CON) || - (SignalCode == L1_SR_PROCESSING_STOP_CON) || - (SignalCode == L1_SR_RECO_STOP_CON) || - (SignalCode == L1_SR_RECO_STOP_IND) ) - { - // Send the message MMI_SR_UPDATE_CHECK_STOP_CON with an update error - #if (OP_RIV_AUDIO == 1) - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_SR_UPDATE_CHECK_STOP_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->header.msg_id = MMI_SR_UPDATE_CHECK_STOP_CON; - - // Fill the message parameter - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(p_message))->error_id = SC_CHECK_ERROR; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId, - p_message); - #else // OP_RIV_AUDIO - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_MMI_SR_UPDATE_CHECK_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = MMI_SR_UPDATE_CHECK_STOP_CON; - - //Fill the message - ((T_MMI_SR_UPDATE_CHECK_STOP_CON *)(conf_msg->SigP))->error_id = SC_CHECK_ERROR; - - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_message(conf_msg); - #endif - - // Send the confirmation message... - os_send_sig(conf_msg, MMI_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - #endif // OP_RIV_AUDIO - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - - // Undefine message pointer macro. - #undef MSG_AUDIO - - } - - #endif // L1_DYN_DSP_DWNLD - #endif // SPEECH_RECO - #if (L1_AEC == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_aec_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* AEC feature. */ - /* */ - /* Starting messages: MMI_AEC_REQ */ - /* */ - /* Result messages (input): none */ - /* */ - /* Result messages (output): MMI_AEC_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ -#if (L1_DYN_DSP_DWNLD == 1) - void l1a_mmi_aec_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_AEC_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_AEC_CON = 3 - }; - - UWORD8 *state = &l1a.state[L1A_AEC_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.aec_task.command.start = FALSE; - - *state = WAIT_AEC_REQ; - } - break; - - case WAIT_AEC_REQ: - { - if (SignalCode == MMI_AEC_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.aec_task.parameters.aec_control = ((T_MMI_AEC_REQ *)(msg->SigP))->aec_control; - #if (L1_NEW_AEC) - l1a_l1s_com.aec_task.parameters.cont_filter = ((T_MMI_AEC_REQ *)(msg->SigP))->cont_filter; - l1a_l1s_com.aec_task.parameters.granularity_att = ((T_MMI_AEC_REQ *)(msg->SigP))->granularity_att; - l1a_l1s_com.aec_task.parameters.coef_smooth = ((T_MMI_AEC_REQ *)(msg->SigP))->coef_smooth; - l1a_l1s_com.aec_task.parameters.es_level_max = ((T_MMI_AEC_REQ *)(msg->SigP))->es_level_max; - l1a_l1s_com.aec_task.parameters.fact_vad = ((T_MMI_AEC_REQ *)(msg->SigP))->fact_vad; - l1a_l1s_com.aec_task.parameters.thrs_abs = ((T_MMI_AEC_REQ *)(msg->SigP))->thrs_abs; - l1a_l1s_com.aec_task.parameters.fact_asd_fil = ((T_MMI_AEC_REQ *)(msg->SigP))->fact_asd_fil; - l1a_l1s_com.aec_task.parameters.fact_asd_mut = ((T_MMI_AEC_REQ *)(msg->SigP))->fact_asd_mut; - #endif - - #if (L1_ANR == 1) - if (l1a_l1s_com.aec_task.parameters.aec_control & 0x0004) - { - // Noise suppression enabled: enable new ANR module for backward compatibility - l1a_l1s_com.aec_task.parameters.aec_control &= ~(0x0104); // Clear noise suppression bits in AEC control - - // Enable L1S ANR task (default settings are used) - l1a_l1s_com.anr_task.parameters.anr_enable = 1; - l1a_l1s_com.anr_task.parameters.min_gain = 0x3313; - l1a_l1s_com.anr_task.parameters.div_factor_shift = -2; - l1a_l1s_com.anr_task.parameters.ns_level = 1; - l1a_l1s_com.anr_task.command.update = TRUE; - - // Here we do not wait for L1S confirmation to have simple implementation - // because the state machine already wait for AEC confirmation and - // ANR confirmation would occur on the same frame - } - else - { - // Noise suppression disabled: disable ANR - l1a_l1s_com.anr_task.parameters.anr_enable = 0; - l1a_l1s_com.anr_task.command.update = TRUE; - - // Here we do not wait for L1S confirmation to have simple implementation - // because the state machine already wait for AEC confirmation and - // ANR confirmation would occur on the same frame - } - #endif - if (l1a.dyn_dwnld.semaphore_vect[ANR_STATE_MACHINE] == GREEN) - { - // WARNING: The following code must be duplicated in WAIT_DYN_DWNLD state when - // activating the command at L1s level - - // Start the L1S AEC task - l1a_l1s_com.aec_task.command.start = TRUE; - - *state = WAIT_AEC_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"AEC SM blocked by DYN DWNLD\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - - // End process - return; - } - break; - case WAIT_DYN_DWNLD: - { - if (SignalCode == API_L1_DYN_DWNLD_FINISHED && l1a.dyn_dwnld.semaphore_vect[ANR_STATE_MACHINE] == GREEN) - { - // Start the L1S AEC task - l1a_l1s_com.aec_task.command.start = TRUE; - - *state = WAIT_AEC_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"AEC SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - break; - case WAIT_AEC_CON: - { - if (SignalCode == L1_AEC_CON) - { - // Send the AEC confirmation message - l1a_audio_send_confirmation(MMI_AEC_CON); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } -#else - void l1a_mmi_aec_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_AEC_REQ = 1, - WAIT_AEC_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_AEC_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.aec_task.command.start = FALSE; - - *state = WAIT_AEC_REQ; - } - break; - - case WAIT_AEC_REQ: - { - if (SignalCode == MMI_AEC_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.aec_task.parameters.aec_control = ((T_MMI_AEC_REQ *)(msg->SigP))->aec_control; - #if (L1_NEW_AEC) - l1a_l1s_com.aec_task.parameters.cont_filter = ((T_MMI_AEC_REQ *)(msg->SigP))->cont_filter; - l1a_l1s_com.aec_task.parameters.granularity_att = ((T_MMI_AEC_REQ *)(msg->SigP))->granularity_att; - l1a_l1s_com.aec_task.parameters.coef_smooth = ((T_MMI_AEC_REQ *)(msg->SigP))->coef_smooth; - l1a_l1s_com.aec_task.parameters.es_level_max = ((T_MMI_AEC_REQ *)(msg->SigP))->es_level_max; - l1a_l1s_com.aec_task.parameters.fact_vad = ((T_MMI_AEC_REQ *)(msg->SigP))->fact_vad; - l1a_l1s_com.aec_task.parameters.thrs_abs = ((T_MMI_AEC_REQ *)(msg->SigP))->thrs_abs; - l1a_l1s_com.aec_task.parameters.fact_asd_fil = ((T_MMI_AEC_REQ *)(msg->SigP))->fact_asd_fil; - l1a_l1s_com.aec_task.parameters.fact_asd_mut = ((T_MMI_AEC_REQ *)(msg->SigP))->fact_asd_mut; - #endif - - #if (L1_ANR == 1) - if (l1a_l1s_com.aec_task.parameters.aec_control & 0x0004) - { - // Noise suppression enabled: enable new ANR module for backward compatibility - l1a_l1s_com.aec_task.parameters.aec_control &= ~(0x0104); // Clear noise suppression bits in AEC control - - // Enable L1S ANR task (default settings are used) - l1a_l1s_com.anr_task.parameters.anr_enable = 1; - l1a_l1s_com.anr_task.parameters.min_gain = 0x3313; - l1a_l1s_com.anr_task.parameters.div_factor_shift = -2; - l1a_l1s_com.anr_task.parameters.ns_level = 1; - l1a_l1s_com.anr_task.command.update = TRUE; - - // Here we do not wait for L1S confirmation to have simple implementation - // because the state machine already wait for AEC confirmation and - // ANR confirmation would occur on the same frame - } - else - { - // Noise suppression disabled: disable ANR - l1a_l1s_com.anr_task.parameters.anr_enable = 0; - l1a_l1s_com.anr_task.command.update = TRUE; - - // Here we do not wait for L1S confirmation to have simple implementation - // because the state machine already wait for AEC confirmation and - // ANR confirmation would occur on the same frame - } - #endif - - // Start the L1S AEC task - l1a_l1s_com.aec_task.command.start = TRUE; - - *state = WAIT_AEC_CON; - } - - // End process - return; - } - break; - - case WAIT_AEC_CON: - { - if (SignalCode == L1_AEC_CON) - { - // Send the AEC confirmation message - l1a_audio_send_confirmation(MMI_AEC_CON); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - #endif // L1_DYN_DSP_DWNLD == 1 - #endif // AEC - - #if (L1_AEC == 2) - /*-------------------------------------------------------*/ - /* l1a_mmi_aec_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* AEC feature. */ - /* */ - /* Starting messages: MMI_AEC_REQ */ - /* */ - /* Result messages (input): none */ - /* */ - /* Result messages (output): MMI_AEC_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - #if (L1_DYN_DSP_DWNLD == 1) - void l1a_mmi_aec_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_AEC_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_AEC_CON = 3 - }; - - UWORD8 *state = &l1a.state[L1A_AEC_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.aec_task.command.start = FALSE; - - *state = WAIT_AEC_REQ; - } - break; - - case WAIT_AEC_REQ: - { - if (SignalCode == MMI_AQI_AEC_REQ) - { - - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.aec_task.aec_control = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_control; - - if(l1a_l1s_com.aec_task.aec_control != L1_AQI_AEC_STOP) - { - - l1a_l1s_com.aec_task.parameters.cont_filter = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.cont_filter; - l1a_l1s_com.aec_task.parameters.granularity_att = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.granularity_att; - l1a_l1s_com.aec_task.parameters.coef_smooth = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.coef_smooth; - l1a_l1s_com.aec_task.parameters.es_level_max = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.es_level_max; - l1a_l1s_com.aec_task.parameters.fact_vad = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.fact_vad; - l1a_l1s_com.aec_task.parameters.thrs_abs = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.thrs_abs; - l1a_l1s_com.aec_task.parameters.fact_asd_fil = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.fact_asd_fil; - l1a_l1s_com.aec_task.parameters.fact_asd_mut = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.fact_asd_mut; - l1a_l1s_com.aec_task.parameters.aec_mode = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.aec_mode; - l1a_l1s_com.aec_task.parameters.mu = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.mu; - l1a_l1s_com.aec_task.parameters.scale_input_ul = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.scale_input_ul; - l1a_l1s_com.aec_task.parameters.scale_input_dl = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.scale_input_dl; - l1a_l1s_com.aec_task.parameters.div_dmax = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.div_dmax; - l1a_l1s_com.aec_task.parameters.div_swap_good = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.div_swap_good; - l1a_l1s_com.aec_task.parameters.div_swap_bad = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.div_swap_bad; - l1a_l1s_com.aec_task.parameters.block_init = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.block_init; -// l1a_l1s_com.aec_task.parameters.block_size = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.block_size; - - } - - if (l1a.dyn_dwnld.semaphore_vect[AEC_STATE_MACHINE] == GREEN) - { - // WARNING: The following code must be duplicated in WAIT_DYN_DWNLD state when - // activating the command at L1s level - - // Start the L1S AEC task - l1a_l1s_com.aec_task.command.start = TRUE; - - *state = WAIT_AEC_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"AEC SM blocked by DYN DWNLD\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - - // End process - return; - } - // omaps00090550 break; - case WAIT_DYN_DWNLD: - { - if (SignalCode == API_L1_DYN_DWNLD_FINISHED && l1a.dyn_dwnld.semaphore_vect[ANR_STATE_MACHINE] == GREEN) - { - // Start the L1S AEC task - l1a_l1s_com.aec_task.command.start = TRUE; - - *state = WAIT_AEC_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"AEC SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - // omaps00090550 break; - case WAIT_AEC_CON: - { - if (SignalCode == L1_AQI_AEC_CON) - { - // Send the AEC confirmation message - l1a_audio_send_result(MMI_AQI_AEC_CON, msg, MMI_QUEUE); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - #else - void l1a_mmi_aec_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_AEC_REQ = 1, - WAIT_AEC_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_AEC_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.aec_task.command.start = FALSE; - - *state = WAIT_AEC_REQ; - } - break; - - case WAIT_AEC_REQ: - { - if (SignalCode == MMI_AQI_AEC_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.aec_task.aec_control = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_control; - - if(l1a_l1s_com.aec_task.aec_control != L1_AQI_AEC_STOP) - { - - l1a_l1s_com.aec_task.parameters.cont_filter = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.cont_filter; - l1a_l1s_com.aec_task.parameters.granularity_att = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.granularity_att; - l1a_l1s_com.aec_task.parameters.coef_smooth = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.coef_smooth; - l1a_l1s_com.aec_task.parameters.es_level_max = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.es_level_max; - l1a_l1s_com.aec_task.parameters.fact_vad = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.fact_vad; - l1a_l1s_com.aec_task.parameters.thrs_abs = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.thrs_abs; - l1a_l1s_com.aec_task.parameters.fact_asd_fil = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.fact_asd_fil; - l1a_l1s_com.aec_task.parameters.fact_asd_mut = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.fact_asd_mut; - l1a_l1s_com.aec_task.parameters.aec_mode = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.aec_mode; - l1a_l1s_com.aec_task.parameters.mu = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.mu; - l1a_l1s_com.aec_task.parameters.scale_input_ul = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.scale_input_ul; - l1a_l1s_com.aec_task.parameters.scale_input_dl = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.scale_input_dl; - l1a_l1s_com.aec_task.parameters.div_dmax = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.div_dmax; - l1a_l1s_com.aec_task.parameters.div_swap_good = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.div_swap_good; - l1a_l1s_com.aec_task.parameters.div_swap_bad = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.div_swap_bad; - l1a_l1s_com.aec_task.parameters.block_init = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.block_init; -// l1a_l1s_com.aec_task.parameters.block_size = ((T_MMI_AQI_AEC_REQ *)(msg->SigP))->aec_parameters.block_size; - - } - - #if (L1_ANR == 1) - if (l1a_l1s_com.aec_task.aec_control & 0x0004) - { - // Noise suppression enabled: enable new ANR module for backward compatibility - l1a_l1s_com.aec_task.aec_control &= ~(0x0104); // Clear noise suppression bits in AEC control - - // Enable L1S ANR task (default settings are used) - l1a_l1s_com.anr_task.parameters.anr_enable = 1; - l1a_l1s_com.anr_task.parameters.min_gain = 0x3313; - l1a_l1s_com.anr_task.parameters.div_factor_shift = -2; - l1a_l1s_com.anr_task.parameters.ns_level = 1; - l1a_l1s_com.anr_task.command.update = TRUE; - - // Here we do not wait for L1S confirmation to have simple implementation - // because the state machine already wait for AEC confirmation and - // ANR confirmation would occur on the same frame - } - else - { - // Noise suppression disabled: disable ANR - l1a_l1s_com.anr_task.parameters.anr_enable = 0; - l1a_l1s_com.anr_task.command.update = TRUE; - - // Here we do not wait for L1S confirmation to have simple implementation - // because the state machine already wait for AEC confirmation and - // ANR confirmation would occur on the same frame - } - #endif - - // Start the L1S AEC task - l1a_l1s_com.aec_task.command.start = TRUE; - - *state = WAIT_AEC_CON; - } - - // End process - return; - } - break; - - case WAIT_AEC_CON: - { - if (SignalCode == L1_AQI_AEC_CON) - { - // Send the AEC confirmation message - l1a_audio_send_result(MMI_AQI_AEC_CON, msg, MMI_QUEUE); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - #endif // L1_DYN_DSP_DWNLD == 1 - #endif // L1_AEC == 2 - - - #if (FIR) - /*-------------------------------------------------------*/ - /* l1a_mmi_fir_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* FIR feature. */ - /* */ - /* Starting messages: MMI_AUDIO_FIR_REQ */ - /* */ - /* Result messages (input): none */ - /* */ - /* Result messages (output): MMI_AUDIO_FIR_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_fir_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_FIR_REQ = 1, - WAIT_FIR_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_FIR_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.fir_task.command.start = FALSE; - - *state = WAIT_FIR_REQ; - } - break; - - case WAIT_FIR_REQ: - { - if (SignalCode == MMI_AUDIO_FIR_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.fir_task.parameters.fir_loop = ((T_MMI_AUDIO_FIR_REQ *)(msg->SigP))->fir_loop; - l1a_l1s_com.fir_task.parameters.update_fir = ((T_MMI_AUDIO_FIR_REQ *)(msg->SigP))->update_fir; - l1a_l1s_com.fir_task.parameters.fir_ul_coefficient = ((T_MMI_AUDIO_FIR_REQ *)(msg->SigP))->fir_ul_coefficient; - - // we update FIR coefficients even if L1_IIR==1 because in case of loop mode - // this is the old FIR API that is used - l1a_l1s_com.fir_task.parameters.fir_dl_coefficient = ((T_MMI_AUDIO_FIR_REQ *)(msg->SigP))->fir_dl_coefficient; - - #if (L1_IIR == 1) - if (l1a_l1s_com.fir_task.parameters.update_fir & DL_FIR) - { - // FIR DL update enabled: enable new IIR/DL module for backward compatibility - - // Enable L1S IIR task - // Settings tuned to have same behavior as DL FIR - l1a_l1s_com.iir_task.parameters.iir_enable = 1; // Filter always enabled - l1a_l1s_com.iir_task.parameters.nb_iir_blocks = 0; // IIR part disabled - l1a_l1s_com.iir_task.parameters.iir_coefs = 0; - l1a_l1s_com.iir_task.parameters.nb_fir_coefs = 0x1f; - l1a_l1s_com.iir_task.parameters.fir_coefs = (WORD16 *)((T_MMI_AUDIO_FIR_REQ *)(msg->SigP))->fir_dl_coefficient; - l1a_l1s_com.iir_task.parameters.input_scaling = 0; - l1a_l1s_com.iir_task.parameters.fir_scaling = 0; - l1a_l1s_com.iir_task.parameters.input_gain_scaling = 0; - l1a_l1s_com.iir_task.parameters.output_gain_scaling = 0; - l1a_l1s_com.iir_task.parameters.output_gain = 0xffff; // Used for IIR using in FIR mode - l1a_l1s_com.iir_task.parameters.feedback = 0; - l1a_l1s_com.iir_task.command.update = TRUE; - - // Here we do not wait for L1S confirmation to have simple implementation - // because the state machine already wait for FIR confirmation and - // there is no chance that upper layer frees the memory used to store - // DL coefficients before L1S copy them into API - } - #endif - - // Start the L1S FIR task - l1a_l1s_com.fir_task.command.start = TRUE; - - *state = WAIT_FIR_CON; - } - - // End process - return; - } - // omaps00090550 break; - - case WAIT_FIR_CON: - { - if (SignalCode == L1_AUDIO_FIR_CON) - { - // Send the FIR confirmation message - l1a_audio_send_confirmation(MMI_AUDIO_FIR_CON); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - #endif // FIR - #if (AUDIO_MODE) - /*-------------------------------------------------------*/ - /* l1a_mmi_audio_mode_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* audio mode features. */ - /* */ - /* Starting messages: MMI_AUDIO_MODE_REQ */ - /* */ - /* Result messages (input): none */ - /* */ - /* Result messages (output): MMI_AUDIO_MODE_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_audio_mode_process (xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_AUDIO_MODE_REQ = 1, - WAIT_AUDIO_MODE_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_AUDIO_MODE_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.audio_mode_task.command.start = FALSE; - - *state = WAIT_AUDIO_MODE_REQ; - } - break; - - case WAIT_AUDIO_MODE_REQ: - { - if (SignalCode == MMI_AUDIO_MODE_REQ) - { - switch (((T_MMI_AUDIO_MODE *)(msg->SigP))->audio_mode) - { - case GSM_ONLY: - { - // Set the GSM only mode - l1a_l1s_com.audio_mode_task.parameters.audio_mode = B_GSM_ONLY; - break; - } - case BT_CORDLESS: - { - // Set the bluetooth cordless mode - l1a_l1s_com.audio_mode_task.parameters.audio_mode = B_BT_CORDLESS; - break; - } - case BT_HEADSET: - { - // Set the bluetooth headset mode - l1a_l1s_com.audio_mode_task.parameters.audio_mode = B_BT_HEADSET; - break; - } - default : - { - break; - } - } // switch - - // Start the L1S AUDIO MODE task - l1a_l1s_com.audio_mode_task.command.start = TRUE; - - *state = WAIT_AUDIO_MODE_CON; - } - - // End process - return; - } - // omaps00090550 break; - - case WAIT_AUDIO_MODE_CON: - { - if (SignalCode == L1_AUDIO_MODE_CON) - { - // Send the AUDIO MODE confirmation message - l1a_audio_send_confirmation(MMI_AUDIO_MODE_CON); - - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - #endif // AUDIO_MODE - #if (MELODY_E2) - #if(L1_DYN_DSP_DWNLD==1) - /*-------------------------------------------------------*/ - /* l1a_mmi_melody0_e2_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* melody 0 format E2 feature. */ - /* */ - /* Starting messages: MMI_MELODY0_E2_START_REQ */ - /* */ - /* Result messages (input): L1_MELODY0_E2_START_CON */ - /* */ - /* Result messages (output): MMI_MELODY0_E2_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_MELDOY0_E2_STOP_REQ */ - /* L1_MELODY0_E2_STOP_CON */ - /* */ - /* Stop message (output): MMI_MELODY0_E2_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_melody0_e2_process(xSignalHeaderRec *msg) - { - enum states - { - M0_RESET = 0, - M0_WAIT_START_REQ = 1, - WAIT_DYN_DWNLD = 2, - M0_WAIT_LOAD_INSTRUMENT = 3, - M0_WAIT_STOP = 4, - M0_WAIT_UNLOAD_INSTRUMENT = 5 - }; - - UWORD8 *state = &l1a.state[L1A_MELODY0_E2_STATE], i; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case M0_RESET: - { - // Reset the commands: - l1a_l1s_com.melody0_e2_task.command.start = FALSE; - l1a_l1s_com.melody0_e2_task.command.stop = FALSE; - - *state = M0_WAIT_START_REQ; - } - break; - - case M0_WAIT_START_REQ: - { - if (SignalCode == MMI_MELODY0_E2_START_REQ) - { - // Download the parameters from the message: - l1a_l1s_com.melody0_e2_task.parameters.session_id = ((T_MMI_MELODY_E2_REQ *)(msg->SigP))->session_id; - l1a_l1s_com.melody0_e2_task.parameters.loopback = ((T_MMI_MELODY_E2_REQ *)(msg->SigP))->loopback; - - if(l1a.dyn_dwnld.semaphore_vect[E2_STATE_MACHINE]==GREEN) - { - - // WARNING: code below must be duplicated in WAIT_DYN_DWNLD state -#if ((TRACE_TYPE==1) || (TRACE_TYPE == 4)) - // Disable trace DSP upon E2 MELODY activation - l1_disable_dsp_trace(); -#endif - // Reset the emergency flag - l1a_l1s_com.melody0_e2_task.parameters.emergency_stop = FALSE; - - // Initialize the buffer parameters - l1a_l1s_com.melody0_e2_task.parameters.ptr_buf = NULL; - l1a_l1s_com.melody0_e2_task.parameters.buffer_size = 0; - l1a_l1s_com.melody0_e2_task.parameters.error_id = Cust_get_pointer((UWORD16 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - l1a_l1s_com.melody0_e2_task.parameters.session_id); - - // Convert the buffer size in bytes unit because the E2 melody is defined in byte unit - l1a_l1s_com.melody0_e2_task.parameters.buffer_size <<= 1; - - // Jump the NumberOfOscillator parameter - l1a_l1s_com.melody0_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - 1, - (UWORD8 *)(&(i))); - - // Read the Header of the melody description in order to download the time factor - // clean the MSB of the global time factor register - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_globaltimefactor &= 0x00FF; - l1a_l1s_com.melody0_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - 1, - (UWORD8 *)(&(i))); - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_globaltimefactor = i; - - - // Find the number of insturment of the melody (jump the header memory) - l1a_l1s_com.melody0_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - 1, - &(l1a_l1s_com.melody0_e2_task.parameters.number_of_instrument)); - - for (i=0; i<(l1a_l1s_com.melody0_e2_task.parameters.number_of_instrument); i++) - { - // find the beginning of the melody description (after the header field) - // and put it in the buf_ptr buffer - l1a_l1s_com.melody0_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - 1, - &(l1a_l1s_com.melody0_e2_task.parameters.waves_table_id[i])); - } - - // Initialize the size (in byte unit) of the header - l1a_l1s_com.melody0_e2_task.parameters.header_size = 3 + l1a_l1s_com.melody0_e2_task.parameters.number_of_instrument; - - // download the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ, 0); - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_MELODY0_E2_START_CON); - - *state = M0_WAIT_LOAD_INSTRUMENT; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"E20 SM blocked by DYN DWNLD\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - return; - } - break; - case WAIT_DYN_DWNLD: - { - if((SignalCode == API_L1_DYN_DWNLD_FINISHED) && (l1a.dyn_dwnld.semaphore_vect[E2_STATE_MACHINE] == GREEN)) - { - // Reset the emergency flag - l1a_l1s_com.melody0_e2_task.parameters.emergency_stop = FALSE; - - // Initialize the buffer parameters - l1a_l1s_com.melody0_e2_task.parameters.ptr_buf = NULL; - l1a_l1s_com.melody0_e2_task.parameters.buffer_size = 0; - l1a_l1s_com.melody0_e2_task.parameters.error_id = Cust_get_pointer((UWORD16 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - l1a_l1s_com.melody0_e2_task.parameters.session_id); - - // Convert the buffer size in bytes unit because the E2 melody is defined in byte unit - l1a_l1s_com.melody0_e2_task.parameters.buffer_size <<= 1; - - // Jump the NumberOfOscillator parameter - l1a_l1s_com.melody0_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - 1, - (UWORD8 *)(&(i))); - - // Read the Header of the melody description in order to download the time factor - // clean the MSB of the global time factor register - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_globaltimefactor &= 0x00FF; - l1a_l1s_com.melody0_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - 1, - (UWORD8 *)(&(i))); - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_globaltimefactor = i; - - - // Find the number of insturment of the melody (jump the header memory) - l1a_l1s_com.melody0_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - 1, - &(l1a_l1s_com.melody0_e2_task.parameters.number_of_instrument)); - - for (i=0; i<(l1a_l1s_com.melody0_e2_task.parameters.number_of_instrument); i++) - { - // find the beginning of the melody description (after the header field) - // and put it in the buf_ptr buffer - l1a_l1s_com.melody0_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - 1, - &(l1a_l1s_com.melody0_e2_task.parameters.waves_table_id[i])); - } - - // Initialize the size (in byte unit) of the header - l1a_l1s_com.melody0_e2_task.parameters.header_size = 3 + l1a_l1s_com.melody0_e2_task.parameters.number_of_instrument; - - // download the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ, 0); - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_MELODY0_E2_START_CON); - - *state = M0_WAIT_LOAD_INSTRUMENT; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"E20 SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - break; - case M0_WAIT_LOAD_INSTRUMENT: - { - if (SignalCode == L1_BACK_MELODY_E2_LOAD_INSTRUMENT_CON) - { - if ( ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(msg->SigP))->melody_id == 0 ) - { - // The load instrument confirmation message is for the melody 0 - if (l1a_l1s_com.melody0_e2_task.parameters.emergency_stop) - { - // Unload the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ, 0); - - *state = M0_WAIT_UNLOAD_INSTRUMENT; - - } - else - { - // Start to play the melody0 - l1a_l1s_com.melody0_e2_task.command.start = TRUE; - - *state = M0_WAIT_STOP; - } - } - } - else - if (SignalCode == MMI_MELODY0_E2_STOP_REQ) - { - // Set the emergency flag - l1a_l1s_com.melody0_e2_task.parameters.emergency_stop = TRUE; - } - - // End process - return; - } - break; - - case M0_WAIT_STOP: - { - if (SignalCode == L1_MELODY0_E2_STOP_CON) - { - // Unload the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ, 0); - - *state = M0_WAIT_UNLOAD_INSTRUMENT; - } - else - if (SignalCode == MMI_MELODY0_E2_STOP_REQ) - { - // Stop the melody 0 L1S task: - l1a_l1s_com.melody0_e2_task.command.stop = TRUE; - } - - // End process - return; - } - break; - - case M0_WAIT_UNLOAD_INSTRUMENT: - { - if (SignalCode == L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_CON) - { - if ( ((T_L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ *)(msg->SigP))->melody_id == 0 ) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_MELODY0_E2_STOP_CON); -#if ((TRACE_TYPE==1) || (TRACE_TYPE == 4)) - // Enable trace DSP upon E2 MELODY deactivation - l1_enable_dsp_trace(); -#endif - - *state = M0_RESET; - } - } - - // End process - return; - } - break; - } // switch - } // while(1) - } - - /*-------------------------------------------------------*/ - /* l1a_mmi_melody1_e2_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* melody 1 format E2 feature. */ - /* */ - /* Starting messages: MMI_MELODY1_E2_START_REQ */ - /* */ - /* Result messages (input): L1_MELODY1_E2_START_CON */ - /* */ - /* Result messages (output): MMI_MELODY1_E2_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_MELDOY0_E2_STOP_REQ */ - /* L1_MELODY1_E2_STOP_CON */ - /* */ - /* Stop message (output): MMI_MELODY1_E2_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_melody1_e2_process(xSignalHeaderRec *msg) - { - enum states - { - M1_RESET = 0, - M1_WAIT_START_REQ = 1, - WAIT_DYN_DWNLD = 2, - M1_WAIT_LOAD_INSTRUMENT = 3, - M1_WAIT_STOP = 4, - M1_WAIT_UNLOAD_INSTRUMENT = 5 - }; - - UWORD8 *state = &l1a.state[L1A_MELODY1_E2_STATE], i; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case M1_RESET: - { - // Reset the commands: - l1a_l1s_com.melody1_e2_task.command.start = FALSE; - l1a_l1s_com.melody1_e2_task.command.stop = FALSE; - - *state = M1_WAIT_START_REQ; - } - break; - - case M1_WAIT_START_REQ: - { - if (SignalCode == MMI_MELODY1_E2_START_REQ) - { - // Download the parameters from the message: - l1a_l1s_com.melody1_e2_task.parameters.session_id = ((T_MMI_MELODY_E2_REQ *)(msg->SigP))->session_id; - l1a_l1s_com.melody1_e2_task.parameters.loopback = ((T_MMI_MELODY_E2_REQ *)(msg->SigP))->loopback; - - if(l1a.dyn_dwnld.semaphore_vect[E2_STATE_MACHINE] == GREEN) - { - // WARNING: code below must be duplicated in WAIT_DYN_DWNLD state -#if ((TRACE_TYPE==1) || (TRACE_TYPE == 4)) - // Disable trace DSP upon E2 MELODY activation - l1_disable_dsp_trace(); -#endif - // Reset the emergency flag - l1a_l1s_com.melody1_e2_task.parameters.emergency_stop = FALSE; - - // Initialize the buffer parameters - l1a_l1s_com.melody1_e2_task.parameters.ptr_buf = NULL; - l1a_l1s_com.melody1_e2_task.parameters.buffer_size = 0; - l1a_l1s_com.melody1_e2_task.parameters.error_id = Cust_get_pointer((UWORD16 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - l1a_l1s_com.melody1_e2_task.parameters.session_id); - - // Convert the buffer size in bytes unit because the E2 melody is defined in byte unit - l1a_l1s_com.melody1_e2_task.parameters.buffer_size <<= 1; - - // Jump the NumberOfOscillator parameter - l1a_l1s_com.melody1_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - 1, - (UWORD8 *)(&(i))); - - // Read the Header of the melody description in order to download the time factor - // clean the MSB of the global time factor register - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_globaltimefactor &= 0x00FF; - l1a_l1s_com.melody1_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - 1, - (UWORD8 *)(&(i))); - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_globaltimefactor = i; - - - // Find the number of insturment of the melody (jump the header memory) - l1a_l1s_com.melody1_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - 1, - &(l1a_l1s_com.melody1_e2_task.parameters.number_of_instrument)); - - for (i=0; i<(l1a_l1s_com.melody1_e2_task.parameters.number_of_instrument); i++) - { - // find the beginning of the melody description (after the header field) - // and put it in the buf_ptr buffer - l1a_l1s_com.melody1_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - 1, - &(l1a_l1s_com.melody1_e2_task.parameters.waves_table_id[i])); - } - - // Initialize the size (in byte unit) of the header - l1a_l1s_com.melody1_e2_task.parameters.header_size = 3 + l1a_l1s_com.melody1_e2_task.parameters.number_of_instrument; - - // download the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ, 1); - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_MELODY1_E2_START_CON); - - *state = M1_WAIT_LOAD_INSTRUMENT; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"E21 SM blocked by DYN DWNLD\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - // End process - return; - } - break; - case WAIT_DYN_DWNLD: - { - if((SignalCode == API_L1_DYN_DWNLD_FINISHED) && (l1a.dyn_dwnld.semaphore_vect[E2_STATE_MACHINE] == GREEN)) - { -#if ((TRACE_TYPE==1) || (TRACE_TYPE == 4)) - // Disable trace DSP upon E2 MELODY activation - l1_disable_dsp_trace(); -#endif - // Reset the emergency flag - l1a_l1s_com.melody1_e2_task.parameters.emergency_stop = FALSE; - - // Initialize the buffer parameters - l1a_l1s_com.melody1_e2_task.parameters.ptr_buf = NULL; - l1a_l1s_com.melody1_e2_task.parameters.buffer_size = 0; - l1a_l1s_com.melody1_e2_task.parameters.error_id = Cust_get_pointer((UWORD16 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - l1a_l1s_com.melody1_e2_task.parameters.session_id); - - // Convert the buffer size in bytes unit because the E2 melody is defined in byte unit - l1a_l1s_com.melody1_e2_task.parameters.buffer_size <<= 1; - - // Jump the NumberOfOscillator parameter - l1a_l1s_com.melody1_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - 1, - (UWORD8 *)(&(i))); - - // Read the Header of the melody description in order to download the time factor - // clean the MSB of the global time factor register - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_globaltimefactor &= 0x00FF; - l1a_l1s_com.melody1_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - 1, - (UWORD8 *)(&(i))); - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_globaltimefactor = i; - - - // Find the number of insturment of the melody (jump the header memory) - l1a_l1s_com.melody1_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - 1, - &(l1a_l1s_com.melody1_e2_task.parameters.number_of_instrument)); - - for (i=0; i<(l1a_l1s_com.melody1_e2_task.parameters.number_of_instrument); i++) - { - // find the beginning of the melody description (after the header field) - // and put it in the buf_ptr buffer - l1a_l1s_com.melody1_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - 1, - &(l1a_l1s_com.melody1_e2_task.parameters.waves_table_id[i])); - } - - // Initialize the size (in byte unit) of the header - l1a_l1s_com.melody1_e2_task.parameters.header_size = 3 + l1a_l1s_com.melody1_e2_task.parameters.number_of_instrument; - - // download the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ, 1); - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_MELODY1_E2_START_CON); - - *state = M1_WAIT_LOAD_INSTRUMENT; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"E21 SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - break; - case M1_WAIT_LOAD_INSTRUMENT: - { - if (SignalCode == L1_BACK_MELODY_E2_LOAD_INSTRUMENT_CON) - { - if ( ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(msg->SigP))->melody_id == 1 ) - { - // The load instrument confirmation message is for the melody 1 - if (l1a_l1s_com.melody1_e2_task.parameters.emergency_stop) - { - // Unload the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ, 1); - - *state = M1_WAIT_UNLOAD_INSTRUMENT; - - } - else - { - // Start to play the melody1 - l1a_l1s_com.melody1_e2_task.command.start = TRUE; - - *state = M1_WAIT_STOP; - } - } - } - else - if (SignalCode == MMI_MELODY1_E2_STOP_REQ) - { - // Set the emergency flag - l1a_l1s_com.melody1_e2_task.parameters.emergency_stop = TRUE; - } - - // End process - return; - } - break; - - case M1_WAIT_STOP: - { - if (SignalCode == L1_MELODY1_E2_STOP_CON) - { - // Unload the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ, 1); - - *state = M1_WAIT_UNLOAD_INSTRUMENT; - } - else - if (SignalCode == MMI_MELODY1_E2_STOP_REQ) - { - // Stop the melody 0 L1S task: - l1a_l1s_com.melody1_e2_task.command.stop = TRUE; - } - - // End process - return; - } - break; - - case M1_WAIT_UNLOAD_INSTRUMENT: - { - if (SignalCode == L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_CON) - { - if ( ((T_L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ *)(msg->SigP))->melody_id == 1 ) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_MELODY1_E2_STOP_CON); - - *state = M1_RESET; -#if ((TRACE_TYPE==1) || (TRACE_TYPE == 4)) - // Enable trace DSP upon E2 MELODY deactivation - l1_enable_dsp_trace(); -#endif - } - } - - // End process - return; - } - break; - } // switch - } // while(1) - } - -#else // L1_DYN_DSP_DWNLD = 0 - - /*-------------------------------------------------------*/ - /* l1a_mmi_melody0_e2_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* melody 0 format E2 feature. */ - /* */ - /* Starting messages: MMI_MELODY0_E2_START_REQ */ - /* */ - /* Result messages (input): L1_MELODY0_E2_START_CON */ - /* */ - /* Result messages (output): MMI_MELODY0_E2_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_MELDOY0_E2_STOP_REQ */ - /* L1_MELODY0_E2_STOP_CON */ - /* */ - /* Stop message (output): MMI_MELODY0_E2_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - - void l1a_mmi_melody0_e2_process(xSignalHeaderRec *msg) - { - enum states - { - M0_RESET = 0, - M0_WAIT_START_REQ = 1, - M0_WAIT_LOAD_INSTRUMENT = 2, - M0_WAIT_STOP = 3, - M0_WAIT_UNLOAD_INSTRUMENT = 4 - }; - - UWORD8 *state = &l1a.state[L1A_MELODY0_E2_STATE], i; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case M0_RESET: - { - // Reset the commands: - l1a_l1s_com.melody0_e2_task.command.start = FALSE; - l1a_l1s_com.melody0_e2_task.command.stop = FALSE; - - *state = M0_WAIT_START_REQ; - } - break; - - case M0_WAIT_START_REQ: - { - if (SignalCode == MMI_MELODY0_E2_START_REQ) - { -#if ((TRACE_TYPE==1) || (TRACE_TYPE == 4)) - // Disable trace DSP upon E2 MELODY activation - l1_disable_dsp_trace(); -#endif - // Download the parameters from the message: - l1a_l1s_com.melody0_e2_task.parameters.session_id = ((T_MMI_MELODY_E2_REQ *)(msg->SigP))->session_id; - l1a_l1s_com.melody0_e2_task.parameters.loopback = ((T_MMI_MELODY_E2_REQ *)(msg->SigP))->loopback; - - // Reset the emergency flag - l1a_l1s_com.melody0_e2_task.parameters.emergency_stop = FALSE; - - // Initialize the buffer parameters - l1a_l1s_com.melody0_e2_task.parameters.ptr_buf = NULL; - l1a_l1s_com.melody0_e2_task.parameters.buffer_size = 0; - l1a_l1s_com.melody0_e2_task.parameters.error_id = Cust_get_pointer((UWORD16 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - l1a_l1s_com.melody0_e2_task.parameters.session_id); - - // Convert the buffer size in bytes unit because the E2 melody is defined in byte unit - l1a_l1s_com.melody0_e2_task.parameters.buffer_size <<= 1; - - // Jump the NumberOfOscillator parameter - l1a_l1s_com.melody0_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - 1, - (UWORD8 *)(&(i))); - - // Read the Header of the melody description in order to download the time factor - // clean the MSB of the global time factor register - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_globaltimefactor &= 0x00FF; - l1a_l1s_com.melody0_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - 1, - (UWORD8 *)(&(i))); - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_globaltimefactor = i; - - - // Find the number of insturment of the melody (jump the header memory) - l1a_l1s_com.melody0_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - 1, - &(l1a_l1s_com.melody0_e2_task.parameters.number_of_instrument)); - - for (i=0; i<(l1a_l1s_com.melody0_e2_task.parameters.number_of_instrument); i++) - { - // find the beginning of the melody description (after the header field) - // and put it in the buf_ptr buffer - l1a_l1s_com.melody0_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1a_l1s_com.melody0_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody0_e2_task.parameters.ptr_buf, - 1, - &(l1a_l1s_com.melody0_e2_task.parameters.waves_table_id[i])); - } - - // Initialize the size (in byte unit) of the header - l1a_l1s_com.melody0_e2_task.parameters.header_size = 3 + l1a_l1s_com.melody0_e2_task.parameters.number_of_instrument; - - // download the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ, 0); - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_MELODY0_E2_START_CON); - - *state = M0_WAIT_LOAD_INSTRUMENT; - } - - // End process - return; - } - break; - - case M0_WAIT_LOAD_INSTRUMENT: - { - if (SignalCode == L1_BACK_MELODY_E2_LOAD_INSTRUMENT_CON) - { - if ( ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(msg->SigP))->melody_id == 0 ) - { - // The load instrument confirmation message is for the melody 0 - if (l1a_l1s_com.melody0_e2_task.parameters.emergency_stop) - { - // Unload the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ, 0); - - *state = M0_WAIT_UNLOAD_INSTRUMENT; - - } - else - { - // Start to play the melody0 - l1a_l1s_com.melody0_e2_task.command.start = TRUE; - - *state = M0_WAIT_STOP; - } - } - } - else - if (SignalCode == MMI_MELODY0_E2_STOP_REQ) - { - // Set the emergency flag - l1a_l1s_com.melody0_e2_task.parameters.emergency_stop = TRUE; - } - - // End process - return; - } - break; - - case M0_WAIT_STOP: - { - if (SignalCode == L1_MELODY0_E2_STOP_CON) - { - // Unload the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ, 0); - - *state = M0_WAIT_UNLOAD_INSTRUMENT; - } - else - if (SignalCode == MMI_MELODY0_E2_STOP_REQ) - { - // Stop the melody 0 L1S task: - l1a_l1s_com.melody0_e2_task.command.stop = TRUE; - } - - // End process - return; - } - break; - - case M0_WAIT_UNLOAD_INSTRUMENT: - { - if (SignalCode == L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_CON) - { - if ( ((T_L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ *)(msg->SigP))->melody_id == 0 ) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_MELODY0_E2_STOP_CON); - - *state = M0_RESET; -#if ((TRACE_TYPE==1) || (TRACE_TYPE == 4)) - // Enable trace DSP upon E2 MELODY deactivation - l1_enable_dsp_trace(); -#endif - } - } - - // End process - return; - } - break; - } // switch - } // while(1) - } - - /*-------------------------------------------------------*/ - /* l1a_mmi_melody1_e2_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* melody 1 format E2 feature. */ - /* */ - /* Starting messages: MMI_MELODY1_E2_START_REQ */ - /* */ - /* Result messages (input): L1_MELODY1_E2_START_CON */ - /* */ - /* Result messages (output): MMI_MELODY1_E2_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_MELDOY0_E2_STOP_REQ */ - /* L1_MELODY1_E2_STOP_CON */ - /* */ - /* Stop message (output): MMI_MELODY1_E2_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_melody1_e2_process(xSignalHeaderRec *msg) - { - enum states - { - M1_RESET = 0, - M1_WAIT_START_REQ = 1, - M1_WAIT_LOAD_INSTRUMENT = 2, - M1_WAIT_STOP = 3, - M1_WAIT_UNLOAD_INSTRUMENT = 4 - }; - - UWORD8 *state = &l1a.state[L1A_MELODY1_E2_STATE], i; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case M1_RESET: - { - // Reset the commands: - l1a_l1s_com.melody1_e2_task.command.start = FALSE; - l1a_l1s_com.melody1_e2_task.command.stop = FALSE; - - *state = M1_WAIT_START_REQ; - } - break; - - case M1_WAIT_START_REQ: - { - if (SignalCode == MMI_MELODY1_E2_START_REQ) - { -#if ((TRACE_TYPE==1) || (TRACE_TYPE == 4)) - // Disable trace DSP upon E2 MELODY activation - l1_disable_dsp_trace(); -#endif - - // Download the parameters from the message: - l1a_l1s_com.melody1_e2_task.parameters.session_id = ((T_MMI_MELODY_E2_REQ *)(msg->SigP))->session_id; - l1a_l1s_com.melody1_e2_task.parameters.loopback = ((T_MMI_MELODY_E2_REQ *)(msg->SigP))->loopback; - - // Reset the emergency flag - l1a_l1s_com.melody1_e2_task.parameters.emergency_stop = FALSE; - - // Initialize the buffer parameters - l1a_l1s_com.melody1_e2_task.parameters.ptr_buf = NULL; - l1a_l1s_com.melody1_e2_task.parameters.buffer_size = 0; - l1a_l1s_com.melody1_e2_task.parameters.error_id = Cust_get_pointer((UWORD16 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - l1a_l1s_com.melody1_e2_task.parameters.session_id); - - // Convert the buffer size in bytes unit because the E2 melody is defined in byte unit - l1a_l1s_com.melody1_e2_task.parameters.buffer_size <<= 1; - - // Jump the NumberOfOscillator parameter - l1a_l1s_com.melody1_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - 1, - (UWORD8 *)(&(i))); - - // Read the Header of the melody description in order to download the time factor - // clean the MSB of the global time factor register - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_globaltimefactor &= 0x00FF; - l1a_l1s_com.melody1_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - 1, - (UWORD8 *)(&(i))); - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_globaltimefactor = i; - - - // Find the number of insturment of the melody (jump the header memory) - l1a_l1s_com.melody1_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - 1, - &(l1a_l1s_com.melody1_e2_task.parameters.number_of_instrument)); - - for (i=0; i<(l1a_l1s_com.melody1_e2_task.parameters.number_of_instrument); i++) - { - // find the beginning of the melody description (after the header field) - // and put it in the buf_ptr buffer - l1a_l1s_com.melody1_e2_task.parameters.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1a_l1s_com.melody1_e2_task.parameters.buffer_size, - (UWORD8 **)&l1a_l1s_com.melody1_e2_task.parameters.ptr_buf, - 1, - &(l1a_l1s_com.melody1_e2_task.parameters.waves_table_id[i])); - } - - // Initialize the size (in byte unit) of the header - l1a_l1s_com.melody1_e2_task.parameters.header_size = 3 + l1a_l1s_com.melody1_e2_task.parameters.number_of_instrument; - - // download the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ, 1); - - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_MELODY1_E2_START_CON); - - *state = M1_WAIT_LOAD_INSTRUMENT; - } - - // End process - return; - } - break; - - case M1_WAIT_LOAD_INSTRUMENT: - { - if (SignalCode == L1_BACK_MELODY_E2_LOAD_INSTRUMENT_CON) - { - if ( ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(msg->SigP))->melody_id == 1 ) - { - // The load instrument confirmation message is for the melody 1 - if (l1a_l1s_com.melody1_e2_task.parameters.emergency_stop) - { - // Unload the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ, 1); - - *state = M1_WAIT_UNLOAD_INSTRUMENT; - - } - else - { - // Start to play the melody1 - l1a_l1s_com.melody1_e2_task.command.start = TRUE; - - *state = M1_WAIT_STOP; - } - } - } - else - if (SignalCode == MMI_MELODY1_E2_STOP_REQ) - { - // Set the emergency flag - l1a_l1s_com.melody1_e2_task.parameters.emergency_stop = TRUE; - } - - // End process - return; - } - break; - - case M1_WAIT_STOP: - { - if (SignalCode == L1_MELODY1_E2_STOP_CON) - { - // Unload the instrument - l1_send_melody_e2_background_msg(L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ, 1); - - *state = M1_WAIT_UNLOAD_INSTRUMENT; - } - else - if (SignalCode == MMI_MELODY1_E2_STOP_REQ) - { - // Stop the melody 0 L1S task: - l1a_l1s_com.melody1_e2_task.command.stop = TRUE; - } - - // End process - return; - } - break; - - case M1_WAIT_UNLOAD_INSTRUMENT: - { - if (SignalCode == L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_CON) - { - if ( ((T_L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ *)(msg->SigP))->melody_id == 1 ) - { - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_MELODY1_E2_STOP_CON); - - *state = M1_RESET; -#if ((TRACE_TYPE==1) || (TRACE_TYPE == 4)) - // Enable trace DSP upon E2 MELODY deactivation - l1_enable_dsp_trace(); -#endif - } - } - - // End process - return; - } - break; - } // switch - } // while(1) - } - #endif // L1_DYN_DSP_DWNLD - #endif // MELODY_E2 - - #if (L1_CPORT == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_cport_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* cport configuration feature. */ - /* */ - /* Starting messages: MMI_CPORT_CONFIGURE_REQ */ - /* */ - /* Result messages (input): L1_CPORT_CONFIGURE_CON */ - /* */ - /* Result messages (output): MMI_CPORT_CONFIGURE_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_cport_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_START_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_CPORT_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.cport_task.command.start = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_CPORT_CONFIGURE_REQ) - { - // Download the parameters from the message: - l1a_l1s_com.cport_task.parameters.configuration = ((T_MMI_CPORT_CONFIGURE_REQ *)(msg->SigP))->configuration; - l1a_l1s_com.cport_task.parameters.cpcfr1 = ((T_MMI_CPORT_CONFIGURE_REQ *)(msg->SigP))->cpcfr1; - l1a_l1s_com.cport_task.parameters.cpcfr2 = ((T_MMI_CPORT_CONFIGURE_REQ *)(msg->SigP))->cpcfr2; - l1a_l1s_com.cport_task.parameters.cpcfr3 = ((T_MMI_CPORT_CONFIGURE_REQ *)(msg->SigP))->cpcfr3; - l1a_l1s_com.cport_task.parameters.cpcfr4 = ((T_MMI_CPORT_CONFIGURE_REQ *)(msg->SigP))->cpcfr4; - l1a_l1s_com.cport_task.parameters.cptctl = ((T_MMI_CPORT_CONFIGURE_REQ *)(msg->SigP))->cptctl; - l1a_l1s_com.cport_task.parameters.cptdat = ((T_MMI_CPORT_CONFIGURE_REQ *)(msg->SigP))->cptdat; - l1a_l1s_com.cport_task.parameters.cpttaddr = ((T_MMI_CPORT_CONFIGURE_REQ *)(msg->SigP))->cpttaddr; - l1a_l1s_com.cport_task.parameters.cptvs = ((T_MMI_CPORT_CONFIGURE_REQ *)(msg->SigP))->cptvs; - l1a_l1s_com.cport_task.parameters.ctrl = ((T_MMI_CPORT_CONFIGURE_REQ *)(msg->SigP))->ctrl; - - // Start the L1S cport task - l1a_l1s_com.cport_task.command.start = TRUE; - - *state = WAIT_START_CON; - } - - // End process - return; - } - break; - - case WAIT_START_CON: - { - if (SignalCode == L1_CPORT_CONFIGURE_CON) - { - // Forward the stop confirmation message - l1a_audio_send_result(MMI_CPORT_CONFIGURE_CON, msg, MMI_QUEUE); - - *state = RESET; - } - - // End process - return; - } - break; - - } // switch - } // while(1) - } - #endif // L1_CPORT == 1 - - #if (L1_EXTERNAL_AUDIO_VOICE_ONOFF == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_audio_onoff_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* audio on/off feature. */ - /* */ - /* Starting messages: MMI_AUDIO_ONOFF_REQ */ - /* */ - /* Result messages (input): L1_AUDIO_ONOFF_CON */ - /* */ - /* Result messages (output): MMI_AUDIO_ONOFF_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_audio_onoff_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_START_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_AUDIO_ONOFF_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.audio_onoff_task.command.start = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_AUDIO_ONOFF_REQ) - { - // Download the parameters from the message: - l1a_l1s_com.audio_onoff_task.parameters.onoff_value = ((T_MMI_AUDIO_ONOFF_REQ *)(msg->SigP))->onoff_value; - - // Start the L1S keybeep task - l1a_l1s_com.audio_onoff_task.command.start = TRUE; - - *state = WAIT_START_CON; - } - - // End process - return; - } - break; - - case WAIT_START_CON: - { - if (SignalCode == L1_AUDIO_ONOFF_CON) - { - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_AUDIO_ONOFF_CON); - - *state = RESET; - } - - // End process - return; - } - break; - } // switch - } // while(1) - } - #endif - - #if (L1_EXT_MCU_AUDIO_VOICE_ONOFF == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_audio_onoff_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* audio on/off feature. */ - /* */ - /* Starting messages: MMI_AUDIO_ONOFF_REQ */ - /* */ - /* Result messages (input): L1_AUDIO_ONOFF_CON */ - /* */ - /* Result messages (output): MMI_AUDIO_ONOFF_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_audio_onoff_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_START_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_AUDIO_ONOFF_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.audio_onoff_task.command.start = FALSE; - - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_AUDIO_ONOFF_REQ) - { - // Download the parameters from the message: - l1a_l1s_com.audio_onoff_task.parameters.vul_onoff_value = ((T_MMI_AUDIO_ONOFF_REQ *)(msg->SigP))->vul_onoff_value; - l1a_l1s_com.audio_onoff_task.parameters.vdl_onoff_value = ((T_MMI_AUDIO_ONOFF_REQ *)(msg->SigP))->vdl_onoff_value; - // Start the L1S keybeep task - l1a_l1s_com.audio_onoff_task.command.start = TRUE; - - *state = WAIT_START_CON; - } - - // End process - return; - } - // omaps00090550 break; - - case WAIT_START_CON: - { - if (SignalCode == L1_AUDIO_ONOFF_CON) - { - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_AUDIO_ONOFF_CON); - - *state = RESET; - } - - // End process - return; - } - // omaps00090550 break; - } // switch - } // while(1) - } - #endif - - - #if (L1_EXT_AUDIO_MGT == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_ext_audio_mgt_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* external audio management feature. */ - /* */ - /* Starting messages: MMI_EXT_AUDIO_MGT_START_REQ */ - /* */ - /* Result messages (input): L1_STEREOPATH_DRV_START_CON */ - /* */ - /* Result messages (output): MMI_EXT_AUDIO_MGT_START_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): MMI_EXT_AUDIO_MGT_STOP_REQ */ - /* L1_STEREOPATH_DRV_STOP_CON */ - /* */ - /* Stop message (output): MMI_EXT_AUDIO_MGT_STOP_CON */ - /* */ - /* Rem: */ - /* ---- */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_ext_audio_mgt_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_START_REQ = 1, - WAIT_START_CON = 2, - WAIT_STOP = 3 - }; - - UWORD8 *state = &l1a.state[L1A_EXT_AUDIO_MGT_STATE]; - UWORD32 SignalCode = msg->SignalCode; - UWORD8 sample_rate; - while(1) - { - switch(*state) - { - case RESET: - { -#if(L1_BT_AUDIO ==1) - midi_task_running=FALSE; -#endif - *state = WAIT_START_REQ; - } - break; - - case WAIT_START_REQ: - { - if (SignalCode == MMI_EXT_AUDIO_MGT_START_REQ) - { - // save global variable - l1s.ext_audio_mgt.session_id = ((T_MMI_EXT_AUDIO_MGT_START_REQ *)(msg->SigP))->session_id; - #if(L1_BT_AUDIO ==1) - l1_audio_bt_init(AUDIO_EXT_MIDI_BUFFER_SIZE); - if(bt_audio.connected_status==TRUE) - { - bt_audio.pcmconfig.bitsPerSample=16; - bt_audio.pcmconfig.numChannels =((T_MMI_EXT_AUDIO_MGT_START_REQ *)(msg->SigP))->mono_stereo+1; - sample_rate =((T_MMI_EXT_AUDIO_MGT_START_REQ *)(msg->SigP))->sampling_frequency; - bt_audio.pcmconfig.sampleRate =l1_ext_audio_get_frequencyrate(sample_rate); - bt_audio.audio_configure_callback(&bt_audio.pcmconfig); - } - #endif - if(bt_audio.connected_status==FALSE) - { - // Download the stereopath description. - l1a_l1s_com.stereopath_drv_task.parameters.sampling_frequency = ((T_MMI_EXT_AUDIO_MGT_START_REQ *)(msg->SigP))->sampling_frequency; - l1a_l1s_com.stereopath_drv_task.parameters.DMA_allocation = AUDIO_SP_DMA_ALLOC_MCU; - l1a_l1s_com.stereopath_drv_task.parameters.DMA_int_callback_fct = l1_ext_audio_mgt_dma_handler; - l1a_l1s_com.stereopath_drv_task.parameters.DMA_channel_number = ((T_MMI_EXT_AUDIO_MGT_START_REQ *)(msg->SigP))->DMA_channel_number; - l1a_l1s_com.stereopath_drv_task.parameters.data_type = ((T_MMI_EXT_AUDIO_MGT_START_REQ *)(msg->SigP))->data_type; - l1a_l1s_com.stereopath_drv_task.parameters.source_port = AUDIO_SP_SOURCE_IMIF; - l1a_l1s_com.stereopath_drv_task.parameters.source_buffer_address = ((T_MMI_EXT_AUDIO_MGT_START_REQ *)(msg->SigP))->source_buffer_address; - l1a_l1s_com.stereopath_drv_task.parameters.element_number = ((T_MMI_EXT_AUDIO_MGT_START_REQ *)(msg->SigP))->element_number; - l1a_l1s_com.stereopath_drv_task.parameters.frame_number = ((T_MMI_EXT_AUDIO_MGT_START_REQ *)(msg->SigP))->frame_number; - l1a_l1s_com.stereopath_drv_task.parameters.mono_stereo = ((T_MMI_EXT_AUDIO_MGT_START_REQ *)(msg->SigP))->mono_stereo; - l1a_l1s_com.stereopath_drv_task.parameters.feature_identifier = AUDIO_SP_EXT_AUDIO_ID; - - // Start the L1S stereopath task - l1a_l1s_com.stereopath_drv_task.command.start = TRUE; -#if(L1_BT_AUDIO ==1) - midi_task_running=TRUE; -#endif - - *state = WAIT_START_CON; - } - else - { - l1a_audio_send_confirmation(MMI_EXT_AUDIO_MGT_START_CON); - - *state = WAIT_STOP; - } - // End process - return; - } - } - // omaps00090550 break; - - case WAIT_START_CON: - { - if (SignalCode == L1_STEREOPATH_DRV_START_CON) - { - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_EXT_AUDIO_MGT_START_CON); - - *state = WAIT_STOP; - } - - // End process - return; - } - // omaps00090550 break; - - case WAIT_STOP: - { - if (SignalCode == MMI_EXT_AUDIO_MGT_STOP_REQ) - { - if(bt_audio.connected_status==TRUE) - { - - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_EXT_AUDIO_MGT_STOP_CON); - midi_task_running=FALSE; - *state = RESET; - } - else - { - // Stop the L1S stereopath task - l1a_l1s_com.stereopath_drv_task.command.stop = TRUE; - - // End process - return; - } - } - - if (SignalCode == L1_STEREOPATH_DRV_STOP_CON) - { - - // Send the stop confirmation message - l1a_audio_send_confirmation(MMI_EXT_AUDIO_MGT_STOP_CON); - #if(L1_BT_AUDIO ==1) - midi_task_running=FALSE; - #endif - *state = RESET; - } - else - { - // End process - return; - } - } - break; - } // switch - } // while(1) - } - #endif // EXT_AUDIO_MGT == 1 - - #if (L1_ANR == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_anr_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* ANR feature. */ - /* */ - /* Starting messages: MMI_ANR_REQ */ - /* */ - /* Result messages (input): L1_ANR_CON */ - /* */ - /* Result messages (output): MMI_ANR_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /*-------------------------------------------------------*/ -#if(L1_DYN_DSP_DWNLD == 1) - void l1a_mmi_anr_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_CON = 3 - }; - - UWORD8 *state = &l1a.state[L1A_ANR_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.anr_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_ANR_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.anr_task.parameters.anr_enable = ((T_MMI_ANR_REQ *)(msg->SigP))->anr_enable; - l1a_l1s_com.anr_task.parameters.min_gain = ((T_MMI_ANR_REQ *)(msg->SigP))->min_gain; - l1a_l1s_com.anr_task.parameters.div_factor_shift = ((T_MMI_ANR_REQ *)(msg->SigP))->div_factor_shift; - l1a_l1s_com.anr_task.parameters.ns_level = ((T_MMI_ANR_REQ *)(msg->SigP))->ns_level; - - if (l1a.dyn_dwnld.semaphore_vect[ANR_STATE_MACHINE] == GREEN) - { - // WARNING: the following code must be copied in the state WAIT_DYN_DWNLD - // when activating the task at L1s level - - // Enable the L1S task - l1a_l1s_com.anr_task.command.update = TRUE; - - *state = WAIT_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"ANR SM blocked by DYN DWNLD\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - - // End process - return; - } - break; - case WAIT_DYN_DWNLD: - { - if(SignalCode == API_L1_DYN_DWNLD_FINISHED && l1a.dyn_dwnld.semaphore_vect[ANR_STATE_MACHINE] == GREEN) - { - // Enable the L1S task - l1a_l1s_com.anr_task.command.update = TRUE; - - *state = WAIT_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"ANR SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - break; - case WAIT_CON: - { - if (SignalCode == L1_ANR_CON) - { - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_ANR_CON); - - *state = RESET; - } - - // End process - return; - } - break; - } // switch - } // while(1) - } -#else - void l1a_mmi_anr_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_ANR_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.anr_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_ANR_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.anr_task.parameters.anr_enable = ((T_MMI_ANR_REQ *)(msg->SigP))->anr_enable; - l1a_l1s_com.anr_task.parameters.min_gain = ((T_MMI_ANR_REQ *)(msg->SigP))->min_gain; - l1a_l1s_com.anr_task.parameters.div_factor_shift = ((T_MMI_ANR_REQ *)(msg->SigP))->div_factor_shift; - l1a_l1s_com.anr_task.parameters.ns_level = ((T_MMI_ANR_REQ *)(msg->SigP))->ns_level; - - // Enable the L1S task - l1a_l1s_com.anr_task.command.update = TRUE; - - *state = WAIT_CON; - } - // End process - return; - } - break; - case WAIT_CON: - { - if (SignalCode == L1_ANR_CON) - { - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_ANR_CON); - - *state = RESET; - } - - // End process - return; - } - break; - } // switch - } // while(1) - } -#endif // L1_DYN_DSP_DWNLD - #endif // L1_ANR -#if (L1_ANR == 2) // ANR 2.13 - /*-------------------------------------------------------*/ - /* l1a_mmi_anr_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* ANR 2.13 feature. */ - /* */ - /* Starting messages: MMI_AQI_ANR_REQ */ - /* */ - /* Result messages (input): L1_AQI_ANR_CON */ - /* */ - /* Result messages (output): MMI_AQI_ANR_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /*-------------------------------------------------------*/ -#if(L1_DYN_DSP_DWNLD == 1) - void l1a_mmi_anr_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_CON = 3 - }; - - UWORD8 *state = &l1a.state[L1A_ANR_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.anr_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_AQI_ANR_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.anr_task.parameters.anr_ul_control = ((T_MMI_AQI_ANR_REQ *)(msg->SigP))->anr_ul_control; - l1a_l1s_com.anr_task.parameters.control = ((T_MMI_AQI_ANR_REQ *)(msg->SigP))->parameters.control; - l1a_l1s_com.anr_task.parameters.ns_level = ((T_MMI_AQI_ANR_REQ *)(msg->SigP))->parameters.ns_level; - l1a_l1s_com.anr_task.parameters.tone_ene_th = ((T_MMI_AQI_ANR_REQ *)(msg->SigP))->parameters.tone_ene_th; - l1a_l1s_com.anr_task.parameters.tone_cnt_th = ((T_MMI_AQI_ANR_REQ *)(msg->SigP))->parameters.tone_cnt_th; - - if (l1a.dyn_dwnld.semaphore_vect[ANR_STATE_MACHINE] == GREEN) - { - // WARNING: the following code must be copied in the state WAIT_DYN_DWNLD - // when activating the task at L1s level - - // Enable the L1S task - l1a_l1s_com.anr_task.command.update = TRUE; - - *state = WAIT_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"ANR SM blocked by DYN DWNLD\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - - // End process - return; - } - // omaps00090550 break; - case WAIT_DYN_DWNLD: - { - if(SignalCode == API_L1_DYN_DWNLD_FINISHED && l1a.dyn_dwnld.semaphore_vect[ANR_STATE_MACHINE] == GREEN) - { - // Enable the L1S task - l1a_l1s_com.anr_task.command.update = TRUE; - - *state = WAIT_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"ANR SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - // omaps00090550 break; - case WAIT_CON: - { - if (SignalCode == L1_AQI_ANR_CON) - { - // Send the confirmation message - l1a_audio_send_result(MMI_AQI_ANR_CON, msg, MMI_QUEUE); - - *state = RESET; - } - - // End process - return; - } - // omaps00090550 break; - } // switch - } // while(1) - } -#else - void l1a_mmi_anr_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_ANR_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.anr_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_AQI_ANR_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.anr_task.parameters.anr_ul_control = ((T_MMI_AQI_ANR_REQ *)(msg->SigP))->anr_ul_control; - l1a_l1s_com.anr_task.parameters.control = ((T_MMI_AQI_ANR_REQ *)(msg->SigP))->parameters.control; - l1a_l1s_com.anr_task.parameters.ns_level = ((T_MMI_AQI_ANR_REQ *)(msg->SigP))->parameters.ns_level; - l1a_l1s_com.anr_task.parameters.tone_ene_th = ((T_MMI_AQI_ANR_REQ *)(msg->SigP))->parameters.tone_ene_th; - l1a_l1s_com.anr_task.parameters.tone_cnt_th = ((T_MMI_AQI_ANR_REQ *)(msg->SigP))->parameters.tone_cnt_th; - - // Enable the L1S task - l1a_l1s_com.anr_task.command.update = TRUE; - - *state = WAIT_CON; - } - // End process - return; - } - break; - case WAIT_CON: - { - if (SignalCode == L1_AQI_ANR_CON) - { - // Send the confirmation message - l1a_audio_send_result(MMI_AQI_ANR_CON, msg, MMI_QUEUE); - - *state = RESET; - } - - // End process - return; - } - break; - } // switch - } // while(1) - } -#endif // L1_DYN_DSP_DWNLD -#endif // L1_ANR - - #if (L1_IIR == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_iir_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* IIR feature. */ - /* */ - /* Starting messages: MMI_IIR_REQ */ - /* */ - /* Result messages (input): L1_IIR_CON */ - /* */ - /* Result messages (output): MMI_IIR_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_iir_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_IIR_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.iir_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_IIR_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.iir_task.parameters.iir_enable = ((T_MMI_IIR_REQ *)(msg->SigP))->iir_enable; - l1a_l1s_com.iir_task.parameters.nb_iir_blocks = ((T_MMI_IIR_REQ *)(msg->SigP))->nb_iir_blocks; - l1a_l1s_com.iir_task.parameters.iir_coefs = ((T_MMI_IIR_REQ *)(msg->SigP))->iir_coefs; - l1a_l1s_com.iir_task.parameters.nb_fir_coefs = ((T_MMI_IIR_REQ *)(msg->SigP))->nb_fir_coefs; - l1a_l1s_com.iir_task.parameters.fir_coefs = ((T_MMI_IIR_REQ *)(msg->SigP))->fir_coefs; - l1a_l1s_com.iir_task.parameters.input_scaling = ((T_MMI_IIR_REQ *)(msg->SigP))->input_scaling; - l1a_l1s_com.iir_task.parameters.fir_scaling = ((T_MMI_IIR_REQ *)(msg->SigP))->fir_scaling; - l1a_l1s_com.iir_task.parameters.input_gain_scaling = ((T_MMI_IIR_REQ *)(msg->SigP))->input_gain_scaling; - l1a_l1s_com.iir_task.parameters.output_gain_scaling = ((T_MMI_IIR_REQ *)(msg->SigP))->output_gain_scaling; - l1a_l1s_com.iir_task.parameters.output_gain = ((T_MMI_IIR_REQ *)(msg->SigP))->output_gain; - l1a_l1s_com.iir_task.parameters.feedback = ((T_MMI_IIR_REQ *)(msg->SigP))->feedback; - - // Enable the L1S task - l1a_l1s_com.iir_task.command.update = TRUE; - - *state = WAIT_CON; - } - - // End process - return; - } - break; - - case WAIT_CON: - { - if (SignalCode == L1_IIR_CON) - { - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_IIR_CON); - - *state = RESET; - } - - // End process - return; - } - break; - } // switch - } // while(1) - } - #endif // L1_IIR - - #if (L1_AGC_UL == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_agc_ul_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* AGC UL feature. */ - /* */ - /* Starting messages: MMI_AQI_AGC_UL_REQ */ - /* */ - /* Result messages (input): L1_AQI_AGC_UL_CON */ - /* */ - /* Result messages (output): MMI_AQI_AGC_UL_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /*-------------------------------------------------------*/ -#if(L1_DYN_DSP_DWNLD == 1) - void l1a_mmi_agc_ul_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_CON = 3 - }; - - UWORD8 *state = &l1a.state[L1A_AGC_UL_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.agc_ul_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_AQI_AGC_UL_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.agc_ul_task.parameters.agc_ul_control = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->agc_ul_control; - l1a_l1s_com.agc_ul_task.parameters.control = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.control; - l1a_l1s_com.agc_ul_task.parameters.frame_size = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.frame_size; - l1a_l1s_com.agc_ul_task.parameters.targeted_level = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.targeted_level; - l1a_l1s_com.agc_ul_task.parameters.signal_up = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.signal_up; - l1a_l1s_com.agc_ul_task.parameters.signal_down = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.signal_down; - l1a_l1s_com.agc_ul_task.parameters.max_scale = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.max_scale; - l1a_l1s_com.agc_ul_task.parameters.gain_smooth_alpha = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.gain_smooth_alpha; - l1a_l1s_com.agc_ul_task.parameters.gain_smooth_alpha_fast = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.gain_smooth_alpha_fast; - l1a_l1s_com.agc_ul_task.parameters.gain_smooth_beta = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.gain_smooth_beta; - l1a_l1s_com.agc_ul_task.parameters.gain_smooth_beta_fast = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.gain_smooth_beta_fast; - l1a_l1s_com.agc_ul_task.parameters.gain_intp_flag = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.gain_intp_flag; - - - if (l1a.dyn_dwnld.semaphore_vect[AGC_UL_STATE_MACHINE] == GREEN) - { - // WARNING: the following code must be copied in the state WAIT_DYN_DWNLD - // when activating the task at L1s level - - // Enable the L1S task - l1a_l1s_com.agc_ul_task.command.update = TRUE; - - *state = WAIT_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"AGC_UL SM blocked by DYN DWNLD\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - - // End process - return; - } - // omaps00090550 break; - case WAIT_DYN_DWNLD: - { - if(SignalCode == API_L1_DYN_DWNLD_FINISHED && l1a.dyn_dwnld.semaphore_vect[AGC_UL_STATE_MACHINE] == GREEN) - { - // Enable the L1S task - l1a_l1s_com.agc_ul_task.command.update = TRUE; - - *state = WAIT_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"AGC_UL SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - // omaps00090550 break; - case WAIT_CON: - { - if (SignalCode == L1_AQI_AGC_UL_CON) - { - // Send the start confirmation message - l1a_audio_send_result(MMI_AQI_AGC_UL_CON, msg, MMI_QUEUE); - - *state = RESET; - } - - // End process - return; - } - // omaps00090550 break; - } // switch - } // while(1) - } -#else - void l1a_mmi_agc_ul_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_AGC_UL_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.agc_ul_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_AQI_AGC_UL_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.agc_ul_task.parameters.agc_ul_control = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->agc_ul_control; - l1a_l1s_com.agc_ul_task.parameters.control = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.control; - l1a_l1s_com.agc_ul_task.parameters.frame_size = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.frame_size; - l1a_l1s_com.agc_ul_task.parameters.targeted_level = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.targeted_level; - l1a_l1s_com.agc_ul_task.parameters.signal_up = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.signal_up; - l1a_l1s_com.agc_ul_task.parameters.signal_down = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.signal_down; - l1a_l1s_com.agc_ul_task.parameters.max_scale = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.max_scale; - l1a_l1s_com.agc_ul_task.parameters.gain_smooth_alpha = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.gain_smooth_alpha; - l1a_l1s_com.agc_ul_task.parameters.gain_smooth_alpha_fast = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.gain_smooth_alpha_fast; - l1a_l1s_com.agc_ul_task.parameters.gain_smooth_beta = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.gain_smooth_beta; - l1a_l1s_com.agc_ul_task.parameters.gain_smooth_beta_fast = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.gain_smooth_beta_fast; - l1a_l1s_com.agc_ul_task.parameters.gain_intp_flag = ((T_MMI_AQI_AGC_UL_REQ *)(msg->SigP))->parameters.gain_intp_flag; - - // Enable the L1S task - l1a_l1s_com.agc_ul_task.command.update = TRUE; - - *state = WAIT_CON; - } - // End process - return; - } - break; - case WAIT_CON: - { - if (SignalCode == L1_AQI_AGC_UL_CON) - { - // Send the start confirmation message - l1a_audio_send_result(MMI_AQI_AGC_UL_CON, msg, MMI_QUEUE); - - *state = RESET; - } - - // End process - return; - } - break; - } // switch - } // while(1) - } -#endif // L1_DYN_DSP_DWNLD - -#endif // L1_AGC_UL - - -#if (L1_AGC_DL == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_agc_dl_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* AGC DL feature. */ - /* */ - /* Starting messages: MMI_AQI_AGC_DL_REQ */ - /* */ - /* Result messages (input): L1_AQI_AGC_DL_CON */ - /* */ - /* Result messages (output): MMI_AQI_AGC_DL_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /*-------------------------------------------------------*/ -#if(L1_DYN_DSP_DWNLD == 1) - void l1a_mmi_agc_dl_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_CON = 3 - }; - - UWORD8 *state = &l1a.state[L1A_AGC_DL_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.agc_dl_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_AQI_AGC_DL_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.agc_dl_task.parameters.agc_dl_control = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->agc_dl_control; - l1a_l1s_com.agc_dl_task.parameters.control = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.control; - l1a_l1s_com.agc_dl_task.parameters.frame_size = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.frame_size; - l1a_l1s_com.agc_dl_task.parameters.targeted_level = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.targeted_level; - l1a_l1s_com.agc_dl_task.parameters.signal_up = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.signal_up; - l1a_l1s_com.agc_dl_task.parameters.signal_down = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.signal_down; - l1a_l1s_com.agc_dl_task.parameters.max_scale = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.max_scale; - l1a_l1s_com.agc_dl_task.parameters.gain_smooth_alpha = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.gain_smooth_alpha; - l1a_l1s_com.agc_dl_task.parameters.gain_smooth_alpha_fast = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.gain_smooth_alpha_fast; - l1a_l1s_com.agc_dl_task.parameters.gain_smooth_beta = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.gain_smooth_beta; - l1a_l1s_com.agc_dl_task.parameters.gain_smooth_beta_fast = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.gain_smooth_beta_fast; - l1a_l1s_com.agc_dl_task.parameters.gain_intp_flag = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.gain_intp_flag; - - - if (l1a.dyn_dwnld.semaphore_vect[AGC_DL_STATE_MACHINE] == GREEN) - { - // WARNING: the following code must be copied in the state WAIT_DYN_DWNLD - // when activating the task at L1s level - - // Enable the L1S task - l1a_l1s_com.agc_dl_task.command.update = TRUE; - - *state = WAIT_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"AGC_DL SM blocked by DYN DWNLD\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - - // End process - return; - } - // omaps00090550 break; - case WAIT_DYN_DWNLD: - { - if(SignalCode == API_L1_DYN_DWNLD_FINISHED && l1a.dyn_dwnld.semaphore_vect[AGC_DL_STATE_MACHINE] == GREEN) - { - // Enable the L1S task - l1a_l1s_com.agc_dl_task.command.update = TRUE; - - *state = WAIT_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"AGC_DL SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - // omaps00090550 break; - case WAIT_CON: - { - if (SignalCode == L1_AQI_AGC_DL_CON) - { - // Send the start confirmation message - l1a_audio_send_result(MMI_AQI_AGC_DL_CON, msg, MMI_QUEUE); - - *state = RESET; - } - - // End process - return; - } - // omaps00090550 break; - } // switch - } // while(1) - } -#else - void l1a_mmi_agc_dl_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_AGC_DL_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.agc_dl_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_AQI_AGC_DL_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.agc_dl_task.parameters.agc_dl_control = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->agc_dl_control; - l1a_l1s_com.agc_dl_task.parameters.control = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.control; - l1a_l1s_com.agc_dl_task.parameters.frame_size = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.frame_size; - l1a_l1s_com.agc_dl_task.parameters.targeted_level = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.targeted_level; - l1a_l1s_com.agc_dl_task.parameters.signal_up = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.signal_up; - l1a_l1s_com.agc_dl_task.parameters.signal_down = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.signal_down; - l1a_l1s_com.agc_dl_task.parameters.max_scale = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.max_scale; - l1a_l1s_com.agc_dl_task.parameters.gain_smooth_alpha = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.gain_smooth_alpha; - l1a_l1s_com.agc_dl_task.parameters.gain_smooth_alpha_fast = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.gain_smooth_alpha_fast; - l1a_l1s_com.agc_dl_task.parameters.gain_smooth_beta = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.gain_smooth_beta; - l1a_l1s_com.agc_dl_task.parameters.gain_smooth_beta_fast = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.gain_smooth_beta_fast; - l1a_l1s_com.agc_dl_task.parameters.gain_intp_flag = ((T_MMI_AQI_AGC_DL_REQ *)(msg->SigP))->parameters.gain_intp_flag; - - // Enable the L1S task - l1a_l1s_com.agc_dl_task.command.update = TRUE; - - *state = WAIT_CON; - } - // End process - return; - } - break; - case WAIT_CON: - { - if (SignalCode == L1_AQI_AGC_DL_CON) - { - // Send the start confirmation message - l1a_audio_send_result(MMI_AQI_AGC_DL_CON, msg, MMI_QUEUE); - - *state = RESET; - } - - // End process - return; - } - break; - } // switch - } // while(1) - } -#endif // L1_DYN_DSP_DWNLD - -#endif // L1_AGC_DL - - - #if (L1_IIR == 2) - /*-------------------------------------------------------*/ - /* l1a_mmi_iir_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* IIR feature. */ - /* */ - /* Starting messages: MMI_AQI_IIR_DL_REQ */ - /* */ - /* Result messages (input): L1_AQI_IIR_DL_CON */ - /* */ - /* Result messages (output): MMI_AQI_IIR_DL_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_iir_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_IIR_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.iir_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_AQI_IIR_DL_REQ) - { - l1a.iir_req_msg_ptr = msg; - l1a.l1_msg_forwarded = TRUE; - - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.iir_task.parameters = (T_MMI_AQI_IIR_DL_REQ *) (msg->SigP); - - // Enable the L1S task - l1a_l1s_com.iir_task.command.update = TRUE; - - *state = WAIT_CON; - } - - // End process - return; - } - // omaps00090550 break; - - case WAIT_CON: - { - if (SignalCode == L1_AQI_IIR_DL_CON) - { - os_free_sig(l1a.iir_req_msg_ptr); - // Send the start confirmation message - l1a_audio_send_result(MMI_AQI_IIR_DL_CON, msg, MMI_QUEUE); - - *state = RESET; - } - - // End process - return; - } - // omaps00090550 break; - } // switch - } // while(1) - } - #endif // L1_IIR - - #if (L1_WCM == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_wcm_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* WCM feature. */ - /* */ - /* Starting messages: MMI_AQI_WCM_REQ */ - /* */ - /* Result messages (input): L1_AQI_WCM_CON */ - /* */ - /* Result messages (output): MMI_AQI_WCM_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /*-------------------------------------------------------*/ - -#if(L1_DYN_DSP_DWNLD == 1) - void l1a_mmi_wcm_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_CON = 3 - }; - - UWORD8 *state = &l1a.state[L1A_WCM_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.wcm_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_AQI_WCM_REQ) - { - l1a.wcm_req_msg_ptr = msg; - l1a.l1_msg_forwarded = TRUE; - - // Load the message into the l1a_l1s_com memory - l1a_l1s_com.wcm_task.parameters = (T_MMI_AQI_WCM_REQ *) (msg->SigP); - - if (l1a.dyn_dwnld.semaphore_vect[WCM_STATE_MACHINE] == GREEN) - { - // WARNING: the following code must be copied in the state WAIT_DYN_DWNLD - // when activating the task at L1s level - - // Enable the L1S task - l1a_l1s_com.wcm_task.command.update = TRUE; - - *state = WAIT_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"WCM SM blocked by DYN DWNLD\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - - // End process - return; - } - // omaps00090550 break; - case WAIT_DYN_DWNLD: - { - if(SignalCode == API_L1_DYN_DWNLD_FINISHED && l1a.dyn_dwnld.semaphore_vect[WCM_STATE_MACHINE] == GREEN) - { - // Enable the L1S task - l1a_l1s_com.wcm_task.command.update = TRUE; - - *state = WAIT_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"WCM SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - // omaps00090550 break; - case WAIT_CON: - { - if (SignalCode == L1_AQI_WCM_CON) - { - os_free_sig(l1a.wcm_req_msg_ptr); - // Send the start confirmation message - l1a_audio_send_result(MMI_AQI_WCM_CON, msg, MMI_QUEUE); - - *state = RESET; - } - - // End process - return; - } - // omaps00090550 break; - } // switch - } // while(1) - } -#else - void l1a_mmi_wcm_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_WCM_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.wcm_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_AQI_WCM_REQ) - { - l1a.wcm_req_msg_ptr = msg; - l1a.l1_msg_forwarded = TRUE; - - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.wcm_task.parameters = (T_MMI_AQI_WCM_REQ *) (msg->SigP); - - // Enable the L1S task - l1a_l1s_com.wcm_task.command.update = TRUE; - - *state = WAIT_CON; - } - // End process - return; - } - break; - case WAIT_CON: - { - if (SignalCode == L1_AQI_WCM_CON) - { - os_free_sig(l1a.wcm_req_msg_ptr); - // Send the start confirmation message - l1a_audio_send_result(MMI_AQI_WCM_CON, msg, MMI_QUEUE); - - *state = RESET; - } - - // End process - return; - } - break; - } // switch - } // while(1) - } -#endif // L1_DYN_DSP_DWNLD - -#endif // L1_WCM - -#if (L1_DRC == 1) // DRC 1.x -// DRC NDB API -T_DRC_MCU_DSP *drc_ndb; -#if (CODE_VERSION == SIMULATION) - T_DRC_MCU_DSP drc_ndb_sim; -#endif - - /*-------------------------------------------------------*/ - /* l1a_mmi_drc_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* DRC 1.x feature. */ - /* */ - /* Starting messages: MMI_AQI_DRC_REQ */ - /* */ - /* Result messages (input): L1_AQI_DRC_CON */ - /* */ - /* Result messages (output): MMI_AQI_DRC_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /*-------------------------------------------------------*/ -#if(L1_DYN_DSP_DWNLD == 1) - void l1a_mmi_drc_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_CON = 3 - }; - - UWORD8 *state = &l1a.state[L1A_DRC_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.drc_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_AQI_DRC_REQ) - { - l1a.drc_req_msg_ptr = msg; - l1a.l1_msg_forwarded = TRUE; - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.drc_task.parameters = (T_MMI_AQI_DRC_REQ *) (msg->SigP); - - if (l1a.dyn_dwnld.semaphore_vect[DRC_STATE_MACHINE] == GREEN) - { - // WARNING: the following code must be copied in the state WAIT_DYN_DWNLD - // when activating the task at L1s level - - // Enable the L1S task - l1a_l1s_com.drc_task.command.update = TRUE; - - *state = WAIT_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"DRC SM blocked by DYN DWNLD\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - - // End process - return; - } - // omaps00090550 break; - case WAIT_DYN_DWNLD: - { - if(SignalCode == API_L1_DYN_DWNLD_FINISHED && l1a.dyn_dwnld.semaphore_vect[DRC_STATE_MACHINE] == GREEN) - { - // Enable the L1S task - l1a_l1s_com.drc_task.command.update = TRUE; - - *state = WAIT_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"DRC SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - // omaps00090550 break; - case WAIT_CON: - { - if (SignalCode == L1_AQI_DRC_CON) - { - os_free_sig(l1a.drc_req_msg_ptr); - // Send the confirmation message - l1a_audio_send_result(MMI_AQI_DRC_CON, msg, MMI_QUEUE); - - *state = RESET; - } - - // End process - return; - } - // omaps00090550 break; - } // switch - } // while(1) - } -#else - void l1a_mmi_drc_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_DRC_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.drc_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_AQI_DRC_REQ) - { - l1a.drc_req_msg_ptr = msg; - l1a.l1_msg_forwarded = TRUE; - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.drc_task.parameters = (T_MMI_AQI_DRC_REQ *) (msg->SigP); - - // Enable the L1S task - l1a_l1s_com.drc_task.command.update = TRUE; - - *state = WAIT_CON; - } - // End process - return; - } - break; - case WAIT_CON: - { - if (SignalCode == L1_AQI_DRC_CON) - { - os_free_sig(l1a.drc_req_msg_ptr); - - // Send the confirmation message - l1a_audio_send_result(MMI_AQI_DRC_CON, msg, MMI_QUEUE); - - *state = RESET; - } - - // End process - return; - } - break; - } // switch - } // while(1) - } -#endif // L1_DYN_DSP_DWNLD -#endif // L1_DRC - - #if (L1_LIMITER == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_limiter_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* LIMITER feature. */ - /* */ - /* Starting messages: MMI_LIMITER_REQ */ - /* */ - /* Result messages (input): L1_LIMITER_CON */ - /* */ - /* Result messages (output): MMI_LIMITER_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /*-------------------------------------------------------*/ - void l1a_mmi_limiter_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_LIMITER_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the commands - l1a_l1s_com.limiter_task.command.update = FALSE; - l1a_l1s_com.limiter_task.command.partial_update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_LIMITER_REQ) - { - // Load the message into the l1a_l1s_com memory. - l1a_l1s_com.limiter_task.parameters.limiter_enable = ((T_MMI_LIMITER_REQ *)(msg->SigP))->limiter_enable; - l1a_l1s_com.limiter_task.parameters.block_size = ((T_MMI_LIMITER_REQ *)(msg->SigP))->block_size; - l1a_l1s_com.limiter_task.parameters.slope_update_period = ((T_MMI_LIMITER_REQ *)(msg->SigP))->slope_update_period; - l1a_l1s_com.limiter_task.parameters.nb_fir_coefs = ((T_MMI_LIMITER_REQ *)(msg->SigP))->nb_fir_coefs; - l1a_l1s_com.limiter_task.parameters.filter_coefs = ((T_MMI_LIMITER_REQ *)(msg->SigP))->filter_coefs; - l1a_l1s_com.limiter_task.parameters.thr_low_0 = ((T_MMI_LIMITER_REQ *)(msg->SigP))->thr_low_0; - l1a_l1s_com.limiter_task.parameters.thr_low_slope = ((T_MMI_LIMITER_REQ *)(msg->SigP))->thr_low_slope; - l1a_l1s_com.limiter_task.parameters.thr_high_0 = ((T_MMI_LIMITER_REQ *)(msg->SigP))->thr_high_0; - l1a_l1s_com.limiter_task.parameters.thr_high_slope = ((T_MMI_LIMITER_REQ *)(msg->SigP))->thr_high_slope; - l1a_l1s_com.limiter_task.parameters.gain_fall = ((T_MMI_LIMITER_REQ *)(msg->SigP))->gain_fall; - l1a_l1s_com.limiter_task.parameters.gain_rise = ((T_MMI_LIMITER_REQ *)(msg->SigP))->gain_rise; - - // Enable the L1S task - l1a_l1s_com.limiter_task.command.update = TRUE; - - *state = WAIT_CON; - } - - // End process - return; - } - // omaps00090550 break; - - case WAIT_CON: - { - if (SignalCode == L1_LIMITER_CON) - { - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_LIMITER_CON); - - *state = RESET; - } - - // End process - return; - } - // omaps00090550 break; - } // switch - } // while(1) - } - #endif // L1_LIMITER - - #if (L1_ES == 1) - /*-------------------------------------------------------*/ - /* l1a_mmi_es_process() */ - /*-------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* Echo Suppressor feature. */ - /* */ - /* Starting messages: MMI_ES_REQ */ - /* */ - /* Result messages (input): L1_ES_CON */ - /* */ - /* Result messages (output): MMI_ES_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none */ - /* */ - /* Stop message (output): none */ - /* */ - /*-------------------------------------------------------*/ -#if (L1_DYN_DSP_DWNLD == 1) - void l1a_mmi_es_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_DYN_DWNLD = 2, - WAIT_CON = 3 - }; - - UWORD8 *state = &l1a.state[L1A_ES_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.es_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_ES_REQ) - { - // Load the message into the l1a_l1s_com memory - l1a_l1s_com.es_task.parameters.es_enable = ((T_MMI_ES_REQ *)(msg->SigP))->es_enable; - l1a_l1s_com.es_task.parameters.es_behavior = ((T_MMI_ES_REQ *)(msg->SigP))->es_behavior; - - if (l1a_l1s_com.es_task.parameters.es_behavior == ES_CUSTOM_PARAM) - { - // Load every parameters from the message - l1a_l1s_com.es_task.parameters.es_config.es_mode = ((T_MMI_ES_REQ *)(msg->SigP))->es_mode; - l1a_l1s_com.es_task.parameters.es_config.es_gain_dl = ((T_MMI_ES_REQ *)(msg->SigP))->es_gain_dl; - l1a_l1s_com.es_task.parameters.es_config.es_gain_ul_1 = ((T_MMI_ES_REQ *)(msg->SigP))->es_gain_ul_1; - l1a_l1s_com.es_task.parameters.es_config.es_gain_ul_2 = ((T_MMI_ES_REQ *)(msg->SigP))->es_gain_ul_2; - l1a_l1s_com.es_task.parameters.es_config.tcl_fe_ls_thr = ((T_MMI_ES_REQ *)(msg->SigP))->tcl_fe_ls_thr; - l1a_l1s_com.es_task.parameters.es_config.tcl_dt_ls_thr = ((T_MMI_ES_REQ *)(msg->SigP))->tcl_dt_ls_thr; - l1a_l1s_com.es_task.parameters.es_config.tcl_fe_ns_thr = ((T_MMI_ES_REQ *)(msg->SigP))->tcl_fe_ns_thr; - l1a_l1s_com.es_task.parameters.es_config.tcl_dt_ns_thr = ((T_MMI_ES_REQ *)(msg->SigP))->tcl_dt_ns_thr; - l1a_l1s_com.es_task.parameters.es_config.tcl_ne_thr = ((T_MMI_ES_REQ *)(msg->SigP))->tcl_ne_thr; - l1a_l1s_com.es_task.parameters.es_config.ref_ls_pwr = ((T_MMI_ES_REQ *)(msg->SigP))->ref_ls_pwr; - l1a_l1s_com.es_task.parameters.es_config.switching_time = ((T_MMI_ES_REQ *)(msg->SigP))->switching_time; - l1a_l1s_com.es_task.parameters.es_config.switching_time_dt = ((T_MMI_ES_REQ *)(msg->SigP))->switching_time_dt; - l1a_l1s_com.es_task.parameters.es_config.hang_time = ((T_MMI_ES_REQ *)(msg->SigP))->hang_time; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_dl_vect[0] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_dl_vect[0]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_dl_vect[1] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_dl_vect[1]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_dl_vect[2] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_dl_vect[2]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_dl_vect[3] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_dl_vect[3]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_ul_vect[0] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_ul_vect[0]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_ul_vect[1] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_ul_vect[1]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_ul_vect[2] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_ul_vect[2]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_ul_vect[3] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_ul_vect[3]; - } - if (l1a.dyn_dwnld.semaphore_vect[ANR_STATE_MACHINE] == GREEN) - { - // WARNING: The following code must be copied in the state WAIT_DYN_DWNLD - // when ES task is activated at L1s level - - // Enable the L1S task - l1a_l1s_com.es_task.command.update = TRUE; - - *state = WAIT_CON; - } - else - { - *state = WAIT_DYN_DWNLD; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"ES SM blocked by DYN DWNLD\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - } - - // End process - return; - } - // omaps00090550 break; - case WAIT_DYN_DWNLD: - { - if (SignalCode == API_L1_DYN_DWNLD_FINISHED && l1a.dyn_dwnld.semaphore_vect[ANR_STATE_MACHINE] == GREEN) - { - // Enable the L1S task - l1a_l1s_com.es_task.command.update = TRUE; - - *state = WAIT_CON; - - #if ((TRACE_TYPE == 1) || (TRACE_TYPE == 4) || (TRACE_TYPE == 5)) - if((trace_info.current_config->l1_dyn_trace) & (1<<L1_DYN_TRACE_DYN_DWNLD)) - { - char str[30]; - sprintf(str,"ES SM un-blocked\r\n"); - #if(CODE_VERSION == SIMULATION) - trace_fct_simu_dyn_dwnld(str); - #else - rvt_send_trace_cpy((T_RVT_BUFFER)str,trace_info.l1_trace_user_id,strlen(str),RVT_ASCII_FORMAT); - #endif - } - #endif // (TRACE_TYPE == 1) || (TRACE_TYPE == 4) - } - return; - } - // omaps00090550 break; - case WAIT_CON: - { - if (SignalCode == L1_ES_CON) - { - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_ES_CON); - - *state = RESET; - } - - // End process - return; - } - // omaps00090550 break; - } // switch - } // while(1) - } - -#else - void l1a_mmi_es_process(xSignalHeaderRec *msg) - { - enum states - { - RESET = 0, - WAIT_REQ = 1, - WAIT_CON = 2 - }; - - UWORD8 *state = &l1a.state[L1A_ES_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while(1) - { - switch(*state) - { - case RESET: - { - // Reset the command - l1a_l1s_com.es_task.command.update = FALSE; - - *state = WAIT_REQ; - } - break; - - case WAIT_REQ: - { - if (SignalCode == MMI_ES_REQ) - { - // Load the message into the l1a_l1s_com memory - l1a_l1s_com.es_task.parameters.es_enable = ((T_MMI_ES_REQ *)(msg->SigP))->es_enable; - l1a_l1s_com.es_task.parameters.es_behavior = ((T_MMI_ES_REQ *)(msg->SigP))->es_behavior; - - if (l1a_l1s_com.es_task.parameters.es_behavior == ES_CUSTOM_PARAM) - { - // Load every parameters from the message - l1a_l1s_com.es_task.parameters.es_config.es_mode = ((T_MMI_ES_REQ *)(msg->SigP))->es_mode; - l1a_l1s_com.es_task.parameters.es_config.es_gain_dl = ((T_MMI_ES_REQ *)(msg->SigP))->es_gain_dl; - l1a_l1s_com.es_task.parameters.es_config.es_gain_ul_1 = ((T_MMI_ES_REQ *)(msg->SigP))->es_gain_ul_1; - l1a_l1s_com.es_task.parameters.es_config.es_gain_ul_2 = ((T_MMI_ES_REQ *)(msg->SigP))->es_gain_ul_2; - l1a_l1s_com.es_task.parameters.es_config.tcl_fe_ls_thr = ((T_MMI_ES_REQ *)(msg->SigP))->tcl_fe_ls_thr; - l1a_l1s_com.es_task.parameters.es_config.tcl_dt_ls_thr = ((T_MMI_ES_REQ *)(msg->SigP))->tcl_dt_ls_thr; - l1a_l1s_com.es_task.parameters.es_config.tcl_fe_ns_thr = ((T_MMI_ES_REQ *)(msg->SigP))->tcl_fe_ns_thr; - l1a_l1s_com.es_task.parameters.es_config.tcl_dt_ns_thr = ((T_MMI_ES_REQ *)(msg->SigP))->tcl_dt_ns_thr; - l1a_l1s_com.es_task.parameters.es_config.tcl_ne_thr = ((T_MMI_ES_REQ *)(msg->SigP))->tcl_ne_thr; - l1a_l1s_com.es_task.parameters.es_config.ref_ls_pwr = ((T_MMI_ES_REQ *)(msg->SigP))->ref_ls_pwr; - l1a_l1s_com.es_task.parameters.es_config.switching_time = ((T_MMI_ES_REQ *)(msg->SigP))->switching_time; - l1a_l1s_com.es_task.parameters.es_config.switching_time_dt = ((T_MMI_ES_REQ *)(msg->SigP))->switching_time_dt; - l1a_l1s_com.es_task.parameters.es_config.hang_time = ((T_MMI_ES_REQ *)(msg->SigP))->hang_time; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_dl_vect[0] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_dl_vect[0]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_dl_vect[1] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_dl_vect[1]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_dl_vect[2] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_dl_vect[2]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_dl_vect[3] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_dl_vect[3]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_ul_vect[0] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_ul_vect[0]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_ul_vect[1] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_ul_vect[1]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_ul_vect[2] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_ul_vect[2]; - l1a_l1s_com.es_task.parameters.es_config.gain_lin_ul_vect[3] = ((T_MMI_ES_REQ *)(msg->SigP))->gain_lin_ul_vect[3]; - } - - // Enable the L1S task - l1a_l1s_com.es_task.command.update = TRUE; - - *state = WAIT_CON; - } - - // End process - return; - } - break; - - case WAIT_CON: - { - if (SignalCode == L1_ES_CON) - { - // Send the start confirmation message - l1a_audio_send_confirmation(MMI_ES_CON); - - *state = RESET; - } - - // End process - return; - } - break; - } // switch - } // while(1) - } - #endif //L1_DYN_DSP_DWNLD - #endif // L1_ES - -// New Vocoder IF process - -#if (L1_VOCODER_IF_CHANGE == 1) - void l1a_mmi_vocoder_cfg_process (xSignalHeaderRec *msg) - { - - BOOL msg_parameter; - - enum states - { - WAIT_REQ = 0, - WAIT_ENABLE_CON = 1, - WAIT_DISABLE_CON = 2 - }; - - enum vocoder_cfg_req - { - VOCODER_DISABLE_REQ = 0, - VOCODER_ENABLE_REQ = 1 - }; - - UWORD8 *state = &l1a.state[L1A_VOCODER_CFG_STATE]; - UWORD32 SignalCode = msg->SignalCode; - - while (1) - { - switch(*state) - { - case WAIT_REQ: - { - - // Waiting PS messages.... - - // If SignalCode is an MPHC_STOP_DEDICATED_REQ and vocoders are enabled, they must be stopped automatically - -#if(L1_CHECK_COMPATIBLE == 1) - if (((SignalCode == MPHC_STOP_DEDICATED_REQ) && (l1a.vocoder_state.enabled == TRUE)) || (l1a.vch_auto_disable == TRUE)) -#else - if (((SignalCode == MPHC_STOP_DEDICATED_REQ) && (l1a.vocoder_state.enabled == TRUE))) -#endif - { - // Command vocoder disabling at L1A-L1s interface and set the automatic disable flag to TRUE - l1a_l1s_com.dedic_set.start_vocoder = TCH_VOCODER_DISABLE_COMMAND; - l1a.vocoder_state.automatic_disable = TRUE; - *state = WAIT_DISABLE_CON; -#if(L1_CHECK_COMPATIBLE == 1) - l1a.vch_auto_disable = FALSE; -#endif - } - else if (SignalCode == MMI_TCH_VOCODER_CFG_REQ) - { - // In case the vocoder START or STOP is commanded by PS - - - msg_parameter = ((T_MMI_TCH_VOCODER_CFG_REQ *) (msg->SigP))->vocoder_state; - // If it is an explicit STOP.... - if (msg_parameter == VOCODER_DISABLE_REQ) - { -#if (AUDIO_DEBUG == 1) - trace_info.audio_debug_var.vocoder_enable_status = 0; -#endif - - //... explicitely disable vocoders if they're enabled commanidng the stop at L1A-L1s interface - if (l1a.vocoder_state.enabled == TRUE) - { - l1a_l1s_com.dedic_set.start_vocoder = TCH_VOCODER_DISABLE_COMMAND; - l1a.vocoder_state.automatic_disable = FALSE; - *state = WAIT_DISABLE_CON; - } - else - { - // ...else, if vocoders are already disabled but PS is sending erroneously the request - // send him however the confirmation without doing anything (protection check). - // In case L1 standalone or SIMULATION, confirmation message must be - // sent to MMI mailbox, else with complete PS software the message must be - // addressed to the ACI queue (WARNING: ACI_QUEUE must be properly defined). - - l1a_send_confirmation(MMI_TCH_VOCODER_CFG_CON, ACI_QUEUE); - } - } - else if (msg_parameter == VOCODER_ENABLE_REQ) - { -#if (AUDIO_DEBUG == 1) - trace_info.audio_debug_var.vocoder_enable_status = 1; -#endif - // If it is a START - if (l1a.vocoder_state.enabled == FALSE) - { - // Command the start at L1A-L1s interface if vocoders are disabled - l1a_l1s_com.dedic_set.start_vocoder = TCH_VOCODER_ENABLE_COMMAND; - *state = WAIT_ENABLE_CON; - } - else - { - // ...else, if vocoders are already enabled but PS is sending erroneously the request - // send him however the confirmation without doing anything (protection check). - // In case L1 standalone or SIMULATION, confirmation message must be - // sent to MMI mailbox, else with complete PS software the message must be - // addressed to the ACI queue (WARNING: ACI_QUEUE must be properly defined). - - l1a_send_confirmation(MMI_TCH_VOCODER_CFG_CON, ACI_QUEUE); - } - } - } - return; - } - // omaps00090550 break; - case WAIT_ENABLE_CON: - { - if (SignalCode == L1_VOCODER_CFG_ENABLE_CON) - { - // when L1s confirms the enabling, forward the confirmation to PS and set the vocoders enabled flag to TRUE - l1a.vocoder_state.enabled = TRUE; - - // in case L1 standalone or SIMULATION, confirmation message must be - // sent to MMI mailbox, else with complete PS software the message must be - // addressed to the ACI queue (WARNING: ACI_QUEUE must be properly defined). - - l1a_send_confirmation(MMI_TCH_VOCODER_CFG_CON, ACI_QUEUE); - *state = WAIT_REQ; - } - return; - } - // omaps00090550 break; - case WAIT_DISABLE_CON: - { - if (SignalCode == L1_VOCODER_CFG_DISABLE_CON) - { - // when L1s confirms the disabling, forwards the confirmation to PS and set the vocoders enabled flag to FALSE - l1a.vocoder_state.enabled = FALSE; - *state = WAIT_REQ; - - if (l1a.vocoder_state.automatic_disable == FALSE) - { - // Only in case it is an explicit request to STOP the vocoders (made previously by PS) - // send him the confirmation. - // In case L1 standalone or SIMULATION, confirmation message must be - // sent to MMI mailbox, else with complete PS software the message must be - // addressed to the ACI queue (WARNING: ACI_QUEUE must be properly defined). - - l1a_send_confirmation(MMI_TCH_VOCODER_CFG_CON, ACI_QUEUE); - } - else - // Reset automatic disable flag - l1a.vocoder_state.automatic_disable = FALSE; - } - return; - } - // omaps00090550 break; - } - } - - } -#endif // L1_VOCODER_IF_CHANGE == 1 - void l1a_mmi_outen_cfg_process (xSignalHeaderRec *msg) - { -#if (OP_RIV_AUDIO == 1) - - UWORD32 SignalCode = msg->SignalCode; - void *p_message; - T_RVF_MB_STATUS mb_status; - - if (SignalCode == MMI_OUTEN_CFG_REQ) - { - l1a_l1s_com.outen_cfg_task.outen1 = ((T_MMI_OUTEN_CFG_REQ *)(msg->SigP))->outen1; - l1a_l1s_com.outen_cfg_task.outen2 = ((T_MMI_OUTEN_CFG_REQ *)(msg->SigP))->outen2; - l1a_l1s_com.outen_cfg_task.outen3 = ((T_MMI_OUTEN_CFG_REQ *)(msg->SigP))->outen3; - l1a_l1s_com.outen_cfg_task.classD = ((T_MMI_OUTEN_CFG_REQ *)(msg->SigP))->classD; - - l1a_l1s_com.outen_cfg_task.command_requested++; - // Send the confirmation message - l1a_audio_send_confirmation(MMI_OUTEN_CFG_CON); - } - else if(SignalCode == MMI_OUTEN_CFG_READ_REQ) - { - // Allocate the Riviera buffer - mb_status = rvf_get_buf ( p_audio_gbl_var->mb_external, - sizeof (T_MMI_OUTEN_CFG_READ_CON), - (T_RVF_BUFFER **) (&p_message)); - - // If insufficient resources, then report a memory error and abort. - if (mb_status == RVF_RED) - { - // the memory is insufficient to continue the non regression test - AUDIO_SEND_TRACE("AUDIO entity has no memory for L1 confirm",RV_TRACE_LEVEL_ERROR); - return; - } - - // Fill the message ID - ((T_MMI_OUTEN_CFG_READ_CON *)(p_message))->header.msg_id = MMI_OUTEN_CFG_READ_CON; - - // Fill the message parameter - ((T_MMI_OUTEN_CFG_READ_CON*)(p_message))->outen1 = l1a_l1s_com.outen_cfg_task.outen1; - ((T_MMI_OUTEN_CFG_READ_CON*)(p_message))->outen2 = l1a_l1s_com.outen_cfg_task.outen2; - ((T_MMI_OUTEN_CFG_READ_CON*)(p_message))->outen3 = l1a_l1s_com.outen_cfg_task.outen3; - ((T_MMI_OUTEN_CFG_READ_CON*)(p_message))->classD = l1a_l1s_com.outen_cfg_task.classD; - - // send the messsage to the audio entity - rvf_send_msg (p_audio_gbl_var->addrId,p_message); - } -#endif /*OP_RIV_AUDIO*/ - } /* end function l1a_mmi_outen_cfg_process */ - -#if(L1_BT_AUDIO ==1) -void l1a_mmi_bt_process(xSignalHeaderRec *msg) -{ - UWORD32 SignalCode = msg->SignalCode; - - if (SignalCode == MMI_BT_ENABLE_REQ) - bt_audio.connected_status = TRUE; - else if(SignalCode == MMI_BT_DISABLE_REQ) - bt_audio.connected_status = FALSE; - -} -#endif -#endif // AUDIO_TASK -
--- a/L1/audio_cfile/l1audio_back.c Fri Jun 10 06:07:27 2016 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,609 +0,0 @@ -/************* Revision Controle System Header ************* - * GSM Layer 1 software - * L1AUDIO_SRBACK.C - * - * Filename l1audio_back.c - * Copyright 2003 (C) Texas Instruments - * - ************* Revision Controle System Header *************/ - -/************************************/ -/* Include files... */ -/************************************/ - -#define L1_SRBACK_COM // switch to define the l1_srback_com variable -#define L1_AUDIOBACK_MELODYE2 // switch to define the audio background variable - -#include "l1_macro.h" -#include "l1_confg.h" - -#if (AUDIO_TASK == 1) && (L1_AUDIO_BACKGROUND_TASK) - - #include "l1_types.h" - #include "sys_types.h" - - #if (CODE_VERSION == SIMULATION) && (AUDIO_SIMULATION) - - - #include <stdlib.h> - #include <string.h> - - #include "iq.h" // Debug / Init hardware ("eva3.lib") - #include "l1_ver.h" - #include "l1_const.h" - #include "l1_signa.h" - - #if TESTMODE - #include "l1tm_defty.h" - #endif - - #include "l1audio_const.h" - #include "l1audio_cust.h" - #include "l1audio_signa.h" - #include "l1audio_defty.h" - #include "l1audio_msgty.h" - #include "l1audio_varex.h" - - #if (L1_GTT == 1) - #include "l1gtt_const.h" - #include "l1gtt_defty.h" - #endif -//added form e-sample for AAC - #if (L1_DYN_DSP_DWNLD == 1) - #include "l1_dyn_dwl_const.h" - #include "l1_dyn_dwl_defty.h" - #endif - #if (L1_MP3 == 1) - #include "l1mp3_defty.h" - #endif - - #if (L1_MIDI == 1) - #include "l1midi_defty.h" - #endif -//added form e-sample for AAC - #if (L1_AAC == 1) - #include "l1aac_defty.h" - #endif - - #include "l1_defty.h" - #include "cust_os.h" - #include "l1_msgty.h" - #include "l1_varex.h" - - #include "l1_mftab.h" - #include "l1_tabs.h" - #include "l1_ctl.h" - - - #include "l1_time.h" - #include "l1_scen.h" - - #else - // Layer1 and debug include files. - - #include <ctype.h> - #include <math.h> - #include "l1_ver.h" - #include "l1_const.h" - #include "l1_signa.h" - - #if TESTMODE - #include "l1tm_defty.h" - #endif - - #include "l1audio_const.h" - #include "l1audio_cust.h" - #include "l1audio_signa.h" - #include "l1audio_defty.h" - #include "l1audio_msgty.h" - #include "l1audio_varex.h" - - #if (L1_GTT == 1) - #include "l1gtt_const.h" - #include "l1gtt_defty.h" - #endif -//added form e-sample for AAC - #if (L1_DYN_DSP_DWNLD == 1) - #include "l1_dyn_dwl_const.h" - #include "l1_dyn_dwl_defty.h" - #endif - #if (L1_MP3 == 1) - #include "l1mp3_defty.h" - #endif - - #if (L1_MIDI == 1) - #include "l1midi_defty.h" - #endif -//added form e-sample for AAC - #if (L1_AAC == 1) - #include "l1aac_defty.h" - #endif - - #include "l1_defty.h" - #include "cust_os.h" - #include "l1_msgty.h" - #include "tpudrv.h" // TPU drivers. ("eva3.lib") - #include "l1_varex.h" - - #include "l1_proto.h" - #include "l1_mftab.h" - #include "l1_tabs.h" - #include "mem.h" - #include "armio.h" - #include "timer.h" - #include "timer1.h" - #include "dma.h" - #include "inth.h" - #include "ulpd.h" - #include "rhea_arm.h" - #include "clkm.h" // Clockm ("eva3.lib") - #include "l1_ctl.h" - - #include "l1_time.h" - #if L2_L3_SIMUL - #include "l1_scen.h" - #endif - #endif - - /****************************************/ - /* Prototypes for audio background task */ - /****************************************/ - void l1_audio_background_task (UWORD32 argc, void *argv); - #if (SPEECH_RECO) - void srback_CTO_algorithm (API *RAM_address); - void srback_save_model_temp (API *RAM_address_input, UWORD16 *RAM_address_output); - #endif - #if (MELODY_E2 && FIR) - void audio_background_melody_e2_download_instrument_manager(xSignalHeaderRec *msg); - #endif - /**************************************/ - /* External prototypes */ - /**************************************/ - #if (SPEECH_RECO) - extern void Cust_srback_save_model (UWORD8 database, UWORD8 index, API *RAM_address); - extern void Cust_srback_save_speech (UWORD8 database, UWORD8 index, UWORD16 *start_buffer, UWORD16 *stop_buffer, UWORD16 *start_speech, UWORD16 *stop_speech); - extern void Cust_srback_load_model (UWORD8 database, UWORD8 index, API *RAM_address); - #endif - #if (MELODY_E2 && FIR) - extern UWORD16 Cust_audio_melody_E2_load_instrument (UWORD8 customer_instrument_id, - API *API_address, - UWORD16 allowed_size); - #endif - -#if (OP_RIV_AUDIO == 0) - /*--------------------------------------------------------*/ - /* l1_audio_background_task() */ - /*--------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is a state machine which handles the */ - /* audio background feature. */ - /* */ - /* Starting messages: L1_SRBACK_SAVE_DATA_REQ */ - /* L1_SRBACK_TEMP_SAVE_DATA_REQ */ - /* L1_SRBACK_LOAD_MODEL_REQ */ - /* L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ */ - /* L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ */ - /* */ - /* Result messages (input): none */ - /* */ - /* Result messages (output): L1_SRBACK_SAVE_DATA_CON */ - /* L1_SRBACK_TEMP_SAVE_DATA_CON */ - /* L1_SRBACK_LOAD_MODEL_CON */ - /* L1_BACK_MELODY_E2_LOAD_INSTRUMENT_CON */ - /* L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): non */ - /* */ - /* Stop message (output): L1_SRBACK_SAVE_DATA_CON */ - /* L1_SRBACK_TEMP_SAVE_DATA_CON */ - /* L1_SRBACK_LOAD_MODEL_CON */ - /* L1_BACK_MELODY_E2_LOAD_INSTRUMENT_CON */ - /* L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_CON */ - /* */ - /* Rem: to stop immeditly the speech reco feature a flag */ - /* ---- is created: l1_srback_com.emergency_stop */ - /* */ - /*--------------------------------------------------------*/ - void l1_audio_background_task(UWORD32 argc, void *argv) - { - xSignalHeaderRec *receive_msg, *confirm_msg; - UWORD8 index; - - while(1) - { - // Wait until a message is receive - receive_msg = os_receive_sig(SRBACK_QUEUE); - - #if (SPEECH_RECO) - if (receive_msg->SignalCode == L1_SRBACK_SAVE_DATA_REQ) - { - if (l1_srback_com.emergency_stop == FALSE) - { - // Call the customer function to save the model - Cust_srback_save_model( ((T_L1_SRBACK_SAVE_DATA_REQ *)(receive_msg->SigP))->database_id, - ((T_L1_SRBACK_SAVE_DATA_REQ *)(receive_msg->SigP))->model_index, - ((T_L1_SRBACK_SAVE_DATA_REQ *)(receive_msg->SigP))->model_RAM_address ); - } - if ( ((T_L1_SRBACK_SAVE_DATA_REQ *)(receive_msg->SigP))->speech ) - { - if (l1_srback_com.emergency_stop == FALSE) - { - // Call the customer function to save the speech from a circular buffer to the database - Cust_srback_save_speech( ((T_L1_SRBACK_SAVE_DATA_REQ *)(receive_msg->SigP))->database_id, - ((T_L1_SRBACK_SAVE_DATA_REQ *)(receive_msg->SigP))->model_index, - ((T_L1_SRBACK_SAVE_DATA_REQ *)(receive_msg->SigP))->start_buffer, - ((T_L1_SRBACK_SAVE_DATA_REQ *)(receive_msg->SigP))->stop_buffer, - ((T_L1_SRBACK_SAVE_DATA_REQ *)(receive_msg->SigP))->start_address, - ((T_L1_SRBACK_SAVE_DATA_REQ *)(receive_msg->SigP))->stop_address); - } - } - - // Send the stop confirmation message - confirm_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - confirm_msg->SignalCode = L1_SRBACK_SAVE_DATA_CON; - os_send_sig(confirm_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } // L1_SRBACK_SAVE_DATA_REQ - else - if (receive_msg->SignalCode == L1_SRBACK_LOAD_MODEL_REQ) - { - if ( ( ((T_L1_SRBACK_LOAD_MODEL_REQ *)(receive_msg->SigP))->CTO_enable ) == FALSE ) - { - if (l1_srback_com.emergency_stop == FALSE) - { - // Call the function to load a model - Cust_srback_load_model( ((T_L1_SRBACK_LOAD_MODEL_REQ *)(receive_msg->SigP))->database_id, - ((T_L1_SRBACK_LOAD_MODEL_REQ *)(receive_msg->SigP))->model_index, - ((T_L1_SRBACK_LOAD_MODEL_REQ *)(receive_msg->SigP))->model_RAM_address ); - } - } - else - { - if (l1_srback_com.emergency_stop == FALSE) - { - // Calculate the good index - index = ((T_L1_SRBACK_LOAD_MODEL_REQ *)(receive_msg->SigP))->model_index>>1; - - // Call the function to load a model with the good index - Cust_srback_load_model( ((T_L1_SRBACK_LOAD_MODEL_REQ *)(receive_msg->SigP))->database_id, - index, - ((T_L1_SRBACK_LOAD_MODEL_REQ *)(receive_msg->SigP))->model_RAM_address ); - } - - // The CTO algorithm is used and the model index is odd - if ( ((T_L1_SRBACK_LOAD_MODEL_REQ *)(receive_msg->SigP))->model_index & 0x01 ) - { - if (l1_srback_com.emergency_stop == FALSE) - { - // Call the function to apply the CTO algorithm to the loaded model - srback_CTO_algorithm( ((T_L1_SRBACK_LOAD_MODEL_REQ *)(receive_msg->SigP))->model_RAM_address ); - } - } - } - - // Send the stop confirmation message - confirm_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - confirm_msg->SignalCode = L1_SRBACK_LOAD_MODEL_CON; - os_send_sig(confirm_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } // L1_SRBACK_LOAD_MODEL_REQ - else - if (receive_msg->SignalCode == L1_SRBACK_TEMP_SAVE_DATA_REQ) - { - if (l1_srback_com.emergency_stop == FALSE) - { - // Call the function to save the model in a temporary buffer - srback_save_model_temp( ((T_L1_SRBACK_TEMP_SAVE_DATA_REQ *)(receive_msg->SigP))->model_RAM_address_input, - ((T_L1_SRBACK_TEMP_SAVE_DATA_REQ *)(receive_msg->SigP))->model_RAM_address_output ); - } - - // Send the stop confirmation message - confirm_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - confirm_msg->SignalCode = L1_SRBACK_TEMP_SAVE_DATA_CON; - os_send_sig(confirm_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } // L1_SRBACK_TEMP_SAVE_DATA_REQ - #endif // SPEECH_RECO - #if (MELODY_E2 && FIR) - if ( (receive_msg->SignalCode == L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ) || - (receive_msg->SignalCode == L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ) ) - { - audio_background_melody_e2_download_instrument_manager(receive_msg); - } // L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ - #endif // MELODY_E2 - - // Deallocate the received message - os_free_sig(receive_msg); - DEBUGMSG(status,NU_ALLOC_ERR) - } // while(1) - } -#endif // OP_RIV_AUDIO - - #if (SPEECH_RECO) - /*-------------------------------------------------------*/ - /* srback_CTO_algorithm() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : RAM_address */ - /* */ - /* Return : none */ - /* */ - /* Description : apply the CTO algorithm to the model. */ - /* */ - /*-------------------------------------------------------*/ - void srback_CTO_algorithm (API *RAM_address) - { - UWORD16 model_size, frame; - UWORD8 frame_size; - - // This alogrithm changes the model: - // |frame 0|frame 1|frame 2|frame 3|frame 4|frame 5|frame 6|frame 7|... - // into a garbage model: - // |0000000|frame 1|0000000|0000000|frame 4|0000000|0000000|frame 7|... - - // look the size of the model in model frame unit (16 words unit) - model_size = *RAM_address++; - - frame = 0; - - while( (frame <= model_size) && - (l1_srback_com.emergency_stop == FALSE) ) - { - if ((frame % 3) == 1) - { - // This frame is kept - RAM_address += SC_SR_MODEL_FRAME_SIZE; - } - else - { - // This frame is set to 0 - frame_size = SC_SR_MODEL_FRAME_SIZE; - while ( (frame_size != 0) && - (l1_srback_com.emergency_stop == FALSE) ) - { - *RAM_address++ = 0; - frame_size--; - } - } - - frame++; - } - } - - /*-------------------------------------------------------*/ - /* srback_CTO_algorithm() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : RAM_address_input */ - /* RAM_address_output */ - /* */ - /* Return : none */ - /* */ - /* Description : apply the CTO algorithm to the model. */ - /* */ - /*-------------------------------------------------------*/ - void srback_save_model_temp (API *RAM_address_input, UWORD16 *RAM_address_output) - { - UWORD16 model_size; - UWORD8 frame_size; - - // look the size of the model in model frame unit (16 words unit) - model_size = *RAM_address_input; - - // save the header of the model - *RAM_address_output++ = *RAM_address_input++; - - while( (model_size != 0) && - (l1_srback_com.emergency_stop == FALSE) ) - { - frame_size = SC_SR_MODEL_FRAME_SIZE; - while ( (frame_size != 0) && - (l1_srback_com.emergency_stop == FALSE) ) - { - *RAM_address_output++ = *RAM_address_input++; - frame_size--; - } - model_size--; - } - } - #endif // SPEECH_RECO - -#if (OP_RIV_AUDIO == 0) - #if (MELODY_E2 && FIR) - /*--------------------------------------------------------*/ - /*audio_background_melody_e2_download_instrument_manager()*/ - /*--------------------------------------------------------*/ - /* */ - /* Description: */ - /* ------------ */ - /* This function is used to load/unload the instrument of */ - /* the melodies E2. */ - /* */ - /* Starting messages: */ - /* L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ */ - /* L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ */ - /* */ - /* Result messages (input): none */ - /* */ - /* Result messages (output): */ - /* L1_BACK_MELODY_E2_LOAD_INSTRUMENT_CON */ - /* L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_CON */ - /* */ - /* Reset messages (input): none */ - /* */ - /* Stop message (input): none. */ - /* */ - /* Stop message (output): */ - /* L1_BACK_MELODY_E2_LOAD_INSTRUMENT_CON */ - /* L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_CON */ - /* */ - /* Rem: to stop immediatly the instrument download flags */ - /* ---- is created: */ - /* l1a_l1s_com.melody0_e2_task.parameters.emergency_stop */ - /* l1a_l1s_com.melody1_e2_task.parameters.emergency_stop */ - /* */ - /*--------------------------------------------------------*/ - void audio_background_melody_e2_download_instrument_manager(xSignalHeaderRec *msg) - { - xSignalHeaderRec *confirm_msg; - UWORD8 instrument_number, max_number_of_instrument, instrument_id, id; - UWORD16 size; - UWORD32 address; - - if (msg->SignalCode == L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ) - { - // Load the instrument - - // Init the first address - address = ( ((UWORD32)(l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_instrument_wave)) - - SC_AUDIO_MCU_API_BEGIN_ADDRESS ); - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_instrument_ptr[0] = - (API)( (address>>1) + SC_AUDIO_DSP_API_BEGIN_ADDRESS ); - - // Download the instrument - max_number_of_instrument = ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(msg->SigP))->number_of_instrument; - for(instrument_number=0; instrument_number < max_number_of_instrument ; instrument_number++) - { - // No instrument was previously download - if (audioback_melody_e2.number_of_user[instrument_number] == 0) - { - // load the insturment ID - instrument_id = - ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(msg->SigP))->waves_table_id[instrument_number]; - - // Find if this instrument was already downloaded - id = 0; - while ( (id < SC_AUDIO_MELODY_E2_MAX_NUMBER_OF_INSTRUMENT) && - ((instrument_id != audioback_melody_e2.instrument_id[id]) || - (audioback_melody_e2.number_of_user[id] == 0)) ) - { - id++; - } - - if (id < SC_AUDIO_MELODY_E2_MAX_NUMBER_OF_INSTRUMENT) - { - // This insturment was already downloaded - // copy the address of this instrument - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_instrument_ptr[instrument_number] = - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_instrument_ptr[id]; - - // The size of this instrument is 0 - audioback_melody_e2.instrument_size[instrument_number] = 0; - } - else - { - // Load the customer instrument - size = Cust_audio_melody_E2_load_instrument ( - ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(msg->SigP))->waves_table_id[instrument_number], - audioback_melody_e2.API_address, - audioback_melody_e2.allowed_size); - - // Added to stop the L1 in case of download error - if (size == 0) - { - // Send a message to stop the L1 - /* send the stop command to the audio L1 */ - /* allocate the buffer for the message to the L1 */ - confirm_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - - if (confirm_msg != NULL) - { - /* send the stop command to the audio L1 */ - if ( ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(confirm_msg->SigP))->melody_id == 0) - { - confirm_msg->SignalCode = MMI_MELODY0_E2_STOP_REQ; - } - else - { - confirm_msg->SignalCode = MMI_MELODY1_E2_STOP_REQ; - } - os_send_sig(confirm_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } - - // Save the size of this instrument - audioback_melody_e2.instrument_size[instrument_number] = size; - } - - // Update the Cust_audio_melody_E2_load_instrument argument - audioback_melody_e2.API_address += audioback_melody_e2.instrument_size[instrument_number]; - audioback_melody_e2.allowed_size -= audioback_melody_e2.instrument_size[instrument_number]; - - // Put the DSP address to the NDB API for the next instrument - if (instrument_number < SC_AUDIO_MELODY_E2_MAX_NUMBER_OF_INSTRUMENT-1) - { - address = ( ((UWORD32)(audioback_melody_e2.API_address)) - - SC_AUDIO_MCU_API_BEGIN_ADDRESS ); - - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_instrument_ptr[instrument_number + 1] = - (API)( (address>>1) + SC_AUDIO_DSP_API_BEGIN_ADDRESS ); - } - - // Save the instrument ID - audioback_melody_e2.instrument_id[instrument_number] = instrument_id; - } - - // Increase the number of user of this instrument number - audioback_melody_e2.number_of_user[instrument_number]++; - } - - // Send the load confirmation message - confirm_msg = os_alloc_sig(sizeof(T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - - // Fill the parameter - ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_CON *)(confirm_msg->SigP))->melody_id = - ((T_L1_BACK_MELODY_E2_LOAD_INSTRUMENT_REQ *)(msg->SigP))->melody_id; - - confirm_msg->SignalCode = L1_BACK_MELODY_E2_LOAD_INSTRUMENT_CON; - - os_send_sig(confirm_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - else - if (msg->SignalCode == L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ) - { - // Unload the instrument - max_number_of_instrument = ((T_L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ *)(msg->SigP))->number_of_instrument; - for(instrument_number = max_number_of_instrument; instrument_number > 0 ; instrument_number--) - { - // Decrease the number of user of this instrument number - audioback_melody_e2.number_of_user[instrument_number-1]--; - - // Check if the instrument must be removed - if (audioback_melody_e2.number_of_user[instrument_number-1] == 0) - { - // Increase the size and decrease the pointer to the API with the size - // of the removed instrument - // Update the Cust_audio_melody_E2_load_instrument argument - audioback_melody_e2.API_address -= audioback_melody_e2.instrument_size[instrument_number-1]; - audioback_melody_e2.allowed_size += audioback_melody_e2.instrument_size[instrument_number-1]; - } - } - - // Send the unload confirmation message - confirm_msg = os_alloc_sig(sizeof(T_L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - - // Fill the paramter - ((T_L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_CON *)(confirm_msg->SigP))->melody_id = - ((T_L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_REQ *)(msg->SigP))->melody_id; - - confirm_msg->SignalCode = L1_BACK_MELODY_E2_UNLOAD_INSTRUMENT_CON; - - os_send_sig(confirm_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } - #endif // MELODY_E2 -#endif // OP_RIV_AUDIO -#endif // AUDIO_TASK == 1 && L1_AUDIO_BACKGROUND_TASK
--- a/L1/audio_cfile/l1audio_func.c Fri Jun 10 06:07:27 2016 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,1310 +0,0 @@ -/************* Revision Controle System Header ************* - * GSM Layer 1 software - * L1AUDIO_FUNC.C - * - * Filename l1audio_func.c - * Copyright 2003 (C) Texas Instruments - * - ************* Revision Controle System Header *************/ - - -/************************************/ -/* Include files... */ -/************************************/ -#include "nucleus.h" //omaps00090550 -#include "l1_macro.h" - -#include "l1_macro.h" -#include "l1_confg.h" -//#include "l1audio_defty.h" - -#if (AUDIO_TASK == 1) - - #include "l1_types.h" - #include "sys_types.h" - #if (CODE_VERSION == SIMULATION) && (AUDIO_SIMULATION) - - - #include <stdlib.h> - #include <string.h> - - #include "iq.h" // Debug / Init hardware ("eva3.lib") - #include "l1_ver.h" - #include "l1_const.h" - #include "l1_signa.h" - - #if TESTMODE - #include "l1tm_defty.h" - #endif - - #include "l1audio_const.h" - #include "l1audio_cust.h" - #include "l1audio_signa.h" - #include "l1audio_defty.h" - #include "l1audio_msgty.h" - #include "l1audio_abb.h" - #include "l1audio_btapi.h" - - #if (L1_GTT == 1) - #include "l1gtt_const.h" - #include "l1gtt_defty.h" - #endif -//added here from e-sample for AAC - #if (L1_DYN_DSP_DWNLD == 1) - #include "l1_dyn_dwl_const.h" - #include "l1_dyn_dwl_defty.h" - #endif - #if (L1_MP3 == 1) - #include "l1mp3_defty.h" - #endif - - #if (L1_MIDI == 1) - #include "l1midi_defty.h" - #endif -//added here from e-sample for AAC - #if (L1_AAC == 1) - #include "l1aac_defty.h" - #endif - - #include "l1_defty.h" - #include "cust_os.h" - #include "l1_msgty.h" - #include "l1_varex.h" - - #include "l1_mftab.h" - #include "l1_tabs.h" - #include "l1_ctl.h" - - - #include "l1_time.h" - #include "l1_scen.h" - - #if TESTMODE - #include "l1tm_msgty.h" - #include "l1tm_signa.h" - #include "l1tm_varex.h" - #endif // TESTMODE - - #if (L1_STEREOPATH == 1) - #include "sys_dma.h" - #include "sys_inth.h" - #include "abb.h" - #include "l1audio_stereo.h" - #endif - - #else - // Layer1 and debug include files. - - #include <ctype.h> - #include <math.h> - #include "l1_ver.h" - #include "l1_const.h" - #include "l1_signa.h" - - #if TESTMODE - #include "l1tm_defty.h" - #endif - - #include "l1audio_const.h" - #include "l1audio_cust.h" - #include "l1audio_signa.h" - #include "l1audio_defty.h" - #include "l1audio_msgty.h" - #include "l1audio_abb.h" - - #if (L1_GTT == 1) - #include "l1gtt_const.h" - #include "l1gtt_defty.h" - #endif -//added here from e-sample for AAC - #if (L1_DYN_DSP_DWNLD == 1) - #include "l1_dyn_dwl_const.h" - #include "l1_dyn_dwl_defty.h" - #endif - #if (L1_MP3 == 1) - #include "l1mp3_defty.h" - #include"l1mp3_const.h" - #endif - - #if (L1_MIDI == 1) - #include "l1midi_defty.h" - #endif -//added here from e-sample for AAC - #if (L1_AAC == 1) - #include "l1aac_defty.h" - #include"l1aac_const.h" - #endif - - #include "l1_defty.h" - #include "cust_os.h" - #include "l1_msgty.h" - #include "tpudrv.h" // TPU drivers. ("eva3.lib") - #include "l1_varex.h" - - #include "l1_proto.h" - #include "l1_mftab.h" - #include "l1_tabs.h" - #include "mem.h" - #include "armio.h" - #include "timer.h" - #include "timer1.h" - #include "dma.h" - #include "inth.h" - #include "ulpd.h" - #include "rhea_arm.h" - #include "clkm.h" // Clockm ("eva3.lib") - #include "l1_ctl.h" - - #if TESTMODE - #include "l1tm_msgty.h" - #include "l1tm_signa.h" - #include "l1tm_varex.h" - #endif // TESTMODE - - #if (L1_STEREOPATH == 1) - #include "sys_dma.h" - #include "sys_inth.h" - #include "abb.h" - #include "l1audio_stereo.h" - #endif - - #include "l1_time.h" - #if L2_L3_SIMUL - #include "l1_scen.h" - #endif - #endif -#if (OP_RIV_AUDIO == 1) - #include "rv_general.h" - #include "audio_api.h" - #include "audio_structs_i.h" - #include "audio_var_i.h" - #include "audio_macro_i.h" - #include "audio_const_i.h" - #endif - - #include "l1audio_macro.h" - - /**************************************/ - /* Prototypes for L1S audio function */ - /**************************************/ - UWORD8 copy_data_from_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD16 **ptr_buf, UWORD16 data_size, API *ptr_dst); - UWORD8 copy_data_to_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD16 **ptr_buf, UWORD16 data_size, API *ptr_src); - #if (MELODY_E2) - UWORD16 audio_twentyms_to_TDMA_convertion(UWORD16 twentyms_value); - #endif - #if (MELODY_E2) || (L1_VOICE_MEMO_AMR) - UWORD8 copy_byte_data_from_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, UWORD8 *ptr_dst); - UWORD8 copy_byte_data_to_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, UWORD8 *ptr_src); - #endif - #if (L1_VOICE_MEMO_AMR) - UWORD8 copy_byte_data_le_from_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, API *ptr_dst); - UWORD8 copy_byte_data_le_to_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, API *ptr_src); - #endif - #if (L1_EXT_AUDIO_MGT == 1) - void l1_ext_audio_mgt_dma_handler(SYS_UWORD16 dma_status); - #endif - #if (L1_IIR == 2) - void l1_audio_iir4x_copy_params(); - #endif - - #if (L1_AGC_UL== 1) - void l1_audio_agc_ul_copy_params(); - #endif - - #if (L1_AGC_DL== 1) - void l1_audio_agc_dl_copy_params(); - #endif - - #if (L1_DRC == 1) - void l1_audio_drc1x_copy_params(); - #endif - -#if(L1_BT_AUDIO ==1)||(L1_WCM ==1) -void l1_audio_manager(UWORD8 *src, UWORD16 size); -void l1_audio_bt_init(UINT16 media_buf_size); -extern void l1mp3_dma_it_handler(SYS_UWORD16 d_dma_channel_it_status); -extern void l1aac_dma_it_handler(SYS_UWORD16 d_dma_channel_it_status); -#endif -#if(L1_BT_AUDIO ==1) -T_L1_BT_AUDIO bt_audio; - -extern T_MP3_DMA_PARAM *mp3_dma; -extern T_AAC_DMA_PARAM *aac_dma; -extern void l1a_bt_audio_noti_process(); -extern UWORD16 pending_dec_req; - -#endif - /**************************************/ - /* External prototypes */ - /**************************************/ - extern UWORD8 Cust_get_pointer (UWORD16 **ptr, UWORD16 *buffer_size, UWORD8 session_id); - - #if ((L1_STEREOPATH == 1) && (OP_L1_STANDALONE == 1)) - extern void l1tm_stereopath_DMA_handler(SYS_UWORD16 dma_status); - #if TESTMODE - extern T_STP_DRV_MCU_DSP *stp_drv_ndb; - #endif - #endif - - #if (L1_EXT_AUDIO_MGT == 1) - extern NU_HISR EXT_AUDIO_MGT_hisr; - extern T_MIDI_DMA_PARAM midi_buf; - #endif - - #if (L1_DRC == 1) - extern T_DRC_MCU_DSP *drc_ndb; - #endif - - /*-------------------------------------------------------*/ - /* copy_data_from_buffer() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : session_id */ - /* buffer_size */ - /* data_size */ - /* ptr_dst */ - /* ptr_src */ - /* */ - /* Return : error_id */ - /* */ - /* Description : */ - /* This function copies the data from the buffer */ - /* (buffer size: buffer_size, start address: ptr_buf) to */ - /* the destination indicated by ptr_dst. The size of the */ - /* data to download is data_size. The session_id */ - /* indicates to the custom flash manager the type of */ - /* data. */ - /* */ - /*-------------------------------------------------------*/ - UWORD8 copy_data_from_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD16 **ptr_buf, UWORD16 data_size, API *ptr_dst) - { - UWORD8 error_id = 0; - - while (data_size != 0) - { - while( (data_size !=0) && (*buffer_size != 0) ) - { - *ptr_dst++ = *(*ptr_buf)++; - data_size--; - (*buffer_size)--; - } - // A new buffer is requested in order to finish to copy the data - if ( data_size != 0) - { - *buffer_size = data_size; - error_id = Cust_get_pointer( ptr_buf, buffer_size, session_id); - - // An error is occured - if (error_id) - return(error_id); - } - } - - return(error_id); - } - - /*-------------------------------------------------------*/ - /* copy_data_to_buffer() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : session_id */ - /* buffer_size */ - /* data_size */ - /* ptr_dst */ - /* ptr_src */ - /* */ - /* Return : error_id */ - /* */ - /* Description : */ - /* This function copies the data to the buffer */ - /* (buffer size: buffer_size, start address: ptr_buf) */ - /* from the source indicated by ptr_src. The size of the */ - /* data to save is data_size. The session_id */ - /* indicates to the custom flash manager the type of */ - /* data. */ - /* */ - /*-------------------------------------------------------*/ - UWORD8 copy_data_to_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD16 **ptr_buf, UWORD16 data_size, API *ptr_src) - { - UWORD8 error_id = 0; - - while (data_size != 0) - { - while( (data_size !=0) && (*buffer_size != 0) ) - { - *(*ptr_buf)++ = *ptr_src++; - data_size--; - (*buffer_size)--; - } - // A new buffer is requested in order to finish to copy the data - if (data_size != 0) - { - *buffer_size = data_size; - error_id = Cust_get_pointer(ptr_buf, buffer_size, session_id); - - // An error is occured - if (error_id) - return(error_id); - } - } - - return(error_id); - } - - #if (MELODY_E2) || (L1_VOICE_MEMO_AMR) - /*-------------------------------------------------------*/ - /* copy_byte_data_from_buffer() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : session_id */ - /* buffer_size */ - /* data_size */ - /* ptr_dst */ - /* ptr_src */ - /* */ - /* Return : error_id */ - /* */ - /* Description : */ - /* This function copies byte per byte the data from */ - /* the buffer (buffer size (in byte): buffer_size, */ - /* start address: ptr_buf) to the destination indicated */ - /* by ptr_dst. The size of the data to download is */ - /* data_size(in byte). The session_id indicates to the */ - /* custom flash manager the type of data. */ - /* */ - /*-------------------------------------------------------*/ - UWORD8 copy_byte_data_from_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, UWORD8 *ptr_dst) - { - UWORD8 error_id = 0; - UWORD16 requested_size; - - while (data_size != 0) - { - while( (data_size !=0) && (*buffer_size != 0) ) - { - *ptr_dst++ = *(*ptr_buf)++; - data_size--; - (*buffer_size)--; - } - // A new buffer is requested in order to finish to copy the data - if ( data_size != 0) - { - // Calculate the size of the data to request in 16-bit word - if (*buffer_size & 0x0001) - { - // The size is a odd value - requested_size = (data_size >> 1) + 1; - } - else - { - // the size is an even value - requested_size = (data_size >> 1); - } - - error_id = Cust_get_pointer( (UWORD16 **)ptr_buf, &requested_size, session_id); - - // An error is occured - if (error_id) - return(error_id); - - *buffer_size = (requested_size << 1); - } - } - - return(error_id); - } - - /*-------------------------------------------------------*/ - /* copy_data_to_buffer() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : session_id */ - /* buffer_size */ - /* data_size */ - /* ptr_dst */ - /* ptr_src */ - /* */ - /* Return : error_id */ - /* */ - /* Description : */ - /* This function copies byte per byte the data to the */ - /* buffer (buffer size in byte: buffer_size, start */ - /* address: ptr_buf) from the source indicated by */ - /* ptr_src. The size in byte of the data to save is */ - /* data_size. The session_id indicates to the custom */ - /* flash manager the type of data. */ - /* */ - /*-------------------------------------------------------*/ - UWORD8 copy_byte_data_to_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, UWORD8 *ptr_src) - { - UWORD8 error_id = 0; - UWORD16 requested_size; - - while (data_size != 0) - { - while( (data_size !=0) && (*buffer_size != 0) ) - { - *(*ptr_buf)++ = *ptr_src++; - data_size--; - (*buffer_size)--; - } - // A new buffer is requested in order to finish to copy the data - if (data_size != 0) - { - // Calculate the size of the data to request in 16-bit word - if (*buffer_size & 0x0001) - { - // The size is a odd value - requested_size = (data_size >> 1) + 1; - } - else - { - // the size is an even value - requested_size = (data_size >> 1); - } - - error_id = Cust_get_pointer((UWORD16 **)ptr_buf, &requested_size, session_id); - - // An error is occured - if (error_id) - return(error_id); - - *buffer_size = (requested_size << 1); - } - } - - return(error_id); - } - #endif //#if (MELODY_E2) || (L1_VOICE_MEMO_AMR) - - #if (MELODY_E2) - - /*-------------------------------------------------------*/ - /* audio_twentyms_to_TDMA_convertion() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : 20ms value */ - /* */ - /* Return : TDMA value */ - /* */ - /* Description : */ - /* This function convert a duration from 20ms unit to */ - /* TDMA unit. */ - /* */ - /*-------------------------------------------------------*/ - UWORD16 audio_twentyms_to_TDMA_convertion(UWORD16 twentyms_value) - { - UWORD16 TDMA_value; - - // 20ms # 4 TDMA - TDMA_value = twentyms_value << 2; - - // Compensation factor: 1 TDMA each 60ms. - TDMA_value += (twentyms_value/3); - - return(TDMA_value); - } - #endif // MELODY_E2 - - #if (L1_VOICE_MEMO_AMR) - /*-------------------------------------------------------*/ - /* copy_byte_data_le_from_buffer() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : session_id */ - /* buffer_size */ - /* data_size */ - /* ptr_dst */ - /* ptr_src */ - /* */ - /* Return : error_id */ - /* */ - /* Description : */ - /* This function copies byte per byte the data from */ - /* the buffer (buffer size (in byte): buffer_size, */ - /* start address: ptr_buf) to the destination indicated */ - /* by ptr_dst. The size of the data to download is */ - /* data_size(in byte). The session_id indicates to the */ - /* custom flash manager the type of data. */ - /* Data in buffer is expected to be big-endian and will */ - /* be copied in order to retrieve little-endian order in */ - /* ptr_dst */ - /* */ - /*-------------------------------------------------------*/ - UWORD8 copy_byte_data_le_from_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, API *ptr_dst) - { - UWORD8 error_id = 0; - UWORD16 requested_size; - UWORD16 data_size_inv = 0; - UWORD16 temp_uword16 = 0 ; //omaps00090550 - - while (data_size_inv != data_size) - { - /* we go from 0 to data_size copying to MSB (even numbers) then LSB (odd numbers) of DSP */ - while( (data_size_inv != data_size) && (*buffer_size != 0) ) - { - if (data_size_inv & 0x0001) - { - temp_uword16 |= *(*ptr_buf)++; - *(ptr_dst)++ = temp_uword16; - } - else - { - temp_uword16 = (*(*ptr_buf)++ << 8); - } - data_size_inv++; - (*buffer_size)--; - } - // A new buffer is requested in order to finish to copy the data - if ( data_size_inv != data_size) - { - // Calculate the size of the data to request in 16-bit word - if ((data_size - data_size_inv) & 0x0001) - { - // The size is an odd value - requested_size = ((data_size - data_size_inv) >> 1) + 1; - } - else - { - // the size is an even value - requested_size = ((data_size - data_size_inv) >> 1); - } - - error_id = Cust_get_pointer((UWORD16 **)ptr_buf, &requested_size, session_id); - - // An error is occured - if (error_id) - return(error_id); - - *buffer_size = (requested_size << 1); - } - } - - if (data_size & 0x0001) - { - *(ptr_dst)++ = temp_uword16; - } - - return(error_id); - } - - /*-------------------------------------------------------*/ - /* copy_byte_data_le_to_buffer() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : session_id */ - /* buffer_size */ - /* data_size */ - /* ptr_dst */ - /* ptr_src */ - /* */ - /* Return : error_id */ - /* */ - /* Description : */ - /* This function copies byte per byte the data to the */ - /* buffer (buffer size in byte: buffer_size, start */ - /* address: ptr_buf) from the source indicated by */ - /* ptr_src. The size in byte of the data to save is */ - /* data_size. The session_id indicates to the custom */ - /* flash manager the type of data. */ - /* Data is expected to be little-endian in ptr_src and */ - /* will be copied in order to retrieve big-endian */ - /* order in buffer */ - /* */ - /*-------------------------------------------------------*/ - UWORD8 copy_byte_data_le_to_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, API *ptr_src) - { - UWORD8 error_id = 0; - UWORD8 data_size_inv = 0; - UWORD16 requested_size; - UWORD16 temp_uword16=0; //omaps00090550 - - /* we go from 0 to data_size copying MSB (even numbers) then LSB (odd numbers) from DSP */ - while (data_size_inv != data_size) - { - while( (data_size_inv != data_size) && (*buffer_size != 0) ) - { - /* if data_size_inv is odd, we need the LSB of the DSP word */ - if (data_size_inv & 0x0001) - { - *(*ptr_buf)++ = (UWORD8)(temp_uword16 & 0x00FF); - } - /* if data_size_inv is even, we need the MSB of the DSP word */ - else - { - temp_uword16 = *(ptr_src)++; - *(*ptr_buf)++ = (UWORD8)(temp_uword16 >> 8); - } - data_size_inv++; - (*buffer_size)--; - } - // A new buffer is requested in order to finish to copy the data - if ( data_size_inv != data_size) - { - // Calculate the size of the data to request in 16-bit word - if ((data_size - data_size_inv) & 0x0001) - { - // The size is a odd value - requested_size = ((data_size - data_size_inv) >> 1) + 1; - } - else - { - // the size is an even value - requested_size = ((data_size - data_size_inv) >> 1); - } - - error_id = Cust_get_pointer((UWORD16 **)ptr_buf, &requested_size, session_id); - - // An error occured - if (error_id) - return(error_id); - - *buffer_size = (requested_size << 1); - } - } - - return(error_id); - } - #endif - - #if (L1_STEREOPATH == 1) && (CODE_VERSION == NOT_SIMULATION) - /*-------------------------------------------------------*/ - /* l1_audio_api_handler() */ - /*-------------------------------------------------------*/ - /* Parameters : */ - /* Return : */ - /* Functionality : API int management */ - /*-------------------------------------------------------*/ - void l1_audio_api_handler(void) - { - UWORD16 rootcause; - - if (l1a_l1s_com.stereopath_drv_task.parameters.feature_identifier == AUDIO_SP_TESTS_ID) - { - #if (TESTMODE && (OP_L1_STANDALONE == 1)) - rootcause = stp_drv_ndb->d_cport_api_dma_rootcause; - - l1tm_stereopath_DMA_handler((SYS_UWORD16) rootcause); - #endif - } - } /* l1_audio_api_handler() */ - #endif // (L1_STEREOPATH == 1) && (CODE_VERSION == NOT_SIMULATION) - - #if (L1_EXT_AUDIO_MGT == 1) - /*-------------------------------------------------------*/ - /* l1_ext_audio_mgt_dma_handler() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : dma_status */ - /* */ - /* Return : none */ - /* */ - /* Description : */ - /* This function is used to handle a DMA interrupt */ - /* that will notify to the external midi play process */ - /* that a new buffer is needed. */ - /* */ - /*-------------------------------------------------------*/ - void l1_ext_audio_mgt_dma_handler(SYS_UWORD16 dma_status) - { - NU_Activate_HISR(&EXT_AUDIO_MGT_hisr); // activate external MIDI HISR - } - #endif - - #if (L1_LIMITER == 1) - /*-------------------------------------------------------*/ - /* l1_audio_lim_update_mul_low_high() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : */ - /* ------------- */ - /* This function is used to update mul_low and mul_high */ - /* Limiter parameters in function to volume gain (Q15) */ - /* First the function read the last controlled volume */ - /* in the MCU/DSP API then it processed mul_low[0/1] */ - /* and mul_high[0/1] according to following equations: */ - /* */ - /* thr_low = - thr_low_slope x volume + thr_low_0 */ - /* thr_high = - thr_high_slope x volume + thr_high_0 */ - /* */ - /* mul_low[0] = 32767 / thr_low */ - /* mul_low[1] = 32767 x thr_low */ - /* mul_high[0] = 32767 / thr_high */ - /* mul_high[1] = 32767 x thr_high */ - /*-------------------------------------------------------*/ - void l1_audio_lim_update_mul_low_high() - { -#if (CODE_VERSION != SIMULATION) - #if (ANALOG == 3) - WORD16 volume_q15 = ABB_Read_DLGain(); - #endif - #if (ANALOG == 11) - WORD16 volume_q15 = (WORD16)(l1_audio_abb_Read_DLGain()); - #endif -#else - WORD16 volume_q15 = 0x4000; // -6 dB for example in simulation -#endif - WORD16 thr_low, thr_high; - - /* Process Thr_low */ - thr_low = (- (l1a_l1s_com.limiter_task.parameters.thr_low_slope * volume_q15)>>15) + - l1a_l1s_com.limiter_task.parameters.thr_low_0; -// if (thr_low > 32767) //OMAPS00090550 -// thr_low = 32767; - - /* Process Thr_high */ - thr_high = (- (l1a_l1s_com.limiter_task.parameters.thr_high_slope * volume_q15)>>15) + - l1a_l1s_com.limiter_task.parameters.thr_high_0; -// if (thr_high > 32767) //OMAPS00090550 -// thr_high = 32767; - - /* Process amd store mul_low[0/1] */ - if (thr_low != 0) - l1s_dsp_com.dsp_ndb_ptr->a_lim_mul_low[0] = 32767 / thr_low; // Q0 - else - l1s_dsp_com.dsp_ndb_ptr->a_lim_mul_low[0] = 32767; // should never happen - l1s_dsp_com.dsp_ndb_ptr->a_lim_mul_low[1] = thr_low; // Q15 - - /* Process and store mul_high[0/1] */ - if (thr_high != 0) - l1s_dsp_com.dsp_ndb_ptr->a_lim_mul_high[0] = 32767 / thr_high; // Q0 - else - l1s_dsp_com.dsp_ndb_ptr->a_lim_mul_high[0] = 32767; // should never happen - l1s_dsp_com.dsp_ndb_ptr->a_lim_mul_high[1] = thr_high; // Q15 - } - - /*-------------------------------------------------------*/ - /* l1_audio_lim_update_mul_low_high() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : */ - /* ------------- */ - /* This function MUST be called at each volume change in */ - /* order to request a limiter partial update. */ - /*-------------------------------------------------------*/ - void l1_audio_lim_partial_update() - { - // Set partial update command - l1a_l1s_com.limiter_task.command.partial_update = TRUE; - // Force L1S execution - l1a_l1s_com.time_to_next_l1s_task = 0; - } - #endif // L1_LIMITER == 1 - - - - #if (L1_AGC_UL == 1) - /*-------------------------------------------------------*/ - /* l1_audio_agc_ul_copy_params */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : */ - /* ------------- */ - /* This function is used to copy the AGC UL 1x parameter */ - /* to API memory using a pointer */ - /*-------------------------------------------------------*/ - - void l1_audio_agc_ul_copy_params() - { - - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_control = l1a_l1s_com.agc_ul_task.parameters.control; - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_frame_size = l1a_l1s_com.agc_ul_task.parameters.frame_size; - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_targeted_level = l1a_l1s_com.agc_ul_task.parameters.targeted_level; - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_signal_up = l1a_l1s_com.agc_ul_task.parameters.signal_up; - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_signal_down = l1a_l1s_com.agc_ul_task.parameters.signal_down; - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_max_scale = l1a_l1s_com.agc_ul_task.parameters.max_scale; - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_gain_smooth_alpha = l1a_l1s_com.agc_ul_task.parameters.gain_smooth_alpha; - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_gain_smooth_alpha_fast = l1a_l1s_com.agc_ul_task.parameters.gain_smooth_alpha_fast; - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_gain_smooth_beta = l1a_l1s_com.agc_ul_task.parameters.gain_smooth_beta; - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_gain_smooth_beta_fast = l1a_l1s_com.agc_ul_task.parameters.gain_smooth_beta_fast; - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_gain_intp_flag = l1a_l1s_com.agc_ul_task.parameters.gain_intp_flag; - - } - #endif - - #if (L1_AGC_DL == 1) - /*-------------------------------------------------------*/ - /* l1_audio_agc_dl_copy_params */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : */ - /* ------------- */ - /* This function is used to copy the AGC DL 1x parameter */ - /* to API memory using a pointer */ - /*-------------------------------------------------------*/ - - void l1_audio_agc_dl_copy_params() - { - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_control = l1a_l1s_com.agc_dl_task.parameters.control; - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_frame_size = l1a_l1s_com.agc_dl_task.parameters.frame_size; - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_targeted_level = l1a_l1s_com.agc_dl_task.parameters.targeted_level; - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_signal_up = l1a_l1s_com.agc_dl_task.parameters.signal_up; - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_signal_down = l1a_l1s_com.agc_dl_task.parameters.signal_down; - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_max_scale = l1a_l1s_com.agc_dl_task.parameters.max_scale; - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_gain_smooth_alpha = l1a_l1s_com.agc_dl_task.parameters.gain_smooth_alpha; - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_gain_smooth_alpha_fast = l1a_l1s_com.agc_dl_task.parameters.gain_smooth_alpha_fast; - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_gain_smooth_beta = l1a_l1s_com.agc_dl_task.parameters.gain_smooth_beta; - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_gain_smooth_beta_fast = l1a_l1s_com.agc_dl_task.parameters.gain_smooth_beta_fast; - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_gain_intp_flag = l1a_l1s_com.agc_dl_task.parameters.gain_intp_flag; - - } - #endif - - - #if (L1_IIR == 2) - /*-------------------------------------------------------*/ - /* l1_audio_iir4x_copy_params */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : */ - /* ------------- */ - /* This function is used to copy the IIR 4x parameter */ - /* to API memory using a pointer */ - /*-------------------------------------------------------*/ - - void l1_audio_iir4x_copy_params() - { - UWORD8 i; - UWORD8 j; - - // Set IIR parameters - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_control = l1a_l1s_com.iir_task.parameters->parameters.control; - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_frame_size = l1a_l1s_com.iir_task.parameters->parameters.frame_size; - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_fir_swap = l1a_l1s_com.iir_task.parameters->parameters.fir_swap; - - // Set parameter os FIR part - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_fir_enable = l1a_l1s_com.iir_task.parameters->parameters.fir_filter.fir_enable; - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_fir_length = l1a_l1s_com.iir_task.parameters->parameters.fir_filter.fir_length; - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_fir_shift = l1a_l1s_com.iir_task.parameters->parameters.fir_filter.fir_shift; - - for (i=0; i < (l1a_l1s_com.iir_task.parameters->parameters.fir_filter.fir_length); i++) - { - l1s_dsp_com.dsp_ndb_ptr->a_iir4x_fir_taps[i] = l1a_l1s_com.iir_task.parameters->parameters.fir_filter.fir_taps[i]; - } - - // Set parameters for IIR part - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_enable = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_enable; - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_number = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_number; - - // Set parameters for IIR part - SOS 1 - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_fact_1 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[0].sos_fact; - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_fact_form_1 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[0].sos_fact_form; - - for (j=0; j < IIR_4X_ORDER_OF_SECTION; j++) - { - l1s_dsp_com.dsp_ndb_ptr->a_iir4x_sos_den_1[j] = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[0].sos_den[j]; - } - for (j=0; j < (IIR_4X_ORDER_OF_SECTION + 1); j++) - { - l1s_dsp_com.dsp_ndb_ptr->a_iir4x_sos_num_1[j] = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[0].sos_num[j]; - } - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_num_form_1 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[0].sos_num_form; - - - // Set parameters for IIR part - SOS 2 - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_fact_2 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[1].sos_fact; - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_fact_form_2 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[1].sos_fact_form; - - for (j=0; j < IIR_4X_ORDER_OF_SECTION; j++) - { - l1s_dsp_com.dsp_ndb_ptr->a_iir4x_sos_den_2[j] = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[1].sos_den[j]; - } - for (j=0; j < (IIR_4X_ORDER_OF_SECTION + 1); j++) - { - l1s_dsp_com.dsp_ndb_ptr->a_iir4x_sos_num_2[j] = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[1].sos_num[j]; - } - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_num_form_2 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[1].sos_num_form; - - - // Set parameters for IIR part - SOS 3 - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_fact_3 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[2].sos_fact; - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_fact_form_3 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[2].sos_fact_form; - - for (j=0; j < IIR_4X_ORDER_OF_SECTION; j++) - { - l1s_dsp_com.dsp_ndb_ptr->a_iir4x_sos_den_3[j] = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[2].sos_den[j]; - } - for (j=0; j < (IIR_4X_ORDER_OF_SECTION + 1); j++) - { - l1s_dsp_com.dsp_ndb_ptr->a_iir4x_sos_num_3[j] = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[2].sos_num[j]; - } - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_num_form_3 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[2].sos_num_form; - - - // Set parameters for IIR part - SOS 4 - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_fact_4 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[3].sos_fact; - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_fact_form_4 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[3].sos_fact_form; - - for (j=0; j < IIR_4X_ORDER_OF_SECTION; j++) - { - l1s_dsp_com.dsp_ndb_ptr->a_iir4x_sos_den_4[j] = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[3].sos_den[j]; - } - for (j=0; j < (IIR_4X_ORDER_OF_SECTION + 1); j++) - { - l1s_dsp_com.dsp_ndb_ptr->a_iir4x_sos_num_4[j] = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[3].sos_num[j]; - } - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_num_form_4 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[3].sos_num_form; - - - // Set parameters for IIR part - SOS 5 - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_fact_5 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[4].sos_fact; - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_fact_form_5 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[4].sos_fact_form; - - for (j=0; j < IIR_4X_ORDER_OF_SECTION; j++) - { - l1s_dsp_com.dsp_ndb_ptr->a_iir4x_sos_den_5[j] = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[4].sos_den[j]; - } - for (j=0; j < (IIR_4X_ORDER_OF_SECTION + 1); j++) - { - l1s_dsp_com.dsp_ndb_ptr->a_iir4x_sos_num_5[j] = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[4].sos_num[j]; - } - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_num_form_5 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[4].sos_num_form; - - - // Set parameters for IIR part - SOS 6 - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_fact_6 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[5].sos_fact; - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_fact_form_6 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[5].sos_fact_form; - - for (j=0; j < IIR_4X_ORDER_OF_SECTION; j++) - { - l1s_dsp_com.dsp_ndb_ptr->a_iir4x_sos_den_6[j] = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[5].sos_den[j]; - } - for (j=0; j < (IIR_4X_ORDER_OF_SECTION + 1); j++) - { - l1s_dsp_com.dsp_ndb_ptr->a_iir4x_sos_num_6[j] = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[5].sos_num[j]; - } - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_sos_num_form_6 = l1a_l1s_com.iir_task.parameters->parameters.sos_filter.sos_filter[5].sos_num_form; - - - - l1s_dsp_com.dsp_ndb_ptr->d_iir4x_gain = l1a_l1s_com.iir_task.parameters->parameters.gain; - - } - - #endif // L1_IIR == 2 - - -#if (L1_DRC == 1) - /*-------------------------------------------------------*/ - /* l1_audio_drc1x_copy_params */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : */ - /* ------------- */ - /* This function is used to copy the DRC 1x parameter */ - /* to API memory using a pointer */ - /*-------------------------------------------------------*/ - - void l1_audio_drc1x_copy_params() - { - UWORD8 i; - - // Set DRC parameters - drc_ndb->d_drc_speech_mode_samp_f = l1a_l1s_com.drc_task.parameters->parameters.speech_mode_samp_f; - drc_ndb->d_drc_num_subbands = l1a_l1s_com.drc_task.parameters->parameters.num_subbands; - drc_ndb->d_drc_frame_len = l1a_l1s_com.drc_task.parameters->parameters.frame_len; - drc_ndb->d_drc_expansion_knee_fb_bs = l1a_l1s_com.drc_task.parameters->parameters.expansion_knee_fb_bs; - drc_ndb->d_drc_expansion_knee_md_hg = l1a_l1s_com.drc_task.parameters->parameters.expansion_knee_md_hg; - drc_ndb->d_drc_expansion_ratio_fb_bs = l1a_l1s_com.drc_task.parameters->parameters.expansion_ratio_fb_bs; - drc_ndb->d_drc_expansion_ratio_md_hg = l1a_l1s_com.drc_task.parameters->parameters.expansion_ratio_md_hg; - drc_ndb->d_drc_max_amplification_fb_bs = l1a_l1s_com.drc_task.parameters->parameters.max_amplification_fb_bs; - drc_ndb->d_drc_max_amplification_md_hg = l1a_l1s_com.drc_task.parameters->parameters.max_amplification_md_hg; - drc_ndb->d_drc_compression_knee_fb_bs = l1a_l1s_com.drc_task.parameters->parameters.compression_knee_fb_bs; - drc_ndb->d_drc_compression_knee_md_hg = l1a_l1s_com.drc_task.parameters->parameters.compression_knee_md_hg; - drc_ndb->d_drc_compression_ratio_fb_bs = l1a_l1s_com.drc_task.parameters->parameters.compression_ratio_fb_bs; - drc_ndb->d_drc_compression_ratio_md_hg = l1a_l1s_com.drc_task.parameters->parameters.compression_ratio_md_hg; - drc_ndb->d_drc_energy_limiting_th_fb_bs = l1a_l1s_com.drc_task.parameters->parameters.energy_limiting_th_fb_bs; - drc_ndb->d_drc_energy_limiting_th_md_hg = l1a_l1s_com.drc_task.parameters->parameters.energy_limiting_th_md_hg; - drc_ndb->d_drc_limiter_threshold_fb = l1a_l1s_com.drc_task.parameters->parameters.limiter_threshold_fb; - drc_ndb->d_drc_limiter_threshold_bs = l1a_l1s_com.drc_task.parameters->parameters.limiter_threshold_bs; - drc_ndb->d_drc_limiter_threshold_md = l1a_l1s_com.drc_task.parameters->parameters.limiter_threshold_md; - drc_ndb->d_drc_limiter_threshold_hg = l1a_l1s_com.drc_task.parameters->parameters.limiter_threshold_hg; - drc_ndb->d_drc_limiter_hangover_spect_preserve = l1a_l1s_com.drc_task.parameters->parameters.limiter_hangover_spect_preserve; - drc_ndb->d_drc_limiter_release_fb_bs = l1a_l1s_com.drc_task.parameters->parameters.limiter_release_fb_bs; - drc_ndb->d_drc_limiter_release_md_hg = l1a_l1s_com.drc_task.parameters->parameters.limiter_release_md_hg; - drc_ndb->d_drc_gain_track_fb_bs = l1a_l1s_com.drc_task.parameters->parameters.gain_track_fb_bs; - drc_ndb->d_drc_gain_track_md_hg = l1a_l1s_com.drc_task.parameters->parameters.gain_track_md_hg; - - for (i=0; i < DRC_LPF_LENGTH; i++) - { - drc_ndb->a_drc_low_pass_filter[i] = l1a_l1s_com.drc_task.parameters->parameters.low_pass_filter[i]; - } - for (i=0; i < DRC_BPF_LENGTH; i++) - { - drc_ndb->a_drc_mid_band_filter[i] = l1a_l1s_com.drc_task.parameters->parameters.mid_band_filter[i]; - } - - } - - #endif // L1_DRC == 1 - -#if(L1_BT_AUDIO == 1) -BOOL L1Audio_InformBtAudioPathState (BOOL connected) -{ - if(connected==bt_audio.connected_status) - return BT_STATUS_OK; - else - return BT_STATUS_ERROR; -} - -void L1Audio_RegisterBthal (L1AudioPcmCallback pcmCallback, L1AudioConfigureCallback configCallback) -{ - bt_audio.audio_configure_callback=configCallback; - bt_audio.audio_pcmblock_callback=pcmCallback; -} -UWORD8 bt_flag=1; - - -L1AudioPcmStatus L1Audio_PullPcmBlock (L1AudioPcmBlock *pcmBlock) -{ - UWORD8 status=0; - if(bt_flag == 0) - { - AUDIO_SEND_TRACE("pull back bef init",RV_TRACE_LEVEL_ERROR); - bt_audio.pcm_data_ready = 0; - // return L1_PCM_PENDING; - } -// AUDIO_SEND_TRACE("pull back called",RV_TRACE_LEVEL_ERROR); - - if(bt_audio.pcm_data_end == 1) - { - AUDIO_SEND_TRACE("abnormal BT request mp3/aac",RV_TRACE_LEVEL_ERROR); - - if(bt_audio.pcmblock.lengthInBytes==2*C_MP3_OUTPUT_BUFFER_SIZE) - l1mp3_dma_it_handler(0); - else if(bt_audio.pcmblock.lengthInBytes==2*C_AAC_OUTPUT_BUFFER_SIZE) - l1aac_dma_it_handler(0); - - bt_audio.pcm_data_end = 0; - bt_audio.pcm_data_ready = 0; - bt_flag = 0; - return L1_PCM_MEDIA_ENDED; - } - - - if(bt_audio.pcm_data_failed==0) - { - if(bt_audio.pcm_data_ready>0) - { - //AUDIO_SEND_TRACE("Data ready for BT-Pull event",RV_TRACE_LEVEL_ERROR); - pcmBlock->pcmBuffer= bt_audio.pcmblock.pcmBuffer; - pcmBlock->lengthInBytes=bt_audio.pcmblock.lengthInBytes; - - bt_audio.pcm_data_ready=0; - - if( bt_audio.pcm_data_end==1) - { - AUDIO_SEND_TRACE("Data ended for BT-Pull event",RV_TRACE_LEVEL_ERROR); - return L1_PCM_MEDIA_ENDED; - } - else - if(bt_audio.pcmblock.lengthInBytes==2*AUDIO_EXT_MIDI_BUFFER_SIZE) - return L1_PCM_READY; - else - status= L1_PCM_READY; - } - else - { - if( bt_audio.pcm_data_end==1) - { - AUDIO_SEND_TRACE("Data ended for BT-Pull event",RV_TRACE_LEVEL_ERROR); - return L1_PCM_MEDIA_ENDED; - } - // AUDIO_SEND_TRACE("Data pending for BT-Pull event",RV_TRACE_LEVEL_ERROR); - bt_audio.pcm_data_pending=1; - status= L1_PCM_PENDING; - } - } - else - { - AUDIO_SEND_TRACE("Data failed for BT-Pull event",RV_TRACE_LEVEL_ERROR); - return L1_PCM_FAILED; - } -if((bt_audio.pcmblock.lengthInBytes==2*C_MP3_OUTPUT_BUFFER_SIZE)&& bt_flag==1) -{ - if(l1a_apihisr_com.mp3.command.stop==TRUE) - { - bt_flag=0; - l1mp3_dma_it_handler(0); - bt_audio.pcm_data_end = 0; - return L1_PCM_MEDIA_ENDED; - } - else - l1mp3_dma_it_handler(0); - -} -else if(bt_audio.pcmblock.lengthInBytes==2*C_AAC_OUTPUT_BUFFER_SIZE&& bt_flag==1) -{ - if(l1a_apihisr_com.aac.command.stop==TRUE) - { - bt_flag=0; - AUDIO_SEND_TRACE("Media ended for BT-Pull event",RV_TRACE_LEVEL_ERROR); - l1aac_dma_it_handler(0); - bt_audio.pcm_data_end = 0; - return L1_PCM_MEDIA_ENDED; - } - else - l1aac_dma_it_handler(0); -} -else if(bt_audio.pcmblock.lengthInBytes==2*AUDIO_EXT_MIDI_BUFFER_SIZE && bt_flag==1) - if( bt_audio.pcm_data_end==1) - { - bt_flag=0; - return L1_PCM_MEDIA_ENDED; - } - else - l1a_bt_audio_noti_process(); -return status; - - -} - -void l1_audio_bt_init(UINT16 media_buf_size) -{ - bt_audio.pcm_data_pending =0; - bt_audio.pcm_data_end =0; - bt_audio.pcm_data_ready =1; - bt_audio.pcm_data_failed =0; - - bt_flag=1; - -if(media_buf_size==C_MP3_OUTPUT_BUFFER_SIZE) -{ - bt_audio.pcmblock.pcmBuffer=(UWORD8 *)&mp3_dma->a_mp3_dma_input_buffer[0][0]; - bt_audio.pcmblock.lengthInBytes=2*media_buf_size; -} -else if(media_buf_size==C_AAC_OUTPUT_BUFFER_SIZE) -{ - bt_audio.pcmblock.pcmBuffer=(UWORD8 *)&aac_dma->a_aac_dma_input_buffer[0][0]; - bt_audio.pcmblock.lengthInBytes=2*media_buf_size; -} -else if(media_buf_size==AUDIO_EXT_MIDI_BUFFER_SIZE) -{ - bt_audio.pcmblock.pcmBuffer=(UWORD8 *)&midi_buf.audio_play_buffer[0]; - bt_audio.pcmblock.lengthInBytes=2*media_buf_size; -} -} -#endif//L1_BT_AUDIO == 1 - -#if(L1_BT_AUDIO==1) ||(L1_WCM==1) -void l1_audio_manager(UWORD8 *src, UWORD16 size) -{ - UWORD16 i ; -#if(L1_BT_AUDIO==1) - bt_audio.pcmblock.pcmBuffer=src; - bt_audio.pcmblock.lengthInBytes=2*size; -#endif - - #if (OP_L1_STANDALONE == 0) - #if 0 - // l1_audio_wcm(src,size); - if( wcm_enable == 1) - { - switch(size) - { - case 2048: - - arm_wcm_module( AAC, (T_SINT16 *)src , &wcm_output[0]); - break; - case 1152: - - arm_wcm_module( MP3, (T_SINT16 *)src , &wcm_output[0]); - break; - - - } - - for (i=0 ; i< size ; i++) - while(size>0) - { - *src++=(API)*wcm_output++; - size--; - } - - /* for (i=0 ; i< size ; i++) - { - *src++ = (UINT8 )wcm_output[i]&0x00ff; - *src++ = (UINT8 )(wcm_output[i] & 0xff00) >> 8; - } - */ - - } - - - #endif - #endif - - #if(L1_BT_AUDIO==1) - if(bt_audio.connected_status==TRUE) - { - if(bt_audio.pcm_data_pending>0) - { - bt_audio.pcm_data_pending = 0; - AUDIO_SEND_TRACE("Pending callback",RV_TRACE_LEVEL_ERROR); - bt_audio.audio_pcmblock_callback(&bt_audio.pcmblock); - - } - else - bt_audio.pcm_data_ready = 1; - } - #endif -} -#endif - -UWORD16 l1_ext_audio_get_frequencyrate(UWORD16 frequency_index) -{ - UWORD16 sampling_frequency=0; - - switch(frequency_index) - { - case 1: - sampling_frequency=8000; - break; - case 2: - sampling_frequency=11025; - break; - case 3: - sampling_frequency=16000; - break; - case 4: - sampling_frequency=22050; - break; - case 5: - sampling_frequency=32000; - break; - case 6: - sampling_frequency=44100; - break; - case 7: - sampling_frequency=48000; - break; - } - - // Sampling frequency should never be zero - return sampling_frequency; -} -#endif // AUDIO_TASK
--- a/L1/audio_cfile/l1audio_stereo.c Fri Jun 10 06:07:27 2016 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,685 +0,0 @@ -/* - * l1audio_stereo.c - * - * Control audio - * - * Filename l1audio_stereo.c - * Copyright 2003 (C) Texas Instruments - * - * - */ - -#include "l1_macro.h" -#include "l1_confg.h" - -#define _L1AUDIO_STEREO_C_ - -#if (AUDIO_TASK == 1) - -#include "l1_types.h" -#include "sys_types.h" - -#if (CODE_VERSION == SIMULATION) && (AUDIO_SIMULATION) - - -#include <stdlib.h> -#include <string.h> - -#include "iq.h" // Debug / Init hardware ("eva3.lib") -#include "l1_ver.h" -#include "l1_const.h" -#include "l1_signa.h" - -#if TESTMODE -#include "l1tm_defty.h" -#endif - -#include "l1audio_const.h" -#include "l1audio_cust.h" -#include "l1audio_signa.h" -#include "l1audio_defty.h" -#include "l1audio_msgty.h" - -#if (L1_GTT == 1) -#include "l1gtt_const.h" -#include "l1gtt_defty.h" -#endif -//added here from e-sample for AAC -#if (L1_DYN_DSP_DWNLD == 1) -#include "l1_dyn_dwl_const.h" -#include "l1_dyn_dwl_defty.h" -#endif -#if (L1_MP3 == 1) -#include "l1mp3_defty.h" -#endif - -#if (L1_MIDI == 1) -#include "l1midi_defty.h" -#endif -//added here from e-sample for AAC -#if (L1_AAC == 1) -#include "l1aac_defty.h" -#endif - -#include "l1_defty.h" -#include "cust_os.h" -#include "l1_msgty.h" -#include "l1_varex.h" - -#include "l1_mftab.h" -#include "l1_tabs.h" -#include "l1_ctl.h" - -#include "l1_time.h" -#include "l1_scen.h" - -#if (L1_STEREOPATH == 1) -#include "sys_dma.h" -#include "sys_inth.h" -#include "abb.h" -#if TESTMODE -#include "l1tm_msgty.h" -#endif -#include "l1audio_stereo.h" -#endif - -#else -// Layer1 and debug include files. - -#include <ctype.h> -#include <math.h> -#include "l1_ver.h" -#include "l1_const.h" -#include "l1_signa.h" - -#if TESTMODE -#include "l1tm_defty.h" -#endif - -#include "l1audio_const.h" -#include "l1audio_cust.h" -#include "l1audio_signa.h" -#include "l1audio_defty.h" -#include "l1audio_msgty.h" - -#if (L1_GTT == 1) -#include "l1gtt_const.h" -#include "l1gtt_defty.h" -#endif -//added here from e-sample for AAC -#if (L1_DYN_DSP_DWNLD == 1) -#include "l1_dyn_dwl_const.h" -#include "l1_dyn_dwl_defty.h" -#endif -#if (L1_MP3 == 1) -#include "l1mp3_defty.h" -#endif - -#if (L1_MIDI == 1) -#include "l1midi_defty.h" -#endif -//added here from e-sample for AAC -#if (L1_AAC == 1) -#include "l1aac_defty.h" -#endif -#include "l1_defty.h" -#include "cust_os.h" -#include "l1_msgty.h" -#include "tpudrv.h" // TPU drivers. ("eva3.lib") -#include "l1_varex.h" - -#include "l1_proto.h" -#include "l1_mftab.h" -#include "l1_tabs.h" -#include "mem.h" -#include "armio.h" -#include "timer.h" -#include "timer1.h" -#include "dma.h" -#include "inth.h" -#include "ulpd.h" -#include "rhea_arm.h" -#include "clkm.h" // Clockm ("eva3.lib") -#include "l1_ctl.h" - -#include "l1_time.h" -#if L2_L3_SIMUL -#include "l1_scen.h" -#endif - -#if (L1_STEREOPATH == 1) -#include "sys_dma.h" -#include "sys_inth.h" -#include "abb.h" -#if TESTMODE -#include "l1tm_msgty.h" -#endif -#include "l1audio_stereo.h" -#endif - -#include "l1audio_abb.h" -#endif - -#include "l1audio_macro.h" - -//add the extern reference of abb_write_done -#if (ANALOG == 11) -#include "bspTwl3029_I2c.h" -#include "bspTwl3029_Aud_Map.h" -#endif - -#if (ANALOG == 11) -Bsp_Twl3029_I2cTransReqArray l1audio_i2cTransArray; -#endif - -#if (L1_STEREOPATH == 1) && (CODE_VERSION == NOT_SIMULATION) - -#if (ANALOG == 11) - #include "bspTwl3029_Int_Map.h" - - -//Add the call back function of the stereo path. -void l1s_stereopath_callback(UWORD8 cbvalue) -{ - BspTwl3029_ReturnCode returnVal = BSP_TWL3029_RETURN_CODE_FAILURE; - UWORD16 count = 0; - UINT8 triton_classD = 0; - - /* callback function info pointer */ - BspTwl3029_I2C_Callback i2c_callback; - BspTwl3029_I2C_CallbackPtr callbackPtr= &i2c_callback; - - /* I2C array */ - Bsp_Twl3029_I2cTransReqArray i2cTransArray; - Bsp_Twl3029_I2cTransReqArrayPtr i2cTransArrayPtr= &i2cTransArray; - - /* twl3029 I2C reg info struct */ - BspTwl3029_I2C_RegisterInfo regInfo[10] ; - BspTwl3029_I2C_RegisterInfo* regInfoPtr = regInfo; - - BspTwl3029_I2C_RegData tmpAudioHFTest1RegData=0; - BspTwl3029_I2C_RegData tmpCtrl3RegData=0; - - bspTwl3029_Audio_getClassD_mode(&triton_classD); - - //Set the valud of abb_write_done to 1 - l1s.abb_write_done = 1; - switch(cbvalue) - { - case L1S_TWL3029_STEROPATH_START: - { - l1a_l1s_com.outen_cfg_task.command_commited = l1a_l1s_com.outen_cfg_task.command_requested; - - returnVal = BspTwl3029_I2c_shadowRegRead(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_AUDIO_CTRL3_OFFSET, - &tmpCtrl3RegData); - returnVal = BspTwl3029_I2c_shadowRegRead(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_AUDIO_HFTEST1_OFFSET, - &tmpAudioHFTest1RegData); - - returnVal = BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN1_OFFSET, - l1a_l1s_com.outen_cfg_task.outen1, regInfoPtr++); - count++; - - returnVal = BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN2_OFFSET, - l1a_l1s_com.outen_cfg_task.outen2, regInfoPtr++); - count++; - - if(l1a_l1s_com.outen_cfg_task.classD == 0x01) // User wants to configure classD - { - if(triton_classD == 0x00) // User wants to switch on and Triton not configured for classD - { - returnVal= BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_CKG_TESTUNLOCK_OFFSET, - 0xb6, regInfoPtr++); - count++; - - returnVal= BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN3_OFFSET, - l1a_l1s_com.outen_cfg_task.outen3, regInfoPtr++); - count++; - - tmpCtrl3RegData |= 0x80; // AUDIO_CTRL3_SPKDIGON - tmpAudioHFTest1RegData = 0x01; // AUDIO_HFTEST1_SPKALLZB - - BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_AUDIO_CTRL3_OFFSET, - tmpCtrl3RegData, regInfoPtr++); - count++; - - BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_AUDIO_HFTEST1_OFFSET, - tmpAudioHFTest1RegData, regInfoPtr++); - count++; - } - } - else if(l1a_l1s_com.outen_cfg_task.classD == 0x00) - { - if(triton_classD != 0x00) // User wants no to classD and Triton configured for classD - { - tmpCtrl3RegData &= 0x7F; // AUDIO_CTRL3_SPKDIGON - tmpAudioHFTest1RegData = 0x00; // AUDIO_HFTEST1_SPKALLZB - - BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_AUDIO_HFTEST1_OFFSET, - tmpAudioHFTest1RegData, regInfoPtr++); - count++; - - BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_AUDIO_CTRL3_OFFSET, - tmpCtrl3RegData, regInfoPtr++); - count++; - - returnVal= BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN3_OFFSET, - l1a_l1s_com.outen_cfg_task.outen3, regInfoPtr++); - count++; - - BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_CKG_TESTUNLOCK_OFFSET, - 0x00, regInfoPtr++); - count++; - } - else // User no classD & Triton also no classD - { - returnVal= BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN3_OFFSET, - l1a_l1s_com.outen_cfg_task.outen3, regInfoPtr++); - count++; - returnVal = BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN2_OFFSET, - l1a_l1s_com.outen_cfg_task.outen2, regInfoPtr++); - count++; - returnVal= BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN3_OFFSET, - l1a_l1s_com.outen_cfg_task.outen3, regInfoPtr++); - count++; - } - } - /*Switch OFF all pop modes unconditionally , it is turned on before turning on STON*/ - returnVal=BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_POPMAN_OFFSET, 0x00,regInfoPtr++); - count++; - - callbackPtr->callbackFunc = l1s_stereopath_callback; - callbackPtr->callbackVal = L1S_TWL3029_STEROPATH_OUTEN_CONFIG; - - if (returnVal != BSP_TWL3029_RETURN_CODE_FAILURE) - { - regInfoPtr = regInfo; - /* now request to I2C manager to write to Triton registers */ - - returnVal = BspTwl3029_I2c_regInfoSend(regInfo,count,callbackPtr, - (BspI2c_TransactionRequest*)i2cTransArrayPtr); - } - break; - } - case L1S_TWL3029_STEROPATH_CONFIG: - case L1S_TWL3029_STEROPATH_OUTEN_CONFIG: - case L1S_TWL3029_STEROPATH_STOP: - break; - default: - break; - }/* end switch */ -} /* end function l1s_stereopath_callback */ - -#endif - -/*-------------------------------------------------------*/ -/* l1s_stereopath_drv_config_ABB() */ -/*-------------------------------------------------------*/ -/* */ -/* Parameters : mono_stereo: indicates if buffer is made */ -/* of mono or stereo samples */ -/* sampling_frequency: sampling freq */ -/* */ -/* Return : none */ -/* */ -/* Description : ABB configuration function */ -/* */ -/*-------------------------------------------------------*/ -void l1s_stereopath_drv_config_ABB(UWORD8 mono_stereo,UWORD8 sampling_frequency) -{ -#if (ANALOG == 3) - UWORD16 regist; - - // Get the VAUDCTRL register - regist = l1s_dsp_com.dsp_ndb_ptr->d_vaud_cfg >> 6; - - // reset sampling frequency and stereo/mono conversion - regist &= 0x319; - - // stereo/mono conversion ? - if (mono_stereo == AUDIO_SP_MONO_OUTPUT) - regist |= 6; - - // apply the request sampling frequency - regist |= (sampling_frequency << 5); - - // update DSP API - l1s_dsp_com.dsp_ndb_ptr->d_vaud_cfg = ABB_L1_WRITE(VAUDCTRL, regist); - - // Get the VBCTRL2 register - regist = l1s_dsp_com.dsp_ndb_ptr->d_vbctrl2 >> 6; - // activate HSOVMID and VMIDFBYP - regist |= 0x90; - l1s_dsp_com.dsp_ndb_ptr->d_vbctrl2 = ABB_L1_WRITE(VBCTRL2, regist); - - // Get the VAUDPLL register - regist = l1s_dsp_com.dsp_ndb_ptr->d_vaud_pll >> 6; - // reset PLL - regist &= 0x3fd; - // switch PLL on - regist |= 0x2; - - // update DSP API - l1s_dsp_com.dsp_ndb_ptr->d_vaud_pll = ABB_L1_WRITE(VAUDPLL, regist); - - // Get the VBPOP register - regist = l1s_dsp_com.dsp_ndb_ptr->d_vbpop >> 6; - // deactivate vbpop for HSO - regist &= 0x3F8; - - // update DSP API - l1s_dsp_com.dsp_ndb_ptr->d_vbpop = ABB_L1_WRITE(VBPOP, regist); - -#endif - -#if (ANALOG == 11) - // Call to the Triton API which would configure the Audio path. - UWORD8 monostereo; - UWORD8 pll; - //Call back function - BspTwl3029_I2C_Callback stereo_callbackFunc; - - //Switch on the Stereo path PLL - Set the STPLLON to 1 - pll = 0x02; - //Check if stereo2mono is required - if (mono_stereo == AUDIO_SP_MONO_OUTPUT) - monostereo = 0x03; - else - monostereo = 0x00; - - //Set the call back function to be called after the Audio configuration - stereo_callbackFunc.callbackFunc = l1s_stereopath_callback ; - //stereo_callbackFunc.callbackVal = L1S_TWL3029_STEROPATH_CONFIG; - stereo_callbackFunc.callbackVal = L1S_TWL3029_STEROPATH_START; - stereo_callbackFunc.i2cTransArrayPtr = &l1audio_i2cTransArray; - - //Call the Triton audio path configuration function - if(BSP_TWL3029_RETURN_CODE_SUCCESS == bspTwl3029_Audio_Configure_Stereopath(&stereo_callbackFunc, - pll, - monostereo, - sampling_frequency )) - { - //Set the valud of abb_write_done to 1 - l1s.abb_write_done = 1; - } - -#endif -} - - -/*-------------------------------------------------------*/ -/* l1s_stereopath_drv_start_ABB() */ -/*-------------------------------------------------------*/ -/* */ -/* Parameters : none */ -/* */ -/* Return : none */ -/* */ -/* Description : ABB start function */ -/* */ -/*-------------------------------------------------------*/ -void l1s_stereopath_drv_start_ABB(void) -{ -#if (ANALOG == 3) - // Get VAUDPLL register - UWORD16 regist = l1s_dsp_com.dsp_ndb_ptr->d_vaud_pll >> 6; - - // Reset I2S - regist &= 0x2ff; - // I2S on - regist |= 0x100; - - // update DSP API - l1s_dsp_com.dsp_ndb_ptr->d_vaud_pll = ABB_L1_WRITE(VAUDPLL, regist); - - // Set AUDON bit of the PWRDNRG register - regist = 0x100; - // update DSP API - l1s_dsp_com.dsp_ndb_ptr->d_togbr2 = ABB_L1_WRITE(TOGBR2, regist); -#endif -#if (ANALOG == 11) - //Call back function - BspTwl3029_I2C_Callback stereo_callbackFunc; - //Set the call back function to be called after the Audio start - stereo_callbackFunc.callbackFunc = l1s_stereopath_callback ; - stereo_callbackFunc.callbackVal = L1S_TWL3029_STEROPATH_CONFIG; - stereo_callbackFunc.i2cTransArrayPtr = &l1audio_i2cTransArray; - - //call the Triton audio path start function - if (BSP_TWL3029_RETURN_CODE_SUCCESS == bspTwl3029_Audio_Start_Stereopath(&stereo_callbackFunc)) - { - l1s.abb_write_done = 1; - }; -#endif - -} - -/*-------------------------------------------------------*/ -/* l1s_stereopath_drv_stop_ABB() */ -/*-------------------------------------------------------*/ -/* */ -/* Parameters : none */ -/* */ -/* Return : none */ -/* */ -/* Description : ABB stop function */ -/* */ -/*-------------------------------------------------------*/ -void l1s_stereopath_drv_stop_ABB(void) -{ -#if (ANALOG == 3) - UWORD16 regist; - - // Reset AUDON bit of the PWRDNRG register - regist = 0x80; - // update DSP API - l1s_dsp_com.dsp_ndb_ptr->d_togbr2 = ABB_L1_WRITE(TOGBR2, regist); - - // Get VAUDPLL register - regist = l1s_dsp_com.dsp_ndb_ptr->d_vaud_pll >> 6; - // PLL/I2S off - regist &= 0x2fd; - ABB_Write_Register_on_page(PAGE1, VAUDPLL, regist); - // update DSP API - l1s_dsp_com.dsp_ndb_ptr->d_vaud_pll = ABB_L1_WRITE(VAUDPLL, regist); -#endif -#if (ANALOG == 11) - //Call back function - BspTwl3029_I2C_Callback stereo_callbackFunc; - - UWORD8 dl_control = 1; // OUTEN_DISABLE - - // Set the call back function to be called after the Audio start - stereo_callbackFunc.callbackFunc = l1s_stereopath_callback ; - stereo_callbackFunc.callbackVal = L1S_TWL3029_STEROPATH_STOP; - stereo_callbackFunc.i2cTransArrayPtr = &l1audio_i2cTransArray; - - if( (l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE] == L1_AUDIO_DL_ON) || - (l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE] == L1_AUDIO_DL_SWITCHON_STARTED)) - { - dl_control = 0; // OUTEN_ENABLE - } - - //call the Triton audio path start function - if (BSP_TWL3029_RETURN_CODE_SUCCESS == bspTwl3029_Audio_Stop_Stereopath(&stereo_callbackFunc, dl_control)) - { - l1s.abb_write_done = 1; - }; -#endif -} - - -/*-------------------------------------------------------*/ -/* l1s_stereopath_drv_start_DMA() */ -/*-------------------------------------------------------*/ -/* */ -/* Parameters : d_dma_channel_parameter: DMA parameters */ -/* DMA_allocation: allocation of the DMA */ -/* (MCU/DSP) */ -/* */ -/* Return : none */ -/* */ -/* Description : DMA config and start function */ -/* */ -/*-------------------------------------------------------*/ -void l1s_stereopath_drv_start_DMA(T_DMA_TYPE_CHANNEL_PARAMETER d_dma_channel_parameter,UWORD8 DMA_allocation) -{ -#if ((CHIPSET == 12) || (CHIPSET == 15)) -#if (L1_MP3_SIX_BUFFER == 1) - // allocate the DMA to the MCU - f_dma_channel_allocation_set(d_dma_channel_parameter.d_dma_channel_number, C_DMA_CHANNEL_ARM); - - // set parameters - f_dma_channel_parameter_set((T_DMA_TYPE_CHANNEL_PARAMETER *)&d_dma_channel_parameter); -#else - // set parameters - f_dma_channel_parameter_set((T_DMA_TYPE_CHANNEL_PARAMETER *)&d_dma_channel_parameter); - - // allocate the DMA to the MCU - f_dma_channel_allocation_set(d_dma_channel_parameter.d_dma_channel_number, C_DMA_CHANNEL_ARM); - -#endif - // Enable the DMA channel - f_dma_channel_enable(d_dma_channel_parameter.d_dma_channel_number); - - - // DMA allocation ? - if (DMA_allocation == AUDIO_SP_DMA_ALLOC_MCU) - { - // DMA is allocate to MCU, just unmask DMA IT - F_INTH_ENABLE_ONE_IT(C_INTH_DMA_IT); - } - else - { - // DMA is allocate to DSP, unmask API IT - F_INTH_ENABLE_ONE_IT(C_INTH_API_IT); - - // Re-allocate DMA to the DSP - f_dma_channel_allocation_set(d_dma_channel_parameter.d_dma_channel_number, C_DMA_CHANNEL_DSP); - } -#endif -} - -/*-------------------------------------------------------*/ -/* l1s_stereopath_drv_reset_DMA() */ -/*-------------------------------------------------------*/ -/* */ -/* Parameters : d_dma_channel_parameter: DMA parameters */ -/* */ -/* Return : none */ -/* */ -/* Description : DMA reset function */ -/* */ -/*-------------------------------------------------------*/ -void l1s_stereopath_drv_reset_DMA(T_DMA_TYPE_CHANNEL_PARAMETER d_dma_channel_parameter) -{ -#if ((CHIPSET == 12) || (CHIPSET == 15)) - // Allocate DMA to MCU - f_dma_channel_allocation_set(d_dma_channel_parameter.d_dma_channel_number, C_DMA_CHANNEL_ARM); - - // Disable DMA channel - f_dma_channel_disable(d_dma_channel_parameter.d_dma_channel_number); - - // Reset DMA channel - f_dma_channel_soft_reset(d_dma_channel_parameter.d_dma_channel_number); -#endif -} - - -/*-------------------------------------------------------*/ -/* l1s_stereopath_drv_reset_CPORT() */ -/*-------------------------------------------------------*/ -/* */ -/* Parameters : none */ -/* */ -/* Return : none */ -/* */ -/* Description : Cport reset function */ -/* */ -/*-------------------------------------------------------*/ -void l1s_stereopath_drv_reset_CPORT(void) -{ -#if ((CHIPSET == 12) || (CHIPSET == 15)) - // init = 1 --> write ctrl register - l1s_dsp_com.dsp_ndb_ptr->d_cport_init = (API) 0x0001; - // set SW_RESET field to 1 to generate a software reset - l1s_dsp_com.dsp_ndb_ptr->d_cport_ctrl = (API) 0x0FFD; -#endif -} - -/*-------------------------------------------------------*/ -/* l1s_stereopath_drv_stop_CPORT() */ -/*-------------------------------------------------------*/ -/* */ -/* Parameters : none */ -/* */ -/* Return : none */ -/* */ -/* Description : Cport stop function */ -/* */ -/*-------------------------------------------------------*/ -void l1s_stereopath_drv_stop_CPORT(void) -{ -#if (CHIPSET == 12) || (CHIPSET == 15) - // init = 1 --> write ctrl register - l1s_dsp_com.dsp_ndb_ptr->d_cport_init = (API) 0x0001; - // Set EXT_MCLK_EN field to 1 to enable external clock - l1s_dsp_com.dsp_ndb_ptr->d_cport_ctrl = (API) 0x0000; -#endif -} - - -/*-------------------------------------------------------*/ -/* l1s_stereopath_drv_config_CPORT() */ -/*-------------------------------------------------------*/ -/* */ -/* Parameters : none */ -/* */ -/* Return : none */ -/* */ -/* Description : Cport config function */ -/* */ -/*-------------------------------------------------------*/ -void l1s_stereopath_drv_config_CPORT(void) -{ -#if (CHIPSET == 12) || (CHIPSET == 15) - // init = 0x281F --> write cfr1,2,3,4 and ctrl register - l1s_dsp_com.dsp_ndb_ptr->d_cport_init = (API) 0x281F; - // 2 timeslots per frame, I2S mode - // 20 CLK_BIT cycles, 16 data bits per time slot - l1s_dsp_com.dsp_ndb_ptr->a_cport_cfr[0] = (API) 0x0C0B; - // one cycle delay, enable data serial output - // CSYNC signal generate with the negative edge of CSCLK - // clk direction set to input - // l1s_dsp_com.dsp_ndb_ptr->a_cport_cfr[1] = (API) 0xEB00; - l1s_dsp_com.dsp_ndb_ptr->a_cport_cfr[1] = (API) 0xFB00; // L1_DSP-SPR-18866 - // mask receive/transmit interrupt request - // Set threshold to 2 (nb of elements = 2) - l1s_dsp_com.dsp_ndb_ptr->d_cport_ctrl = (API) 0x012C; -#endif -} - - -/*-------------------------------------------------------*/ -/* l1s_stereopath_drv_start_CPORT() */ -/*-------------------------------------------------------*/ -/* */ -/* Parameters : none */ -/* */ -/* Return : none */ -/* */ -/* Description : Cport start function */ -/* */ -/*-------------------------------------------------------*/ -void l1s_stereopath_drv_start_CPORT(void) -{ -#if (CHIPSET == 12) || (CHIPSET == 15) - // init = 0x20 --> write tcl_tadt register - l1s_dsp_com.dsp_ndb_ptr->d_cport_init = (API) 0x0020; - // CPEN = 1 --> cport enable - l1s_dsp_com.dsp_ndb_ptr->d_cport_tcl_tadt = (API) 0x0800; -#endif -} - -#endif // L1_STEREOPATH && CODE_VERSION - -#endif // AUDIO_TASK
--- a/L1/audio_cfile/l1audio_sync.c Fri Jun 10 06:07:27 2016 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,8085 +0,0 @@ -/************* Revision Controle System Header ************* - * GSM Layer 1 software - * L1AUDIO_SYNC.C - * - * Filename l1audio_sync.c - * Copyright 2003 (C) Texas Instruments - * - ************* Revision Controle System Header *************/ - -/************************************/ -/* Include files... */ -/************************************/ -#include "l1_macro.h" -#include "l1_confg.h" - -#if (AUDIO_TASK == 1) - - #include "l1_types.h" - #include "sys_types.h" - - #if (CODE_VERSION == SIMULATION) && (AUDIO_SIMULATION) - - #include <stdlib.h> - #include <string.h> - - #include "iq.h" // Debug / Init hardware ("eva3.lib") - #include "l1_ver.h" - #include "l1_const.h" - #include "l1_signa.h" - - #if TESTMODE - #include "l1tm_defty.h" - #endif - - #include "l1audio_const.h" - #include "l1audio_cust.h" - #include "l1audio_signa.h" - #include "l1audio_defty.h" - #include "l1audio_msgty.h" - - #if (L1_GTT == 1) - #include "l1gtt_const.h" - #include "l1gtt_defty.h" - #endif - - #if (L1_MP3 == 1) - #include "l1mp3_const.h" - #include "l1mp3_defty.h" - #endif - - #if (L1_MIDI == 1) - #include "l1midi_const.h" - #include "l1midi_defty.h" - #endif - - #if (L1_AAC == 1) - #include "l1aac_const.h" - #include "l1aac_defty.h" - #endif - #include "l1_defty.h" - #include "cust_os.h" - #include "l1_msgty.h" - #include "l1_varex.h" - - #include "l1_mftab.h" - #include "l1_tabs.h" - #include "l1_ctl.h" - - #include "l1_time.h" - #include "l1_scen.h" - - #if (L1_STEREOPATH == 1) - #include "sys_dma.h" - #include "abb.h" - #if TESTMODE - #include "l1tm_msgty.h" - #endif - #include "l1audio_stereo.h" - #endif - - #include "mem.h" - - #else - // Layer1 and debug include files. - - #include <ctype.h> - #include <math.h> - #include "l1_ver.h" - #include "l1_const.h" - #include "l1_signa.h" - - #if TESTMODE - #include "l1tm_defty.h" - #endif - - #include "l1audio_const.h" - #include "l1audio_cust.h" - #include "l1audio_signa.h" - #include "l1audio_defty.h" - #include "l1audio_msgty.h" - - #if (L1_GTT == 1) - #include "l1gtt_const.h" - #include "l1gtt_defty.h" - #endif - - #if (L1_MP3 == 1) - #include "l1mp3_const.h" - #include "l1mp3_defty.h" - #endif - - #if (L1_MIDI == 1) - #include "l1midi_const.h" - #include "l1midi_defty.h" - #endif - - #if (L1_AAC == 1) - #include "l1aac_const.h" - #include "l1aac_defty.h" - #endif - - #include "l1_defty.h" - #include "cust_os.h" - #include "l1_msgty.h" - #include "tpudrv.h" // TPU drivers. ("eva3.lib") - #include "l1_varex.h" - - #include "l1_proto.h" - #include "l1_mftab.h" - #include "l1_tabs.h" - #include "mem.h" - #include "armio.h" - #include "timer.h" - #include "timer1.h" - #include "dma.h" - #include "inth.h" - #include "ulpd.h" - #include "rhea_arm.h" - #include "clkm.h" // Clockm ("eva3.lib") - #include "l1_ctl.h" - - #include "l1_time.h" - #if L2_L3_SIMUL - #include "l1_scen.h" - #endif - - #if (L1_STEREOPATH == 1) - #include "sys_dma.h" - #include "abb.h" - #if TESTMODE - #include "l1tm_msgty.h" - #endif - #include "l1audio_stereo.h" - #endif - - #include "mem.h" - - #endif - - #include "l1audio_macro.h" - #include "l1_trace.h" - #if (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 */ - /**************************************/ - void l1s_audio_manager(void); - #if (KEYBEEP) - void l1s_keybeep_manager(void); - #endif - #if (TONE) - void l1s_tone_manager(void); - #endif - #if (L1_CPORT == 1) - void l1s_cport_manager(void); - #endif - #if (MELODY_E1) - void l1s_melody0_manager(void); - void l1s_melody1_manager(void); - #endif - #if (VOICE_MEMO) - void l1s_vm_play_manager (void); - void l1s_vm_record_manager(void); - void l1s_tone_ul_manager (void); - #endif - #if (L1_PCM_EXTRACTION) - void l1s_pcm_download_manager (void); - void l1s_pcm_upload_manager (void); - #endif - #if (L1_VOICE_MEMO_AMR) - void l1s_vm_amr_play_manager (void); - void l1s_vm_amr_record_manager(void); - #endif - #if (SPEECH_RECO) - void l1s_sr_enroll_manager (void); - void l1s_sr_update_manager (void); - void l1s_sr_reco_manager (void); - void l1s_sr_processing_manager(void); - void l1s_sr_speech_manager (void); - #endif - #if (L1_AEC == 1) - void l1s_aec_manager (void); - #endif - #if (L1_AEC == 2) - void l1s_aec_manager (void); - #endif - #if (FIR) - void l1s_fir_manager (void); - void l1s_fir_set_params (void); - - #endif - #if (AUDIO_MODE) - void l1s_audio_mode_manager (void); - #endif - #if (MELODY_E2) - void l1s_melody0_e2_manager(void); - void l1s_melody1_e2_manager(void); - #endif - #if (L1_MP3 == 1) - void l1s_mp3_manager(void); - #endif - #if (L1_MIDI == 1) - void l1s_midi_manager(void); - #endif - #if (L1_AAC == 1) - void l1s_aac_manager(void); - #endif - #if (L1_EXTERNAL_AUDIO_VOICE_ONOFF == 1) - void l1s_audio_onoff_manager(void); - #endif - #if (L1_EXT_MCU_AUDIO_VOICE_ONOFF == 1) - void l1s_audio_voice_onoff_manager(void); - #endif - #if (L1_STEREOPATH == 1) - void l1s_stereopath_drv_manager(void); - #endif - #if (L1_ANR == 1 || L1_ANR == 2) - void l1s_anr_manager(void); - #endif - #if (L1_IIR == 1 || L1_IIR == 2) - void l1s_iir_manager(void); - #endif - #if (L1_WCM == 1) - void l1s_wcm_manager(void); - #endif - #if (L1_AGC_UL == 1) - void l1s_agc_ul_manager(void); - #endif - #if (L1_AGC_DL == 1) - void l1s_agc_dl_manager(void); - #endif - #if (L1_DRC == 1) - void l1s_drc_manager(void); - #endif - #if (L1_LIMITER == 1) - void l1s_limiter_manager(void); - #endif - #if (L1_ES == 1) - void l1s_es_manager(void); - #endif - - void l1s_audio_it_manager(void); - /**************************************/ - /* External prototypes */ - /**************************************/ - extern UWORD8 copy_data_from_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD16 **ptr_buf, UWORD16 data_size, API *ptr_dst); - extern UWORD8 copy_data_to_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD16 **ptr_buf, UWORD16 data_size, API *ptr_src); - extern UWORD8 Cust_get_pointer (UWORD16 **ptr, UWORD16 *buffer_size, UWORD8 session_id); - #if (MELODY_E2) - extern UWORD16 audio_twentyms_to_TDMA_convertion (UWORD16 twentyms_value); - #endif - #if (MELODY_E2) || (L1_VOICE_MEMO_AMR) - extern UWORD8 copy_byte_data_from_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, UWORD8 *ptr_dst); - extern UWORD8 copy_byte_data_to_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, UWORD8 *ptr_src); - #endif - #if (L1_VOICE_MEMO_AMR) - extern UWORD8 copy_byte_data_le_from_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, API *ptr_dst); - extern UWORD8 copy_byte_data_le_to_buffer (UWORD8 session_id, UWORD16 *buffer_size, UWORD8 **ptr_buf, UWORD16 data_size, API *ptr_src); - #endif - - #if (L1_LIMITER == 1) - void l1_audio_lim_update_mul_low_high (); - #endif - - #if (L1_AGC_UL == 1) - extern void l1_audio_agc_ul_copy_params(); - #endif - - #if (L1_AGC_DL == 1) - extern void l1_audio_agc_dl_copy_params(); - #endif - - #if (L1_IIR == 2) - extern void l1_audio_iir4x_copy_params(); - #endif - -#if (L1_DRC == 1) - extern void l1_audio_drc1x_copy_params(); - #endif - - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - static void l1s_audio_ul_onoff_manager(); - static void l1s_audio_dl_onoff_manager(); - - void l1_audio_abb_ul_on_callback(void); - void l1_audio_abb_ul_off_callback(void); - void l1_audio_abb_dl_on_callback(void); - void l1_audio_abb_dl_off_callback(void); - void l1_audio_abb_ul_off_dl_off_callback(void); - void l1_audio_abb_ul_off_dl_on_callback(void); - void l1_audio_abb_ul_on_dl_off_callback(void); - void l1_audio_abb_ul_on_dl_on_callback(void); - void l1_audio_ul_onoff_trace(); - void l1_audio_dl_onoff_trace(); -#if (CODE_VERSION != SIMULATION) - BspTwl3029_ReturnCode l1_outen_update(void); -#endif - -#if (CODE_VERSION == SIMULATION) - signed char l1_outen_update(void); -#endif -#endif // L1_AUDIO_MCU_ONOFF - -#if (CODE_VERSION == SIMULATION)&&(L1_AUDIO_MCU_ONOFF == 1) - -// Triton Audio ON/OFF Changes -void l1_audio_abb_ul_on_req ( void(*callback_fn)(void) ); -void l1_audio_abb_dl_on_req ( void(*callback_fn)(void) ); -void l1_audio_abb_ul_off_req ( void(*callback_fn)(void) ); -void l1_audio_abb_dl_off_req ( void(*callback_fn)(void) ); -void l1_audio_abb_ul_off_dl_off_req ( void(*callback_fn)(void) ); -void l1_audio_abb_ul_off_dl_on_req ( void(*callback_fn)(void) ); -void l1_audio_abb_ul_on_dl_off_req ( void(*callback_fn)(void) ); -void l1_audio_abb_ul_on_dl_on_req ( void(*callback_fn)(void) ); - - -#endif - -#if (ANALOG == 11) -//sundi: add the abb_write_done variable for I2C write acknowledgement -//UWORD8 abb_write_done = 0; -#endif - - /*-------------------------------------------------------*/ - /* l1s_audio_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Global manager of the L1S audio task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_audio_manager(void) - { - BOOL l1_audio_it_com = FALSE; - - // Initialize the ITCOM for audio task - l1s.l1_audio_it_com = FALSE; - - #if (KEYBEEP) - // the keybeep task is activated? - if ((l1a_l1s_com.keybeep_task.command.start) || - (l1s.audio_state[L1S_KEYBEEP_STATE] != 0)) - { - l1s_keybeep_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (TONE) - // the tone task is activated? - if ((l1a_l1s_com.tone_task.command.start) || - (l1s.audio_state[L1S_TONE_STATE] != 0)) - { - l1s_tone_manager(); - l1_audio_it_com = TRUE; - } - #endif - - #if (MELODY_E1) - // the melody0 task is activated? - if ((l1a_l1s_com.melody0_task.command.start) || - (l1s.audio_state[L1S_MELODY0_STATE] != 0)) - { - l1s_melody0_manager(); - l1_audio_it_com = TRUE; - } - // the melody1 task is activated? - if ((l1a_l1s_com.melody1_task.command.start) || - (l1s.audio_state[L1S_MELODY1_STATE] != 0)) - { - l1s_melody1_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (VOICE_MEMO) - // the voicememo playing task is activated? - if ((l1a_l1s_com.voicememo_task.play.command.start) || - (l1s.audio_state[L1S_VM_PLAY_STATE] != 0)) - { - l1s_vm_play_manager(); - l1_audio_it_com = TRUE; - } - else // voicememo playing task and voice memo recoding task isn't compatible - { - // the voicememo recording task is activated? - if ((l1a_l1s_com.voicememo_task.record.command.start) || - (l1s.audio_state[L1S_VM_RECORD_STATE] != 0)) - { - l1s_vm_record_manager(); - l1_audio_it_com = TRUE; - } - // the voicememo tone uplink task is activated? - if ((l1a_l1s_com.voicememo_task.record.tone_ul.start) || - (l1s.audio_state[L1S_TONE_UL_STATE] != 0)) - { - l1s_tone_ul_manager(); - l1_audio_it_com = TRUE; - } - } - #endif - #if (L1_PCM_EXTRACTION) - // the PCM download task is activated? - if ((l1a_l1s_com.pcm_task.download.command.start) || - (l1s.audio_state[L1S_PCM_DOWNLOAD_STATE] != 0)) - { - l1s_pcm_download_manager(); - l1_audio_it_com = TRUE; - } - // the PCM upload task is activated? - if ((l1a_l1s_com.pcm_task.upload.command.start) || - (l1s.audio_state[L1S_PCM_UPLOAD_STATE] != 0)) - { - l1s_pcm_upload_manager(); - l1_audio_it_com = TRUE; - } - #endif /* L1_PCM_EXTRACTION */ - #if (L1_VOICE_MEMO_AMR) - // the voicememo playing task is activated? - if ((l1a_l1s_com.voicememo_amr_task.play.command.start) || - (l1s.audio_state[L1S_VM_AMR_PLAY_STATE] != 0)) - { - l1s_vm_amr_play_manager(); - l1_audio_it_com = TRUE; - } - else // voicememo playing task and voice memo recoding task isn't compatible - { - // the voicememo recording task is activated? - if ((l1a_l1s_com.voicememo_amr_task.record.command.start) || - (l1s.audio_state[L1S_VM_AMR_RECORD_STATE] != 0)) - { - l1s_vm_amr_record_manager(); - l1_audio_it_com = TRUE; - } - } - #endif - #if (SPEECH_RECO) - // the speech recognition enroll task is activated? - if ((l1a_l1s_com.speechreco_task.command.enroll_start) || - (l1s.audio_state[L1S_SR_ENROLL_STATE] != 0)) - { - l1s_sr_enroll_manager(); - l1_audio_it_com = TRUE; - } - else - // the speech recognition update task is activated? - if ((l1a_l1s_com.speechreco_task.command.update_start) || - (l1s.audio_state[L1S_SR_UPDATE_STATE] != 0)) - { - l1s_sr_update_manager(); - l1_audio_it_com = TRUE; - } - else - // the speech recognition reco task is activated? - if ((l1a_l1s_com.speechreco_task.command.reco_start) || - (l1s.audio_state[L1S_SR_RECO_STATE] != 0)) - { - l1s_sr_reco_manager(); - l1_audio_it_com = TRUE; - } - else - // the speech recognition processing task is activated? - if ((l1a_l1s_com.speechreco_task.command.processing_start) || - (l1s.audio_state[L1S_SR_PROCESSING_STATE] != 0)) - { - l1s_sr_processing_manager(); - l1_audio_it_com = TRUE; - } - // the speech recognition speech recording task is activated? - if ((l1a_l1s_com.speechreco_task.command.speech_start) || - (l1s.audio_state[L1S_SR_SPEECH_STATE] != 0)) - { - l1s_sr_speech_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (L1_AEC == 1) - // the AEC is activated? - if ((l1a_l1s_com.aec_task.command.start) || - (l1s.audio_state[L1S_AEC_STATE] != 0)) - { - l1s_aec_manager(); - // It's not necessary to enable the IT DSP because the - // AEC works with the dedicated speech therefor an IT DSP is - // already requested by the modem - } - #endif - #if (L1_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; - } - #endif - #if (FIR) - // the FIR is activated? -if ((l1a_l1s_com.fir_task.command.start) || - (l1s.audio_state[L1S_FIR_STATE] !=0 )) - { - l1s_fir_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (AUDIO_MODE) - // the AUDIO MODE is activated? - if (l1a_l1s_com.audio_mode_task.command.start) - { - l1s_audio_mode_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (MELODY_E2) - // Handling counters - if (l1s.melody_e2.dsp_task == TRUE) - { - l1s.melody_e2.timebase++; - l1s.melody_e2.timebase_mod_60ms++; - if (l1s.melody_e2.timebase_mod_60ms == 13) - l1s.melody_e2.timebase_mod_60ms = 0; - } - else - { - l1s.melody_e2.timebase = 0; - l1s.melody_e2.timebase_mod_60ms = 0; - } - - // Update the oscillator active fields with DSP active oscillators - l1s.melody_e2.global_osc_active = l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_osc_active; - l1s.melody_e2.global_osc_to_start = 0; - - // oscillator active fields can't be updated until dsp has acknowledged new notes - if (l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_semaphore == 0) - { - l1s.melody0_e2.oscillator_active &= l1s.melody_e2.global_osc_active; - l1s.melody1_e2.oscillator_active &= l1s.melody_e2.global_osc_active; - } - - // Both states machines are inactive => Start or Stop DSP module - if ( (l1s.audio_state[L1S_MELODY0_E2_STATE] == 0) && - (l1s.audio_state[L1S_MELODY1_E2_STATE] == 0) ) - { - // Start command + DSP module not running => Start DSP module - if( ((l1a_l1s_com.melody0_e2_task.command.start) || - (l1a_l1s_com.melody1_e2_task.command.start)) && - (l1s.melody_e2.dsp_task == FALSE) ) - { - // Set the bit TONE to do the init only at the first start - // of the first melody (in case of 2 melodies) - // Select the melody E2 instead of E1 or tones - l1s_dsp_com.dsp_ndb_ptr->d_melody_selection = MELODY_E2_SELECTED; - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= (B_MELO | B_TONE); - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_deltatime = 0; - - // set delta_time as non valid - l1s.melody0_e2.delta_time = 0xFFFF; - l1s.melody1_e2.delta_time = 0xFFFF; - - // Set the flag to confirm that the DSP melody E2 task is started - l1s.melody_e2.dsp_task = TRUE; - } - // No command, DSP module running => Stop DSP module - else - if (l1s.melody_e2.dsp_task) - { - // The 2 melodies are stopped therefore the DSP must be - // stopped so the bit B_MELO must be reset. - l1s_dsp_com.dsp_ndb_ptr->d_melody_selection = MELODY_E2_SELECTED; - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= (B_MELO | B_TONE); - - // Reset the flag to know if the DSP melody E2 task runs - l1s.melody_e2.dsp_task = FALSE; - - l1_audio_it_com = TRUE; - } - } - - // the melody0 task is activated? - if ( (l1a_l1s_com.melody0_e2_task.command.start) || - (l1s.audio_state[L1S_MELODY0_E2_STATE] != 0) ) - { - l1s_melody0_e2_manager(); - l1_audio_it_com = TRUE; - } - // the melody0 task is activated? - if ( (l1a_l1s_com.melody1_e2_task.command.start) || - (l1s.audio_state[L1S_MELODY1_E2_STATE] != 0) ) - { - l1s_melody1_e2_manager(); - l1_audio_it_com = TRUE; - } - - // We updated some oscillators so we must set the semaphore - if (l1s.melody_e2.global_osc_to_start != 0x0000) - { - // Set the melody E2 semaphore - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_semaphore = 0x0001; - - // Update delta_time by min_delta_time(melo0, melo1) - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_deltatime = l1s.melody0_e2.delta_time; - if (l1s.melody1_e2.delta_time < l1s.melody0_e2.delta_time) - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_deltatime = l1s.melody1_e2.delta_time; - - l1s.melody0_e2.delta_time = 0xFFFF; - l1s.melody1_e2.delta_time = 0xFFFF; - } - #endif - - #if (L1_MP3 == 1) - if ((l1a_l1s_com.mp3_task.command.start) || - (l1s.audio_state[L1S_MP3_STATE] != 0)) - { - l1s_mp3_manager(); - l1_audio_it_com=TRUE; - } - #endif // L1_MP3 - - #if (L1_AAC == 1) - if ((l1a_l1s_com.aac_task.command.start) || - (l1s.audio_state[L1S_AAC_STATE] != 0)) - { - l1s_aac_manager(); - l1_audio_it_com=TRUE; - } - #endif // L1_AAC - #if (L1_CPORT == 1) - // the Cport task is activated? - if ((l1a_l1s_com.cport_task.command.start) || - (l1s.audio_state[L1S_CPORT_STATE] != 0)) - { - l1s_cport_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (L1_EXTERNAL_AUDIO_VOICE_ONOFF == 1) - // the audio on off task is activated? - if (l1a_l1s_com.audio_onoff_task.command.start || - (l1s.audio_state[L1S_AUDIO_ONOFF_STATE] != 0)) - { - l1s_audio_onoff_manager(); - l1_audio_it_com = TRUE; - } - #endif - - #if (L1_EXT_MCU_AUDIO_VOICE_ONOFF == 1) - // the audio on off task is activated? - if (l1a_l1s_com.audio_onoff_task.command.start || - (l1s.audio_state[L1S_AUDIO_ONOFF_STATE] != 0)) - { - l1s_audio_voice_onoff_manager(); - l1_audio_it_com = TRUE; - } - #endif - - #if (L1_STEREOPATH == 1) - // the Stereopath task is activated? - if ((l1a_l1s_com.stereopath_drv_task.command.start) || - (l1s.audio_state[L1S_STEREOPATH_DRV_STATE] != 0)) - { - l1s_stereopath_drv_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (L1_ANR == 1 || L1_ANR == 2) - // the ANR task is activated? - if (l1a_l1s_com.anr_task.command.update || - (l1s.audio_state[L1S_ANR_STATE] != 0)) - { - l1s_anr_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (L1_IIR == 1 || L1_IIR == 2) - // the IIR task is activated? - if (l1a_l1s_com.iir_task.command.update || - (l1s.audio_state[L1S_IIR_STATE] != 0)) - { - l1s_iir_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (L1_WCM == 1) - // the WCM task is activated? - if (l1a_l1s_com.wcm_task.command.update || - (l1s.audio_state[L1S_WCM_STATE] != 0)) - { - l1s_wcm_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (L1_DRC == 1) - // the DRC task is activated? - if (l1a_l1s_com.drc_task.command.update || - (l1s.audio_state[L1S_DRC_STATE] != 0)) - { - l1s_drc_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (L1_AGC_UL == 1) - // the AGC UL task is activated? - if (l1a_l1s_com.agc_ul_task.command.update || - (l1s.audio_state[L1S_AGC_UL_STATE] != 0)) - { - l1s_agc_ul_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (L1_AGC_DL == 1) - // the AGC DL task is activated? - if (l1a_l1s_com.agc_dl_task.command.update || - (l1s.audio_state[L1S_AGC_DL_STATE] != 0)) - { - l1s_agc_dl_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (L1_LIMITER == 1) - // the LIMITER task is activated? - if (l1a_l1s_com.limiter_task.command.update || - l1a_l1s_com.limiter_task.command.partial_update || - (l1s.audio_state[L1S_LIMITER_STATE] != 0)) - { - l1s_limiter_manager(); - l1_audio_it_com = TRUE; - } - #endif - #if (L1_ES == 1) - // the echo suppressor task is activated? - if (l1a_l1s_com.es_task.command.update || - (l1s.audio_state[L1S_ES_STATE] != 0)) - { - l1s_es_manager(); - l1_audio_it_com = TRUE; - } - #endif - - // the audio It task is activated? - if (l1a_l1s_com.audioIt_task.command.start) - { - l1s_audio_it_manager(); - l1_audio_it_com = TRUE; - } - - #if (L1_MIDI == 1) - if ((l1a_l1s_com.midi_task.command.start) || - (l1s.audio_state[L1S_MIDI_STATE] != 0)) - { - l1s_midi_manager(); - l1_audio_it_com=TRUE; - } - #endif // L1_MIDI - - // 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; - - l1s.l1_audio_it_com = l1_audio_it_com; - } - - -#if (L1_AUDIO_MCU_ONOFF == 1) - void l1s_audio_onoff_manager(void) - { - T_L1S_AUDIO_ONOFF_MANAGER *onoff_ctl = &(l1s.audio_on_off_ctl); - - //l1_audio_onoff_entry_sim_log(); -#if (AUDIO_DEBUG == 1) - trace_info.audio_debug_var.ul_state = l1s.audio_state[L1S_AUDIO_UL_ONOFF_STATE]; - trace_info.audio_debug_var.dl_state = l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE]; - trace_info.audio_debug_var.ul_onoff_counter = onoff_ctl->l1_audio_switch_on_ul_request; - trace_info.audio_debug_var.dl_onoff_counter = onoff_ctl->l1_audio_switch_on_dl_request; -#endif - - l1s_audio_ul_onoff_manager(); - l1s_audio_dl_onoff_manager(); - - // Call the driver depending on the actions - switch(onoff_ctl->l1_audio_ul_action) - { - case L1_AUDIO_NO_ACTION: - { - switch(onoff_ctl->l1_audio_dl_action) - { - case L1_AUDIO_NO_ACTION: - { - // UL No Action and DL No Action Do nothing - } - break; - case L1_AUDIO_TURN_ON: - { - // UL No Action and DL Turn on - l1_audio_abb_dl_on_req(l1_audio_abb_dl_on_callback); - } - break; - case L1_AUDIO_TURN_OFF: - { - // UL No Action and DL Turn off - l1_audio_abb_dl_off_req(l1_audio_abb_dl_off_callback); - } - break; - default: - { - // Invalid Action send error trace here - } - break; - } // end switch(l1_audio_dl_action) - } - break; - case L1_AUDIO_TURN_ON: - { - switch(onoff_ctl->l1_audio_dl_action) - { - case L1_AUDIO_NO_ACTION: - { - // UL Action ON and DL No Action - l1_audio_abb_ul_on_req(l1_audio_abb_ul_on_callback); - } - break; - case L1_AUDIO_TURN_ON: - { - // UL Action ON and DL Action ON - l1_audio_abb_ul_on_dl_on_req(l1_audio_abb_ul_on_dl_on_callback); - } - break; - case L1_AUDIO_TURN_OFF: - { - // UL Action ON and DL Action OFF - l1_audio_abb_ul_on_dl_off_req(l1_audio_abb_ul_on_dl_off_callback); - } - break; - default: - { - // Invalid Action Send error trace here - } - break; - } // end switch(l1_audio_dl_action) - - } - break; - case L1_AUDIO_TURN_OFF: - { - switch(onoff_ctl->l1_audio_dl_action) - { - case L1_AUDIO_NO_ACTION: - { - // UL Action OFF DL No Action - l1_audio_abb_ul_off_req(l1_audio_abb_ul_off_callback); - } - break; - case L1_AUDIO_TURN_ON: - { - // UL Action OFF DL Action ON - l1_audio_abb_ul_off_dl_on_req(l1_audio_abb_ul_off_dl_on_callback); - } - break; - case L1_AUDIO_TURN_OFF: - { - // UL Action OFF DL Action OFF - l1_audio_abb_ul_off_dl_off_req(l1_audio_abb_ul_off_dl_off_callback); - } - break; - default: - { - } - break; - } // end switch(l1_audio_dl_action) - - } - break; - default: - { - // Invalid Action send error trace here - } - break; - } // end switch(l1_audio_ul_action) - - } // end l1s_audio_triton_onoff_manager() - - static void l1s_audio_ul_onoff_manager() - { - - T_L1S_AUDIO_ONOFF_MANAGER *onoff_ctl = &(l1s.audio_on_off_ctl); - UWORD8 *state = &l1s.audio_state[L1S_AUDIO_UL_ONOFF_STATE]; - - onoff_ctl->l1_audio_ul_action = L1_AUDIO_NO_ACTION; - - - if(onoff_ctl->l1_audio_switch_on_ul_request >= 1) - { - // At least one module requires UL audio path to be on - switch(*state) - { - case L1_AUDIO_UL_OFF: - { - // UL audio path is OFF and needs to be started - onoff_ctl->l1_audio_ul_on2off_hold_time = - L1_AUDIO_ON2OFF_UL_HOLD_TIME; - onoff_ctl->l1_audio_ul_action = L1_AUDIO_TURN_ON; - *state = L1_AUDIO_UL_SWITCHON_STARTED; - onoff_ctl->l1_audio_ul_switched_on = FALSE; - onoff_ctl->l1_audio_ul_switched_off = TRUE; - } - break; - case L1_AUDIO_UL_SWITCHON_STARTED: - { - // UL audio path in the process of turning on - // Check if it is turned on, if so change state to UL on - if(onoff_ctl->l1_audio_ul_switched_on == TRUE) - { - onoff_ctl->l1_audio_ul_switched_off = FALSE; - *state = L1_AUDIO_UL_ON; - } - #if(CODE_VERSION == NOT_SIMULATION) - l1s.l1_audio_it_com = TRUE; - #endif - } - break; - case L1_AUDIO_UL_ON: - { - // UL audio path is on and some module wants it to be so - // Do nothing essentially except initialize the hold time - onoff_ctl->l1_audio_ul_on2off_hold_time = - L1_AUDIO_ON2OFF_UL_HOLD_TIME; - #if(CODE_VERSION == NOT_SIMULATION) - l1s.l1_audio_it_com = TRUE; - #endif - } - break; - case L1_AUDIO_UL_SWITCHOFF_STARTED: - { - // UL is being switched off and some module requests switch on! - // Since the driver is required to maintain the order of requests - // we perform the same actions as in the UL_OFF state - onoff_ctl->l1_audio_ul_on2off_hold_time = - L1_AUDIO_ON2OFF_UL_HOLD_TIME; - onoff_ctl->l1_audio_ul_action = L1_AUDIO_TURN_ON; - *state = L1_AUDIO_UL_SWITCHON_STARTED; - onoff_ctl->l1_audio_ul_switched_on = FALSE; - onoff_ctl->l1_audio_ul_switched_off = TRUE; - #if(CODE_VERSION == NOT_SIMULATION) - l1s.l1_audio_it_com = TRUE; - #endif - } - break; - default: - { - // Invalid state put error trace here - } - break; - } // end switch(l1_audio_ul_state) - - } // end if(l1_audio_switch_on_ul_req >= 1) - else - { - // No module requires UL Audio path to be on - switch(*state) - { - case L1_AUDIO_UL_OFF: - { - // UL audio path is off and all modules want it that way, do nothing - } - break; - case L1_AUDIO_UL_SWITCHON_STARTED: - { - // UL audio path being switched on. Modules want it turned off! - // Allow UL to be turned on, still if modules want it turned off - // we will wait for ON2OFF hold time and turn it off - if(onoff_ctl->l1_audio_ul_switched_on == TRUE) - { - onoff_ctl->l1_audio_ul_switched_off = FALSE; - *state = L1_AUDIO_UL_ON; - } - #if(CODE_VERSION == NOT_SIMULATION) - l1s.l1_audio_it_com = TRUE; - #endif - } - break; - case L1_AUDIO_UL_ON: - { - // UL audio path is on and all modules want turn off. We wait - // for the ON2OFF hold time and then actually turn it off - if(onoff_ctl->l1_audio_ul_on2off_hold_time == 0) - { - onoff_ctl->l1_audio_ul_action = L1_AUDIO_TURN_OFF; - *state = L1_AUDIO_UL_SWITCHOFF_STARTED; - onoff_ctl->l1_audio_ul_switched_off = FALSE; - onoff_ctl->l1_audio_ul_switched_on = TRUE; - } - else - onoff_ctl->l1_audio_ul_on2off_hold_time--; - #if(CODE_VERSION == NOT_SIMULATION) - l1s.l1_audio_it_com = TRUE; - #endif - } - break; - case L1_AUDIO_UL_SWITCHOFF_STARTED: - { - if(onoff_ctl->l1_audio_ul_switched_off == TRUE) - { - *state = L1_AUDIO_UL_OFF; - } - #if(CODE_VERSION == NOT_SIMULATION) - l1s.l1_audio_it_com = TRUE; - #endif - } - break; - default: - { - // Invalid state send error trace here - } - break; - } // end switch(l1_audio_ul_state) - - } // end if(l1_audio_switch_on_ul_req >= 1)else - -#if (CODE_VERSION == SIMULATION) - l1_audio_ul_onoff_simu_trace(); -#else - l1_audio_ul_onoff_trace(); -#endif - - } // end l1s_audio_ul_onoff_manager() - - static void l1s_audio_dl_onoff_manager() - { - - T_L1S_AUDIO_ONOFF_MANAGER *onoff_ctl = &(l1s.audio_on_off_ctl); - UWORD8 *state = &l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE]; - - onoff_ctl->l1_audio_dl_action = L1_AUDIO_NO_ACTION; - - - if(onoff_ctl->l1_audio_switch_on_dl_request >= 1) - { - // At least one module requires DL audio path to be on - switch(*state) - { - case L1_AUDIO_DL_OFF: - { - // DL audio path is OFF and needs to be started - onoff_ctl->l1_audio_dl_on2off_hold_time = - L1_AUDIO_ON2OFF_DL_HOLD_TIME; - onoff_ctl->l1_audio_dl_action = L1_AUDIO_TURN_ON; - *state = L1_AUDIO_DL_SWITCHON_STARTED; - onoff_ctl->l1_audio_dl_switched_on = FALSE; - onoff_ctl->l1_audio_dl_switched_off = TRUE; - } - break; - case L1_AUDIO_DL_SWITCHON_STARTED: - { - // DL audio path in the process of turning on - // Check if it is turned on, if so change state to DL on - if(onoff_ctl->l1_audio_dl_switched_on == TRUE) - { - onoff_ctl->l1_audio_dl_switched_off = FALSE; - *state = L1_AUDIO_DL_ON; - } - #if(CODE_VERSION == NOT_SIMULATION) - l1s.l1_audio_it_com = TRUE; - #endif - } - break; - case L1_AUDIO_DL_ON: - { - - /* OUTEN registers have been updated */ - if(l1a_l1s_com.outen_cfg_task.command_requested != l1a_l1s_com.outen_cfg_task.command_commited) - { - #if (CODE_VERSION != SIMULATION) - l1_outen_update(); - #endif - } - // DL audio path is on and some module wants it to be so - // Do nothing essentially except initialize the hold time - onoff_ctl->l1_audio_dl_on2off_hold_time = - L1_AUDIO_ON2OFF_DL_HOLD_TIME; - #if(CODE_VERSION == NOT_SIMULATION) - l1s.l1_audio_it_com = TRUE; - #endif - } - break; - case L1_AUDIO_DL_SWITCHOFF_STARTED: - { - // DL is being switched off and some module requests switch on! - // Since the driver is required to maintain the order of requests - // we perform the same actions as in the DL_OFF state - onoff_ctl->l1_audio_dl_on2off_hold_time = - L1_AUDIO_ON2OFF_DL_HOLD_TIME; - onoff_ctl->l1_audio_dl_action = L1_AUDIO_TURN_ON; - *state = L1_AUDIO_DL_SWITCHON_STARTED; - onoff_ctl->l1_audio_dl_switched_on = FALSE; - onoff_ctl->l1_audio_dl_switched_off = TRUE; - - #if(CODE_VERSION == NOT_SIMULATION) - l1s.l1_audio_it_com = TRUE; - #endif - } - break; - default: - { - // Invalid state put error trace here - } - break; - } // end switch(l1_audio_dl_state) - - } // end if(l1_audio_switch_on_dl_req >= 1) - else - { - // No module requires DL Audio path to be on - switch(*state) - { - case L1_AUDIO_DL_OFF: - { - // DL audio path is off and all modules want it that way, do nothing - } - break; - case L1_AUDIO_DL_SWITCHON_STARTED: - { - // DL audio path being switched on. Modules want it turned off! - // Allow DL to be turned on, still if modules want it turned off - // we will wait for ON2OFF hold time and turn it off - if(onoff_ctl->l1_audio_dl_switched_on == TRUE) - { - onoff_ctl->l1_audio_dl_switched_off = FALSE; - *state = L1_AUDIO_DL_ON; - } - #if(CODE_VERSION == NOT_SIMULATION) - l1s.l1_audio_it_com = TRUE; - #endif - } - break; - case L1_AUDIO_DL_ON: - { - // DL audio path is on and all modules want turn off. We wait - // for the ON2OFF hold time and then actually turn it off - if(onoff_ctl->l1_audio_dl_on2off_hold_time == 0) - { - onoff_ctl->l1_audio_dl_action = L1_AUDIO_TURN_OFF; - *state = L1_AUDIO_DL_SWITCHOFF_STARTED; - onoff_ctl->l1_audio_dl_switched_off = FALSE; - onoff_ctl->l1_audio_dl_switched_on = TRUE; - } - else - onoff_ctl->l1_audio_dl_on2off_hold_time--; - - #if(CODE_VERSION == NOT_SIMULATION) - l1s.l1_audio_it_com = TRUE; - #endif - } - break; - case L1_AUDIO_DL_SWITCHOFF_STARTED: - { - if(onoff_ctl->l1_audio_dl_switched_off == TRUE) - { - *state = L1_AUDIO_DL_OFF; - } - #if(CODE_VERSION == NOT_SIMULATION) - l1s.l1_audio_it_com = TRUE; - #endif - } - break; - default: - { - // Invalid state send error trace here - } - break; - } // end switch(l1_audio_dl_state) - - } // end if(l1_audio_switch_on_dl_req >= 1)else - -#if (CODE_VERSION == SIMULATION) - l1_audio_dl_onoff_simu_trace(); -#else - l1_audio_dl_onoff_trace(); -#endif - - - } // end l1s_audio_dl_onoff_manager() - -#if (CODE_VERSION == NOT_SIMULATION) -void l1_audio_ul_onoff_trace() -{ - static T_L1_AUDIO_UL_STATE prev_state = L1_INVALID; - UWORD8 *curr_state = &l1s.audio_state[L1S_AUDIO_UL_ONOFF_STATE]; - - if(*curr_state != prev_state) - { - prev_state =(T_L1_AUDIO_UL_STATE) *curr_state; - switch(prev_state) - { - case L1_AUDIO_UL_OFF: - { - //L1_trace_string("UL AUDIO OFF\r\n"); - l1_trace_ul_audio_onoff(L1_AUDIO_UL_OFF); - } - break; - case L1_AUDIO_UL_SWITCHON_STARTED: - { - l1_trace_ul_audio_onoff(L1_AUDIO_UL_SWITCHON_STARTED); - } - break; - case L1_AUDIO_UL_ON: - { - l1_trace_ul_audio_onoff(L1_AUDIO_UL_ON); - } - break; - case L1_AUDIO_UL_SWITCHOFF_STARTED: - { - l1_trace_ul_audio_onoff(L1_AUDIO_UL_SWITCHOFF_STARTED); - } - break; - - } // End switch(prev_state) - } // end if(l1s.ul_state == prev_state) - -} - -void l1_audio_dl_onoff_trace() -{ - static T_L1_AUDIO_DL_STATE prev_state = L1_DL_INVALID; - UWORD8 *curr_state = &l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE]; - - if(*curr_state != prev_state) - { - prev_state = (T_L1_AUDIO_DL_STATE) *curr_state; - switch(prev_state) - { - case L1_AUDIO_DL_OFF: - { - l1_trace_dl_audio_onoff(L1_AUDIO_DL_OFF); - } - break; - case L1_AUDIO_DL_SWITCHON_STARTED: - { - l1_trace_dl_audio_onoff(L1_AUDIO_DL_SWITCHON_STARTED); - } - break; - case L1_AUDIO_DL_ON: - { - l1_trace_dl_audio_onoff(L1_AUDIO_DL_ON); - } - break; - case L1_AUDIO_DL_SWITCHOFF_STARTED: - { - l1_trace_dl_audio_onoff(L1_AUDIO_DL_SWITCHOFF_STARTED); - } - break; - - } // End switch(prev_state) - } // end if(l1s.ul_state == prev_state) -} - -#endif // CODE_VERSION == NOT_SIMULATION - - void l1_audio_abb_ul_on_callback(void) - { - l1s.audio_on_off_ctl.l1_audio_ul_switched_on = TRUE; - } - void l1_audio_abb_ul_off_callback(void) - { - l1s.audio_on_off_ctl.l1_audio_ul_switched_off = TRUE; - } - void l1_audio_abb_dl_on_callback(void) - { - l1_outen_update(); - } - void l1_audio_abb_dl_off_callback(void) - { - l1s.audio_on_off_ctl.l1_audio_dl_switched_off = TRUE; - } - void l1_audio_abb_ul_off_dl_off_callback(void) - { - l1s.audio_on_off_ctl.l1_audio_ul_switched_off = TRUE; - l1s.audio_on_off_ctl.l1_audio_dl_switched_off = TRUE; - } - void l1_audio_abb_ul_off_dl_on_callback(void) - { - l1s.audio_on_off_ctl.l1_audio_ul_switched_off = TRUE; - l1_outen_update(); - } - void l1_audio_abb_ul_on_dl_off_callback(void) - { - l1s.audio_on_off_ctl.l1_audio_ul_switched_on = TRUE; - l1s.audio_on_off_ctl.l1_audio_dl_switched_off = TRUE; - } - void l1_audio_abb_ul_on_dl_on_callback(void) - { - l1s.audio_on_off_ctl.l1_audio_ul_switched_on = TRUE; - - l1_outen_update(); - } - - void l1_audio_abb_outen_cfg_callback(UWORD8 argument) - { - (void)(argument); - l1s.audio_on_off_ctl.l1_audio_dl_switched_on = TRUE; - } -#if (CODE_VERSION != SIMULATION) - -BspTwl3029_ReturnCode l1_outen_update(void) -{ - BspTwl3029_ReturnCode returnVal = BSP_TWL3029_RETURN_CODE_FAILURE; - UWORD16 count = 0; - UINT8 triton_classD = 0; - - /* callback function info pointer */ - BspTwl3029_I2C_Callback i2c_callback; - BspTwl3029_I2C_CallbackPtr callbackPtr= &i2c_callback; - - /* I2C array */ - Bsp_Twl3029_I2cTransReqArray i2cTransArray; - Bsp_Twl3029_I2cTransReqArrayPtr i2cTransArrayPtr= &i2cTransArray; - - /* twl3029 I2C reg info struct */ - BspTwl3029_I2C_RegisterInfo regInfo[11] ; - BspTwl3029_I2C_RegisterInfo* regInfoPtr = regInfo; - - BspTwl3029_I2C_RegData tmpAudioHFTest1RegData=0; - BspTwl3029_I2C_RegData tmpCtrl3RegData=0; - - - l1a_l1s_com.outen_cfg_task.command_requested = l1a_l1s_com.outen_cfg_task.command_commited; - - bspTwl3029_Audio_getClassD_mode(&triton_classD); - - returnVal = BspTwl3029_I2c_shadowRegRead(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_AUDIO_CTRL3_OFFSET, - &tmpCtrl3RegData); - returnVal = BspTwl3029_I2c_shadowRegRead(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_AUDIO_HFTEST1_OFFSET, - &tmpAudioHFTest1RegData); - - returnVal = BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN1_OFFSET, - l1a_l1s_com.outen_cfg_task.outen1, regInfoPtr++); - count++; - - returnVal = BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN2_OFFSET, - l1a_l1s_com.outen_cfg_task.outen2, regInfoPtr++); - count++; - - if(l1a_l1s_com.outen_cfg_task.classD == 0x01) // User wants to configure classD - { - if(triton_classD == 0x00) // User wants to switch on and Triton not configured for classD - { - - BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_CKG_TESTUNLOCK_OFFSET, - 0xb6, regInfoPtr++); - count++; - - - returnVal= BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN3_OFFSET, - l1a_l1s_com.outen_cfg_task.outen3, regInfoPtr++); - count++; - - tmpCtrl3RegData |= 0x80; // AUDIO_CTRL3_SPKDIGON - tmpAudioHFTest1RegData = 0x01; // AUDIO_HFTEST1_SPKALLZB - - BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_AUDIO_CTRL3_OFFSET, - tmpCtrl3RegData, regInfoPtr++); - count++; - - BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_AUDIO_HFTEST1_OFFSET, - tmpAudioHFTest1RegData, regInfoPtr++); - count++; - } - } - else if(l1a_l1s_com.outen_cfg_task.classD == 0x00) - { - if(triton_classD != 0x00) // User wants no to classD and Triton configured for classD - { - tmpCtrl3RegData &= 0x7F; // AUDIO_CTRL3_SPKDIGON - tmpAudioHFTest1RegData = 0x00; // AUDIO_HFTEST1_SPKALLZB - - BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_AUDIO_HFTEST1_OFFSET, - tmpAudioHFTest1RegData, regInfoPtr++); - count++; - - BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_AUDIO_CTRL3_OFFSET, - tmpCtrl3RegData, regInfoPtr++); - count++; - - returnVal= BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN3_OFFSET, - l1a_l1s_com.outen_cfg_task.outen3, regInfoPtr++); - count++; - - BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD, BSP_TWL_3029_MAP_CKG_TESTUNLOCK_OFFSET, - 0x00, regInfoPtr++); - count++; - - } - else // User no classD & Triton also no classD - { - returnVal= BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN3_OFFSET, - l1a_l1s_com.outen_cfg_task.outen3, regInfoPtr++); - count++; - returnVal = BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN2_OFFSET, - l1a_l1s_com.outen_cfg_task.outen2, regInfoPtr++); - count++; - returnVal= BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_OUTEN3_OFFSET, - l1a_l1s_com.outen_cfg_task.outen3, regInfoPtr++); - count++; - } - } - - returnVal= BspTwl3029_I2c_regQueWrite(BSP_TWL3029_I2C_AUD,BSP_TWL_3029_MAP_AUDIO_POPMAN_OFFSET, - 0x00,regInfoPtr++); - count++; - callbackPtr->callbackFunc = l1_audio_abb_outen_cfg_callback; - callbackPtr->callbackVal = 0; - - if (returnVal != BSP_TWL3029_RETURN_CODE_FAILURE) - { - regInfoPtr = regInfo; - /* now request to I2C manager to write to Triton registers */ - - returnVal = BspTwl3029_I2c_regInfoSend(regInfo,count,callbackPtr, - (BspI2c_TransactionRequest*)i2cTransArrayPtr); - } - - return returnVal; - } /* end function l1s_outen_update */ - - -#endif -#if (CODE_VERSION == SIMULATION) - // This function is written to turn on the flag l1_audio_dl_switched_on during simulation -signed char l1_outen_update(void) - { - l1s.audio_on_off_ctl.l1_audio_dl_switched_on = TRUE; - } -#endif -#endif // L1_AUDIO_MCU_ONOFF - -// END Triton Audio ON/OFF Changes - - - #if (KEYBEEP) - /*-------------------------------------------------------*/ - /* l1s_keybeep_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Keybeep L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_keybeep_manager(void) - { - enum states - { - IDLE = 0, -#if (L1_AUDIO_MCU_ONOFF == 1) - WAIT_AUDIO_ON = 1, -#endif - WAIT_KEYBEEP_START = 2, - WAIT_KEYBEEP_STOP = 3 - }; - - UWORD8 *state = &l1s.audio_state[L1S_KEYBEEP_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - - case IDLE: - { - // Triton Audio ON/OFF Changes -#if(L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request++; - *state = WAIT_AUDIO_ON; -#else - // Start the DSP keybeep task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_KEYBEEP; - *state = WAIT_KEYBEEP_START; -#endif // L1_AUDIO_MCU_ONOFF - } - break; - -#if (L1_AUDIO_MCU_ONOFF == 1) - case WAIT_AUDIO_ON: - { - // Triton Audio ON/OFF Changes - if((l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE] == L1_AUDIO_DL_ON)) - { - // Start the DSP keybeep task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_KEYBEEP; - *state = WAIT_KEYBEEP_START; - } - } - break; -#endif // L1_AUDIO_MCU_ONOFF - - case WAIT_KEYBEEP_START: - { - // the DSP acknowledges the L1S start request. - if ((!(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init & B_KEYBEEP)) && - (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_KEYBEEP)) - { - // Send the start confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_KEYBEEP_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_KEYBEEP_STOP; - } - } - break; - - case WAIT_KEYBEEP_STOP: - { - // the DSP is stopped - if (!(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_KEYBEEP)) - { - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request--; -#endif - - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_KEYBEEP_STOP_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - else - // the MMI requests to stop the current keybeep - if (l1a_l1s_com.keybeep_task.command.stop) - { - // Stop the DSP keybeep task - l1s_dsp_com.dsp_ndb_ptr->d_dur_kb = 0; - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_KEYBEEP; - - // Disable the stop command - l1a_l1s_com.keybeep_task.command.stop = FALSE; - } - } - break; - } // switch - } - #endif // KEYBEEP - #if (TONE) - /*-------------------------------------------------------*/ - /* l1s_tone_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Tone L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_tone_manager(void) - { - enum states - { - IDLE = 0, -// Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF== 1) - WAIT_AUDIO_ON = 1, -#endif - WAIT_TONE_START = 2, - WAIT_TONE_STOP = 3 - }; - - UWORD8 *state = &l1s.audio_state[L1S_TONE_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request++; - *state = WAIT_AUDIO_ON; -#else - // Start the DSP tone task - #if ((DSP == 33) || (DSP == 34) || (DSP == 35) || (DSP == 36) || (DSP == 37) || (DSP == 38) || (DSP == 39)) - // Linked to E2 melody - // In case of WCP, there is a WCP variable at this address - l1s_dsp_com.dsp_ndb_ptr->d_melody_selection = NO_MELODY_SELECTED; - #endif - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init &= ~(B_MELO); - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_TONE; - - *state = WAIT_TONE_START; -#endif // L1_AUDIO_MCU_ONOFF - } - break; - -#if (L1_AUDIO_MCU_ONOFF == 1) - case WAIT_AUDIO_ON: - { - - // Triton Audio ON/OFF Changes - if((l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE] == L1_AUDIO_DL_ON)) - { - // Start the DSP tone task - #if ((DSP == 33) || (DSP == 34) || (DSP == 35) || (DSP == 36) || (DSP == 37) || (DSP == 38) || (DSP == 39)) - // Linked to E2 melody - // In case of WCP, there is a WCP variable at this address - l1s_dsp_com.dsp_ndb_ptr->d_melody_selection = NO_MELODY_SELECTED; - #endif - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init &= ~(B_MELO); - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_TONE; - - *state = WAIT_TONE_START; - } - } - break; -#endif // L1_AUDIO_MCU_ONOFF - - case WAIT_TONE_START: - { - // the DSP acknowledges the L1S start request. - if ((!(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init & B_TONE)) && - (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_TONE)) - { - // Send the start confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_TONE_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_TONE_STOP; - } - } - break; - - case WAIT_TONE_STOP: - { - // the DSP is stopped - if (!(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_TONE)) - { - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request--; -#endif // L1_AUDIO_MCU_ONOFF - - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_TONE_STOP_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - else - // the MMI requests to stop the current tone - if (l1a_l1s_com.tone_task.command.stop) - { - // Stop the DSP tone task - l1s_dsp_com.dsp_ndb_ptr->d_pe_rep = 0; - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_TONE; - - // Disable the stop command - l1a_l1s_com.tone_task.command.stop = FALSE; - } - } - break; - } // switch - } - #endif // TONE - #if (MELODY_E1) - /*-------------------------------------------------------*/ - /* l1s_melody0_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Melody 0 L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_melody0_manager(void) - { - enum states - { - M0_INACTIVE = 0, -#if (L1_AUDIO_MCU_ONOFF == 1) - M0_WAIT_AUDIO_START = 1, -#endif - M0_WAIT_DSP_START = 2, - M0_WAIT_COUNTER_EQUAL_0 = 3, - M0_WAIT_DESCRIPTION_START = 4, - M0_WAIT_END_MELO = 5 - }; - - UWORD8 *state = &l1s.audio_state[L1S_MELODY0_STATE]; - xSignalHeaderRec *conf_msg; - UWORD8 i, load_size; - UWORD16 melo_header[2], trash[4]; - API *osc_used; - - switch(*state) - { - case M0_INACTIVE: - { - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request++; - *state = M0_WAIT_AUDIO_START; -#else - // Initialize the oscilators used: - for (i=0; i<SC_NUMBER_OSCILLATOR; i++) - { - if (l1a_l1s_com.melody0_task.parameters.oscillator_used_bitmap & (0x1<<i)) - *(l1s.melody0.oscillator[i]) = SC_END_OSCILLATOR_MASK; - } - // Initialize the pointer to the buffer, the buffer size - l1s.melody0.ptr_buf = l1a_l1s_com.melody0_task.parameters.ptr_buf; - l1s.melody0.buffer_size = l1a_l1s_com.melody0_task.parameters.buffer_size; - - // Download the header of the first description of the melody - l1s.melody0.error_id = copy_data_from_buffer (l1a_l1s_com.melody0_task.parameters.session_id, - &l1s.melody0.buffer_size, - (UWORD16 **)&l1s.melody0.ptr_buf, - 1, - &l1s.melody0.melody_header); - - // Initialize the counter with the first offset time: - l1s.melody0.counter = ( ( Field(l1s.melody0.melody_header, SC_MELO_TIME_OFFSET_MASK, SC_MELO_TIME_OFFSET_SHIFT) ) * SC_MELO_DOWNLOAD_TIME_UNIT ) - 1; - - // Enable the oscillator used - l1s_dsp_com.dsp_ndb_ptr->d_melo_osc_used |= l1a_l1s_com.melody0_task.parameters.oscillator_used_bitmap; - - // Start the DSP melody task - #if ((DSP==33) || (DSP == 34) || (DSP==35) || (DSP==36) || (DSP == 37) || (DSP == 38) || (DSP == 39)) - // Linked to E2 melody - // In case of WCP, there is a WCP variable at this address - l1s_dsp_com.dsp_ndb_ptr->d_melody_selection = MELODY_E1_SELECTED; - #endif - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= (B_TONE | B_MELO); - - *state = M0_WAIT_DSP_START; -#endif // L1_AUDIO_MCU_ONOFF - } - break; -#if (L1_AUDIO_MCU_ONOFF == 1) - case M0_WAIT_AUDIO_START: - { - // Triton Audio ON/OFF Changes - if((l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE] == L1_AUDIO_DL_ON)) - { - // Initialize the oscilators used: - for (i=0; i<SC_NUMBER_OSCILLATOR; i++) - { - if (l1a_l1s_com.melody0_task.parameters.oscillator_used_bitmap & (0x1<<i)) - *(l1s.melody0.oscillator[i]) = SC_END_OSCILLATOR_MASK; - } - // Initialize the pointer to the buffer, the buffer size - l1s.melody0.ptr_buf = l1a_l1s_com.melody0_task.parameters.ptr_buf; - l1s.melody0.buffer_size = l1a_l1s_com.melody0_task.parameters.buffer_size; - - // Download the header of the first description of the melody - l1s.melody0.error_id = copy_data_from_buffer (l1a_l1s_com.melody0_task.parameters.session_id, - &l1s.melody0.buffer_size, - (UWORD16 **)&l1s.melody0.ptr_buf, - 1, - &l1s.melody0.melody_header); - - // Initialize the counter with the first offset time: - l1s.melody0.counter = ( ( Field(l1s.melody0.melody_header, SC_MELO_TIME_OFFSET_MASK, SC_MELO_TIME_OFFSET_SHIFT) ) * SC_MELO_DOWNLOAD_TIME_UNIT ) - 1; - - // Enable the oscillator used - l1s_dsp_com.dsp_ndb_ptr->d_melo_osc_used |= l1a_l1s_com.melody0_task.parameters.oscillator_used_bitmap; - - // Start the DSP melody task - #if ((DSP==33) || (DSP == 34) || (DSP==35) || (DSP==36) || (DSP == 37) || (DSP == 38) || (DSP == 39)) - // Linked to E2 melody - // In case of WCP, there is a WCP variable at this address - l1s_dsp_com.dsp_ndb_ptr->d_melody_selection = MELODY_E1_SELECTED; - #endif - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= (B_TONE | B_MELO); - - *state = M0_WAIT_DSP_START; - } - } - break; -#endif // L1_AUDIO_MCU_ONOFF - - case M0_WAIT_DSP_START: - { - // The DSP is started - if ( !(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init & B_TONE) ) - { - // Send the start confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_MELODY0_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = M0_WAIT_COUNTER_EQUAL_0; - } - } - break; - - case M0_WAIT_COUNTER_EQUAL_0: - { - // The MMI resquests to stop the current melody 0. - if (l1a_l1s_com.melody0_task.command.stop) - { - // Initialize the oscilators used: - for (i=0; i<SC_NUMBER_OSCILLATOR; i++) - { - if (l1a_l1s_com.melody0_task.parameters.oscillator_used_bitmap & (0x1<<i)) - *(l1s.melody0.oscillator[i]) = SC_END_OSCILLATOR_MASK; - } - - // Disable the loopback - l1a_l1s_com.melody0_task.parameters.loopback = FALSE; - - // Disable the stop command - l1a_l1s_com.melody0_task.command.stop = FALSE; - - *state = M0_WAIT_END_MELO; - } - else - { - // Decrease the download coundter - l1s.melody0.counter--; - - // The description must be downloaded. - if (l1s.melody0.counter == 0) - { - // Set the oscillator used in the following description - l1s.melody0.oscillator_used_in_desc = Field(l1s.melody0.melody_header, SC_MELO_OSCILLATOR_USED_MASK, SC_MELO_OSCILLATOR_USED_SHIFT); - l1s.melody0.oscillator_started = 0; - - // Download the new description - for (i=0; i<SC_NUMBER_OSCILLATOR; i++) - { - if (Field(l1s.melody0.oscillator_used_in_desc, (0x01<<i), i)) - { - // This oscillator description must be used. - if (l1a_l1s_com.melody0_task.parameters.melody_to_oscillator[i] != SC_NUMBER_OSCILLATOR) - { - osc_used = l1s.melody0.oscillator[l1a_l1s_com.melody0_task.parameters.melody_to_oscillator[i]]; - l1s.melody0.oscillator_started |= (0x01<<(l1a_l1s_com.melody0_task.parameters.melody_to_oscillator[i])); - } - else - // The oscillator description isn't used and put to the "trash" - { - osc_used = trash; - } - - // Download the two first words of the oscillator description - l1s.melody0.error_id = copy_data_from_buffer (l1a_l1s_com.melody0_task.parameters.session_id, - &l1s.melody0.buffer_size, - (UWORD16 **)&l1s.melody0.ptr_buf, - 2, - osc_used); - - load_size = 0; - if (Field(*(osc_used+1), SC_MELO_LOAD1_MASK, SC_MELO_LOAD1_SHIFT)) - load_size++; - if (Field(*(osc_used+1), SC_MELO_LOAD2_MASK, SC_MELO_LOAD2_SHIFT)) - load_size++; - - // Download the next word(s) of the oscillator description - l1s.melody0.error_id = copy_data_from_buffer (l1a_l1s_com.melody0_task.parameters.session_id, - &l1s.melody0.buffer_size, - (UWORD16 **)&l1s.melody0.ptr_buf, - load_size, - osc_used+2); - - // Enable this new description - *osc_used |= 1; - } - } - - *state = M0_WAIT_DESCRIPTION_START; - } - } - } - break; - - case M0_WAIT_DESCRIPTION_START: - { - - // The new description is started or no oscillator of the description was allocated. - if ((l1s.melody0.oscillator_started & l1s_dsp_com.dsp_ndb_ptr->d_melo_osc_active) || - (l1s.melody0.oscillator_started == 0) ) - { - // Download the header of the next description of the melody - l1s.melody0.error_id = copy_data_from_buffer (l1a_l1s_com.melody0_task.parameters.session_id, - &l1s.melody0.buffer_size, - (UWORD16 **)&l1s.melody0.ptr_buf, - 1, - &l1s.melody0.melody_header); - - // Is it the end of the melody? - if (l1s.melody0.melody_header == 0x0000) - { - *state = M0_WAIT_END_MELO; - // Header is wrong - L1 needs a forcible stop here -#if (CODE_VERSION == SIMULATION) - // l1a_l1s_com.melody1_task.command.stop = TRUE; -#else - l1a_l1s_com.melody1_task.command.stop = TRUE; -#endif - } - else - { - // Initialize the counter with the next offset time: - l1s.melody0.counter = ( ( Field(l1s.melody0.melody_header, SC_MELO_TIME_OFFSET_MASK, SC_MELO_TIME_OFFSET_SHIFT) ) * SC_MELO_DOWNLOAD_TIME_UNIT ) - 1; - - *state = M0_WAIT_COUNTER_EQUAL_0; - } - } - } - break; - - case M0_WAIT_END_MELO: - { - if (l1a_l1s_com.melody0_task.command.stop) - { - // Initialize the oscillators used: - for (i=0; i<SC_NUMBER_OSCILLATOR; i++) - { - if (l1a_l1s_com.melody0_task.parameters.oscillator_used_bitmap & (0x1<<i)) - *(l1s.melody0.oscillator[i]) = SC_END_OSCILLATOR_MASK; - } - - // Disable the loopback - l1a_l1s_com.melody0_task.parameters.loopback = FALSE; - - // Disable the stop command - l1a_l1s_com.melody0_task.command.stop = FALSE; - - *state = M0_WAIT_END_MELO; - } - else - // All oscillators used are stopped. - if (!( l1a_l1s_com.melody0_task.parameters.oscillator_used_bitmap & l1s_dsp_com.dsp_ndb_ptr->d_melo_osc_active)) - { - // The melody is in loopback mode? - if (l1a_l1s_com.melody0_task.parameters.loopback) - { - // Reset the buffer description - #if (OP_RIV_AUDIO == 0) - l1s.melody0.ptr_buf = NULL; - #endif - l1s.melody0.buffer_size = 0; - l1s.melody0.error_id = Cust_get_pointer((UWORD16 **)&l1s.melody0.ptr_buf, - &l1s.melody0.buffer_size, - l1a_l1s_com.melody0_task.parameters.session_id); - - // Download the 2 first words of the melody - l1s.melody0.error_id = copy_data_from_buffer (l1a_l1s_com.melody0_task.parameters.session_id, - &l1s.melody0.buffer_size, - (UWORD16 **)&l1s.melody0.ptr_buf, - 2, - (UWORD16 *)&melo_header); - - // Save the header of the first melody score description - l1s.melody0.melody_header = melo_header[1]; - - // Initialize the counter with the first offset time: - l1s.melody0.counter = ( ( Field(l1s.melody0.melody_header, SC_MELO_TIME_OFFSET_MASK, SC_MELO_TIME_OFFSET_SHIFT) ) * SC_MELO_DOWNLOAD_TIME_UNIT ) - 1; - - *state = M0_WAIT_COUNTER_EQUAL_0; - } - else - { - // Disable the oscillator dedicated to this melody - l1s_dsp_com.dsp_ndb_ptr->d_melo_osc_used &= ~(l1a_l1s_com.melody0_task.parameters.oscillator_used_bitmap); - - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request--; -#endif - - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_MELODY0_STOP_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = M0_INACTIVE; - } - } - } - break; - } // switch - } - - /*-------------------------------------------------------*/ - /* l1s_melody1_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Melody 1 L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_melody1_manager(void) - { - enum states - { - M1_INACTIVE = 0, -#if (L1_AUDIO_MCU_ONOFF == 1) - M1_WAIT_AUDIO_START = 1, -#endif - M1_WAIT_DSP_START = 2, - M1_WAIT_COUNTER_EQUAL_0 = 3, - M1_WAIT_DESCRIPTION_START = 4, - M1_WAIT_END_MELO = 5 - }; - - UWORD8 *state = &l1s.audio_state[L1S_MELODY1_STATE]; - xSignalHeaderRec *conf_msg; - UWORD8 i, load_size; - UWORD16 melo_header[2], trash[4]; - API *osc_used; - - switch(*state) - { - case M1_INACTIVE: - { -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request++; - *state = M1_WAIT_AUDIO_START; -#else - // Initialize the oscilators used: - for (i=0; i<SC_NUMBER_OSCILLATOR; i++) - { - if (l1a_l1s_com.melody1_task.parameters.oscillator_used_bitmap & (0x1<<i)) - *(l1s.melody1.oscillator[i]) = SC_END_OSCILLATOR_MASK; - } - // Initialize the pointer to the buffer, the buffer size - l1s.melody1.ptr_buf = l1a_l1s_com.melody1_task.parameters.ptr_buf; - l1s.melody1.buffer_size = l1a_l1s_com.melody1_task.parameters.buffer_size; - - // Download the header of the first description of the melody - l1s.melody1.error_id = copy_data_from_buffer (l1a_l1s_com.melody1_task.parameters.session_id, - &l1s.melody1.buffer_size, - (UWORD16 **)&l1s.melody1.ptr_buf, - 1, - &l1s.melody1.melody_header); - - // Initialize the counter with the first offset time: - l1s.melody1.counter = ( ( Field(l1s.melody1.melody_header, SC_MELO_TIME_OFFSET_MASK, SC_MELO_TIME_OFFSET_SHIFT) ) * SC_MELO_DOWNLOAD_TIME_UNIT ) - 1; - - // Enable the oscillator used - l1s_dsp_com.dsp_ndb_ptr->d_melo_osc_used |= l1a_l1s_com.melody1_task.parameters.oscillator_used_bitmap; - - // Start the DSP melody task - #if ((DSP==33) || (DSP == 34) || (DSP==35) || (DSP==36) || (DSP == 37) || (DSP == 38) || (DSP == 39)) - // Linked to E2 melody - // In case of WCP, there is a WCP variable at this address - l1s_dsp_com.dsp_ndb_ptr->d_melody_selection = MELODY_E1_SELECTED; - #endif - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= (B_TONE | B_MELO); - - *state = M1_WAIT_DSP_START; -#endif - } - break; -#if (L1_AUDIO_MCU_ONOFF == 1) - case M1_WAIT_AUDIO_START: - { - if((l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE] == L1_AUDIO_DL_ON)) - { - // Initialize the oscilators used: - for (i=0; i<SC_NUMBER_OSCILLATOR; i++) - { - if (l1a_l1s_com.melody1_task.parameters.oscillator_used_bitmap & (0x1<<i)) - *(l1s.melody1.oscillator[i]) = SC_END_OSCILLATOR_MASK; - } - // Initialize the pointer to the buffer, the buffer size - l1s.melody1.ptr_buf = l1a_l1s_com.melody1_task.parameters.ptr_buf; - l1s.melody1.buffer_size = l1a_l1s_com.melody1_task.parameters.buffer_size; - - // Download the header of the first description of the melody - l1s.melody1.error_id = copy_data_from_buffer (l1a_l1s_com.melody1_task.parameters.session_id, - &l1s.melody1.buffer_size, - (UWORD16 **)&l1s.melody1.ptr_buf, - 1, - &l1s.melody1.melody_header); - - // Initialize the counter with the first offset time: - l1s.melody1.counter = ( ( Field(l1s.melody1.melody_header, SC_MELO_TIME_OFFSET_MASK, SC_MELO_TIME_OFFSET_SHIFT) ) * SC_MELO_DOWNLOAD_TIME_UNIT ) - 1; - - // Enable the oscillator used - l1s_dsp_com.dsp_ndb_ptr->d_melo_osc_used |= l1a_l1s_com.melody1_task.parameters.oscillator_used_bitmap; - - // Start the DSP melody task - #if ((DSP==33) || (DSP == 34) || (DSP==35) || (DSP==36) || (DSP == 37) || (DSP == 38) || (DSP == 39)) - // Linked to E2 melody - // In case of WCP, there is a WCP variable at this address - l1s_dsp_com.dsp_ndb_ptr->d_melody_selection = MELODY_E1_SELECTED; - #endif - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= (B_TONE | B_MELO); - - *state = M1_WAIT_DSP_START; - } - } - break; -#endif // L1_AUDIO_MCU_ONOFF - - case M1_WAIT_DSP_START: - { - // The DSP is started - if ( !(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init & B_TONE) ) - { - // Send the start confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_MELODY1_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = M1_WAIT_COUNTER_EQUAL_0; - } - } - break; - - case M1_WAIT_COUNTER_EQUAL_0: - { - // The MMI resquests to stop the current melody 1. - if (l1a_l1s_com.melody1_task.command.stop) - { - // Initialize the oscilators used: - for (i=0; i<SC_NUMBER_OSCILLATOR; i++) - { - if (l1a_l1s_com.melody1_task.parameters.oscillator_used_bitmap & (0x1<<i)) - *(l1s.melody1.oscillator[i]) = SC_END_OSCILLATOR_MASK; - } - - // Disable the loopback - l1a_l1s_com.melody1_task.parameters.loopback = FALSE; - - // Disable the stop command - l1a_l1s_com.melody1_task.command.stop = FALSE; - - *state = M1_WAIT_END_MELO; - } - else - { - // Decrease the download coundter - l1s.melody1.counter--; - - // The description must be downloaded. - if (l1s.melody1.counter == 0) - { - // Set the oscillator used in the following description - l1s.melody1.oscillator_used_in_desc = Field(l1s.melody1.melody_header, SC_MELO_OSCILLATOR_USED_MASK, SC_MELO_OSCILLATOR_USED_SHIFT); - l1s.melody1.oscillator_started = 0; - - // Download the new description - for (i=0; i<SC_NUMBER_OSCILLATOR; i++) - { - if (Field(l1s.melody1.oscillator_used_in_desc, (0x01<<i), i)) - { - // This oscillator description must be used. - if (l1a_l1s_com.melody1_task.parameters.melody_to_oscillator[i] != SC_NUMBER_OSCILLATOR) - { - osc_used = l1s.melody1.oscillator[l1a_l1s_com.melody1_task.parameters.melody_to_oscillator[i]]; - l1s.melody1.oscillator_started |= (0x01<<(l1a_l1s_com.melody1_task.parameters.melody_to_oscillator[i])); - } - else - // The oscillator description isn't used and put to the "trash" - { - osc_used = trash; - } - - // Download the two first words of the oscillator description - l1s.melody1.error_id = copy_data_from_buffer (l1a_l1s_com.melody1_task.parameters.session_id, - &l1s.melody1.buffer_size, - (UWORD16 **)&l1s.melody1.ptr_buf, - 2, - osc_used); - - load_size = 0; - if (Field(*(osc_used+1), SC_MELO_LOAD1_MASK, SC_MELO_LOAD1_SHIFT)) - load_size++; - if (Field(*(osc_used+1), SC_MELO_LOAD2_MASK, SC_MELO_LOAD2_SHIFT)) - load_size++; - - // Download the next word(s) of the oscillator description - l1s.melody1.error_id = copy_data_from_buffer (l1a_l1s_com.melody1_task.parameters.session_id, - &l1s.melody1.buffer_size, - (UWORD16 **)&l1s.melody1.ptr_buf, - load_size, - osc_used+2); - - // Enable this new description - *osc_used |= 1; - } - } - - *state = M1_WAIT_DESCRIPTION_START; - } - } - } - break; - - case M1_WAIT_DESCRIPTION_START: - { - // The new description is started or no oscillator of the description was allocated. - if ((l1s.melody1.oscillator_started & l1s_dsp_com.dsp_ndb_ptr->d_melo_osc_active) || - (l1s.melody1.oscillator_started == 0) ) - { - // Download the header of the next description of the melody - l1s.melody1.error_id = copy_data_from_buffer (l1a_l1s_com.melody1_task.parameters.session_id, - &l1s.melody1.buffer_size, - (UWORD16 **)&l1s.melody1.ptr_buf, - 1, - &l1s.melody1.melody_header); - - // Is it the end of the melody? - if (l1s.melody1.melody_header == 0x0000) - { - *state = M1_WAIT_END_MELO; - /* Header is wrong - L1 needs a forcible stop here */ -#if (CODE_VERSION == SIMULATION) - // l1a_l1s_com.melody1_task.command.stop = TRUE; -#else - l1a_l1s_com.melody1_task.command.stop = TRUE; -#endif - - } - else - { - // Initialize the counter with the next offset time: - l1s.melody1.counter = ( ( Field(l1s.melody1.melody_header, SC_MELO_TIME_OFFSET_MASK, SC_MELO_TIME_OFFSET_SHIFT) ) * SC_MELO_DOWNLOAD_TIME_UNIT ) - 1; - - *state = M1_WAIT_COUNTER_EQUAL_0; - } - } - } - break; - - case M1_WAIT_END_MELO: - { - if (l1a_l1s_com.melody1_task.command.stop) - { - // Initialize the oscillators used: - for (i=0; i<SC_NUMBER_OSCILLATOR; i++) - { - if (l1a_l1s_com.melody1_task.parameters.oscillator_used_bitmap & (0x1<<i)) - *(l1s.melody1.oscillator[i]) = SC_END_OSCILLATOR_MASK; - } - - // Disable the loopback - l1a_l1s_com.melody1_task.parameters.loopback = FALSE; - - // Disable the stop command - l1a_l1s_com.melody1_task.command.stop = FALSE; - - *state = M1_WAIT_END_MELO; - } - else - // All oscillators used are stopped. - if (!( l1a_l1s_com.melody1_task.parameters.oscillator_used_bitmap & l1s_dsp_com.dsp_ndb_ptr->d_melo_osc_active)) - { - // The melody is in loopback mode? - if (l1a_l1s_com.melody1_task.parameters.loopback) - { - // Reset the pointer to the buffer - #if (OP_RIV_AUDIO == 0) - l1s.melody1.ptr_buf = NULL; - #endif - l1s.melody1.buffer_size = 0; - l1s.melody1.error_id = Cust_get_pointer((UWORD16 **)&l1s.melody1.ptr_buf, - &l1s.melody1.buffer_size, - l1a_l1s_com.melody1_task.parameters.session_id); - - // Download the 2 first words of the first description of the melody - l1s.melody1.error_id = copy_data_from_buffer (l1a_l1s_com.melody1_task.parameters.session_id, - &l1s.melody1.buffer_size, - (UWORD16 **)&l1s.melody1.ptr_buf, - 2, - (UWORD16 *)&melo_header); - - // Save the header of the first melody score description - l1s.melody1.melody_header = melo_header[1]; - - // Initialize the counter with the first offset time: - l1s.melody1.counter = ( ( Field(l1s.melody1.melody_header, SC_MELO_TIME_OFFSET_MASK, SC_MELO_TIME_OFFSET_SHIFT) ) * SC_MELO_DOWNLOAD_TIME_UNIT ) - 1; - - *state = M1_WAIT_COUNTER_EQUAL_0; - } - else - { - // Disable the oscillator dedicated to this melody - l1s_dsp_com.dsp_ndb_ptr->d_melo_osc_used &= ~(l1a_l1s_com.melody1_task.parameters.oscillator_used_bitmap); -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request--; -#endif - - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_MELODY1_STOP_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = M1_INACTIVE; - } - } - } - break; - } // switch - } - #endif // MELODY_E1 - #if (VOICE_MEMO) - /*-------------------------------------------------------*/ - /* l1s_vm_play_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Voice memo playing L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_vm_play_manager(void) - { - enum states - { - IDLE = 0, -#if (L1_AUDIO_MCU_ONOFF == 1) - WAIT_AUDIO_ON = 1, -#endif - WAIT_DSP_START = 2, - WAIT_DSP_REQUEST = 3, - WAIT_DSP_STOP = 4 - }; - - UWORD8 *state = &l1s.audio_state[L1S_VM_PLAY_STATE]; - xSignalHeaderRec *conf_msg; - UWORD16 sample_header; - - switch(*state) - { - case IDLE: - { -#if (L1_AUDIO_MCU_ONOFF == 1) - // Triton Audio ON/OFF Changes - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request++; - *state = WAIT_AUDIO_ON; -#else - // Initialize the buffer parameters - l1s.voicememo.play.ptr_buf = NULL; - l1s.voicememo.play.buffer_size = 0; - l1s.voicememo.play.error_id = Cust_get_pointer((UWORD16 **)&l1s.voicememo.play.ptr_buf, - &l1s.voicememo.play.buffer_size, - l1a_l1s_com.voicememo_task.play.parameters.session_id); - - // Start the voice memo playing DSP task - #if ((DSP == 34) || (DSP == 35) || (DSP == 36) || (DSP == 37) || (DSP == 38) || (DSP == 39)) - // use TCH/FS vocoder - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode &= ~(B_VM_VOCODER_SELECT); - #endif - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_PLAY_START; - - // Determine which a_du buffer is currently used - l1s.voicememo.play.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_1; - if (l1a_l1s_com.dedic_set.aset != NULL) - { - if ( (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->channel_type == TCH_H) && - (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->subchannel == 1) ) - l1s.voicememo.play.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_0; - } - - // Download the header of the new speech sample - l1s.voicememo.play.error_id = copy_data_from_buffer (l1a_l1s_com.voicememo_task.play.parameters.session_id, - &l1s.voicememo.play.buffer_size, - (UWORD16 **)&l1s.voicememo.play.ptr_buf, - 1, - &sample_header); - - // Download the data to the a_du_x buffer if the sample isn't a noise sample. - if (sample_header & B_VM_SPEECH) - { - l1s.voicememo.play.error_id = copy_data_from_buffer (l1a_l1s_com.voicememo_task.play.parameters.session_id, - &l1s.voicememo.play.buffer_size, - (UWORD16 **)&l1s.voicememo.play.ptr_buf, - SC_VM_SPEECH_SAMPLE-1, - l1s.voicememo.play.a_du_x+1); - } - // Send the header to the DSP - *l1s.voicememo.play.a_du_x = sample_header; - - *state = WAIT_DSP_START; -#endif // L1_AUDIO_MCU_ONOFF - } - break; -#if (L1_AUDIO_MCU_ONOFF == 1) - case WAIT_AUDIO_ON: - { - // Triton Audio ON/OFF Changes - if((l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE] == L1_AUDIO_DL_ON)) - { - // Initialize the buffer parameters - l1s.voicememo.play.ptr_buf = NULL; - l1s.voicememo.play.buffer_size = 0; - l1s.voicememo.play.error_id = Cust_get_pointer((UWORD16 **)&l1s.voicememo.play.ptr_buf, - &l1s.voicememo.play.buffer_size, - l1a_l1s_com.voicememo_task.play.parameters.session_id); - - // Start the voice memo playing DSP task - #if (DSP == 34) || (DSP == 35) || (DSP == 36) || (DSP == 37) || (DSP == 38) || (DSP == 39) - // use TCH/FS vocoder - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode &= ~(B_VM_VOCODER_SELECT); - #endif - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_PLAY_START; - - // Determine which a_du buffer is currently used - l1s.voicememo.play.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_1; - if (l1a_l1s_com.dedic_set.aset != NULL) - { - if ( (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->channel_type == TCH_H) && - (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->subchannel == 1) ) - l1s.voicememo.play.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_0; - } - - // Download the header of the new speech sample - l1s.voicememo.play.error_id = copy_data_from_buffer (l1a_l1s_com.voicememo_task.play.parameters.session_id, - &l1s.voicememo.play.buffer_size, - (UWORD16 **)&l1s.voicememo.play.ptr_buf, - 1, - &sample_header); - - // Download the data to the a_du_x buffer if the sample isn't a noise sample. - if (sample_header & B_VM_SPEECH) - { - l1s.voicememo.play.error_id = copy_data_from_buffer (l1a_l1s_com.voicememo_task.play.parameters.session_id, - &l1s.voicememo.play.buffer_size, - (UWORD16 **)&l1s.voicememo.play.ptr_buf, - SC_VM_SPEECH_SAMPLE-1, - l1s.voicememo.play.a_du_x+1); - } - // Send the header to the DSP - *l1s.voicememo.play.a_du_x = sample_header; - - *state = WAIT_DSP_START; - } - } - break; -#endif // L1_AUDIO_MCU_ONOFF - - case WAIT_DSP_START: - { - // The DSP task is started - if (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_VM_PLAY_ON_GOING) - { - // Send the start confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_VM_PLAY_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_DSP_REQUEST; - } - } - break; - - case WAIT_DSP_REQUEST: - { - // The MMI requests to stop the voice memorization playing task - if (l1a_l1s_com.voicememo_task.play.command.stop) - { - // Stop the DSP voice memorization playing task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_PLAY_STOP; - - *state = WAIT_DSP_STOP; - } - else - // The DSP needs a new block - { - // Determine which a_du buffer is currently used - l1s.voicememo.play.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_1; - if (l1a_l1s_com.dedic_set.aset != NULL) - { - if ( (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->channel_type == TCH_H) && - (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->subchannel == 1) ) - l1s.voicememo.play.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_0; - } - - if (!(*(l1s.voicememo.play.a_du_x) & B_BLOCK_READY)) - { - // Download the header of the new speech sample - l1s.voicememo.play.error_id = copy_data_from_buffer (l1a_l1s_com.voicememo_task.play.parameters.session_id, - &l1s.voicememo.play.buffer_size, - (UWORD16 **)&l1s.voicememo.play.ptr_buf, - 1, - &sample_header); - - // Is it the end of the voice memo data buffer? - if ( sample_header == SC_VM_END_MASK ) - { - // Stop the DSP voice memorization playing task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_PLAY_STOP; - - *state = WAIT_DSP_STOP; - } - else - { - // Download the data to the a_du_x buffer if the sample isn't a noise sample. - if (sample_header & B_VM_SPEECH) - { - l1s.voicememo.play.error_id = copy_data_from_buffer (l1a_l1s_com.voicememo_task.play.parameters.session_id, - &l1s.voicememo.play.buffer_size, - (UWORD16 **)&l1s.voicememo.play.ptr_buf, - SC_VM_SPEECH_SAMPLE-1, - l1s.voicememo.play.a_du_x+1); - } - // Send the header to the DSP - *l1s.voicememo.play.a_du_x = sample_header; - } - } - } - } - break; - - case WAIT_DSP_STOP: - { - // The DSP voice memorization playing task is stopped - if (!(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_VM_PLAY_ON_GOING)) - { - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request--; -#endif // L1_AUDIO_MCU_ONOFF - - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_VM_PLAY_STOP_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - - /*-------------------------------------------------------*/ - /* l1s_vm_record_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Voice memo recoding L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_vm_record_manager(void) - { - enum states - { - IDLE = 0, -#if (L1_AUDIO_MCU_ONOFF == 1) - WAIT_AUDIO_ON = 1, -#endif // L1_AUDIO_MCU_ONOFF - WAIT_DSP_START = 2, - WAIT_DSP_SAMPLE = 3, - WAIT_DSP_STOP = 4 - }; - - UWORD8 *state = &l1s.audio_state[L1S_VM_RECORD_STATE]; - xSignalHeaderRec *conf_msg; - UWORD8 size; - UWORD16 data; - - switch(*state) - { - case IDLE: - { - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_ul_request++; - *state = WAIT_AUDIO_ON; -#else - // Initialize the buffer parameters - l1s.voicememo.record.ptr_buf = NULL; - l1s.voicememo.record.buffer_size = 0; - l1s.voicememo.record.error_id = Cust_get_pointer((UWORD16 **)&l1s.voicememo.record.ptr_buf, - &l1s.voicememo.record.buffer_size, - l1a_l1s_com.voicememo_task.record.parameters.session_id); - - // Initialize the size of the Voice memo to record - l1s.voicememo.record.recorded_size = 0; - - // Initialize the DTX mode - if (l1a_l1s_com.voicememo_task.record.parameters.dtx) - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode |= B_VOICE_MEMO_DTX; - else - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode &= ~(B_VOICE_MEMO_DTX); - - #if ((DSP == 34) || (DSP == 35) || (DSP == 36) || (DSP == 37) || (DSP == 38) || (DSP == 39)) - // use TCH/FS vocoder - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode &= ~(B_VM_VOCODER_SELECT); - #endif - - // Start the voice memo recording DSP task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_RECORD_START; - - *state = WAIT_DSP_START; - -#endif // L1_AUDIO_MCU_ONOFF - } - break; - -#if (L1_AUDIO_MCU_ONOFF == 1) - case WAIT_AUDIO_ON: - { - // Triton Audio ON/OFF Changes - if((l1s.audio_state[L1S_AUDIO_UL_ONOFF_STATE] == L1_AUDIO_UL_ON)) - { - // Initialize the buffer parameters - l1s.voicememo.record.ptr_buf = NULL; - l1s.voicememo.record.buffer_size = 0; - l1s.voicememo.record.error_id = Cust_get_pointer((UWORD16 **)&l1s.voicememo.record.ptr_buf, - &l1s.voicememo.record.buffer_size, - l1a_l1s_com.voicememo_task.record.parameters.session_id); - - // Initialize the size of the Voice memo to record - l1s.voicememo.record.recorded_size = 0; - - // Initialize the DTX mode - if (l1a_l1s_com.voicememo_task.record.parameters.dtx) - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode |= B_VOICE_MEMO_DTX; - else - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode &= ~(B_VOICE_MEMO_DTX); - - #if (DSP == 34) || (DSP == 35) || (DSP == 36) || (DSP == 37) || (DSP == 38) || (DSP == 39) - // use TCH/FS vocoder - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode &= ~(B_VM_VOCODER_SELECT); - #endif - - // Start the voice memo recording DSP task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_RECORD_START; - - *state = WAIT_DSP_START; - } - } - break; -#endif // L1_AUDIO_MCU_ONOFF - - case WAIT_DSP_START: - { - // The DSP task is started - if (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_VM_RECORD_ON_GOING) - { - // Send the start confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_VM_RECORD_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_DSP_SAMPLE; - } - } - break; - - case WAIT_DSP_SAMPLE: - { - // The MMI requests to stop the voice memorization recording task - if (l1a_l1s_com.voicememo_task.record.command.stop) - { - // Write the end mask at the end of the voice data RAM buffer - data = SC_VM_END_MASK; - l1s.voicememo.record.error_id = copy_data_to_buffer (l1a_l1s_com.voicememo_task.record.parameters.session_id, - &l1s.voicememo.record.buffer_size, - (UWORD16 **)&l1s.voicememo.record.ptr_buf, - 1, - &data); - - // Increase the recorded size - l1s.voicememo.record.recorded_size++; - - // Stop the DSP voice memorization playing task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_RECORD_STOP; - - // Clear the a_du_x header: - *(l1s.voicememo.record.a_du_x) = 0; - - *state = WAIT_DSP_STOP; - } - else - // The DSP needs a new block - { - // Determine which a_du buffer is currently used - l1s.voicememo.record.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_1; - if (l1a_l1s_com.dedic_set.aset != NULL) - { - if ( (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->channel_type == TCH_H) && - (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->subchannel == 1) ) - l1s.voicememo.record.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_0; - } - - // The DSP sends a new block? - if ( (*(l1s.voicememo.record.a_du_x)) & B_BLOCK_READY ) - { - // Check if the block contains a sample of noise or speech - if ( (*(l1s.voicememo.record.a_du_x)) & B_VM_SPEECH ) - size = SC_VM_SPEECH_SAMPLE; - else - size = SC_VM_NOISE_SAMPLE; - - // The maximum allocated size is reached? - if ( (l1s.voicememo.record.recorded_size+size+1) <= l1a_l1s_com.voicememo_task.record.parameters.maximum_size) - { - // Download the data to the a_du_x buffer. - l1s.voicememo.record.error_id = copy_data_to_buffer (l1a_l1s_com.voicememo_task.record.parameters.session_id, - &l1s.voicememo.record.buffer_size, - (UWORD16 **)&l1s.voicememo.record.ptr_buf, - size, - l1s.voicememo.record.a_du_x); - - // Increase the recorded size - l1s.voicememo.record.recorded_size += size; - - // Clear the a_du_x header: - *(l1s.voicememo.record.a_du_x) = 0; - } - else - { - // Write the end mask at the end of the voice data RAM buffer - data = SC_VM_END_MASK; - l1s.voicememo.record.error_id = copy_data_to_buffer (l1a_l1s_com.voicememo_task.record.parameters.session_id, - &l1s.voicememo.record.buffer_size, - (UWORD16 **)&l1s.voicememo.record.ptr_buf, - 1, - &data); - - // Increase the recorded size - l1s.voicememo.record.recorded_size++; - - // Stop the DSP voice memorization playing task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_RECORD_STOP; - - // Clear the a_du_x header: - *(l1s.voicememo.record.a_du_x) = 0; - - *state = WAIT_DSP_STOP; - } - } - } - } - break; - - case WAIT_DSP_STOP: - { - // The DSP voice memorization playing task is stopped - if (!(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_VM_RECORD_ON_GOING)) - { - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_ul_request--; -#endif // L1_AUDIO_MCU_ONOFF - - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_L1_VM_RECORD_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_VM_RECORD_STOP_CON; - //Fill the message - ((T_L1_VM_RECORD_CON *)(conf_msg->SigP))->recorded_size = l1s.voicememo.record.recorded_size; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - - /*-------------------------------------------------------*/ - /* l1s_tone_ul_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : tone uplink L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_tone_ul_manager(void) - { - enum states - { - IDLE = 0, -#if (L1_AUDIO_MCU_ONOFF == 1) - WAIT_AUDIO_ON = 1, -#endif - WAIT_DEDIC_SPEECH_MODE = 2, - WAIT_TONE_UL_START = 3, - WAIT_TONE_UL_STOP = 4 - }; - - UWORD8 *state = &l1s.audio_state[L1S_TONE_UL_STATE]; - - switch(*state) - { - case IDLE: - { -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request++; - *state = WAIT_AUDIO_ON; -#else - // Start the tone uplink task - if (l1a_l1s_com.voicememo_task.record.tone_ul.start) - { - // Set the tone uplink option: - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_TONE_UL; - } - - *state = WAIT_DEDIC_SPEECH_MODE; -#endif - } - break; - -#if (L1_AUDIO_MCU_ONOFF == 1) - case WAIT_AUDIO_ON: - { - if((l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE] == L1_AUDIO_DL_ON)) - { - // Start the tone uplink task - if (l1a_l1s_com.voicememo_task.record.tone_ul.start) - { - // Set the tone uplink option: - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_TONE_UL; - } - - *state = WAIT_DEDIC_SPEECH_MODE; - } - } - break; -#endif // (L1_AUDIO_MCU_ONOFF == 1) - - case WAIT_DEDIC_SPEECH_MODE: - { - // The voice memorization task is stopping: - if (!(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init & B_VM_TONE_UL)) - { - // Reset the start command - l1a_l1s_com.voicememo_task.record.tone_ul.start = FALSE; -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request--; -#endif // L1_AUDIO_MCU_ONOFF - *state = IDLE; - } - else - // Dedicated mode speech start? - if (l1a_l1s_com.dedic_set.aset != NULL) - { - #if (AMR == 1) - if ( (l1a_l1s_com.dedic_set.aset->achan_ptr->mode == TCH_HS_MODE) || - (l1a_l1s_com.dedic_set.aset->achan_ptr->mode == TCH_EFR_MODE) || - (l1a_l1s_com.dedic_set.aset->achan_ptr->mode == TCH_FS_MODE) || - (l1a_l1s_com.dedic_set.aset->achan_ptr->mode == TCH_AFS_MODE) || - (l1a_l1s_com.dedic_set.aset->achan_ptr->mode == TCH_AHS_MODE) ) - #else - if ( (l1a_l1s_com.dedic_set.aset->achan_ptr->mode == TCH_HS_MODE) || - (l1a_l1s_com.dedic_set.aset->achan_ptr->mode == TCH_EFR_MODE) || - (l1a_l1s_com.dedic_set.aset->achan_ptr->mode == TCH_FS_MODE) ) - #endif - { - - // Start the tone uplink DSP task - #if ((DSP==33) || (DSP == 34) || (DSP==35) || (DSP==36) || (DSP == 37) || (DSP == 38) || (DSP == 39)) - // Linked to E2 melody - // In case of WCP, there is a WCP variable at this address - l1s_dsp_com.dsp_ndb_ptr->d_melody_selection = NO_MELODY_SELECTED; - #endif - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init &= ~(B_MELO); - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_TONE; - - *state = WAIT_TONE_UL_START; - } - } - } - break; - - case WAIT_TONE_UL_START: - { - // the tone uplink task is started - if (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_TONE) - { - *state = WAIT_TONE_UL_STOP; - } - } - break; - - case WAIT_TONE_UL_STOP: - { - // The voice memorization task is stopping: - if (!(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init & B_VM_TONE_UL)) - { - // Stop the tone uplink task: - l1s_dsp_com.dsp_ndb_ptr->d_pe_rep = 0; - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_TONE; -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request--; -#endif // L1_AUDIO_MCU_ONOFF - *state = IDLE; - } - else - // The tone uplink task is stopped - if (!(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_TONE)) - { -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request--; -#endif // L1_AUDIO_MCU_ONOFF - *state = IDLE; - } - } - break; - } // switch - } - - #endif // VOICE_MEMO - - #if (L1_PCM_EXTRACTION) - /*-------------------------------------------------------*/ - /* l1s_pcm_download_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : PCM download L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_pcm_download_manager(void) - { - enum states - { - IDLE = 0, -#if (L1_AUDIO_MCU_ONOFF == 1) - WAIT_AUDIO_ON = 1, -#endif - WAIT_DSP_START = 2, - WAIT_DSP_REQUEST = 3, - WAIT_DSP_STOP = 4 - }; - - UWORD8 *state = &l1s.audio_state[L1S_PCM_DOWNLOAD_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { -#if (L1_AUDIO_MCU_ONOFF == 1) - // Triton Audio ON/OFF Changes - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request++; - *state = WAIT_AUDIO_ON; -#else - // Initialize the buffer parameters - l1s.pcm.download.ptr_buf = NULL; - l1s.pcm.download.buffer_size = 0; - l1s.pcm.download.error_id = Cust_get_pointer((UWORD16 **)&l1s.pcm.download.ptr_buf, - &l1s.pcm.download.buffer_size, - l1a_l1s_com.pcm_task.download.parameters.session_id); - - // Download the PCM samples - l1s.pcm.download.error_id = copy_data_from_buffer (l1a_l1s_com.pcm_task.download.parameters.session_id, - &l1s.pcm.download.buffer_size, - (UWORD16 **)&l1s.pcm.download.ptr_buf, - SC_PCM_DOWNLOAD_SAMPLE, - l1s_dsp_com.dsp_ndb_ptr->a_pcm_api_download); - - // Increase the downloaded size of PCM samples - l1s.pcm.download.downloaded_size = SC_PCM_DOWNLOAD_SAMPLE; - - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_download |= (B_PCM_DOWNLOAD_READY); - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_PCM_DOWNLOAD_START; - - *state = WAIT_DSP_START; -#endif // L1_AUDIO_MCU_ONOFF - } - break; - -#if (L1_AUDIO_MCU_ONOFF == 1) - case WAIT_AUDIO_ON: - { - // Triton Audio ON/OFF Changes - if((l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE] == L1_AUDIO_DL_ON)) - { - // Initialize the buffer parameters - l1s.pcm.download.ptr_buf = NULL; - l1s.pcm.download.buffer_size = 0; - l1s.pcm.download.error_id = Cust_get_pointer((UWORD16 **)&l1s.pcm.download.ptr_buf, - &l1s.pcm.download.buffer_size, - l1a_l1s_com.pcm_task.download.parameters.session_id); - - // Download the PCM samples - l1s.pcm.download.error_id = copy_data_from_buffer (l1a_l1s_com.pcm_task.download.parameters.session_id, - &l1s.pcm.download.buffer_size, - (UWORD16 **)&l1s.pcm.download.ptr_buf, - SC_PCM_DOWNLOAD_SAMPLE, - l1s_dsp_com.dsp_ndb_ptr->a_pcm_api_download); - - // Increase the downloaded size of PCM samples - l1s.pcm.download.downloaded_size = SC_PCM_DOWNLOAD_SAMPLE; - - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_download |= (B_PCM_DOWNLOAD_READY); - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_PCM_DOWNLOAD_START; - - *state = WAIT_DSP_START; - } - } - break; -#endif // L1_AUDIO_MCU_ONOFF - - - case WAIT_DSP_START: - { - // The DSP task is started - if (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_PCM_DOWNLOAD_ON_GOING) - { - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_PCM_DOWNLOAD_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_DSP_REQUEST; - } - } - break; - - case WAIT_DSP_REQUEST: - { - if (l1a_l1s_com.pcm_task.download.command.stop) - { - // Stop the DSP PCM playing task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_PCM_DOWNLOAD_STOP; - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_download = 0; - *state = WAIT_DSP_STOP; - } - else - { - // B_PCM_DOWNLOAD_READY is reset if DSP is ready to get new sample - if (!(l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_download & B_PCM_DOWNLOAD_READY)) - { - - if(l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_error & B_PCM_DOWNLOAD_ERROR) - { - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_PCM_DSP_error(); - #endif - } /* end if DSP error check - underflow */ - - if ((l1s.pcm.download.downloaded_size + SC_PCM_DOWNLOAD_SAMPLE) <= - l1a_l1s_com.pcm_task.download.parameters.maximum_size) - { - - // Download the data to the a_pcm_api_download buffer - l1s.pcm.download.error_id = copy_data_from_buffer (l1a_l1s_com.pcm_task.download.parameters.session_id, - &l1s.pcm.download.buffer_size, - (UWORD16 **)&l1s.pcm.download.ptr_buf, - SC_PCM_DOWNLOAD_SAMPLE, - l1s_dsp_com.dsp_ndb_ptr->a_pcm_api_download); - // Increase the downloaded size - l1s.pcm.download.downloaded_size += SC_PCM_DOWNLOAD_SAMPLE; - - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_download |= (B_PCM_DOWNLOAD_READY); - } /* end if download speech sample*/ - else - { - // Stop the DSP PCM playing task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_PCM_DOWNLOAD_STOP; - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_download = 0; - *state = WAIT_DSP_STOP; - } /* end else - download buffer size reached */ - } /* end if DSP requested new block */ - } /* end else not download task stop command */ - } - break; - - case WAIT_DSP_STOP: - { - if (!(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_PCM_DOWNLOAD_ON_GOING)) - { - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request--; -#endif // L1_AUDIO_MCU_ONOFF - - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_PCM_DOWNLOAD_STOP_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - - /*-------------------------------------------------------*/ - /* l1s_pcm_upload_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : PCM uploading manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_pcm_upload_manager(void) - { - enum states - { - IDLE = 0, -#if (L1_AUDIO_MCU_ONOFF == 1) - WAIT_AUDIO_ON = 1, -#endif // L1_AUDIO_MCU_ONOFF - WAIT_DSP_START = 2, - WAIT_DSP_SAMPLE = 3, - WAIT_DSP_STOP = 4 - }; - - UWORD8 *state = &l1s.audio_state[L1S_PCM_UPLOAD_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_ul_request++; - *state = WAIT_AUDIO_ON; -#else - // Initialize the buffer parameters - l1s.pcm.upload.ptr_buf = NULL; - l1s.pcm.upload.buffer_size = 0; - l1s.pcm.upload.error_id = Cust_get_pointer((UWORD16 **)&l1s.pcm.upload.ptr_buf, - &l1s.pcm.upload.buffer_size, - l1a_l1s_com.pcm_task.upload.parameters.session_id); - - // Initialize the size of the PCM upload - l1s.pcm.upload.uploaded_size = 0; - - // Start the PCM recording DSP task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_PCM_UPLOAD_START; - - *state = WAIT_DSP_START; -#endif // L1_AUDIO_MCU_ONOFF - } - break; - -#if (L1_AUDIO_MCU_ONOFF == 1) - case WAIT_AUDIO_ON: - { - // Triton Audio ON/OFF Changes - if((l1s.audio_state[L1S_AUDIO_UL_ONOFF_STATE] == L1_AUDIO_UL_ON)) - { - // Initialize the buffer parameters - l1s.pcm.upload.ptr_buf = NULL; - l1s.pcm.upload.buffer_size = 0; - l1s.pcm.upload.error_id = Cust_get_pointer((UWORD16 **)&l1s.pcm.upload.ptr_buf, - &l1s.pcm.upload.buffer_size, - l1a_l1s_com.pcm_task.upload.parameters.session_id); - - // Initialize the size of the PCM upload - l1s.pcm.upload.uploaded_size = 0; - - // Start the PCM recording DSP task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_PCM_UPLOAD_START; - - *state = WAIT_DSP_START; - } - } - break; -#endif // L1_AUDIO_MCU_ONOFF - - - case WAIT_DSP_START: - { - // The DSP task is started - if (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_PCM_UPLOAD_ON_GOING) - { - // Send the start confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_PCM_UPLOAD_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_DSP_SAMPLE; - } - } - break; - - case WAIT_DSP_SAMPLE: - { - // The MMI requests to stop the PCM recording task - if (l1a_l1s_com.pcm_task.upload.command.stop) - { - // Stop the DSP PCM recording task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_PCM_UPLOAD_STOP; - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_upload = 0; - - *state = WAIT_DSP_STOP; - } - else - // The DSP needs a new block - { - - // The DSP sends a new block? - if (l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_upload & B_PCM_UPLOAD_READY ) - { - - if(l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_error & B_PCM_UPLOAD_ERROR) - { - #if (TRACE_TYPE==1) || (TRACE_TYPE==4) - l1_trace_PCM_DSP_error(); - #endif - } /* end if DSP error check - overflow */ - - if ((l1s.pcm.upload.uploaded_size + SC_PCM_UPLOAD_SAMPLE) <= l1a_l1s_com.pcm_task.upload.parameters.maximum_size) - { - // Download the data to the a_pcm_api_upload buffer. - - l1s.pcm.upload.error_id = copy_data_to_buffer (l1a_l1s_com.pcm_task.upload.parameters.session_id, - &l1s.pcm.upload.buffer_size, - (UWORD16 **)&l1s.pcm.upload.ptr_buf, - SC_PCM_UPLOAD_SAMPLE, - l1s_dsp_com.dsp_ndb_ptr->a_pcm_api_upload); - - // Increase the recorded size - l1s.pcm.upload.uploaded_size += SC_PCM_UPLOAD_SAMPLE; - - // Clear the d_pcm_api_upload header - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_upload &= (~B_PCM_UPLOAD_READY); - } - else - { - // Stop the DSP PCM recording task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_PCM_UPLOAD_STOP; - l1s_dsp_com.dsp_ndb_ptr->d_pcm_api_upload = 0; - - *state = WAIT_DSP_STOP; - } /* end else maximum uplaod size reached */ - } /* end if DSP sends a new block */ - } /* end else */ - } - break; - - case WAIT_DSP_STOP: - { - // The DSP PCM upload task is stopped - if (!(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_PCM_UPLOAD_ON_GOING)) - { - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_ul_request--; -#endif // L1_AUDIO_MCU_ONOFF - - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_L1_PCM_UPLOAD_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_PCM_UPLOAD_STOP_CON; - //Fill the message - ((T_L1_PCM_UPLOAD_STOP_CON *)(conf_msg->SigP))->uploaded_size = l1s.pcm.upload.uploaded_size; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - - #endif /* L1_PCM_EXTRACTION */ - - #if (L1_VOICE_MEMO_AMR) - /*-------------------------------------------------------*/ - /* l1s_vm_amr_play_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Voice memo amr playing L1S manager task.*/ - /* */ - /*-------------------------------------------------------*/ - void l1s_vm_amr_play_manager(void) - { - BOOL l1_vm_amr_in_pause=FALSE; - enum states - { - IDLE = 0, -#if (L1_AUDIO_MCU_ONOFF == 1) - WAIT_AUDIO_ON = 1, -#endif - WAIT_DSP_START = 2, - WAIT_DSP_REQUEST = 3, - WAIT_DSP_STOP = 4 - }; - - UWORD8 *state = &l1s.audio_state[L1S_VM_AMR_PLAY_STATE]; - xSignalHeaderRec *conf_msg; - UWORD8 sample_header; - - switch(*state) - { - case IDLE: - { - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request++; - *state = WAIT_AUDIO_ON; -#else - // Initialize the buffer parameters - l1s.voicememo_amr.play.ptr_buf = NULL; - l1s.voicememo_amr.play.buffer_size = 0; - l1s.voicememo_amr.play.error_id = Cust_get_pointer((UWORD16 **)&l1s.voicememo_amr.play.ptr_buf, - &l1s.voicememo_amr.play.buffer_size, - l1a_l1s_com.voicememo_amr_task.play.parameters.session_id); - - // Convert the buffer size in bytes unit because VM AMR is defined in byte unit - l1s.voicememo_amr.play.buffer_size <<= 1; - - // Initialize previous sample parameters in order to create ONSET on first SAMPLE - l1s.voicememo_amr.play.previous_type = SC_VM_AMR_NO_DATA; - l1s.voicememo_amr.play.transition_header = 0; - - // Initialize a_du_x - // 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) - { - if ( (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->channel_type == TCH_H) && - (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->subchannel == 1) ) - l1s.voicememo_amr.play.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_0; - } - *(l1s.voicememo_amr.play.a_du_x) = 0; - - // Start the voice memo playing DSP task - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode |= B_VM_VOCODER_SELECT; - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_AMR_PLAY_START; - - *state = WAIT_DSP_START; -#endif // L1_AUDIO_MCU_ONOFF - } - -#if (L1_AUDIO_MCU_ONOFF == 1) - case WAIT_AUDIO_ON: - { - // Triton Audio ON/OFF Changes - if((l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE] == L1_AUDIO_DL_ON)) - { - // Initialize the buffer parameters - l1s.voicememo_amr.play.ptr_buf = NULL; - l1s.voicememo_amr.play.buffer_size = 0; - l1s.voicememo_amr.play.error_id = Cust_get_pointer((UWORD16 **)&l1s.voicememo_amr.play.ptr_buf, - &l1s.voicememo_amr.play.buffer_size, - l1a_l1s_com.voicememo_amr_task.play.parameters.session_id); - - // Convert the buffer size in bytes unit because VM AMR is defined in byte unit - l1s.voicememo_amr.play.buffer_size <<= 1; - - // Initialize previous sample parameters in order to create ONSET on first SAMPLE - l1s.voicememo_amr.play.previous_type = SC_VM_AMR_NO_DATA; - l1s.voicememo_amr.play.transition_header = 0; - - // Initialize a_du_x - // 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) - { - if ( (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->channel_type == TCH_H) && - (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->subchannel == 1) ) - l1s.voicememo_amr.play.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_0; - } - *(l1s.voicememo_amr.play.a_du_x) = 0; - - // Start the voice memo playing DSP task - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode |= B_VM_VOCODER_SELECT; - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_AMR_PLAY_START; - - *state = WAIT_DSP_START; - } - } - break; -#endif // L1_AUDIO_MCU_ONOFF - - case WAIT_DSP_START: - { - // The DSP task is started - if (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_VM_AMR_PLAY_ON_GOING) - { - // Send the start confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_VM_AMR_PLAY_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_DSP_REQUEST; - } - } - break; - - case WAIT_DSP_REQUEST: - { - // The MMI requests to stop the voice memorization playing task - if (l1a_l1s_com.voicememo_amr_task.play.command.stop) - { - // Stop the DSP voice memorization playing task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_AMR_PLAY_STOP; - - *state = WAIT_DSP_STOP; - } - 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) - { - if ( (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->channel_type == TCH_H) && - (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->subchannel == 1) ) - l1s.voicememo_amr.play.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_0; - } - - // B_BLOCK_READY is not set if DSP is ready to get new sample - if (!(*(l1s.voicememo_amr.play.a_du_x) & B_BLOCK_READY)) - { - // Issue: transition from not speech sample to speech sample requires creation of transition ONSET sample + storing temporarily speech header - // We use it on next DSP request => when previous sample was ONSET, header must be taken from transition_header - if (l1s.voicememo_amr.play.previous_type == SC_VM_AMR_ONSET) - { - // we use speech header temprarily stored in transition_header - sample_header = l1s.voicememo_amr.play.transition_header; - } - else - { - // Download the header of the new sample - l1s.voicememo_amr.play.error_id = copy_byte_data_from_buffer (l1a_l1s_com.voicememo_amr_task.play.parameters.session_id, - &l1s.voicememo_amr.play.buffer_size, - (UWORD8 **)&l1s.voicememo_amr.play.ptr_buf, - 1, - &sample_header); - } - - // Is it the end of the voice memo data buffer? - if ( sample_header == SC_VM_AMR_END_MASK ) - { - // Stop the DSP voice memorization playing task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_AMR_PLAY_STOP; - - *state = WAIT_DSP_STOP; - } - else - { - UWORD8 temp_header =0; //omaps00090550 - UWORD8 data_size =0; //omaps00090550 - - // Identify AMR sample RX_TX_TYPE - temp_header = sample_header & SC_RX_TX_TYPE_MASK; - switch(temp_header) - { - case SC_VM_AMR_RXTX_SPEECH_GOOD: - case SC_VM_AMR_RXTX_SPEECH_BAD: - { - // Check if previous sample is a non speech sample so we have to create ONSET sample - if ( (l1s.voicememo_amr.play.previous_type == SC_VM_AMR_NOISE)||(l1s.voicememo_amr.play.previous_type == SC_VM_AMR_NO_DATA) ) - { - l1s.voicememo_amr.play.previous_type = SC_VM_AMR_ONSET; - l1s.voicememo_amr.play.transition_header = sample_header; - sample_header = SC_VM_AMR_RXTX_ONSET; - data_size = SC_VM_AMR_ONSET_DATA_SIZE; - } - else - { - l1s.voicememo_amr.play.previous_type = SC_VM_AMR_SPEECH; - - // read channel type to know which vocoder is used (and size of data bits) - temp_header = sample_header & SC_CHAN_TYPE_MASK; - switch(temp_header) - { - case SC_VM_AMR_SPEECH_475: - data_size = SC_VM_AMR_SPEECH_475_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_515: - data_size = SC_VM_AMR_SPEECH_515_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_59: - data_size = SC_VM_AMR_SPEECH_59_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_67: - data_size = SC_VM_AMR_SPEECH_67_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_74: - data_size = SC_VM_AMR_SPEECH_74_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_795: - data_size = SC_VM_AMR_SPEECH_795_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_102: - data_size = SC_VM_AMR_SPEECH_102_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_122: - data_size = SC_VM_AMR_SPEECH_122_DATA_SIZE; - break; - } // switch(temp_header) - } - } - break; - case SC_VM_AMR_RXTX_SID_FIRST: - data_size = SC_VM_AMR_SID_FIRST_DATA_SIZE; - l1s.voicememo_amr.play.previous_type = SC_VM_AMR_NOISE; - break; - case SC_VM_AMR_RXTX_SID_UPDATE: - data_size = SC_VM_AMR_SID_UPDATE_DATA_SIZE; - l1s.voicememo_amr.play.previous_type = SC_VM_AMR_NOISE; - break; - case SC_VM_AMR_RXTX_SID_BAD: - data_size = SC_VM_AMR_SID_BAD_DATA_SIZE; - l1s.voicememo_amr.play.previous_type = SC_VM_AMR_NOISE; - break; - case SC_VM_AMR_RXTX_NO_DATA: - data_size = SC_VM_AMR_NO_DATA_DATA_SIZE; - l1s.voicememo_amr.play.previous_type = SC_VM_AMR_NO_DATA; - break; - default: - // trace error - break; - } - - // if data_size is 0 (SID_FIRST, NO_DATA and ONSET), nothing to copy - if (data_size > 0) - { - // go beyond the 2 DSP words after the header, which are not used in MMS (so a_du_x + 3 in words) - l1s.voicememo_amr.play.error_id = copy_byte_data_le_from_buffer (l1a_l1s_com.voicememo_amr_task.play.parameters.session_id, - &l1s.voicememo_amr.play.buffer_size, - (UWORD8 **)&l1s.voicememo_amr.play.ptr_buf, - data_size, - l1s.voicememo_amr.play.a_du_x + 3); - } - // Send the header to the DSP - *l1s.voicememo_amr.play.a_du_x = (sample_header | B_BLOCK_READY); - } - } - if(l1_vm_amr_in_pause==TRUE) - { - (*(l1s.voicememo_amr.play.a_du_x) = *(l1s.voicememo_amr.play.a_du_x) & ~B_BLOCK_READY); - l1_vm_amr_in_pause=FALSE; - } - } - } - break; - - case WAIT_DSP_STOP: - { - // The DSP voice memorization playing task is stopped - if (!(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_VM_AMR_PLAY_ON_GOING)) - { - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request--; -#endif // L1_AUDIO_MCU_ONOFF - - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_VM_AMR_PLAY_STOP_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - - /*-------------------------------------------------------*/ - /* l1s_vm_amr_record_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Voice memo amr recoding L1S manager task*/ - /* */ - /*-------------------------------------------------------*/ - void l1s_vm_amr_record_manager(void) - { - enum states - { - IDLE = 0, -#if (L1_AUDIO_MCU_ONOFF == 1) - WAIT_AUDIO_ON = 1, -#endif - WAIT_DSP_START = 2, - WAIT_DSP_SAMPLE = 3, - WAIT_DSP_STOP = 4 - }; - - UWORD8 *state = &l1s.audio_state[L1S_VM_AMR_RECORD_STATE]; - xSignalHeaderRec *conf_msg; - UWORD8 sample_header; - - switch(*state) - { - case IDLE: - { - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_ul_request++; - *state = WAIT_AUDIO_ON; -#else - // Initialize the buffer parameters - l1s.voicememo_amr.record.ptr_buf = NULL; - l1s.voicememo_amr.record.buffer_size = 0; - l1s.voicememo_amr.record.error_id = Cust_get_pointer((UWORD16 **)&l1s.voicememo_amr.record.ptr_buf, - &l1s.voicememo_amr.record.buffer_size, - l1a_l1s_com.voicememo_amr_task.record.parameters.session_id); - - // Convert the buffer size in bytes unit because VM AMR is defined in byte unit - l1s.voicememo_amr.record.buffer_size <<= 1; - - // Initialize the size of the Voice memo to record - l1s.voicememo_amr.record.recorded_size = 0; - - // Initialize the DTX mode - if (l1a_l1s_com.voicememo_amr_task.record.parameters.dtx) - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode |= B_VOICE_MEMO_DTX; - else - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode &= ~(B_VOICE_MEMO_DTX); - - // Select AMR vocoder and specified channel type - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode |= B_VM_VOCODER_SELECT; // AMR voice memo - l1s_dsp_com.dsp_ndb_ptr->d_amms_ul_voc &= ~(SC_CHAN_TYPE_MASK); - l1s_dsp_com.dsp_ndb_ptr->d_amms_ul_voc |= l1a_l1s_com.voicememo_amr_task.record.parameters.amr_vocoder; - - l1s.voicememo_amr.record.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_1; - if (l1a_l1s_com.dedic_set.aset != NULL) - { - if ( (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->channel_type == TCH_H) && - (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->subchannel == 1) ) - l1s.voicememo_amr.record.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_0; - } - *(l1s.voicememo_amr.record.a_du_x) = 0; - - // Start the voice memo recording DSP task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_AMR_RECORD_START; - - *state = WAIT_DSP_START; -#endif // L1_AUDIO_MCU_ONOFF - } - break; - -#if (L1_AUDIO_MCU_ONOFF == 1) - - case WAIT_AUDIO_ON: - { - // Triton Audio ON/OFF Changes - if((l1s.audio_state[L1S_AUDIO_UL_ONOFF_STATE] == L1_AUDIO_UL_ON)) - { - // Initialize the buffer parameters - l1s.voicememo_amr.record.ptr_buf = NULL; - l1s.voicememo_amr.record.buffer_size = 0; - l1s.voicememo_amr.record.error_id = Cust_get_pointer((UWORD16 **)&l1s.voicememo_amr.record.ptr_buf, - &l1s.voicememo_amr.record.buffer_size, - l1a_l1s_com.voicememo_amr_task.record.parameters.session_id); - - // Convert the buffer size in bytes unit because VM AMR is defined in byte unit - l1s.voicememo_amr.record.buffer_size <<= 1; - - // Initialize the size of the Voice memo to record - l1s.voicememo_amr.record.recorded_size = 0; - - // Initialize the DTX mode - if (l1a_l1s_com.voicememo_amr_task.record.parameters.dtx) - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode |= B_VOICE_MEMO_DTX; - else - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode &= ~(B_VOICE_MEMO_DTX); - - // Select AMR vocoder and specified channel type - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode |= B_VM_VOCODER_SELECT; // AMR voice memo - l1s_dsp_com.dsp_ndb_ptr->d_amms_ul_voc &= ~(SC_CHAN_TYPE_MASK); - l1s_dsp_com.dsp_ndb_ptr->d_amms_ul_voc |= l1a_l1s_com.voicememo_amr_task.record.parameters.amr_vocoder; - - l1s.voicememo_amr.record.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_1; - if (l1a_l1s_com.dedic_set.aset != NULL) - { - if ( (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->channel_type == TCH_H) && - (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->subchannel == 1) ) - l1s.voicememo_amr.record.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_0; - } - *(l1s.voicememo_amr.record.a_du_x) = 0; - - // Start the voice memo recording DSP task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_AMR_RECORD_START; - - *state = WAIT_DSP_START; - } - } - break; - -#endif // L1_AUDIO_MCU_ONOFF - - case WAIT_DSP_START: - { - // The DSP task is started - if (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_VM_AMR_RECORD_ON_GOING) - { - // Send the start confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_VM_AMR_RECORD_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_DSP_SAMPLE; - } - } // case WAIT_DSP_START: - break; - - case WAIT_DSP_SAMPLE: - { - // The MMI requests to stop the voice memorization recording task - if (l1a_l1s_com.voicememo_amr_task.record.command.stop) - { - // Write the end mask at the end of the voice data RAM buffer - sample_header = SC_VM_AMR_END_MASK; - l1s.voicememo_amr.record.error_id = copy_byte_data_to_buffer (l1a_l1s_com.voicememo_amr_task.record.parameters.session_id, - &l1s.voicememo_amr.record.buffer_size, - (UWORD8 **)&l1s.voicememo_amr.record.ptr_buf, - 1, - &sample_header); - - // Increase the recorded size - l1s.voicememo_amr.record.recorded_size++; - - // Stop the DSP voice memorization playing task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_AMR_RECORD_STOP; - - *state = WAIT_DSP_STOP; - } // if (l1a_l1s_com.voicememo_amr_task.record.command.stop) - else - // The DSP sends a new block ? - { - // Determine which a_du buffer is currently used - l1s.voicememo_amr.record.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_1; - if (l1a_l1s_com.dedic_set.aset != NULL) - { - if ( (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->channel_type == TCH_H) && - (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->subchannel == 1) ) - l1s.voicememo_amr.record.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_0; - } - - // The DSP sends a new block? - if ( (*(l1s.voicememo_amr.record.a_du_x)) & B_BLOCK_READY ) - { - UWORD8 sample_header, temp_header; - UWORD8 data_size=0 ;//omaps00090550; - - // get RX_TYPE to identify frame (SPEECH_GOOD, SID_FIRST, SID_UPDATE, NO_DATA) - sample_header = (*l1s.voicememo_amr.record.a_du_x & 0x00FF); - temp_header = sample_header & SC_RX_TX_TYPE_MASK; - - // Check if the block contains speech or SID or NO_DATA - switch(temp_header) - { - case SC_VM_AMR_RXTX_SPEECH_GOOD: - { - temp_header = sample_header & SC_CHAN_TYPE_MASK; - switch(temp_header) - { - case SC_VM_AMR_SPEECH_475: - data_size = SC_VM_AMR_SPEECH_475_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_515: - data_size = SC_VM_AMR_SPEECH_515_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_59: - data_size = SC_VM_AMR_SPEECH_59_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_67: - data_size = SC_VM_AMR_SPEECH_67_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_74: - data_size = SC_VM_AMR_SPEECH_74_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_795: - data_size = SC_VM_AMR_SPEECH_795_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_102: - data_size = SC_VM_AMR_SPEECH_102_DATA_SIZE; - break; - case SC_VM_AMR_SPEECH_122: - data_size = SC_VM_AMR_SPEECH_122_DATA_SIZE; - break; - } - } // case SC_VM_AMR_RXTX_SPEECH_GOOD: - break; - case SC_VM_AMR_RXTX_SID_FIRST: - data_size = SC_VM_AMR_SID_FIRST_DATA_SIZE; - break; - case SC_VM_AMR_RXTX_SID_UPDATE: - data_size = SC_VM_AMR_SID_UPDATE_DATA_SIZE; - break; - case SC_VM_AMR_RXTX_NO_DATA: - data_size = SC_VM_AMR_NO_DATA_DATA_SIZE; - break; - default: - // trace error - break; - } // switch(temp_header) - - // The maximum allocated size is reached? (need to be able to store header + data + end_mask) - if ( (l1s.voicememo_amr.record.recorded_size+data_size+SC_VM_AMR_HEADER_SIZE+SC_VM_AMR_END_MASK_SIZE) <= l1a_l1s_com.voicememo_amr_task.record.parameters.maximum_size) - { - // Download the header from the a_du_x buffer. - l1s.voicememo_amr.record.error_id = copy_byte_data_to_buffer (l1a_l1s_com.voicememo_amr_task.record.parameters.session_id, - &l1s.voicememo_amr.record.buffer_size, - (UWORD8 **)&l1s.voicememo_amr.record.ptr_buf, - 1, - &sample_header); - - if (data_size > 0) - { - l1s.voicememo_amr.record.error_id = copy_byte_data_le_to_buffer (l1a_l1s_com.voicememo_amr_task.record.parameters.session_id, - &l1s.voicememo_amr.record.buffer_size, - (UWORD8 **)&l1s.voicememo_amr.record.ptr_buf, - data_size, - l1s.voicememo_amr.record.a_du_x + 3); - } - - // Increase the recorded size (header + data_bits) - l1s.voicememo_amr.record.recorded_size += data_size + SC_VM_AMR_HEADER_SIZE; - - // Clear the a_du_x header: - *(l1s.voicememo_amr.record.a_du_x) = 0; - } - else - { - // Write the end mask at the end of the voice data RAM buffer - sample_header = SC_VM_AMR_END_MASK; - l1s.voicememo_amr.record.error_id = copy_byte_data_to_buffer (l1a_l1s_com.voicememo_amr_task.record.parameters.session_id, - &l1s.voicememo_amr.record.buffer_size, - (UWORD8 **)&l1s.voicememo_amr.record.ptr_buf, - 1, - &sample_header); - - // Increase the recorded size - l1s.voicememo_amr.record.recorded_size++; - - // Clear the a_du_x header: - *(l1s.voicememo_amr.record.a_du_x) = 0; - - // Stop the DSP voice memorization playing task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_AMR_RECORD_STOP; - - *state = WAIT_DSP_STOP; - } - } - } // else of if (l1a_l1s_com.voicememo_amr_task.record.command.stop) - } - break; - - case WAIT_DSP_STOP: - { - // The DSP voice memorization playing task is stopped - if (!(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_VM_AMR_RECORD_ON_GOING)) - { - // Triton Audio ON/OFF Changes -#if (L1_AUDIO_MCU_ONOFF == 1) - l1s.audio_on_off_ctl.l1_audio_switch_on_ul_request--; -#endif // L1_AUDIO_MCU_ONOFF - - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_L1_VM_AMR_RECORD_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_VM_AMR_RECORD_STOP_CON; - //Fill the message - ((T_L1_VM_AMR_RECORD_CON *)(conf_msg->SigP))->recorded_size = l1s.voicememo_amr.record.recorded_size; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch(*state) - } - - #endif // L1_VOICE_MEMO_AMR - - #if (SPEECH_RECO) - /*-------------------------------------------------------*/ - /* l1s_sr_enroll_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : speech recognition enroll */ - /* L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_sr_enroll_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_START = 1, - WAIT_ACQUISITION_STATUS = 2, - WAIT_DSP_STOP = 3 - }; - - UWORD8 *state = &l1s.audio_state[L1S_SR_ENROLL_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - // Initialize the status register - l1s_dsp_com.dsp_ndb_ptr->d_sr_status = 0; - - // Disable the DSP bit exact test - l1s_dsp_com.dsp_ndb_ptr->d_sr_bit_exact_test &= 0xff80; - - // Initialize the watchdog timer with the time to acquire a word - l1s.speechreco.time_out = SC_SR_AQUISITION_TIME_OUT; - - // Start the DSP enroll task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_ENROLL; - - *state = WAIT_DSP_START; - } - break; - - case WAIT_DSP_START: - { - // The DSP enroll task is started - if (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_SR_ENROLL_TASK) - { - // Send the start confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_SR_ENROLL_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_ACQUISITION_STATUS; - } - } - break; - - case WAIT_ACQUISITION_STATUS: - { - // the allowed time isn't out - if (l1s.speechreco.time_out--) - { - // The DSP enroll task ran bad or the MMI stop the enroll task - if ( (l1s_dsp_com.dsp_ndb_ptr->d_sr_status & B_BAD_ACQUISITION) || - (l1a_l1s_com.speechreco_task.command.enroll_stop) ) - { - // Error: bad acquisition - l1s.speechreco.error = SC_BAD_ACQUISITION; - - // Stop the DSP enroll task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_STOP; - - *state = WAIT_DSP_STOP; - } - else - // The DSP enroll task ran good - if (l1s_dsp_com.dsp_ndb_ptr->d_sr_status & B_GOOD_ACQUISITION) - { - // No error - l1s.speechreco.error = SC_NO_ERROR; - - // Stop the DSP enroll task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_STOP; - - *state = WAIT_DSP_STOP; - } - } - else - { - // Error: time is out - l1s.speechreco.error = SC_TIME_OUT; - - // Stop the DSP enroll task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_STOP; - - *state = WAIT_DSP_STOP; - } - } - break; - - case WAIT_DSP_STOP: - { - // The DSP enroll task is stopped - if ( !(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & (B_SR_ENROLL_TASK | B_VM_RECORD_ON_GOING)) ) - { - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_L1_SR_ENROLL_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_SR_ENROLL_STOP_CON; - //Fill the message - ((T_L1_SR_ENROLL_STOP_CON *)(conf_msg->SigP))->error_id = l1s.speechreco.error; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - - /*-------------------------------------------------------*/ - /* l1s_sr_update_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : speech recognition update */ - /* L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_sr_update_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_START = 1, - WAIT_ACQUISITION_STATUS = 2, - WAIT_UPDATE_STATUS = 3, - WAIT_DSP_STOP = 4 - }; - - UWORD8 *state = &l1s.audio_state[L1S_SR_UPDATE_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - // Initialize the status register - l1s_dsp_com.dsp_ndb_ptr->d_sr_status = 0; - - // Disable the DSP bit exact test - l1s_dsp_com.dsp_ndb_ptr->d_sr_bit_exact_test &= 0xff80; - - // Initialize the watchdog timer with the time to acquire a word - l1s.speechreco.time_out = SC_SR_AQUISITION_TIME_OUT; - - // Start the DSP update task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_UPDATE; - - #if (W_A_DSP_SR_BGD) - // Management of DSP tasks in background - if (l1s_dsp_com.dsp_param_ptr->d_gsm_bgd_mgt & B_DSPBGD_UPD) - { - l1s_dsp_com.dsp_ndb_ptr->d_background_enable |= (1 << C_BGD_ALIGN); - } - #endif - - *state = WAIT_DSP_START; - } - break; - - case WAIT_DSP_START: - { - // The DSP update task is started - if (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_SR_UPDATE_TASK) - { - // Send the start confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_SR_UPDATE_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_ACQUISITION_STATUS; - } - } - break; - - case WAIT_ACQUISITION_STATUS: - { - // the allowed time isn't out - if (l1s.speechreco.time_out--) - { - // The DSP acquisition task ran bad or the MMI stop the update task - if ( (l1s_dsp_com.dsp_ndb_ptr->d_sr_status & B_BAD_ACQUISITION) || - (l1a_l1s_com.speechreco_task.command.update_stop) ) - { - // Error: bad acquisition - l1s.speechreco.error = SC_BAD_ACQUISITION; - - // Stop the DSP acquisition task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_STOP; - - *state = WAIT_DSP_STOP; - } - else - // The DSP enroll task ran good - if (l1s_dsp_com.dsp_ndb_ptr->d_sr_status & B_GOOD_ACQUISITION) - { - // Initialize the watchdog timer with the time to update a word - l1s.speechreco.time_out = SC_SR_UPDATE_TIME_OUT; - - *state = WAIT_UPDATE_STATUS; - } - } - else - { - // Error: time is out - l1s.speechreco.error = SC_TIME_OUT; - - // Stop the DSP acquisition task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_STOP; - - *state = WAIT_DSP_STOP; - } - } - break; - - - case WAIT_UPDATE_STATUS: - { - // the allowed time isn't out - if (l1s.speechreco.time_out--) - { - // The DSP update task ran bad or the MMI stop the update task - if ( (l1s_dsp_com.dsp_ndb_ptr->d_sr_status & B_BAD_UPDATE) || - (l1a_l1s_com.speechreco_task.command.update_stop) ) - { - // Error: bad update - l1s.speechreco.error = SC_BAD_UPDATE; - - // Stop the DSP update task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_STOP; - - *state = WAIT_DSP_STOP; - } - else - // The DSP update task ran good - if (l1s_dsp_com.dsp_ndb_ptr->d_sr_status & B_GOOD_UPDATE) - { - // No error: - l1s.speechreco.error = SC_NO_ERROR; - - // Stop the DSP update task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_STOP; - - *state = WAIT_DSP_STOP; - } - } - else - { - // Error: time is out - l1s.speechreco.error = SC_TIME_OUT; - - // Stop the DSP enroll task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_STOP; - - *state = WAIT_DSP_STOP; - } - } - break; - - case WAIT_DSP_STOP: - { - // The DSP enroll task is stopped - if ( !( l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & (B_SR_UPDATE_TASK | B_SR_ALIGNMENT_TASK | B_VM_RECORD_ON_GOING) ) ) - { - #if (W_A_DSP_SR_BGD) - // Management of DSP tasks in background - if (l1s_dsp_com.dsp_param_ptr->d_gsm_bgd_mgt & B_DSPBGD_UPD) - { - l1s_dsp_com.dsp_ndb_ptr->d_background_enable &= ~(1 << C_BGD_ALIGN); - } - #endif - - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_L1_SR_UPDATE_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_SR_UPDATE_STOP_CON; - //Fill the message - ((T_L1_SR_UPDATE_STOP_CON *)(conf_msg->SigP))->error_id = l1s.speechreco.error; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - - /*-------------------------------------------------------*/ - /* l1s_sr_reco_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : speech recognition reco acquisition */ - /* L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_sr_reco_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_START = 1, - WAIT_ACQUISITION_STATUS = 2, - WAIT_DSP_STOP = 3 - }; - - UWORD8 *state = &l1s.audio_state[L1S_SR_RECO_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - // Initialize the status register - l1s_dsp_com.dsp_ndb_ptr->d_sr_status = 0; - - // Disable the DSP bit exact test - l1s_dsp_com.dsp_ndb_ptr->d_sr_bit_exact_test &= 0xff80; - - // Initialize the watchdog timer with the time to acquire a word - l1s.speechreco.time_out = SC_SR_AQUISITION_TIME_OUT; - - // Start the DSP acquisition reco task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_RECO; - - *state = WAIT_DSP_START; - } - break; - - case WAIT_DSP_START: - { - // The DSP reco task is started - if (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_SR_RECO_TASK) - { - // Send the start confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_SR_RECO_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_ACQUISITION_STATUS; - } - } - break; - - case WAIT_ACQUISITION_STATUS: - { - // the allowed time isn't out - if (l1s.speechreco.time_out--) - { - // The DSP acquisition reco task ran bad or the MMI stop the acquisition reco task - if ( (l1s_dsp_com.dsp_ndb_ptr->d_sr_status & B_BAD_ACQUISITION) || - (l1a_l1s_com.speechreco_task.command.reco_stop) ) - { - // Error: bad acquisition - l1s.speechreco.error = SC_BAD_ACQUISITION; - - // Stop the DSP acquisition reco task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_STOP; - - *state = WAIT_DSP_STOP; - } - else - // The DSP enroll task ran good - if (l1s_dsp_com.dsp_ndb_ptr->d_sr_status & B_GOOD_ACQUISITION) - { - // No error - l1s.speechreco.error = SC_NO_ERROR; - - // Stop the DSP acquisition reco task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_STOP; - - *state = WAIT_DSP_STOP; - } - } - else - { - // Error: time is out - l1s.speechreco.error = SC_TIME_OUT; - - // Stop the DSP acquisition reco task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_STOP; - - *state = WAIT_DSP_STOP; - } - } - break; - - case WAIT_DSP_STOP: - { - // The DSP enroll task is stopped - if ( !(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_SR_RECO_TASK) ) - { - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_L1_SR_RECO_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_SR_RECO_STOP_CON; - //Fill the message - ((T_L1_SR_RECO_STOP_CON *)(conf_msg->SigP))->error_id = l1s.speechreco.error; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - - /*-------------------------------------------------------*/ - /* l1s_sr_processing_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : speech recognition reco processing */ - /* L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_sr_processing_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_PROCESSING_STOP = 1, - WAIT_DSP_RESULT = 2, - WAIT_DSP_STOP = 3 - }; - - UWORD8 *state = &l1s.audio_state[L1S_SR_PROCESSING_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - // Initialize the status register - l1s_dsp_com.dsp_ndb_ptr->d_sr_status = 0; - - // Disable the DSP bit exact test - l1s_dsp_com.dsp_ndb_ptr->d_sr_bit_exact_test &= 0xff80; - - // Initialize the OOV algorithm - l1s_dsp_com.dsp_ndb_ptr->d_sr_param &= 0x20; - l1s_dsp_com.dsp_ndb_ptr->d_sr_param |= SC_SR_OOV_SFT_THR; - - // Transmit ot the DSP the number of word to compare - l1s_dsp_com.dsp_ndb_ptr->d_sr_nb_words = l1a_l1s_com.speechreco_task.parameters.vocabulary_size; - - // Initialize the watchdog timer with the time to process a word - l1s.speechreco.time_out = SC_SR_PROCESSING_TIME_OUT; - - // Start the DSP processing task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_PROCESSING; - - #if (W_A_DSP_SR_BGD) - // Management of DSP tasks in background - if (l1s_dsp_com.dsp_param_ptr->d_gsm_bgd_mgt & B_DSPBGD_RECO) - { - l1s_dsp_com.dsp_ndb_ptr->d_background_enable |= (1 << C_BGD_RECOGN); - } - #endif - - // Reset the start command - l1a_l1s_com.speechreco_task.command.processing_start = FALSE; - - *state = WAIT_DSP_PROCESSING_STOP; - } - break; - - case WAIT_DSP_PROCESSING_STOP: - { - if (l1s.speechreco.time_out--) - { - // The MMI stops the processing task - if (l1a_l1s_com.speechreco_task.command.processing_stop) - { - // Error: bad acquisition - l1s.speechreco.error = SC_BAD_RECOGNITION; - - // Stop the DSP processing task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_STOP; - - *state = WAIT_DSP_STOP; - } - else - // The DSP processing task is stopped - if ( !(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_SR_PROCESSING_TASK) ) - { - // It was the last model - if (l1a_l1s_com.speechreco_task.parameters.index_counter == l1a_l1s_com.speechreco_task.parameters.vocabulary_size) - { - *state = WAIT_DSP_RESULT; - } - else - { - // Send the stop confirmation message with no error - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_L1_SR_PROCESSING_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_SR_PROCESSING_STOP_CON; - //Fill the message - ((T_L1_SR_PROCESSING_STOP_CON *)(conf_msg->SigP))->error_id = SC_NO_ERROR; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - } - else - // the allowed time is out - { - // Error: time is out - l1s.speechreco.error = SC_TIME_OUT; - - // Stop the DSP processing task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_SR_STOP; - - *state = WAIT_DSP_STOP; - } - } - break; - - case WAIT_DSP_RESULT: - { - - #if (W_A_DSP_SR_BGD) - // Management of DSP tasks in background - if (l1s_dsp_com.dsp_param_ptr->d_gsm_bgd_mgt & B_DSPBGD_RECO) - { - l1s_dsp_com.dsp_ndb_ptr->d_background_enable &= ~(1 << C_BGD_RECOGN); - } - #endif - - // The DSP recognition task was bad - if (l1s_dsp_com.dsp_ndb_ptr->d_sr_status & B_BAD_ACQUISITION) - { - // Send the stop indication message with an bad recognition error - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_L1_SR_RECO_STOP_IND)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_SR_RECO_STOP_IND; - //Fill the message - ((T_L1_SR_RECO_STOP_IND *)(conf_msg->SigP))->error_id = SC_BAD_RECOGNITION; - - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - else - // The DSP recognition task was good: - { - // Send the stop indication message without any error - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_L1_SR_RECO_STOP_IND)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_SR_RECO_STOP_IND; - //Fill the message - ((T_L1_SR_RECO_STOP_IND *)(conf_msg->SigP))->error_id = SC_NO_ERROR; - ((T_L1_SR_RECO_STOP_IND *)(conf_msg->SigP))->best_word_index = l1s_dsp_com.dsp_ndb_ptr->a_n_best_words[0]; - ((T_L1_SR_RECO_STOP_IND *)(conf_msg->SigP))->best_word_score = l1s_dsp_com.dsp_ndb_ptr->a_n_best_score[0] | (l1s_dsp_com.dsp_ndb_ptr->a_n_best_score[1] << 16); - ((T_L1_SR_RECO_STOP_IND *)(conf_msg->SigP))->second_best_word_index = l1s_dsp_com.dsp_ndb_ptr->a_n_best_words[1]; - ((T_L1_SR_RECO_STOP_IND *)(conf_msg->SigP))->second_best_word_score = l1s_dsp_com.dsp_ndb_ptr->a_n_best_score[2] | (l1s_dsp_com.dsp_ndb_ptr->a_n_best_score[3] << 16); - ((T_L1_SR_RECO_STOP_IND *)(conf_msg->SigP))->third_best_word_index = l1s_dsp_com.dsp_ndb_ptr->a_n_best_words[2]; - ((T_L1_SR_RECO_STOP_IND *)(conf_msg->SigP))->third_best_word_score = l1s_dsp_com.dsp_ndb_ptr->a_n_best_score[4] | (l1s_dsp_com.dsp_ndb_ptr->a_n_best_score[5] << 16); - ((T_L1_SR_RECO_STOP_IND *)(conf_msg->SigP))->fourth_best_word_index = l1s_dsp_com.dsp_ndb_ptr->a_n_best_words[3]; - ((T_L1_SR_RECO_STOP_IND *)(conf_msg->SigP))->fourth_best_word_score = l1s_dsp_com.dsp_ndb_ptr->a_n_best_score[6] | (l1s_dsp_com.dsp_ndb_ptr->a_n_best_score[7] << 16); - ((T_L1_SR_RECO_STOP_IND *)(conf_msg->SigP))->d_sr_db_level = l1s_dsp_com.dsp_ndb_ptr->d_sr_db_level; - ((T_L1_SR_RECO_STOP_IND *)(conf_msg->SigP))->d_sr_db_noise = l1s_dsp_com.dsp_ndb_ptr->d_sr_db_noise; - ((T_L1_SR_RECO_STOP_IND *)(conf_msg->SigP))->d_sr_model_size = l1s_dsp_com.dsp_ndb_ptr->d_sr_mod_size; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - - case WAIT_DSP_STOP: - { - // The DSP processing task is stopped - if ( !(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_SR_PROCESSING_TASK) ) - { - // Send the stop confirmation message with an error - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_L1_SR_PROCESSING_STOP_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_SR_PROCESSING_STOP_CON; - //Fill the message - ((T_L1_SR_PROCESSING_STOP_CON *)(conf_msg->SigP))->error_id = l1s.speechreco.error; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - - /*-------------------------------------------------------*/ - /* l1s_sr_speech_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : speech recognition speech recording */ - /* L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_sr_speech_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_START = 1, - WAIT_DSP_SAMPLE = 2, - WAIT_DSP_STOP = 3 - }; - - UWORD8 *state = &l1s.audio_state[L1S_SR_SPEECH_STATE]; - API *a_du_x; - UWORD8 i; - - switch(*state) - { - case IDLE: - { - // Initialize the current pointer - l1s.speechreco.speech_pointer = l1a_l1s_com.speechreco_task.parameters.speech_address; - l1s.speechreco.end_pointer = (UWORD16 *)(l1s.speechreco.speech_pointer + SC_SR_MMI_2_L1_SPEECH_SIZE); - - // Initialize the flag to know if it's the first pass in the circular buffer - l1s.speechreco.first_pass = TRUE; - - // Initialize the status register - l1s_dsp_com.dsp_ndb_ptr->d_sr_status = 0; - - // No DTX mode - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode &= ~(B_VOICE_MEMO_DTX); - #if ((DSP == 34) || (DSP == 35) || (DSP == 36) || (DSP == 37) || (DSP == 38) || (DSP == 39)) - // use TCH/FS vocoder - l1s_dsp_com.dsp_ndb_ptr->d_tch_mode &= ~(B_VM_VOCODER_SELECT); - #endif - - - // Start the voice memo recodgin DSP task: - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_RECORD_START; - - *state = WAIT_DSP_START; - } - break; - - case WAIT_DSP_START: - { - // The DSP is started - if (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_VM_RECORD_ON_GOING) - { - *state = WAIT_DSP_SAMPLE; - } - } - break; - - case WAIT_DSP_SAMPLE: - { - // A beginning of word is detected - if ( ((l1s_dsp_com.dsp_ndb_ptr->d_sr_status & SC_SR_WORD_MASK) == SC_SR_WORD_BEGINNING) && - (l1s.speechreco.speech_old_status == SC_SR_WORD_SEARCHING) ) - { - // Calculate the address of the beginning of the word - l1a_l1s_com.speechreco_task.parameters.start_address = - l1s.speechreco.speech_pointer - ((SC_SR_SPEECH_WORD_BEGIN_VAD_LATENCY + SC_SR_SPEECH_WORD_BEGIN_MARGIN) * SC_SR_SPEECH_FRAME_SIZE); - if (l1a_l1s_com.speechreco_task.parameters.start_address < l1a_l1s_com.speechreco_task.parameters.speech_address) - { - if (l1s.speechreco.first_pass == FALSE) - { - l1a_l1s_com.speechreco_task.parameters.start_address = l1s.speechreco.end_pointer - - ( l1a_l1s_com.speechreco_task.parameters.speech_address - (l1s.speechreco.speech_pointer - ((SC_SR_SPEECH_WORD_BEGIN_VAD_LATENCY + SC_SR_SPEECH_WORD_BEGIN_MARGIN) * SC_SR_SPEECH_FRAME_SIZE)) ); - } - else - { - l1a_l1s_com.speechreco_task.parameters.start_address = l1a_l1s_com.speechreco_task.parameters.speech_address; - } - } - } - else - // A end of word is detected - if ( ((l1s_dsp_com.dsp_ndb_ptr->d_sr_status & SC_SR_WORD_MASK) == SC_SR_WORD_ENDING) && - (l1s.speechreco.speech_old_status == SC_SR_WORD_ON_GOING) ) - { - // Calculate the address of the end of the word - l1a_l1s_com.speechreco_task.parameters.stop_address = - l1s.speechreco.speech_pointer - ((SC_SR_SPEECH_WORD_END_VAD_LATENCY - SC_SR_SPEECH_WORD_END_MARGIN)* SC_SR_SPEECH_FRAME_SIZE); - if (l1a_l1s_com.speechreco_task.parameters.stop_address < l1a_l1s_com.speechreco_task.parameters.speech_address) - { - l1a_l1s_com.speechreco_task.parameters.stop_address = l1s.speechreco.end_pointer - - ( l1a_l1s_com.speechreco_task.parameters.speech_address - (l1s.speechreco.speech_pointer - ((SC_SR_SPEECH_WORD_END_VAD_LATENCY - SC_SR_SPEECH_WORD_END_MARGIN) * SC_SR_SPEECH_FRAME_SIZE)) ); - } - } - - // Save the current status - l1s.speechreco.speech_old_status = l1s_dsp_com.dsp_ndb_ptr->d_sr_status & SC_SR_WORD_MASK; - - // Determine which a_du buffer is currently used - l1s.speechreco.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_1; - if (l1a_l1s_com.dedic_set.aset != NULL) - { - if ( (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->channel_type == TCH_H) && - (l1a_l1s_com.dedic_set.aset->achan_ptr->desc_ptr->subchannel == 1) ) - l1s.speechreco.a_du_x = l1s_dsp_com.dsp_ndb_ptr->a_du_0; - } - - // The acquisition was good - if (l1s_dsp_com.dsp_ndb_ptr->d_sr_status & B_GOOD_ACQUISITION) - { - // Stop the voice memorization recording task - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_RECORD_STOP; - - *state = WAIT_DSP_STOP; - } - else - // The task must be stopped - if ( (l1s_dsp_com.dsp_ndb_ptr->d_sr_status & B_BAD_ACQUISITION) || - (l1a_l1s_com.speechreco_task.command.speech_stop) || - (l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init & B_SR_STOP) ) - { - // Stop the DSP voice memorization recording task: - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= B_VM_RECORD_STOP; - - *state = WAIT_DSP_STOP; - } - else - // The DSP sends a new block - if (l1s.speechreco.a_du_x[0] & B_BLOCK_READY) - { - // Is there enough place in the RAM buffer - if (l1s.speechreco.speech_pointer == l1s.speechreco.end_pointer) - { - // Rewind the current pointer - l1s.speechreco.speech_pointer = l1a_l1s_com.speechreco_task.parameters.speech_address; - - // It isn't the first pass - l1s.speechreco.first_pass = FALSE; - } - - // Download the speech sample from the a_du_x to the RAM buffer - a_du_x = l1s.speechreco.a_du_x; - for(i=0; i < SC_SR_SPEECH_FRAME_SIZE; i++) - { - *(l1s.speechreco.speech_pointer)++ = *a_du_x++; - } - - // Clear the a_du_x header - l1s.speechreco.a_du_x[0] = 0; - } - } - break; - - case WAIT_DSP_STOP: - { - // The DSP speech recoding task is stopped - if ( !(l1s_dsp_com.dsp_ndb_ptr->d_toneskb_status & B_VM_RECORD_ON_GOING) ) - { - *state = IDLE; - } - } - break; - } // switch - } - - #endif // SPEECH_RECO - #if (L1_AEC == 1) - /*-------------------------------------------------------*/ - /* l1s_aec_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : AEC L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_aec_manager(void) - { - enum states - { - IDLE = 0, - #if (L1_NEW_AEC) - WAIT_DSP_AVAILABLE = 1, - AEC_VISIBILITY = 2 - #else - WAIT_DSP_AVAILABLE = 1 - #endif - }; - - UWORD8 *state = &l1s.audio_state[L1S_AEC_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - // Set the d_aec_ctrl register - l1s.aec.aec_control = (l1a_l1s_com.aec_task.parameters.aec_control | B_AEC_ACK); - #if (L1_NEW_AEC) - l1s.aec.aec_visibility = (l1s.aec.aec_control & B_AEC_VISIBILITY) >> SC_AEC_VISIBILITY_SHIFT; - l1s.aec.cont_filter = l1a_l1s_com.aec_task.parameters.cont_filter; - l1s.aec.granularity_att = l1a_l1s_com.aec_task.parameters.granularity_att; - l1s.aec.coef_smooth = l1a_l1s_com.aec_task.parameters.coef_smooth; - l1s.aec.es_level_max = l1a_l1s_com.aec_task.parameters.es_level_max; - l1s.aec.fact_vad = l1a_l1s_com.aec_task.parameters.fact_vad; - l1s.aec.thrs_abs = l1a_l1s_com.aec_task.parameters.thrs_abs; - l1s.aec.fact_asd_fil = l1a_l1s_com.aec_task.parameters.fact_asd_fil; - l1s.aec.fact_asd_mut = l1a_l1s_com.aec_task.parameters.fact_asd_mut; - #endif - - // Reset the start command - l1a_l1s_com.aec_task.command.start = FALSE; - - // Send the AEC confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AEC_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_DSP_AVAILABLE; - } - break; - - case WAIT_DSP_AVAILABLE: - { - // the new settings come from the MMI - if (l1a_l1s_com.aec_task.command.start) - { - // Set the d_aec_ctrl register - l1s.aec.aec_control = (l1a_l1s_com.aec_task.parameters.aec_control | B_AEC_ACK); - #if (L1_NEW_AEC) - l1s.aec.aec_visibility = (l1s.aec.aec_control & B_AEC_VISIBILITY) >> SC_AEC_VISIBILITY_SHIFT; - l1s.aec.cont_filter = l1a_l1s_com.aec_task.parameters.cont_filter; - l1s.aec.granularity_att = l1a_l1s_com.aec_task.parameters.granularity_att; - l1s.aec.coef_smooth = l1a_l1s_com.aec_task.parameters.coef_smooth; - l1s.aec.es_level_max = l1a_l1s_com.aec_task.parameters.es_level_max; - l1s.aec.fact_vad = l1a_l1s_com.aec_task.parameters.fact_vad; - l1s.aec.thrs_abs = l1a_l1s_com.aec_task.parameters.thrs_abs; - l1s.aec.fact_asd_fil = l1a_l1s_com.aec_task.parameters.fact_asd_fil; - l1s.aec.fact_asd_mut = l1a_l1s_com.aec_task.parameters.fact_asd_mut; - #endif - - // Reset the start command - l1a_l1s_com.aec_task.command.start = FALSE; - - // Send the AEC confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AEC_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - - // the new settings can be written to the DSP -#if(DSP == 38) || (DSP == 39) - if ( (l1s_dsp_com.dsp_ndb_ptr->d_aec_ul_ctrl & B_AEC_ACK) == FALSE ) -#else - if ( (l1s_dsp_com.dsp_ndb_ptr->d_aec_ctrl & B_AEC_ACK) == FALSE ) -#endif - { - -#if(DSP == 38) || (DSP == 39) - l1s_dsp_com.dsp_ndb_ptr->d_aec_ul_ctrl = l1s.aec.aec_control; -#else - l1s_dsp_com.dsp_ndb_ptr->d_aec_ctrl = l1s.aec.aec_control; -#endif - - #if (L1_NEW_AEC) - l1s_dsp_com.dsp_ndb_ptr->d_cont_filter = l1s.aec.cont_filter; - l1s_dsp_com.dsp_ndb_ptr->d_granularity_att = l1s.aec.granularity_att; - l1s_dsp_com.dsp_ndb_ptr->d_coef_smooth = l1s.aec.coef_smooth; - l1s_dsp_com.dsp_ndb_ptr->d_es_level_max = l1s.aec.es_level_max; - l1s_dsp_com.dsp_ndb_ptr->d_fact_vad = l1s.aec.fact_vad; - l1s_dsp_com.dsp_ndb_ptr->d_thrs_abs = l1s.aec.thrs_abs; - l1s_dsp_com.dsp_ndb_ptr->d_fact_asd_fil = l1s.aec.fact_asd_fil; - l1s_dsp_com.dsp_ndb_ptr->d_fact_asd_mut = l1s.aec.fact_asd_mut; - - // AEC visibility allows tracing some AEC internal output values - if (l1s.aec.aec_visibility) - *state = AEC_VISIBILITY; - else - *state = IDLE; - #else - *state = IDLE; - #endif - } - } - break; - - #if (L1_NEW_AEC) - case AEC_VISIBILITY: - { - // the new settings come from the MMI - if (l1a_l1s_com.aec_task.command.start) - { - // Set the d_aec_ctrl register - l1s.aec.aec_control = (l1a_l1s_com.aec_task.parameters.aec_control | B_AEC_ACK); - l1s.aec.aec_visibility = (l1s.aec.aec_control & B_AEC_VISIBILITY) >> SC_AEC_VISIBILITY_SHIFT; - l1s.aec.cont_filter = l1a_l1s_com.aec_task.parameters.cont_filter; - l1s.aec.granularity_att = l1a_l1s_com.aec_task.parameters.granularity_att; - l1s.aec.coef_smooth = l1a_l1s_com.aec_task.parameters.coef_smooth; - l1s.aec.es_level_max = l1a_l1s_com.aec_task.parameters.es_level_max; - l1s.aec.fact_vad = l1a_l1s_com.aec_task.parameters.fact_vad; - l1s.aec.thrs_abs = l1a_l1s_com.aec_task.parameters.thrs_abs; - l1s.aec.fact_asd_fil = l1a_l1s_com.aec_task.parameters.fact_asd_fil; - l1s.aec.fact_asd_mut = l1a_l1s_com.aec_task.parameters.fact_asd_mut; - - // Reset the start command - l1a_l1s_com.aec_task.command.start = FALSE; - - // Send the AEC confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AEC_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_DSP_AVAILABLE; - } - - if ( (l1a_l1s_com.dedic_set.aset != NULL) && - ((l1a_l1s_com.dedic_set.aset->achan_ptr->mode == TCH_FS_MODE) || - (l1a_l1s_com.dedic_set.aset->achan_ptr->mode == TCH_HS_MODE) || - (l1a_l1s_com.dedic_set.aset->achan_ptr->mode == TCH_EFR_MODE)) ) - { - l1s.aec.visibility_interval--; - - if (l1s.aec.visibility_interval < 0) - { - conf_msg = os_alloc_sig(sizeof(T_L1_AEC_IND)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AEC_IND; - - ((T_L1_AEC_IND *)(conf_msg->SigP))->es_level = l1s_dsp_com.dsp_ndb_ptr->d_es_level_api; - ((T_L1_AEC_IND *)(conf_msg->SigP))->far_end_pow = ( (l1s_dsp_com.dsp_ndb_ptr->d_far_end_pow_h << 16) - | (l1s_dsp_com.dsp_ndb_ptr->d_far_end_pow_l)); - ((T_L1_AEC_IND *)(conf_msg->SigP))->far_end_noise = ( (l1s_dsp_com.dsp_ndb_ptr->d_far_end_noise_h << 16) - | (l1s_dsp_com.dsp_ndb_ptr->d_far_end_noise_l)); - - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - // reset delay between 2 traces - l1s.aec.visibility_interval = SC_AEC_VISIBILITY_INTERVAL; - } - } - else - // It forces aec traces when entering dedicated mode - l1s.aec.visibility_interval = 1; - } - break; - #endif - } // switch - } - #endif // AEC - - #if(L1_AEC == 2) - - /*-------------------------------------------------------*/ - /* l1s_aec_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : AEC L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ -void l1s_aec_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_ACK = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_AEC_STATE]; - xSignalHeaderRec *conf_msg; - UWORD16 current_state; - static T_AEC_ACTION l1s_aec_action = L1_AQI_AEC_STOPPED; - static UWORD16 l_aec_ctrl; - - - switch(*state) - { - case IDLE: - { - - current_state = l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & 0x0800; - - if((l1a_l1s_com.aec_task.aec_control == L1_AQI_AEC_START)||(l1a_l1s_com.aec_task.aec_control == L1_AQI_AEC_UPDATE)) - { - if(current_state ) - { - -#if(DSP == 38) || (DSP == 39) - l1s_dsp_com.dsp_ndb_ptr->d_aec_ul_ctrl = l1s_dsp_com.dsp_ndb_ptr->d_aec_ul_ctrl | 0x0004; -#else - l1s_dsp_com.dsp_ndb_ptr->d_aec_ctrl = l1s_dsp_com.dsp_ndb_ptr->d_aec_ctrl | 0x0004; -#endif - - l_aec_ctrl = 0x0004; - l1s_aec_action = L1_AQI_AEC_UPDATED; - } - else - { - - -#if(DSP == 38) || (DSP == 39) - l1s_dsp_com.dsp_ndb_ptr->d_aec_ul_ctrl = l1s_dsp_com.dsp_ndb_ptr->d_aec_ul_ctrl | 0x0001; -#else - l1s_dsp_com.dsp_ndb_ptr->d_aec_ctrl = l1s_dsp_com.dsp_ndb_ptr->d_aec_ctrl | 0x0001; -#endif - l_aec_ctrl = 0x0001; - l1s_aec_action = L1_AQI_AEC_STARTED; - } - - l1s_dsp_com.dsp_ndb_ptr->d_cont_filter = l1a_l1s_com.aec_task.parameters.cont_filter; - l1s_dsp_com.dsp_ndb_ptr->d_granularity_att = l1a_l1s_com.aec_task.parameters.granularity_att; - l1s_dsp_com.dsp_ndb_ptr->d_coef_smooth = l1a_l1s_com.aec_task.parameters.coef_smooth; - l1s_dsp_com.dsp_ndb_ptr->d_es_level_max = l1a_l1s_com.aec_task.parameters.es_level_max; - l1s_dsp_com.dsp_ndb_ptr->d_fact_vad = l1a_l1s_com.aec_task.parameters.fact_vad; - l1s_dsp_com.dsp_ndb_ptr->d_thrs_abs = l1a_l1s_com.aec_task.parameters.thrs_abs; - l1s_dsp_com.dsp_ndb_ptr->d_fact_asd_fil = l1a_l1s_com.aec_task.parameters.fact_asd_fil; - l1s_dsp_com.dsp_ndb_ptr->d_fact_asd_mut = l1a_l1s_com.aec_task.parameters.fact_asd_mut; - l1s_dsp_com.dsp_ndb_ptr->d_aec_mode = l1a_l1s_com.aec_task.parameters.aec_mode; - l1s_dsp_com.dsp_ndb_ptr->d_mu = l1a_l1s_com.aec_task.parameters.mu; - l1s_dsp_com.dsp_ndb_ptr->d_scale_input_ul = l1a_l1s_com.aec_task.parameters.scale_input_ul; - l1s_dsp_com.dsp_ndb_ptr->d_scale_input_dl = l1a_l1s_com.aec_task.parameters.scale_input_dl; - l1s_dsp_com.dsp_ndb_ptr->d_div_dmax = l1a_l1s_com.aec_task.parameters.div_dmax; - l1s_dsp_com.dsp_ndb_ptr->d_div_swap_good = l1a_l1s_com.aec_task.parameters.div_swap_good; - l1s_dsp_com.dsp_ndb_ptr->d_div_swap_bad = l1a_l1s_com.aec_task.parameters.div_swap_bad; - l1s_dsp_com.dsp_ndb_ptr->d_block_init = l1a_l1s_com.aec_task.parameters.block_init; - - - } - else if(l1a_l1s_com.aec_task.aec_control == L1_AQI_AEC_STOP) - { - if(current_state ) - { -#if(DSP == 38) || (DSP == 39) - l1s_dsp_com.dsp_ndb_ptr->d_aec_ul_ctrl = (l1s_dsp_com.dsp_ndb_ptr->d_aec_ul_ctrl) | 0x0002; -#else - l1s_dsp_com.dsp_ndb_ptr->d_aec_ctrl = (l1s_dsp_com.dsp_ndb_ptr->d_aec_ctrl) | 0x0002; -#endif - - l_aec_ctrl = 0x0002; - l1s_aec_action = L1_AQI_AEC_STOPPED; - } - else - { - l1a_l1s_com.aec_task.command.start = FALSE; - - // Send the AEC confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_L1_AQI_AEC_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_AEC_CON; - ((T_L1_AQI_AEC_CON*)(conf_msg->SigP))->aec_action = L1_AQI_AEC_NO_ACTION; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - return; - } - } - - *state = WAIT_DSP_ACK; - - - break; - } - - case WAIT_DSP_ACK: - { - -#if(DSP == 38) || (DSP == 39) - if(((l1s_dsp_com.dsp_ndb_ptr->d_aec_ul_ctrl) & (l_aec_ctrl)) == 0) -#else - if(((l1s_dsp_com.dsp_ndb_ptr->d_aec_ctrl) & (l_aec_ctrl)) == 0) -#endif - - { - l1a_l1s_com.aec_task.command.start = FALSE; - - // Send the AEC confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_L1_AQI_AEC_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_AEC_CON; - ((T_L1_AQI_AEC_CON*)(conf_msg->SigP))->aec_action = l1s_aec_action; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - - break; - } - }/* End of switch statement */ -} - - #endif - - #if (FIR) - /*-------------------------------------------------------*/ - /* l1s_fir_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : FIR L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - 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? - if (l1a_l1s_com.fir_task.parameters.update_fir & DL_FIR) - { - // 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; - #else - 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++; - } - } - } - 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 - } - } - } - - - } - #endif // FIR - #if (AUDIO_MODE) - /*-------------------------------------------------------*/ - /* l1s_audio_mode_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Audio mode L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_audio_mode_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_CONFIRM = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_AUDIO_MODE_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - - // Reset the d_audio_init - l1s_dsp_com.dsp_ndb_ptr->d_audio_init &= ~(B_GSM_ONLY | B_BT_HEADSET | B_BT_CORDLESS); - - // Set the new mode - l1s_dsp_com.dsp_ndb_ptr->d_audio_init - |= l1a_l1s_com.audio_mode_task.parameters.audio_mode; - - *state = WAIT_DSP_CONFIRM; - } - break; - - case WAIT_DSP_CONFIRM: - { - // the DSP acknowledges the new settings. - if ( l1s_dsp_com.dsp_ndb_ptr->d_audio_init == l1s_dsp_com.dsp_ndb_ptr->d_audio_status ) - { - // Send the Audio mode confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AUDIO_MODE_CON; - - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - // Reset the start command - l1a_l1s_com.audio_mode_task.command.start = FALSE; - - *state = IDLE; - } - } - break; - } // switch - } - #endif // AUDIO_MODE - #if (MELODY_E2) - /*-------------------------------------------------------*/ - /* l1s_melody0_e2_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Audio melody 0 format E2 L1S manager */ - /* task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_melody0_e2_manager(void) - { - enum states - { - M0_INACTIVE = 0, - M0_ALIGN_40MS_BOUNDARY = 1, - M0_WAIT_COUNTER_EQUAL_0 = 2, - M0_WAIT_END_MELODY = 3 - }; - - UWORD8 *state = &l1s.audio_state[L1S_MELODY0_E2_STATE]; - xSignalHeaderRec *conf_msg; - UWORD8 trash[SC_MELODY_E2_MAXIMUM_HEADER_SIZE+1], oscillator_number, extension_index; - UWORD16 oscillator_not_available; - - switch(*state) - { - case M0_INACTIVE: - { - // Reset the commands: - l1a_l1s_com.melody0_e2_task.command.start = FALSE; - - // Initialize the pointer and size to the new description - l1s.melody0_e2.ptr_buf = l1a_l1s_com.melody0_e2_task.parameters.ptr_buf; - l1s.melody0_e2.buffer_size = l1a_l1s_com.melody0_e2_task.parameters.buffer_size; - - *state = M0_ALIGN_40MS_BOUNDARY; - } - break; - - case M0_ALIGN_40MS_BOUNDARY: - { - // Initialize the counter to the first time - l1s.melody0_e2.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1s.melody0_e2.buffer_size, - (UWORD8 **)&l1s.melody0_e2.ptr_buf, - 1, - (UWORD8 *)(&l1s.melody0_e2.counter)); - - // Save the extension flag - l1s.melody0_e2.extension_flag = Field(l1s.melody0_e2.counter, - SC_MELODY_E2_EXTENSION_FLAG_MASK, - SC_MELODY_E2_EXTENSION_FLAG_SHIFT); - - // Save delta-time in 20ms unit - l1s.melody0_e2.counter = Field(l1s.melody0_e2.counter, - SC_MELODY_E2_DELTA_TIME_MASK, - SC_MELODY_E2_DELTA_TIME_SHIFT); - l1s.melody0_e2.note_start_20ms = l1s.melody0_e2.counter; - - // Adjust note_start on 20ms boundary because global counter could be running for another melody or loopback - // Timebase can be computed as k*60ms + timebase_mod_60ms - l1s.melody0_e2.note_start_20ms += ((l1s.melody_e2.timebase - l1s.melody_e2.timebase_mod_60ms) / 13 * 3); - if (l1s.melody_e2.timebase_mod_60ms < 4) - { - l1s.melody0_e2.note_start_20ms += 1; - } - else if (l1s.melody_e2.timebase_mod_60ms < 8) - { - l1s.melody0_e2.note_start_20ms += 2; - } - else if (l1s.melody_e2.timebase_mod_60ms < 13) - { - l1s.melody0_e2.note_start_20ms += 3; - } - - // Align on 40ms boundary - if ( (l1s.melody0_e2.note_start_20ms & 1) == 1 ) - l1s.melody0_e2.note_start_20ms++; - - // Convert to TDMA - l1s.melody0_e2.counter = audio_twentyms_to_TDMA_convertion(l1s.melody0_e2.note_start_20ms); - - // Compute TDMA to wait (-1 to take into account this TDMA) - l1s.melody0_e2.counter = l1s.melody0_e2.counter - l1s.melody_e2.timebase - 1; - - // Wait to download the first description - *state = M0_WAIT_COUNTER_EQUAL_0; - } // M0_INIT - break; - - case M0_WAIT_COUNTER_EQUAL_0: - { - // Stop command - if (l1a_l1s_com.melody0_e2_task.command.stop) - { - // wait until all the ocillator are stopped - *state = M0_WAIT_END_MELODY; - } - else if (l1s.melody0_e2.counter > 0) - { - // Decrease the counter - l1s.melody0_e2.counter--; - } - else - { - // Wait until the semaphore is set to 0 by the DSP - if (!(l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_semaphore & SC_MELODY_E2_SEMAPHORE_MASK)) - { - // Initialize oscillators available, oscillators can be used by the DSP (d_melody_e2_osc_active) - // or by the other melody E2 generator (melody_e2_osc_stop) - oscillator_not_available = - l1s.melody_e2.global_osc_active | l1s.melody_e2.global_osc_to_start; - - // find an available oscillator - oscillator_number = 0; - while( (oscillator_number < SC_MELODY_E2_NUMBER_OF_OSCILLATOR) && - (oscillator_not_available & (0x0001<<oscillator_number)) ) - { - oscillator_number++; - } - - // Initialize end of file - l1s.melody0_e2.end_of_file = FALSE; - - // download the description until the delta time is different from 0 - // or end of the melody file - while ( (l1s.melody0_e2.counter == 0) && - (l1s.melody0_e2.end_of_file == FALSE) ) - { - // Download the byte of the note descriptor extension in trash - l1s.melody0_e2.error_id= copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1s.melody0_e2.buffer_size, - (UWORD8 **)&l1s.melody0_e2.ptr_buf, - 2, - &trash[0]); - - // Check end of melody - if ( (trash[0] != 0x00) || (trash[1] != 0x00) ) - { - // It is not the end of melody - - // If an oscillator is available, use it - if (oscillator_number < SC_MELODY_E2_NUMBER_OF_OSCILLATOR) - { - // Reset the oscillator description - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_osc[oscillator_number][0] = 0x0000; - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_osc[oscillator_number][1] = 0x0000; - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_osc[oscillator_number][2] = 0x0000; - - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_osc[oscillator_number][0] = - trash[0] + (trash[1] << 8); - - // Update the oscillators to start bit field - l1s.melody_e2.global_osc_to_start |= (0x0001<<oscillator_number); - - // Save the oscillator as active for this melody - l1s.melody0_e2.oscillator_active |= (0x0001<<oscillator_number); - - // oscillator is no longer available - oscillator_not_available |= (0x0001<<oscillator_number); - } - - // Download the extensions - extension_index = 1; - while(l1s.melody0_e2.extension_flag) - { - // Download the byte of the note descriptor extension - l1s.melody0_e2.error_id= copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1s.melody0_e2.buffer_size, - (UWORD8 **)&l1s.melody0_e2.ptr_buf, - 2, - &trash[0]); - - // Read the extension flag - l1s.melody0_e2.extension_flag = Field(trash[0], - SC_MELODY_E2_EXTENSION_FLAG_MASK, - SC_MELODY_E2_EXTENSION_FLAG_SHIFT); - - // If an oscillator is available, use it - if (oscillator_number < SC_MELODY_E2_NUMBER_OF_OSCILLATOR) - { - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_osc[oscillator_number][extension_index] = - trash[0] + (trash[1] << 8); - } - - extension_index++; - } // extension download - - // find next available oscillator - while( (oscillator_number < SC_MELODY_E2_NUMBER_OF_OSCILLATOR) && - (oscillator_not_available & (0x0001<<oscillator_number)) ) - { - oscillator_number++; - } - - // Read next delta time - l1s.melody0_e2.error_id= copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1s.melody0_e2.buffer_size, - (UWORD8 **)&l1s.melody0_e2.ptr_buf, - 1, - (UWORD8 *)(&l1s.melody0_e2.counter)); - - // Save the extension flag - l1s.melody0_e2.extension_flag = Field(l1s.melody0_e2.counter, - SC_MELODY_E2_EXTENSION_FLAG_MASK, - SC_MELODY_E2_EXTENSION_FLAG_SHIFT); - - l1s.melody0_e2.counter = Field(l1s.melody0_e2.counter, - SC_MELODY_E2_DELTA_TIME_MASK, - SC_MELODY_E2_DELTA_TIME_SHIFT); - } // if ( (trash[0] != 0x00) || (trash[1] != 0x00) ) - else - { - // it's the end of the melody file - l1s.melody0_e2.end_of_file = TRUE; - } - } // while ( (l1s.melody0_e2.counter == 0) && (l1s.melody0_e2.end_of_file == FALSE) ) - - // Perform TDMA convertion or handle end of file - if (l1s.melody0_e2.end_of_file == FALSE) - { - // Update note start - l1s.melody0_e2.note_start_20ms += l1s.melody0_e2.counter; - - l1s.melody0_e2.delta_time = l1s.melody0_e2.counter; - - // Convert the delta time into TDMA time unit - l1s.melody0_e2.counter = audio_twentyms_to_TDMA_convertion(l1s.melody0_e2.note_start_20ms) - - l1s.melody_e2.timebase; - - // decrease the counter - l1s.melody0_e2.counter--; - - *state = M0_WAIT_COUNTER_EQUAL_0; - } - else - { - l1s.melody0_e2.delta_time = 0xFFFF; - *state = M0_WAIT_END_MELODY; - } - } // semaphore check - } // if (l1a_l1s_com.melody0_e2_task.command.stop) (2nd else) - } // case M0_WAIT_COUNTER_EQUAL_0: - break; - - case M0_WAIT_END_MELODY: - { - if (l1a_l1s_com.melody0_e2_task.command.stop) - { - // Stop immediatly the current melody - // Wait until the semaphore is set to 0 by the DSP to stop the current description - if (!(l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_semaphore & SC_MELODY_E2_SEMAPHORE_MASK)) - { - // Stop the oscillator mentionned in the bits field melody0_e2.oscillator_active - for(oscillator_number=0; oscillator_number<SC_MELODY_E2_NUMBER_OF_OSCILLATOR; oscillator_number++) - { - if (l1s.melody0_e2.oscillator_active & (0x0001<<oscillator_number)) - { - // Stop the current oscillator - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_osc_stop |= (0x0001<<oscillator_number); - } - } - // wait until all the oscillator are stopped - l1a_l1s_com.melody0_e2_task.parameters.loopback = FALSE; - l1a_l1s_com.melody0_e2_task.command.stop = FALSE; - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_deltatime = 0xFFFF;// another melody could be running - } // semaphore - } - else if (l1s.melody0_e2.oscillator_active == 0x0000) - { - // all oscillators are stopped - if (l1a_l1s_com.melody0_e2_task.parameters.loopback) - { - // It's the loopback mode - // Reset the pointer to the current melody - #if (OP_RIV_AUDIO == 0) - l1s.melody0_e2.ptr_buf = NULL; - #endif - l1s.melody0_e2.buffer_size = 0; - l1s.melody0_e2.error_id = Cust_get_pointer((UWORD16 **)&l1s.melody0_e2.ptr_buf, - &l1s.melody0_e2.buffer_size, - l1a_l1s_com.melody0_e2_task.parameters.session_id); - - // Jump the header field - l1s.melody0_e2.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody0_e2_task.parameters.session_id, - &l1s.melody0_e2.buffer_size, - (UWORD8 **)&l1s.melody0_e2.ptr_buf, - (UWORD16)(l1a_l1s_com.melody0_e2_task.parameters.header_size), - &trash[0]); - - // Wait until the description can be downloaded - *state = M0_ALIGN_40MS_BOUNDARY; - } - else - { - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_MELODY0_E2_STOP_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - // Go to inactive mode - *state = M0_INACTIVE; - } - } - break; - } // M0_WAIT_END_MELODY - } // switch - } // l1s_melody0_e2_manager - - /*-------------------------------------------------------*/ - /* l1s_melody1_e2_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Audio melody 0 format E2 L1S manager */ - /* task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_melody1_e2_manager(void) - { - enum states - { - M1_INACTIVE = 0, - M1_ALIGN_40MS_BOUNDARY = 1, - M1_WAIT_COUNTER_EQUAL_0 = 2, - M1_WAIT_END_MELODY = 3 - }; - - UWORD8 *state = &l1s.audio_state[L1S_MELODY1_E2_STATE]; - xSignalHeaderRec *conf_msg; - UWORD8 trash[SC_MELODY_E2_MAXIMUM_HEADER_SIZE+1], oscillator_number, extension_index; - UWORD16 oscillator_not_available; - - switch(*state) - { - case M1_INACTIVE: - { - // Reset the commands: - l1a_l1s_com.melody1_e2_task.command.start = FALSE; - - // Initialize the pointer and size to the new description - l1s.melody1_e2.ptr_buf = l1a_l1s_com.melody1_e2_task.parameters.ptr_buf; - l1s.melody1_e2.buffer_size = l1a_l1s_com.melody1_e2_task.parameters.buffer_size; - - *state = M1_ALIGN_40MS_BOUNDARY; - } - break; - - case M1_ALIGN_40MS_BOUNDARY: - { - // Initialize the counter to the first time - l1s.melody1_e2.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1s.melody1_e2.buffer_size, - (UWORD8 **)&l1s.melody1_e2.ptr_buf, - 1, - (UWORD8 *)(&l1s.melody1_e2.counter)); - - // Save the extension flag - l1s.melody1_e2.extension_flag = Field(l1s.melody1_e2.counter, - SC_MELODY_E2_EXTENSION_FLAG_MASK, - SC_MELODY_E2_EXTENSION_FLAG_SHIFT); - - // Save delta-time in 20ms unit - l1s.melody1_e2.counter = Field(l1s.melody1_e2.counter, - SC_MELODY_E2_DELTA_TIME_MASK, - SC_MELODY_E2_DELTA_TIME_SHIFT); - l1s.melody1_e2.note_start_20ms = l1s.melody1_e2.counter; - - // Adjust note_start on 20ms boundary because global counter could be running for another melody or loopback - // Timebase can be computed as k*60ms + timebase_mod_60ms - l1s.melody1_e2.note_start_20ms += ((l1s.melody_e2.timebase - l1s.melody_e2.timebase_mod_60ms) / 13 * 3); - if (l1s.melody_e2.timebase_mod_60ms < 4) - { - l1s.melody1_e2.note_start_20ms += 1; - } - else if (l1s.melody_e2.timebase_mod_60ms < 8) - { - l1s.melody1_e2.note_start_20ms += 2; - } - else if (l1s.melody_e2.timebase_mod_60ms < 13) - { - l1s.melody1_e2.note_start_20ms += 3; - } - - // Align on 40ms boundary - if ( (l1s.melody1_e2.note_start_20ms & 1) == 1 ) - l1s.melody1_e2.note_start_20ms++; - - // Convert to TDMA - l1s.melody1_e2.counter = audio_twentyms_to_TDMA_convertion(l1s.melody1_e2.note_start_20ms); - - // Compute TDMA to wait (-1 to take into account this TDMA) - l1s.melody1_e2.counter = l1s.melody1_e2.counter - l1s.melody_e2.timebase - 1; - - // Wait to download the first description - *state = M1_WAIT_COUNTER_EQUAL_0; - } // M1_INIT - break; - - case M1_WAIT_COUNTER_EQUAL_0: - { - // Stop command - if (l1a_l1s_com.melody1_e2_task.command.stop) - { - // wait until all the ocillator are stopped - *state = M1_WAIT_END_MELODY; - } - else if (l1s.melody1_e2.counter > 0) - { - // Decrease the counter - l1s.melody1_e2.counter--; - } - else - { - // Wait until the semaphore is set to 0 by the DSP - if (!(l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_semaphore & SC_MELODY_E2_SEMAPHORE_MASK)) - { - // Initialize oscillators available, oscillators can be used by the DSP (d_melody_e2_osc_active) - // or by the other melody E2 generator (melody_e2_osc_stop) - oscillator_not_available = - l1s.melody_e2.global_osc_active | l1s.melody_e2.global_osc_to_start; - - // find an available oscillator - oscillator_number = 0; - while( (oscillator_number < SC_MELODY_E2_NUMBER_OF_OSCILLATOR) && - (oscillator_not_available & (0x0001<<oscillator_number)) ) - { - oscillator_number++; - } - - // Initialize end of file - l1s.melody1_e2.end_of_file = FALSE; - - // download the description until the delta time is different from 0 - // or end of the melody file - while ( (l1s.melody1_e2.counter == 0) && - (l1s.melody1_e2.end_of_file == FALSE) ) - { - // Download the byte of the note descriptor extension in trash - l1s.melody1_e2.error_id= copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1s.melody1_e2.buffer_size, - (UWORD8 **)&l1s.melody1_e2.ptr_buf, - 2, - &trash[0]); - - // Check end of melody - if ( (trash[0] != 0x00) || (trash[1] != 0x00) ) - { - // It is not the end of melody - - // If an oscillator is available, use it - if (oscillator_number < SC_MELODY_E2_NUMBER_OF_OSCILLATOR) - { - // Reset the oscillator description - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_osc[oscillator_number][0] = 0x0000; - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_osc[oscillator_number][1] = 0x0000; - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_osc[oscillator_number][2] = 0x0000; - - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_osc[oscillator_number][0] = - trash[0] + (trash[1] << 8); - - // Update the oscillators to start bit field - l1s.melody_e2.global_osc_to_start |= (0x0001<<oscillator_number); - - // Save the oscillator as active for this melody - l1s.melody1_e2.oscillator_active |= (0x0001<<oscillator_number); - - // oscillator is no longer available - oscillator_not_available |= (0x0001<<oscillator_number); - } - - // Download the extensions - extension_index = 1; - while(l1s.melody1_e2.extension_flag) - { - // Download the byte of the note descriptor extension - l1s.melody1_e2.error_id= copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1s.melody1_e2.buffer_size, - (UWORD8 **)&l1s.melody1_e2.ptr_buf, - 2, - &trash[0]); - - // Read the extension flag - l1s.melody1_e2.extension_flag = Field(trash[0], - SC_MELODY_E2_EXTENSION_FLAG_MASK, - SC_MELODY_E2_EXTENSION_FLAG_SHIFT); - - // If an oscillator is available, use it - if (oscillator_number < SC_MELODY_E2_NUMBER_OF_OSCILLATOR) - { - l1s_dsp_com.dsp_ndb_ptr->a_melody_e2_osc[oscillator_number][extension_index] = - trash[0] + (trash[1] << 8); - } - - extension_index++; - } // extension download - - // find next available oscillator - while( (oscillator_number < SC_MELODY_E2_NUMBER_OF_OSCILLATOR) && - (oscillator_not_available & (0x0001<<oscillator_number)) ) - { - oscillator_number++; - } - - // Read next delta time - l1s.melody1_e2.error_id= copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1s.melody1_e2.buffer_size, - (UWORD8 **)&l1s.melody1_e2.ptr_buf, - 1, - (UWORD8 *)(&l1s.melody1_e2.counter)); - - // Save the extension flag - l1s.melody1_e2.extension_flag = Field(l1s.melody1_e2.counter, - SC_MELODY_E2_EXTENSION_FLAG_MASK, - SC_MELODY_E2_EXTENSION_FLAG_SHIFT); - - l1s.melody1_e2.counter = Field(l1s.melody1_e2.counter, - SC_MELODY_E2_DELTA_TIME_MASK, - SC_MELODY_E2_DELTA_TIME_SHIFT); - } // if ( (trash[0] != 0x00) || (trash[1] != 0x00) ) - else - { - // it's the end of the melody file - l1s.melody1_e2.end_of_file = TRUE; - } - } // while ( (l1s.melody1_e2.counter == 0) && (l1s.melody1_e2.end_of_file == FALSE) ) - - // Perform TDMA convertion or handle end of file - if (l1s.melody1_e2.end_of_file == FALSE) - { - // Update note start - l1s.melody1_e2.note_start_20ms += l1s.melody1_e2.counter; - - l1s.melody1_e2.delta_time = l1s.melody1_e2.counter; - - // Convert the delta time into TDMA time unit - l1s.melody1_e2.counter = audio_twentyms_to_TDMA_convertion(l1s.melody1_e2.note_start_20ms) - - l1s.melody_e2.timebase; - - // decrease the counter - l1s.melody1_e2.counter--; - - *state = M1_WAIT_COUNTER_EQUAL_0; - } - else - { - l1s.melody1_e2.delta_time = 0xFFFF; - *state = M1_WAIT_END_MELODY; - } - } // semaphore check - } // if (l1a_l1s_com.melody1_e2_task.command.stop) (2nd else) - } // case M1_WAIT_COUNTER_EQUAL_0: - break; - - case M1_WAIT_END_MELODY: - { - if (l1a_l1s_com.melody1_e2_task.command.stop) - { - // Stop immediatly the current melody - // Wait until the semaphore is set to 0 by the DSP to stop the current description - if (!(l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_semaphore & SC_MELODY_E2_SEMAPHORE_MASK)) - { - // Stop the oscillator mentionned in the bits field melody1_e2.oscillator_active - for(oscillator_number=0; oscillator_number<SC_MELODY_E2_NUMBER_OF_OSCILLATOR; oscillator_number++) - { - if (l1s.melody1_e2.oscillator_active & (0x0001<<oscillator_number)) - { - // Stop the current oscillator - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_osc_stop |= (0x0001<<oscillator_number); - } - } - // wait until all the oscillator are stopped - l1a_l1s_com.melody1_e2_task.parameters.loopback = FALSE; - l1a_l1s_com.melody1_e2_task.command.stop = FALSE; - l1s_dsp_com.dsp_ndb_ptr->d_melody_e2_deltatime = 0xFFFF; // another melody could be running - } // semaphore - } - else if (l1s.melody1_e2.oscillator_active == 0x0000) - { - // all oscillators are stopped - if (l1a_l1s_com.melody1_e2_task.parameters.loopback) - { - // It's the loopback mode - // Reset the pointer to the current melody - #if (OP_RIV_AUDIO == 0) - l1s.melody1_e2.ptr_buf = NULL; - #endif - l1s.melody1_e2.buffer_size = 0; - l1s.melody1_e2.error_id = Cust_get_pointer((UWORD16 **)&l1s.melody1_e2.ptr_buf, - &l1s.melody1_e2.buffer_size, - l1a_l1s_com.melody1_e2_task.parameters.session_id); - - // Jump the header field - l1s.melody1_e2.error_id = copy_byte_data_from_buffer (l1a_l1s_com.melody1_e2_task.parameters.session_id, - &l1s.melody1_e2.buffer_size, - (UWORD8 **)&l1s.melody1_e2.ptr_buf, - (UWORD16)(l1a_l1s_com.melody1_e2_task.parameters.header_size), - &trash[0]); - - // Wait until the description can be downloaded - *state = M1_ALIGN_40MS_BOUNDARY; - } - else - { - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_MELODY1_E2_STOP_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - // Go to inactive mode - *state = M1_INACTIVE; - } - } - break; - } // M1_WAIT_END_MELODY - } // switch - } // l1s_melody1_e2_manager - - #endif // MELODY_E2 - - #if (L1_CPORT == 1) - /*-------------------------------------------------------*/ - /* l1s_cport_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Cport L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_cport_manager(void) - { - enum states - { - IDLE = 0, - WAIT_CPORT_CONF = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_CPORT_STATE]; - xSignalHeaderRec *conf_msg; - API temp_write_var; - - switch(*state) - { - case IDLE: - { - // Check if a cport configuration is not yet in progress in DSP - if (l1s_dsp_com.dsp_ndb_ptr->d_cport_status == (API) (CPORT_R_NONE | CPORT_W_NONE)) - { - // ok, we can start the DSP Cport configuration task - if (l1a_l1s_com.cport_task.parameters.configuration & CPORT_W_CTRL) - l1s_dsp_com.dsp_ndb_ptr->d_cport_ctrl = l1a_l1s_com.cport_task.parameters.ctrl; - - if (l1a_l1s_com.cport_task.parameters.configuration & (CPORT_W_CPCFR1 | CPORT_W_CPCFR2)) - { - temp_write_var = 0; - - if (l1a_l1s_com.cport_task.parameters.configuration & CPORT_W_CPCFR1) - temp_write_var = l1a_l1s_com.cport_task.parameters.cpcfr1 << 8; - - if (l1a_l1s_com.cport_task.parameters.configuration & CPORT_W_CPCFR2) - temp_write_var |= l1a_l1s_com.cport_task.parameters.cpcfr2; - - l1s_dsp_com.dsp_ndb_ptr->a_cport_cfr[0] = temp_write_var; - } - - - if (l1a_l1s_com.cport_task.parameters.configuration & (CPORT_W_CPCFR3 | CPORT_W_CPCFR4)) - { - temp_write_var = 0; - - if (l1a_l1s_com.cport_task.parameters.configuration & CPORT_W_CPCFR3) - temp_write_var = l1a_l1s_com.cport_task.parameters.cpcfr3 << 8; - - if (l1a_l1s_com.cport_task.parameters.configuration & CPORT_W_CPCFR4) - temp_write_var |= l1a_l1s_com.cport_task.parameters.cpcfr4; - - l1s_dsp_com.dsp_ndb_ptr->a_cport_cfr[1] = temp_write_var; - } - - - if (l1a_l1s_com.cport_task.parameters.configuration & (CPORT_W_CPTCTL | CPORT_W_CPTTADDR)) - { - temp_write_var = 0; - - if (l1a_l1s_com.cport_task.parameters.configuration & CPORT_W_CPTCTL) - temp_write_var = l1a_l1s_com.cport_task.parameters.cptctl << 8; - - if (l1a_l1s_com.cport_task.parameters.configuration & CPORT_W_CPTTADDR) - temp_write_var |= l1a_l1s_com.cport_task.parameters.cpttaddr; - - l1s_dsp_com.dsp_ndb_ptr->d_cport_tcl_tadt = temp_write_var; - } - - - if (l1a_l1s_com.cport_task.parameters.configuration & CPORT_W_CPTDAT) - l1s_dsp_com.dsp_ndb_ptr->d_cport_tdat = l1a_l1s_com.cport_task.parameters.cptdat; - - if (l1a_l1s_com.cport_task.parameters.configuration & CPORT_W_CPTVS) - l1s_dsp_com.dsp_ndb_ptr->d_cport_tvs = l1a_l1s_com.cport_task.parameters.cptvs; - - l1s_dsp_com.dsp_ndb_ptr->d_cport_init = l1a_l1s_com.cport_task.parameters.configuration; - - *state = WAIT_CPORT_CONF; - - // Reset the command - l1a_l1s_com.cport_task.command.start = FALSE; - - } - - // else, we do nothing -> check will be done again at next frame - } - break; - - case WAIT_CPORT_CONF: - { - // the DSP acknowledges the L1S start request. - if (l1s_dsp_com.dsp_ndb_ptr->d_cport_init - == l1s_dsp_com.dsp_ndb_ptr->d_cport_status) - { - // task is over - l1s_dsp_com.dsp_ndb_ptr->d_cport_init = (API) (CPORT_R_NONE | CPORT_W_NONE); - l1s_dsp_com.dsp_ndb_ptr->d_cport_ctrl = (API) 0; - l1s_dsp_com.dsp_ndb_ptr->a_cport_cfr[0] = (API) 0; - l1s_dsp_com.dsp_ndb_ptr->a_cport_cfr[1] = (API) 0; - l1s_dsp_com.dsp_ndb_ptr->d_cport_tcl_tadt = (API) 0; - l1s_dsp_com.dsp_ndb_ptr->d_cport_tdat = (API) 0; - l1s_dsp_com.dsp_ndb_ptr->d_cport_tvs = (API) 0; - - // Send the configuration confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(sizeof(T_L1_CPORT_CONFIGURE_CON)); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_CPORT_CONFIGURE_CON; - - //Fill the message - ((T_L1_CPORT_CONFIGURE_CON *)(conf_msg->SigP))->register_id = (l1s_dsp_com.dsp_ndb_ptr->d_cport_status & CPORT_READ_MASK); - ((T_L1_CPORT_CONFIGURE_CON *)(conf_msg->SigP))->register_value = l1s_dsp_com.dsp_ndb_ptr->d_cport_reg_value; - - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - - } // switch - } - #endif // L1_CPORT == 1 - - /*-------------------------------------------------------*/ - /* l1s_audio_it_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Audio it manager */ - /* */ - /*-------------------------------------------------------*/ - void l1s_audio_it_manager(void) - { - // Reset the command : - l1a_l1s_com.audioIt_task.command.start = FALSE; - - // this is an empty state machin only used to generate an - // audio IT to DSP in case another sw entity has changed - // something in the API - } - - - #if (L1_EXTERNAL_AUDIO_VOICE_ONOFF == 1) - /*-------------------------------------------------------*/ - /* l1s_audio_onoff_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : audio on/off L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_audio_onoff_manager(void) - { - enum states - { - IDLE = 0, - WAIT_AUDIO_ONOFF_CON = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_AUDIO_ONOFF_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - // Disable the start command - l1a_l1s_com.audio_onoff_task.command.start = FALSE; - - // Update the audio on/off value except if the L1S is already forcing it - if ((l1a_l1s_com.audio_onoff_task.parameters.onoff_value == TRUE) && - (l1a_l1s_com.audio_forced_by_l1s == FALSE)) - // l1a_l1s_com.audio_onoff_task.parameters.onoff_value == AUDIO_ON - { - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= (API) B_AUDIO_ON_START; - } - else if ((l1a_l1s_com.audio_onoff_task.parameters.onoff_value == FALSE) && - (l1a_l1s_com.audio_forced_by_l1s == FALSE)) - // l1a_l1s_com.audio_onoff_task.parameters.onoff_value == AUDIO_OFF - { - l1s_dsp_com.dsp_ndb_ptr->d_toneskb_init |= (API) B_AUDIO_OFF_STOP; - } - - *state = WAIT_AUDIO_ONOFF_CON; - } - break; - - case WAIT_AUDIO_ONOFF_CON: - { - // The L1 has to send the confirmation message even if the request was to disable the audio on/off - // and it is still forced. This confirmation message is only to acknowledge the reception of the message, - // it is not correlated to the state of the audio into the DSP. - - // Allocate memory for confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AUDIO_ONOFF_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - break; - - } // switch - } - #endif - - #if (L1_EXT_MCU_AUDIO_VOICE_ONOFF == 1) - /*-------------------------------------------------------*/ - /* l1s_audio_onoff_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : audio on/off L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_audio_voice_onoff_manager(void) - { - enum states - { - IDLE = 0, - WAIT_AUDIO_ONOFF_CON = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_AUDIO_ONOFF_STATE]; - UWORD8 *ul_state = &l1s.audio_state[L1S_AUDIO_UL_ONOFF_STATE]; - UWORD8 *dl_state = &l1s.audio_state[L1S_AUDIO_DL_ONOFF_STATE]; - UWORD8 *vul_state = &l1a_l1s_com.audio_onoff_task.parameters.vul_onoff_value; - UWORD8 *vdl_state = &l1a_l1s_com.audio_onoff_task.parameters.vdl_onoff_value; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - // Disable the start command - l1a_l1s_com.audio_onoff_task.command.start = FALSE; - - // Update the Voice Uplink count - if(l1a_l1s_com.audio_onoff_task.parameters.vul_onoff_value == L1_AUDIO_VOICE_UL_ON) - { - l1s.audio_on_off_ctl.l1_audio_switch_on_ul_request++; - } - else if(l1a_l1s_com.audio_onoff_task.parameters.vul_onoff_value == L1_AUDIO_VOICE_UL_OFF ) - { - if(l1s.audio_on_off_ctl.l1_audio_switch_on_ul_request) - l1s.audio_on_off_ctl.l1_audio_switch_on_ul_request--; - } - - // Update the Voice Downlink count - if(l1a_l1s_com.audio_onoff_task.parameters.vdl_onoff_value == L1_AUDIO_VOICE_DL_ON) - { - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request++; - } - else if(l1a_l1s_com.audio_onoff_task.parameters.vdl_onoff_value == L1_AUDIO_VOICE_DL_OFF) - { - if(l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request) - l1s.audio_on_off_ctl.l1_audio_switch_on_dl_request--; - } - - *state = WAIT_AUDIO_ONOFF_CON; - } - break; - - case WAIT_AUDIO_ONOFF_CON: - { - // For Voice Uplink or Downlink switch on is done only after the VUL or VDL is actually switched ON - // For switch off there could be potentially other tasks that use the VUL or VDL and hence a blind - // confirmation is given - if( (((*vul_state == L1_AUDIO_VOICE_UL_ON) && (*ul_state == L1_AUDIO_UL_ON)) || - (*vul_state == L1_AUDIO_VOICE_UL_OFF) || (*vul_state == L1_AUDIO_VOICE_UL_NO_ACTION)) && - (((*vdl_state == L1_AUDIO_VOICE_DL_ON) && (*dl_state == L1_AUDIO_DL_ON)) || - (*vdl_state == L1_AUDIO_VOICE_DL_OFF) || (*vdl_state == L1_AUDIO_VOICE_DL_NO_ACTION))) - { - // The L1 has to send the confirmation message even if the request was to disable the audio on/off - // and it is still forced. This confirmation message is only to acknowledge the reception of the message, - // it is not correlated to the state of the audio into the DSP. - - // Allocate memory for confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AUDIO_ONOFF_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - - } // switch - } - #endif - - #if (L1_STEREOPATH == 1) - /*-------------------------------------------------------*/ - /* l1s_stereopath_drv_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : Generic Stereopath L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ -#if (CODE_VERSION == SIMULATION) - void l1s_stereopath_drv_manager(void) - { - enum states - { - IDLE=0, - WAIT_STOP - }; - - xSignalHeaderRec *conf_msg; - - if(l1a_l1s_com.stereopath_drv_task.command.start==TRUE) - { - // reset the command - l1a_l1s_com.stereopath_drv_task.command.start=FALSE; - - // change state - l1s.audio_state[L1S_STEREOPATH_DRV_STATE]=WAIT_STOP; - - // send confirmation to the L1A - conf_msg=os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode=L1_STEREOPATH_DRV_START_CON; - os_send_sig(conf_msg,L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - - if(l1a_l1s_com.stereopath_drv_task.command.stop==TRUE) - { - // reset the command - l1a_l1s_com.stereopath_drv_task.command.stop=FALSE; - - // change state - l1s.audio_state[L1S_STEREOPATH_DRV_STATE]=IDLE; - - // send confirmation to the L1A - conf_msg=os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode=L1_STEREOPATH_DRV_STOP_CON; - os_send_sig(conf_msg,L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } -#else // CODE_VERSION - void l1s_stereopath_drv_manager(void) - { - //sundi: change in the enum values for the ABB states -#if (ANALOG == 11) - enum states - { - IDLE = 0, - ABB_CONFIGURE_DONE = 1, - ABB_START = 2, - ABB_START_DONE = 3, - DMA_CONF = 4, - CPORT_CONF = 5, - CPORT_START = 6, - WAIT_STOP = 7, - CPORT_STOP = 8, - ABB_STOP_DONE = 9, - DMA_STOP = 10, - STOP_CON = 11 - }; -#else - enum states - { - IDLE = 0, - ABB_START = 1, - DMA_CONF = 2, - CPORT_CONF = 3, - CPORT_START = 4, - WAIT_STOP = 5, - CPORT_STOP = 6, - DMA_STOP = 7, - STOP_CON = 8 - }; -#endif - - UWORD8 *state = &l1s.audio_state[L1S_STEREOPATH_DRV_STATE]; - xSignalHeaderRec *conf_msg; - static UWORD16 wait_pll_on_counter = L1S_STEREOPATH_DRV_WAIT_PLL_COUNTER; - - // This is the default parameters structure for a DMA channel - static T_DMA_TYPE_CHANNEL_PARAMETER d_dma_channel_parameter= - { - f_dma_default_call_back_it, // call back function - C_DMA_CHANNEL_2, // channel number - C_DMA_CHANNEL_NOT_SECURED, // channel security - C_DMA_DATA_S16, // data type - C_DMA_IMIF_PORT, // source port - C_DMA_CHANNEL_NOT_PACKED, // source packing - C_DMA_CHANNEL_SINGLE, // source bursting - C_DMA_RHEA_PORT, // destination port - C_DMA_CHANNEL_NOT_PACKED, // destination packing - C_DMA_CHANNEL_SINGLE, // destination bursting - C_DMA_CHANNEL_CPORT_TX, // hw synchro - C_DMA_CHANNEL_PRIORITY_HIGH, // channel priority - C_DMA_CHANNEL_AUTO_INIT_ON, // autoinit option - C_DMA_CHANNEL_FIFO_FLUSH_OFF, // fifo flush option - C_DMA_CHANNEL_ADDR_MODE_POST_INC, // source addressing mode - C_DMA_CHANNEL_ADDR_MODE_CONSTANT, // destination addressing mode - C_DMA_CHANNEL_IT_TIME_OUT_ON, // IT time out control - C_DMA_CHANNEL_IT_DROP_ON, // IT drop control - C_DMA_CHANNEL_IT_FRAME_OFF, // IT frame control - C_DMA_CHANNEL_IT_BLOCK_ON, // IT block control - C_DMA_CHANNEL_IT_HALF_BLOCK_ON, // IT half_block control - 0, // source start address - 0xFFFFD800L, // destination start address - 2, // element number - 0 // frame number - }; - - switch(*state) - { - case IDLE: - { -#if (ANALOG == 11) - //Sundi:Set the abb_write_done variable to 0. This variable gets set in I2C call back fn. - l1s.abb_write_done = 0; -#endif - // Configure the ABB audio part in order to get the correct clock for the Cport - l1s_stereopath_drv_config_ABB(l1a_l1s_com.stereopath_drv_task.parameters.mono_stereo, - l1a_l1s_com.stereopath_drv_task.parameters.sampling_frequency); - -#if (ANALOG == 11) - // Must wait for the PLL to be locked. The value of 1 is subtracted from the standard value - // in order to take care of the extra state added - ABB_CONFIGURE_DONE. - wait_pll_on_counter = L1S_STEREOPATH_DRV_WAIT_PLL_COUNTER - 1; -#else - // Must wait for the PLL to be locked. - wait_pll_on_counter = L1S_STEREOPATH_DRV_WAIT_PLL_COUNTER; - -#endif - - // Reset the command - l1a_l1s_com.stereopath_drv_task.command.start = FALSE; -#if (ANALOG == 11) - //sundi: change the state to ABB_CONFIGURE_DONE to wait for I2C write ACK. - *state = ABB_CONFIGURE_DONE; - -#else - *state = ABB_START; -#endif - } - break; -#if (ANALOG == 11) - //sundi: add the new state - case ABB_CONFIGURE_DONE: - { - //sundi: continue to be in this state till an I2C write ACK comes. - //abb_write_done is set to 1 by the call back function - //that is passed to the I2C write function. - if (l1s.abb_write_done == 1) - { - *state = ABB_START; - - } - } - break; -#endif - case ABB_START: - { - if (wait_pll_on_counter == 0) - { -#if (ANALOG == 11) - //Sundi:Set the abb_write_done variable to 0. This variable gets set in I2C call back fn. - l1s.abb_write_done = 0; -#endif - // PLL is locked, the ABB can be started - l1s_stereopath_drv_start_ABB(); -#if (ANALOG == 11) - //sundi: Change state to ABB_START_DONE - *state = ABB_START_DONE; -#else - *state = DMA_CONF; -#endif - } - else - wait_pll_on_counter--; - } - break; -#if (ANALOG == 11) - //sundi: Add the new state ABB_START_DONE - case ABB_START_DONE: - { - //sundi: continue to be in this state till an I2C write ACK comes. - //abb_write_done is set to 1 by the call back function - //that is passed to the I2C write function. - if (l1s.abb_write_done == 1) - { - *state = DMA_CONF; - - } - } - break; -#endif - // After 1 TDMA frame, DSP has necessarily programmed ABB - case DMA_CONF: - { - // update the DMA defaut parameters structure with received parameters - d_dma_channel_parameter.pf_dma_call_back_address = (T_DMA_CALL_BACK) l1a_l1s_com.stereopath_drv_task.parameters.DMA_int_callback_fct; - d_dma_channel_parameter.d_dma_channel_number = (T_DMA_TYPE_CHANNEL_NUMBER) l1a_l1s_com.stereopath_drv_task.parameters.DMA_channel_number; - d_dma_channel_parameter.d_dma_channel_data_type = (T_DMA_TYPE_CHANNEL_DATA_TYPE) l1a_l1s_com.stereopath_drv_task.parameters.data_type; - d_dma_channel_parameter.d_dma_channel_src_port = (T_DMA_TYPE_CHANNEL_PORT) l1a_l1s_com.stereopath_drv_task.parameters.source_port; - d_dma_channel_parameter.d_dma_channel_src_address = (SYS_UWORD32) l1a_l1s_com.stereopath_drv_task.parameters.source_buffer_address; - d_dma_channel_parameter.d_dma_channel_element_number = (SYS_UWORD16) l1a_l1s_com.stereopath_drv_task.parameters.element_number; - d_dma_channel_parameter.d_dma_channel_frame_number = (SYS_UWORD16) l1a_l1s_com.stereopath_drv_task.parameters.frame_number; - - // Configure and start the DMA channel - l1s_stereopath_drv_start_DMA(d_dma_channel_parameter,l1a_l1s_com.stereopath_drv_task.parameters.DMA_allocation); - - // Reset the Cport - l1s_stereopath_drv_reset_CPORT(); - - *state = CPORT_CONF; - - } - break; - - case CPORT_CONF: - { - // Configure the Cport - l1s_stereopath_drv_config_CPORT(); - - *state = CPORT_START; - - } - break; - - case CPORT_START: - { - // Start the Cport - l1s_stereopath_drv_start_CPORT(); - - // Send the start confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_STEREOPATH_DRV_START_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = WAIT_STOP; - } - break; - - case WAIT_STOP: - { - /* OUTEN registers have been updated */ - if(l1a_l1s_com.outen_cfg_task.command_requested != l1a_l1s_com.outen_cfg_task.command_commited) - { - l1s_stereopath_callback(L1S_TWL3029_STEROPATH_START); - } - if (l1a_l1s_com.stereopath_drv_task.command.stop) - { - // Stop command received - - // Reset the Cport - l1s_stereopath_drv_reset_CPORT(); - - *state = CPORT_STOP; - - // Disable the stop command - l1a_l1s_com.stereopath_drv_task.command.stop = FALSE; - } - } - break; - - case CPORT_STOP: - { - // Stop the Cport - l1s_stereopath_drv_stop_CPORT(); -#if (ANALOG == 11) - //Set the abb_write_done variable to 0. This variable gets set in I2C call back fn. - l1s.abb_write_done = 0; -#endif - // Stop the ABB - l1s_stereopath_drv_stop_ABB(); -#if (ANALOG == 11) - //sundi: change state to ABB_STOP_DONE - *state = ABB_STOP_DONE; -#else - *state = DMA_STOP; -#endif - } - break; -#if (ANALOG == 11) - //sundi: Add a new state ABB_STOP_DONE - case ABB_STOP_DONE: - { - //sundi:continue to be in this state till an I2C write ACK comes. - //abb_write_done is set to 1 by the call back function - //that is passed to the I2C write function. - if (l1s.abb_write_done == 1) - { - *state = DMA_STOP; - } - } - break; -#endif - case DMA_STOP: - { - // Reset the DMA channel - l1s_stereopath_drv_reset_DMA(d_dma_channel_parameter); - - *state = STOP_CON; - } - break; - - case STOP_CON: - { - // Send the stop confirmation message - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_STEREOPATH_DRV_STOP_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR); - - *state = IDLE; - } - break; - - } // switch - } -#endif // CODE_VERSION - #endif // L1_STEREOPATH == 1 - - #if (L1_ANR == 1) - /*-------------------------------------------------------*/ - /* l1s_anr_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : ANR L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_anr_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_ACK = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_ANR_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - if (l1a_l1s_com.anr_task.parameters.anr_enable) - { - // ANR start requested - //-------------------- - - // Set ANR parameters - l1s_dsp_com.dsp_ndb_ptr->d_anr_min_gain = l1a_l1s_com.anr_task.parameters.min_gain; - l1s_dsp_com.dsp_ndb_ptr->d_anr_div_factor_shift = l1a_l1s_com.anr_task.parameters.div_factor_shift; - l1s_dsp_com.dsp_ndb_ptr->d_anr_ns_level = l1a_l1s_com.anr_task.parameters.ns_level; -#if (DSP == 38) || (DSP == 39) - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_ANR_UL_STATE) -#else - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_ANR_STATE) -#endif - { - // ANR already started: update the DSP ANR module - l1s_dsp_com.dsp_ndb_ptr->d_anr_ul_ctrl = B_ANR_FULL_UPDATE; - - *state = WAIT_DSP_ACK; - } - else - { - // Set ANR constants - l1s_dsp_com.dsp_ndb_ptr->d_anr_vad_thr = C_ANR_VAD_THR; - l1s_dsp_com.dsp_ndb_ptr->d_anr_gamma_slow = C_ANR_GAMMA_SLOW; - l1s_dsp_com.dsp_ndb_ptr->d_anr_gamma_fast = C_ANR_GAMMA_FAST; - l1s_dsp_com.dsp_ndb_ptr->d_anr_gamma_gain_slow = C_ANR_GAMMA_GAIN_SLOW; - l1s_dsp_com.dsp_ndb_ptr->d_anr_gamma_gain_fast = C_ANR_GAMMA_GAIN_FAST; - l1s_dsp_com.dsp_ndb_ptr->d_anr_thr2 = C_ANR_THR2; - l1s_dsp_com.dsp_ndb_ptr->d_anr_thr4 = C_ANR_THR4; - l1s_dsp_com.dsp_ndb_ptr->d_anr_thr5 = C_ANR_THR5; - l1s_dsp_com.dsp_ndb_ptr->d_anr_mean_ratio_thr1 = C_ANR_MEAN_RATIO_THR1; - l1s_dsp_com.dsp_ndb_ptr->d_anr_mean_ratio_thr2 = C_ANR_MEAN_RATIO_THR2; - l1s_dsp_com.dsp_ndb_ptr->d_anr_mean_ratio_thr3 = C_ANR_MEAN_RATIO_THR3; - l1s_dsp_com.dsp_ndb_ptr->d_anr_mean_ratio_thr4 = C_ANR_MEAN_RATIO_THR4; - - // Enable the DSP ANR module - l1s_dsp_com.dsp_ndb_ptr->d_anr_ul_ctrl = B_ANR_ENABLE; - - *state = WAIT_DSP_ACK; - } - } - else // ANR start requested - { - // ANR stop requested - //------------------- -#if (DSP == 38) || (DSP == 39) - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_ANR_UL_STATE) -#else - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_ANR_STATE) -#endif - { - // Disable the DSP ANR module - l1s_dsp_com.dsp_ndb_ptr->d_anr_ul_ctrl = B_ANR_DISABLE; - - *state = WAIT_DSP_ACK; - } - else - { - // ANR already disabled: confirm - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_ANR_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } - - // Disable the update command - l1a_l1s_com.anr_task.command.update = FALSE; - } - break; - - case WAIT_DSP_ACK: - { - // The DSP acknowledged the L1S command - if (l1s_dsp_com.dsp_ndb_ptr->d_anr_ul_ctrl == 0) - { - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_ANR_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - #endif // L1_ANR == 1 - - #if (L1_ANR == 2) - /*-------------------------------------------------------*/ - /* l1s_anr_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : ANR 2.13 L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_anr_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_ACK = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_ANR_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - if (l1a_l1s_com.anr_task.parameters.anr_ul_control == ANR_START || - l1a_l1s_com.anr_task.parameters.anr_ul_control == ANR_UPDATE ) - { - // ANR start or update requested - //------------------------------ - - // Set ANR parameters - l1s_dsp_com.dsp_ndb_ptr->d_anr_control = l1a_l1s_com.anr_task.parameters.control; - l1s_dsp_com.dsp_ndb_ptr->d_anr_ns_level = l1a_l1s_com.anr_task.parameters.ns_level; - l1s_dsp_com.dsp_ndb_ptr->d_anr_tone_ene_th = l1a_l1s_com.anr_task.parameters.tone_ene_th; - l1s_dsp_com.dsp_ndb_ptr->d_anr_tone_cnt_th = l1a_l1s_com.anr_task.parameters.tone_cnt_th; - - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_ANR_UL_STATE) - { - // ANR already started: update the DSP ANR module - l1s_dsp_com.dsp_ndb_ptr->d_anr_ul_ctrl = B_ANR_FULL_UPDATE; - l1s.anr_ul_action = ANR_UPDATED; - - *state = WAIT_DSP_ACK; - } - else - { - // Enable the DSP ANR module - l1s_dsp_com.dsp_ndb_ptr->d_anr_ul_ctrl = B_ANR_ENABLE; - l1s.anr_ul_action = ANR_STARTED; - - *state = WAIT_DSP_ACK; - } - } - - - if (l1a_l1s_com.anr_task.parameters.anr_ul_control == ANR_STOP) - { - // ANR stop requested - //------------------- - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_ANR_UL_STATE) - { - // Disable the DSP ANR module - l1s_dsp_com.dsp_ndb_ptr->d_anr_ul_ctrl = B_ANR_DISABLE; - l1s.anr_ul_action = ANR_STOPPED; - - *state = WAIT_DSP_ACK; - } - else - { - // ANR already disabled: confirm - // Allocate confirmation message... - l1s.anr_ul_action = ANR_NO_ACTION; - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_ANR_CON; - ((T_L1_AQI_ANR_CON *)(conf_msg->SigP))->anr_ul_action = l1s.anr_ul_action; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } - - // Disable the update command - l1a_l1s_com.anr_task.command.update = FALSE; - } - break; - - case WAIT_DSP_ACK: - { - // The DSP acknowledged the L1S command - if (l1s_dsp_com.dsp_ndb_ptr->d_anr_ul_ctrl == 0) - { - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_ANR_CON; - ((T_L1_AQI_ANR_CON *)(conf_msg->SigP))->anr_ul_action = l1s.anr_ul_action; - - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - #endif // L1_ANR == 2 - - #if (L1_IIR == 1) - /*-------------------------------------------------------*/ - /* l1s_iir_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : IIR L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_iir_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_ACK = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_IIR_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - if (l1a_l1s_com.iir_task.parameters.iir_enable) - { - UWORD8 i; - - // IIR start requested - //-------------------- - - // Set IIR parameters - l1s_dsp_com.dsp_ndb_ptr->d_iir_nb_iir_blocks = l1a_l1s_com.iir_task.parameters.nb_iir_blocks; - - for (i=0; i < (l1a_l1s_com.iir_task.parameters.nb_iir_blocks * 8); i++) - l1s_dsp_com.dsp_ndb_ptr->a_iir_iir_coefs[i] = l1a_l1s_com.iir_task.parameters.iir_coefs[i]; - - l1s_dsp_com.dsp_ndb_ptr->d_iir_nb_fir_coefs = l1a_l1s_com.iir_task.parameters.nb_fir_coefs; - - for (i=0; i < l1a_l1s_com.iir_task.parameters.nb_fir_coefs; i++) - l1s_dsp_com.dsp_ndb_ptr->a_iir_fir_coefs[i] = l1a_l1s_com.iir_task.parameters.fir_coefs[i]; - - l1s_dsp_com.dsp_ndb_ptr->d_iir_input_scaling = l1a_l1s_com.iir_task.parameters.input_scaling; - l1s_dsp_com.dsp_ndb_ptr->d_iir_fir_scaling = l1a_l1s_com.iir_task.parameters.fir_scaling; - l1s_dsp_com.dsp_ndb_ptr->d_iir_input_gain_scaling = l1a_l1s_com.iir_task.parameters.input_gain_scaling; - l1s_dsp_com.dsp_ndb_ptr->d_iir_output_gain_scaling = l1a_l1s_com.iir_task.parameters.output_gain_scaling; - l1s_dsp_com.dsp_ndb_ptr->d_iir_output_gain = l1a_l1s_com.iir_task.parameters.output_gain; - l1s_dsp_com.dsp_ndb_ptr->d_iir_feedback = l1a_l1s_com.iir_task.parameters.feedback; - -#if (DSP == 38) || (DSP == 39) - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_IIR_DL_STATE) -#else - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_IIR_STATE) -#endif - { - // IIR already started: update the DSP IIR module - l1s_dsp_com.dsp_ndb_ptr->d_iir_dl_ctrl = B_IIR_FULL_UPDATE; - - *state = WAIT_DSP_ACK; - } - else - { - // Enable the DSP IIR module - l1s_dsp_com.dsp_ndb_ptr->d_iir_dl_ctrl = B_IIR_ENABLE; - - *state = WAIT_DSP_ACK; - } - } - else // IIR start requested - { - // IIR stop requested - //------------------- -#if (DSP == 38) || (DSP == 39) - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_IIR_DL_STATE) -#else - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_IIR_STATE) -#endif - { - // Disable the DSP IIR module - l1s_dsp_com.dsp_ndb_ptr->d_iir_dl_ctrl = B_IIR_DISABLE; - - *state = WAIT_DSP_ACK; - } - else - { - // IIR already disabled: confirm - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_IIR_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } - - // Disable the update command - l1a_l1s_com.iir_task.command.update = FALSE; - } - break; - - case WAIT_DSP_ACK: - { - // The DSP acknowledged the L1S command - if (l1s_dsp_com.dsp_ndb_ptr->d_iir_dl_ctrl == 0) - { - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_IIR_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - #endif // L1_IIR == 1 - - #if (L1_AGC_UL == 1) - /*-------------------------------------------------------*/ - /* l1s_agc_ul_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : AGC_UL L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_agc_ul_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_ACK = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_AGC_UL_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - if (l1a_l1s_com.agc_ul_task.parameters.agc_ul_control == AGC_START || - l1a_l1s_com.agc_ul_task.parameters.agc_ul_control == AGC_UPDATE) - { - // AGC_UL start or update requested - //--------------------------------- - - // Set AGC UL parameters - - l1_audio_agc_ul_copy_params(); - - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_AGC_UL_STATE) - { - // AGC UL already started: update the DSP AGC UL module - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_ctrl = B_AGC_FULL_UPDATE; - l1s.agc_ul_action = AGC_UPDATED; - - *state = WAIT_DSP_ACK; - } - else - { - - // Enable the DSP AGC UL module - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_ctrl = B_AGC_ENABLE; - l1s.agc_ul_action = AGC_STARTED; - - *state = WAIT_DSP_ACK; - } - } - - if (l1a_l1s_com.agc_ul_task.parameters.agc_ul_control == AGC_STOP) - { - // AGC UL stop requested - //------------------- - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_AGC_UL_STATE) - { - // Disable the DSP AGC UL module - l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_ctrl = B_AGC_DISABLE; - l1s.agc_ul_action = AGC_STOPPED; - - *state = WAIT_DSP_ACK; - } - else - { - // AGC UL already disabled: confirm - // Allocate confirmation message... - l1s.agc_ul_action = AGC_NO_ACTION; - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_AGC_UL_CON; - ((T_L1_AQI_AGC_UL_CON *)(conf_msg->SigP))->agc_ul_action = l1s.agc_ul_action; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } - - // Disable the update command - l1a_l1s_com.agc_ul_task.command.update = FALSE; - } - break; - - case WAIT_DSP_ACK: - { - // The DSP acknowledged the L1S command - if (l1s_dsp_com.dsp_ndb_ptr->d_agc_ul_ctrl == 0) - { - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_AGC_UL_CON; - ((T_L1_AQI_AGC_UL_CON *)(conf_msg->SigP))->agc_ul_action = l1s.agc_ul_action; - - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - #endif // L1_AGC_UL == 1 - - - #if (L1_AGC_DL == 1) - /*-------------------------------------------------------*/ - /* l1s_agc_dl_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : AGC DL L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_agc_dl_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_ACK = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_AGC_DL_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - if (l1a_l1s_com.agc_dl_task.parameters.agc_dl_control == AGC_START || - l1a_l1s_com.agc_dl_task.parameters.agc_dl_control == AGC_UPDATE) - { - // AGC DL start or update requested - //--------------------------------- - - // Set AGC DL parameters - - l1_audio_agc_dl_copy_params(); - - - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_AGC_DL_STATE) - { - // AGC DL already started: update the DSP AGC DL module - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_ctrl = B_AGC_FULL_UPDATE; - l1s.agc_dl_action = AGC_UPDATED; - - *state = WAIT_DSP_ACK; - } - else - { - - // Enable the DSP AGC DL module - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_ctrl = B_AGC_ENABLE; - l1s.agc_dl_action = AGC_STARTED; - - *state = WAIT_DSP_ACK; - } - } - - if (l1a_l1s_com.agc_dl_task.parameters.agc_dl_control == AGC_STOP) - { - // AGC DL stop requested - //------------------- - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_AGC_DL_STATE) - { - // Disable the DSP AGC DL module - l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_ctrl = B_AGC_DISABLE; - l1s.agc_dl_action = AGC_STOPPED; - - *state = WAIT_DSP_ACK; - } - else - { - // AGC DL already disabled: confirm - // Allocate confirmation message... - l1s.agc_dl_action = AGC_NO_ACTION; - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_AGC_DL_CON; - ((T_L1_AQI_AGC_DL_CON *)(conf_msg->SigP))->agc_dl_action = l1s.agc_dl_action; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } - - // Disable the update command - l1a_l1s_com.agc_dl_task.command.update = FALSE; - } - break; - - case WAIT_DSP_ACK: - { - // The DSP acknowledged the L1S command - if (l1s_dsp_com.dsp_ndb_ptr->d_agc_dl_ctrl == 0) - { - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_AGC_DL_CON; - ((T_L1_AQI_AGC_DL_CON *)(conf_msg->SigP))->agc_dl_action = l1s.agc_dl_action; - - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - #endif // L1_AGC_DL == 1 - -#if (L1_IIR == 2) - /*-------------------------------------------------------*/ - /* l1s_iir_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : IIR L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_iir_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_ACK = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_IIR_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - if (l1a_l1s_com.iir_task.parameters->iir_dl_control == IIR_START || - l1a_l1s_com.iir_task.parameters->iir_dl_control == IIR_UPDATE ) - { - // IIR start or update requested - //------------------------------ - - l1_audio_iir4x_copy_params(); - - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_IIR_DL_STATE) - { - // IIR already started: update the DSP IIR module - l1s_dsp_com.dsp_ndb_ptr->d_iir_dl_ctrl = B_IIR_FULL_UPDATE; - l1s.iir_dl_action = IIR_UPDATED; - - *state = WAIT_DSP_ACK; - } - else - { - // Enable the DSP IIR module - l1s_dsp_com.dsp_ndb_ptr->d_iir_dl_ctrl = B_IIR_ENABLE; - l1s.iir_dl_action = IIR_STARTED; - - *state = WAIT_DSP_ACK; - } - } - - if (l1a_l1s_com.iir_task.parameters->iir_dl_control == IIR_STOP) - { - // IIR stop requested - //------------------- - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_IIR_DL_STATE) - { - // Disable the DSP IIR module - l1s_dsp_com.dsp_ndb_ptr->d_iir_dl_ctrl = B_IIR_DISABLE; - l1s.iir_dl_action = IIR_STOPPED; - - *state = WAIT_DSP_ACK; - } - else - { - // IIR already disabled: confirm - // Allocate confirmation message... - l1s.iir_dl_action = IIR_NO_ACTION; - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_IIR_DL_CON; - ((T_L1_AQI_IIR_DL_CON *)(conf_msg->SigP))->iir_dl_action = l1s.iir_dl_action; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } - - // Disable the update command - l1a_l1s_com.iir_task.command.update = FALSE; - } - break; - - case WAIT_DSP_ACK: - { - // The DSP acknowledged the L1S command - if (l1s_dsp_com.dsp_ndb_ptr->d_iir_dl_ctrl == 0) - { - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_IIR_DL_CON; - ((T_L1_AQI_IIR_DL_CON *)(conf_msg->SigP))->iir_dl_action = l1s.iir_dl_action; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - #endif // L1_IIR == 2 - - #if (L1_WCM == 1) - /*-------------------------------------------------------*/ - /* l1s_wcm_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : WCM L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_wcm_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_ACK = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_WCM_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - if (l1a_l1s_com.wcm_task.parameters->wcm_control == WCM_START || - l1a_l1s_com.wcm_task.parameters->wcm_control == WCM_UPDATE ) - { - UWORD8 i; - - // WCM start or update requested - //------------------------------ - - l1s_dsp_com.dsp_ndb_ptr->d_wcm_mode = l1a_l1s_com.wcm_task.parameters->parameters.mode; - l1s_dsp_com.dsp_ndb_ptr->d_wcm_frame_size = l1a_l1s_com.wcm_task.parameters->parameters.frame_size; - l1s_dsp_com.dsp_ndb_ptr->d_wcm_num_sub_frames = l1a_l1s_com.wcm_task.parameters->parameters.num_sub_frames; - l1s_dsp_com.dsp_ndb_ptr->d_wcm_ratio = l1a_l1s_com.wcm_task.parameters->parameters.ratio; - l1s_dsp_com.dsp_ndb_ptr->d_wcm_threshold = l1a_l1s_com.wcm_task.parameters->parameters.threshold; - - for (i=0; i < (WCM_1X_GAIN_TABLE_LENGTH); i++) - { - l1s_dsp_com.dsp_ndb_ptr->a_wcm_gain[i] = l1a_l1s_com.wcm_task.parameters->parameters.gain[i]; - } - - if (l1s_dsp_com.dsp_ndb_ptr->d_audio_apps_status & B_WCM_STATE) - { - // WCM already started: update the DSP WCM module - l1s_dsp_com.dsp_ndb_ptr->d_audio_apps_ctrl = B_WCM_FULL_UPDATE; - l1s.wcm_action = WCM_UPDATED; - - *state = WAIT_DSP_ACK; - } - else - { - // Enable the DSP WCM module - l1s_dsp_com.dsp_ndb_ptr->d_audio_apps_ctrl = B_WCM_ENABLE; - l1s.wcm_action = WCM_STARTED; - - *state = WAIT_DSP_ACK; - } - } - - if (l1a_l1s_com.wcm_task.parameters->wcm_control == WCM_STOP) - { - // WCM stop requested - //------------------- - if (l1s_dsp_com.dsp_ndb_ptr->d_audio_apps_status & B_WCM_STATE) - { - // Disable the DSP WCM module - l1s_dsp_com.dsp_ndb_ptr->d_audio_apps_ctrl = B_WCM_DISABLE; - l1s.wcm_action = WCM_STOPPED; - - *state = WAIT_DSP_ACK; - } - else - { - // WCM already disabled: confirm - // Allocate confirmation message... - l1s.wcm_action = WCM_NO_ACTION; - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_WCM_CON; - ((T_L1_AQI_WCM_CON *)(conf_msg->SigP))->wcm_action = l1s.wcm_action; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } - - // Disable the update command - l1a_l1s_com.wcm_task.command.update = FALSE; - } - break; - - case WAIT_DSP_ACK: - { - // The DSP acknowledged the L1S command - if (l1s_dsp_com.dsp_ndb_ptr->d_audio_apps_ctrl == 0) - { - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_WCM_CON; - ((T_L1_AQI_WCM_CON *)(conf_msg->SigP))->wcm_action = l1s.wcm_action; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - #endif // L1_WCM == 2 - -#if (L1_DRC == 1) - /*-------------------------------------------------------*/ - /* l1s_drc_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : DRC L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_drc_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_ACK = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_DRC_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - if (l1a_l1s_com.drc_task.parameters->drc_dl_control == DRC_START || - l1a_l1s_com.drc_task.parameters->drc_dl_control == DRC_UPDATE) - { - // DRC start or update requested - //------------------------------ - - l1_audio_drc1x_copy_params(); - - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_DRC_DL_STATE) - { - // DRC already started: update the DSP DRC module - l1s_dsp_com.dsp_ndb_ptr->d_drc_dl_ctrl = B_DRC_FULL_UPDATE; - l1s.drc_dl_action = DRC_UPDATED; - - *state = WAIT_DSP_ACK; - } - else - { - // Enable the DSP DRC module - l1s_dsp_com.dsp_ndb_ptr->d_drc_dl_ctrl = B_DRC_ENABLE; - l1s.drc_dl_action = DRC_STARTED; - - *state = WAIT_DSP_ACK; - } - } - - if (l1a_l1s_com.drc_task.parameters->drc_dl_control == DRC_STOP) - { - // DRC stop requested - //------------------- - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_DRC_DL_STATE) - { - // Disable the DSP DRC module - l1s_dsp_com.dsp_ndb_ptr->d_drc_dl_ctrl = B_DRC_DISABLE; - l1s.drc_dl_action = DRC_STOPPED; - - *state = WAIT_DSP_ACK; - } - else - { - // DRC already disabled: confirm - // Allocate confirmation message... - l1s.drc_dl_action = DRC_NO_ACTION; - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_DRC_CON; - ((T_L1_AQI_DRC_CON *)(conf_msg->SigP))->drc_dl_action = l1s.drc_dl_action; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } - - // Disable the update command - l1a_l1s_com.drc_task.command.update = FALSE; - } - break; - - case WAIT_DSP_ACK: - { - // The DSP acknowledged the L1S command - if (l1s_dsp_com.dsp_ndb_ptr->d_drc_dl_ctrl == 0) - { - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_AQI_DRC_CON; - ((T_L1_AQI_DRC_CON *)(conf_msg->SigP))->drc_dl_action = l1s.drc_dl_action; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - #endif // L1_DRC == 1 - - #if (L1_LIMITER == 1) - /*-------------------------------------------------------*/ - /* l1s_limiter_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : LIMITER L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_limiter_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_ACK = 1, - WAIT_PARTIAL_UPDATE = 2 - }; - - UWORD8 *state = &l1s.audio_state[L1S_LIMITER_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - /* LIMITER update command */ - /*------------------------*/ - - if (l1a_l1s_com.limiter_task.command.update) - { - if (l1a_l1s_com.limiter_task.parameters.limiter_enable) - { - UWORD8 i; - - // LIMITER start requested - //------------------------ - - // Set LIMITER parameters - l1s_dsp_com.dsp_ndb_ptr->d_lim_block_size = l1a_l1s_com.limiter_task.parameters.block_size; - l1s_dsp_com.dsp_ndb_ptr->d_lim_slope_update_period = l1a_l1s_com.limiter_task.parameters.slope_update_period; - l1s_dsp_com.dsp_ndb_ptr->d_lim_nb_fir_coefs = l1a_l1s_com.limiter_task.parameters.nb_fir_coefs; - - for (i=0; i < ((l1a_l1s_com.limiter_task.parameters.nb_fir_coefs - 1)>>1) + 1; i++) - l1s_dsp_com.dsp_ndb_ptr->a_lim_filter_coefs[i] = l1a_l1s_com.limiter_task.parameters.filter_coefs[i]; - - l1s_dsp_com.dsp_ndb_ptr->d_lim_gain_fall_q15 = l1a_l1s_com.limiter_task.parameters.gain_fall; - l1s_dsp_com.dsp_ndb_ptr->d_lim_gain_rise_q15 = l1a_l1s_com.limiter_task.parameters.gain_rise; - - // a_lim_mul_low/high computation and update - l1_audio_lim_update_mul_low_high(); - - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_LIM_STATE) - { - // LIMITER already started: update the DSP LIMITER module - l1s_dsp_com.dsp_ndb_ptr->d_lim_dl_ctrl = B_LIM_FULL_UPDATE; - - *state = WAIT_DSP_ACK; - } - else - { - // Enable the DSP LIMITER module - l1s_dsp_com.dsp_ndb_ptr->d_lim_dl_ctrl = B_LIM_ENABLE; - - *state = WAIT_DSP_ACK; - } - } - else // LIMITER start requested - { - // LIMITER stop requested - //----------------------- - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_LIM_STATE) - { - // Disable the DSP LIMITER module - l1s_dsp_com.dsp_ndb_ptr->d_lim_dl_ctrl = B_LIM_DISABLE; - - *state = WAIT_DSP_ACK; - } - else - { - // LIMITER already disabled: confirm - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_LIMITER_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } - - // Disable the update command - l1a_l1s_com.limiter_task.command.update = FALSE; - } // LIMITER update - - /* LIMITER partial update command */ - /*--------------------------------*/ - - else if (l1a_l1s_com.limiter_task.command.partial_update) - { - // Only update if the module is enabled - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_LIM_STATE) - { - // a_lim_mul_low/high computation and update - l1_audio_lim_update_mul_low_high(); - - // Partial update of the DSP LIMITER module - l1s_dsp_com.dsp_ndb_ptr->d_lim_dl_ctrl = B_LIM_UPDATE; - - *state = WAIT_PARTIAL_UPDATE; - } - - // Disable the partial update command - l1a_l1s_com.limiter_task.command.partial_update = FALSE; - } - } - break; - - case WAIT_DSP_ACK: - { - // The DSP acknowledged the L1S command - if (l1s_dsp_com.dsp_ndb_ptr->d_lim_dl_ctrl == 0) - { - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_LIMITER_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - - case WAIT_PARTIAL_UPDATE: - { - // The DSP acknowledged the L1S command - if (l1s_dsp_com.dsp_ndb_ptr->d_lim_dl_ctrl == 0) - { - *state = IDLE; - } - } - break; - } // switch - } - #endif // L1_LIMITER == 1 - - #if (L1_ES == 1) - - /*******************************************/ - /* ES configuration tables */ - /*******************************************/ -#pragma DATA_SECTION(default_es_configs,".flashcnst"); -const T_ES_CONFIG default_es_configs[7] = - { - // Behavior 1 - { - (B_ES_UL | B_ES_DL | B_ES_NSF), - C_ES_GAIN_DL_OFF, - C_ES_GAIN_UL_1_OFF, - C_ES_GAIN_UL_2_OFF, - C_ES_TCL_6DB, - C_ES_TCL_0DB, - C_ES_TCL_12DB, - C_ES_TCL_6DB, - C_ES_TCL_0DB, - C_ES_TCL_LOUD, - C_ES_SW_CNT, - C_ES_DT_CNT, - C_ES_HG_CNT_1, - /* DL attenuation */ - {C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_0DB, C_ES_ATT_LIN_3DB}, - /* UL attenuation */ - {C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_15DB, C_ES_ATT_LIN_0DB} - } , - - // Behavior 1a - { - (B_ES_UL | B_ES_DL), - C_ES_GAIN_DL_OFF, - C_ES_GAIN_UL_1_OFF, - C_ES_GAIN_UL_2_OFF, - C_ES_TCL_6DB, - C_ES_TCL_0DB, - C_ES_TCL_12DB, - C_ES_TCL_6DB, - C_ES_TCL_0DB, - C_ES_TCL_LOUD, - C_ES_SW_CNT, - C_ES_DT_CNT, - C_ES_HG_CNT_1A, - /* DL attenuation */ - {C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_0DB, C_ES_ATT_LIN_3DB}, - /* UL attenuation */ - {C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_6DB, C_ES_ATT_LIN_0DB} - } , - - // Behavior 2a - { - (B_ES_UL | B_ES_DL | B_ES_NSF), - C_ES_GAIN_DL_OFF, - C_ES_GAIN_UL_1_OFF, - C_ES_GAIN_UL_2_OFF, - C_ES_TCL_6DB, - C_ES_TCL_0DB, - C_ES_TCL_12DB, - C_ES_TCL_6DB, - C_ES_TCL_0DB, - C_ES_TCL_LOUD, - C_ES_SW_CNT, - C_ES_DT_CNT, - C_ES_HG_CNT_2A, - /* DL attenuation */ - {C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_5DB, C_ES_ATT_LIN_0DB, C_ES_ATT_LIN_5DB}, - /* UL attenuation */ - {C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_6DB, C_ES_ATT_LIN_24DB, C_ES_ATT_LIN_0DB} - } , - - // Behavior 2b - { - (B_ES_UL | B_ES_DL | B_ES_CNG), - C_ES_GAIN_DL_OFF, - C_ES_GAIN_UL_1_OFF, - C_ES_GAIN_UL_2_OFF, - C_ES_TCL_6DB, - C_ES_TCL_0DB, - C_ES_TCL_10DB, - C_ES_TCL_4DB, - C_ES_TCL_0DB, - C_ES_TCL_LOUD, - C_ES_SW_CNT, - C_ES_DT_CNT, - C_ES_HG_CNT_2B, - /* DL attenuation */ - {C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_8DB, C_ES_ATT_LIN_0DB, C_ES_ATT_LIN_8DB}, - /* UL attenuation */ - {C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_9DB, C_ES_ATT_LIN_36DB, C_ES_ATT_LIN_0DB} - } , - - // Behavior 2c - { - (B_ES_UL | B_ES_DL | B_ES_CNG), - C_ES_GAIN_DL_OFF, - C_ES_GAIN_UL_1_OFF, - C_ES_GAIN_UL_2_OFF, - C_ES_TCL_M6DB, - C_ES_TCL_M23DB, - C_ES_TCL_0DB, - C_ES_TCL_M6DB, - C_ES_TCL_M3DB, - C_ES_TCL_LOUD, - C_ES_SW_CNT, - C_ES_DT_CNT, - C_ES_HG_CNT_2C, - /* DL attenuation */ - {C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_10DB, C_ES_ATT_LIN_0DB, C_ES_ATT_LIN_10DB}, - /* UL attenuation */ - {C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_12DB, C_ES_ATT_LIN_48DB, C_ES_ATT_LIN_0DB} - } , - - // Behavior 2c_idle - { - (B_ES_UL | B_ES_DL | B_ES_CNG), - C_ES_GAIN_DL_OFF, - C_ES_GAIN_UL_1_OFF, - C_ES_GAIN_UL_2_OFF, - C_ES_TCL_M6DB, - C_ES_TCL_M23DB, - C_ES_TCL_0DB, - C_ES_TCL_M6DB, - C_ES_TCL_M3DB, - C_ES_TCL_LOUD, - C_ES_SW_CNT, - C_ES_DT_CNT, - C_ES_HG_CNT_2C_IDLE, - /* DL attenuation */ - {C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_10DB, C_ES_ATT_LIN_0DB, C_ES_ATT_LIN_10DB}, - /* UL attenuation */ - {C_ES_ATT_LIN_12DB, C_ES_ATT_LIN_12DB, C_ES_ATT_LIN_48DB, C_ES_ATT_LIN_0DB} - } , - - // Behavior 3 - { - (B_ES_UL | B_ES_DL | B_ES_CNG), - C_ES_GAIN_DL_OFF, - C_ES_GAIN_UL_1_OFF, - C_ES_GAIN_UL_2_OFF, - C_ES_TCL_B3_FE_LS, - C_ES_TCL_B3_DT_LS, - C_ES_TCL_B3_FE_NS, - C_ES_TCL_B3_DT_NS, - C_ES_TCL_B3_NE, - C_ES_TCL_LOUD, - C_ES_SW_CNT, - C_ES_DT_CNT, - C_ES_HG_CNT_3, - /* DL attenuation */ - {C_ES_ATT_LIN_3DB, C_ES_ATT_LIN_16DB, C_ES_ATT_LIN_0DB, C_ES_ATT_LIN_21DB}, - /* UL attenuation */ - {C_ES_ATT_LIN_19DB, C_ES_ATT_LIN_19DB, C_ES_ATT_LIN_66DB, C_ES_ATT_LIN_0DB} - } - }; - - /*-------------------------------------------------------*/ - /* l1s_es_manager() */ - /*-------------------------------------------------------*/ - /* */ - /* Parameters : */ - /* */ - /* Return : */ - /* */ - /* Description : ES L1S manager task. */ - /* */ - /*-------------------------------------------------------*/ - void l1s_es_manager(void) - { - enum states - { - IDLE = 0, - WAIT_DSP_ACK = 1 - }; - - UWORD8 *state = &l1s.audio_state[L1S_ES_STATE]; - xSignalHeaderRec *conf_msg; - - switch(*state) - { - case IDLE: - { - if (l1a_l1s_com.es_task.parameters.es_enable) - { - const T_ES_CONFIG *es_cfg; - - // ES start requested - //-------------------- - - // Set ES parameters - if (l1a_l1s_com.es_task.parameters.es_behavior == ES_CUSTOM_PARAM) - { - es_cfg = &(l1a_l1s_com.es_task.parameters.es_config); - } - else - { - es_cfg = &(default_es_configs[l1a_l1s_com.es_task.parameters.es_behavior]); - } - - // Set parameters in the API - l1s_dsp_com.dsp_ndb_ptr->d_es_mode = es_cfg->es_mode; - l1s_dsp_com.dsp_ndb_ptr->d_es_gain_dl = es_cfg->es_gain_dl; - l1s_dsp_com.dsp_ndb_ptr->d_es_gain_ul_1 = es_cfg->es_gain_ul_1; - l1s_dsp_com.dsp_ndb_ptr->d_es_gain_ul_2 = es_cfg->es_gain_ul_2; - l1s_dsp_com.dsp_ndb_ptr->d_es_tcl_fe_ls_thr = es_cfg->tcl_fe_ls_thr; - l1s_dsp_com.dsp_ndb_ptr->d_es_tcl_dt_ls_thr = es_cfg->tcl_dt_ls_thr; - l1s_dsp_com.dsp_ndb_ptr->d_es_tcl_fe_ns_thr = es_cfg->tcl_fe_ns_thr; - l1s_dsp_com.dsp_ndb_ptr->d_es_tcl_dt_ns_thr = es_cfg->tcl_dt_ns_thr; - l1s_dsp_com.dsp_ndb_ptr->d_es_tcl_ne_thr = es_cfg->tcl_ne_thr; - l1s_dsp_com.dsp_ndb_ptr->d_es_ref_ls_pwr = es_cfg->ref_ls_pwr; - l1s_dsp_com.dsp_ndb_ptr->d_es_switching_time = es_cfg->switching_time; - l1s_dsp_com.dsp_ndb_ptr->d_es_switching_time_dt = es_cfg->switching_time_dt; - l1s_dsp_com.dsp_ndb_ptr->d_es_hang_time = es_cfg->hang_time; - l1s_dsp_com.dsp_ndb_ptr->a_es_gain_lin_dl_vect[0] = es_cfg->gain_lin_dl_vect[0]; - l1s_dsp_com.dsp_ndb_ptr->a_es_gain_lin_dl_vect[1] = es_cfg->gain_lin_dl_vect[1]; - l1s_dsp_com.dsp_ndb_ptr->a_es_gain_lin_dl_vect[2] = es_cfg->gain_lin_dl_vect[2]; - l1s_dsp_com.dsp_ndb_ptr->a_es_gain_lin_dl_vect[3] = es_cfg->gain_lin_dl_vect[3]; - l1s_dsp_com.dsp_ndb_ptr->a_es_gain_lin_ul_vect[0] = es_cfg->gain_lin_ul_vect[0]; - l1s_dsp_com.dsp_ndb_ptr->a_es_gain_lin_ul_vect[1] = es_cfg->gain_lin_ul_vect[1]; - l1s_dsp_com.dsp_ndb_ptr->a_es_gain_lin_ul_vect[2] = es_cfg->gain_lin_ul_vect[2]; - l1s_dsp_com.dsp_ndb_ptr->a_es_gain_lin_ul_vect[3] = es_cfg->gain_lin_ul_vect[3]; - - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_ES_STATE) - { - // ES already started: update the DSP ES module - l1s_dsp_com.dsp_ndb_ptr->d_es_ctrl = B_ES_FULL_UPDATE; - - *state = WAIT_DSP_ACK; - } - else - { - // Enable the DSP ES module - l1s_dsp_com.dsp_ndb_ptr->d_es_ctrl = B_ES_ENABLE; - - *state = WAIT_DSP_ACK; - } - } - else // ES start requested - { - // ES stop requested - //------------------- - if (l1s_dsp_com.dsp_ndb_ptr->d_aqi_status & B_ES_STATE) - { - // Disable the DSP ES module - l1s_dsp_com.dsp_ndb_ptr->d_es_ctrl = B_ES_DISABLE; - - *state = WAIT_DSP_ACK; - } - else - { - // ES already disabled: confirm - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_ES_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - } - } - - // Disable the update command - l1a_l1s_com.es_task.command.update = FALSE; - } - break; - - case WAIT_DSP_ACK: - { - // The DSP acknowledged the L1S command - if (l1s_dsp_com.dsp_ndb_ptr->d_es_ctrl == 0) - { - // Allocate confirmation message... - conf_msg = os_alloc_sig(0); - DEBUGMSG(status,NU_ALLOC_ERR) - conf_msg->SignalCode = L1_ES_CON; - // Send confirmation message... - os_send_sig(conf_msg, L1C1_QUEUE); - DEBUGMSG(status,NU_SEND_QUEUE_ERR) - - *state = IDLE; - } - } - break; - } // switch - } - #endif // L1_ES == 1 - -#endif // AUDIO_TASK