FreeCalypso > hg > fc-magnetite
diff src/cs/layer1/audio_cust0/l1audio_cust.c @ 234:b870b6a44d31
l1audio and l1tm reconstructed source imported from tcs211-l1-reconst
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 20 Mar 2017 00:51:20 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/cs/layer1/audio_cust0/l1audio_cust.c Mon Mar 20 00:51:20 2017 +0000 @@ -0,0 +1,2085 @@ +/************* Revision Controle System Header ************* + * GSM Layer 1 software + * L1AUDIO_CUST.C + * + * Filename l1audio_cust.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 "tc_defs.h" + + #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_defty.h" + #include "l1audio_msgty.h" + #include "l1audio_varex.h" + #include "l1audio_signa.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 + #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_GPRS + #include "l1p_cons.h" + #include "l1p_msgt.h" + #include "l1p_deft.h" + #include "l1p_vare.h" + #include "l1p_tabs.h" + #include "l1p_macr.h" + #include "l1p_sign.h" + #endif + + #include "sim_cfg.h" + #include "sim_cons.h" + #include "sim_def.h" + #include "sim_var.h" + #include "sim_prot.h" + + #include "audio_sim_cons.h" + #include "audio_sim_def.h" + #include "mmi_simul.h" + #include "audio_sim_var.h" + + #else + // Layer1 and debug include files. + + #include <ctype.h> + #include <string.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_defty.h" + #include "l1audio_msgty.h" + #include "l1audio_varex.h" + #include "l1audio_signa.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 + + #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 (AUDIO_L1_STANDALONE) + #include "mmi_simul.h" + #endif + + #if (OP_RIV_AUDIO == 1) + #if (MELODY_E1) || (VOICE_MEMO) || (SPEECH_RECO) || (L1_EXT_AUDIO_MGT) || (MELODY_E2) + #include "rv_general.h" + #include "audio_api.h" + #include "audio_structs_i.h" + #include "audio_var_i.h" + #include "audio_ffs_i.h" + #include "audio_const_i.h" + #include "audio_error_hdlr_i.h" + #include "ffs/ffs_api.h" + #include "audio_macro_i.h" + #endif + #endif + + #endif + + #include "l1_trace.h" + //extern void L1_trace_string(char *s); + //extern void L1_trace_char (char s); + + /**************************************/ + /* Prototypes for L1 ASYNCH task */ + /**************************************/ + #if (SPEECH_RECO) + void Cust_srback_save_model (UWORD8 database, UWORD8 index, API *RAM_address); + void Cust_srback_save_speech (UWORD8 database, UWORD8 index, UWORD16 *start_buffer, UWORD16 *stop_buffer, UWORD16 *start_speech, UWORD16 *stop_speech); + void Cust_srback_load_model (UWORD8 database, UWORD8 index, API *RAM_address); + #endif + UWORD8 Cust_get_pointer (UWORD16 **ptr, UWORD16 *buffer_size, UWORD8 session_id); + + #if (L1_EXT_AUDIO_MGT) + void Cust_ext_audio_mgt_hisr(void); + #endif + void l1a_bt_audio_noti_process(void); + + /**************************************/ + /* External prototypes */ + /**************************************/ + #if (OP_RIV_AUDIO == 1) + #if (SPEECH_RECO) + extern void audio_sr_error_trace(UINT8 error_id); + #endif + #endif + + + /***************************************/ + /* Global variables for MP3 management */ + /***************************************/ + #if (L1_MP3 == 1) + UWORD8 mp3_tempbuf_idx; + UWORD16 Cust_get_pointer_mp3_last_buffer_size; + BOOL Cust_get_pointer_mp3_buffer_last; + #endif + + /***************************************/ + /* Global variables for AAC management */ + /***************************************/ + #if (L1_AAC == 1) + UWORD8 aac_tempbuf_idx; + UWORD16 Cust_get_pointer_aac_last_buffer_size; + BOOL Cust_get_pointer_aac_buffer_last; + #endif + + /* + * FreeCalypso TCS211 reconstruction: the following unused trivial + * function has been reconstruction in order to aid the diffing + * of the functions that follow. + */ + void audio_test_callback(void *buffer) + { + rvf_free_buf(buffer); + } + + #if (SPEECH_RECO) + /*-------------------------------------------------------*/ + /* Cust_srback_save_model() */ + /*-------------------------------------------------------*/ + /* */ + /* Parameters : database */ + /* index */ + /* RAM_address */ + /* */ + /* Return : none */ + /* */ + /* Description : save the model into a database. */ + /* */ + /*-------------------------------------------------------*/ + void Cust_srback_save_model (UWORD8 database, UWORD8 index, API *RAM_address) + { + #if (AUDIO_SIMULATION) || (AUDIO_L1_STANDALONE) + UWORD16 model_size; + UWORD16 *ptr_dst; + UWORD8 frame_size; + + // initialize the pointer to the database + ptr_dst = sr_mmi_database[database][index].model; + + // look the size of the model in model frame unit (16 words unit) + model_size = *RAM_address++; + + // save the header of the model + *ptr_dst++ = model_size; + + 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) ) + { + *ptr_dst++ = *RAM_address++; + frame_size--; + } + + model_size--; + } + #endif + + #if (OP_RIV_AUDIO == 1) + T_FFS_FD ffs_fd; + UWORD16 model_size; + UWORD8 i; + char *p_model_path; + + if (p_audio_gbl_var->speech_reco.sr_enroll.state != AUDIO_SR_ENROLL_IDLE) + { + ffs_fd = p_audio_gbl_var->speech_reco.sr_enroll.sr_ffs_fd; + } + else + if (p_audio_gbl_var->speech_reco.sr_update.state != AUDIO_SR_UPDATE_IDLE) + { + /* reach the path of the corresponding model */ + p_model_path = p_audio_gbl_var->speech_reco.sr_update.p_database; + for (i=0; i<index; i++) + { + p_model_path += AUDIO_PATH_NAME_MAX_SIZE; + } + + ffs_fd = ffs_open(p_model_path, + FFS_O_CREATE | FFS_O_WRONLY | FFS_O_TRUNC | FFS_O_APPEND); + if ( ffs_fd <= 0) + { + audio_sr_error_trace(AUDIO_ENTITY_MODEL_NO_SAVED); + return; + } + } + + /* look the size of the model in model frame unit (16 words unit) */ + model_size = ((*RAM_address)<<1); + model_size *= SC_SR_MODEL_FRAME_SIZE; + + /* save the model in flash */ + if (ffs_write(ffs_fd, (void *)RAM_address, model_size) <= EFFS_OK) + { + audio_sr_error_trace(AUDIO_ENTITY_MODEL_NO_SAVED); + } + + /* close the model file flash */ + if (ffs_close(ffs_fd) != EFFS_OK) + { + audio_sr_error_trace(AUDIO_ENTITY_MODEL_NO_SAVED); + } + #endif // OP_RIV_AUDIO + } + + /*-------------------------------------------------------*/ + /* Cust_srback_save_speech() */ + /*-------------------------------------------------------*/ + /* */ + /* Parameters : database */ + /* index */ + /* start_buffer */ + /* stop_buffer */ + /* start_speech */ + /* stop_speech */ + /* */ + /* Return : none */ + /* */ + /* Description : save the speech from a circular buffer */ + /* to a database. And add the end VM mask */ + /* */ + /*-------------------------------------------------------*/ + void Cust_srback_save_speech (UWORD8 database, UWORD8 index, UWORD16 *start_buffer, UWORD16 *stop_buffer, UWORD16 *start_speech, UWORD16 *stop_speech) + { + #if (AUDIO_SIMULATION) || (AUDIO_L1_STANDALONE) + UWORD16 *ptr_dst; + + // initialize the pointer to the database + ptr_dst = sr_mmi_database[database][index].speech; + + // The speech samples can be in two positions in the circular buffer: + + // Position 1: + // [.............XXXXXXXXXXXXX.............] + // ^ ^ ^ ^ + // | | | | + // start_buffer start_speech stop_speech stop_buffer + if (start_speech < stop_speech) + { + while ( (start_speech < stop_speech) && + (l1_srback_com.emergency_stop == FALSE) ) + { + *ptr_dst++ = *start_speech++; + } + + // Write the end VM mask + *ptr_dst = SC_VM_END_MASK; + } + else + // Position 2: + // [XXXXXXXXXXXX..............XXXXXXXXXXXXX] + // ^ ^ ^ ^ + // | | | | + // start_buffer stop_speech start_speech stop_buffer + { + while ( (start_speech < stop_buffer) && + (l1_srback_com.emergency_stop == FALSE) ) + { + *ptr_dst++ = *start_speech++; + } + + while ( (start_buffer < stop_speech) && + (l1_srback_com.emergency_stop == FALSE) ) + { + *ptr_dst++ = *start_buffer++; + } + + // Write the end VM mask + *ptr_dst = SC_VM_END_MASK; + } + #endif + + #if (OP_RIV_AUDIO == 1) + T_FFS_FD ffs_fd; + UWORD16 speech_size; + char *p_model_path, + sr_speech_path[AUDIO_SR_PATH_NAME_MAX_SIZE]; + UWORD8 i; + + if (p_audio_gbl_var->speech_reco.sr_enroll.state !=AUDIO_SR_ENROLL_IDLE ) + { + ffs_fd = p_audio_gbl_var->speech_reco.sr_enroll.voice_ffs_fd; + } + else + if (p_audio_gbl_var->speech_reco.sr_update.state != AUDIO_SR_UPDATE_IDLE) + { + /* reach the path of the corresponding model */ + p_model_path = p_audio_gbl_var->speech_reco.sr_update.p_database; + for (i=0; i<index; i++) + { + p_model_path += AUDIO_PATH_NAME_MAX_SIZE; + } + + /* build the speech path name */ + speech_size = ( strlen(p_model_path)- 3); + strncpy(sr_speech_path, p_model_path, speech_size); + sr_speech_path[speech_size] = 0; + + ffs_fd = ffs_open(sr_speech_path, + FFS_O_CREATE | FFS_O_WRONLY | FFS_O_TRUNC | FFS_O_APPEND); + if (ffs_fd <= 0) + { + audio_sr_error_trace(AUDIO_ENTITY_SPEECH_NO_SAVED); + return; + } + } + + // The speech samples can be in two positions in the circular buffer: + + // Position 1: + // [.............XXXXXXXXXXXXX.............] + // ^ ^ ^ ^ + // | | | | + // start_buffer start_speech stop_speech stop_buffer + if (start_speech < stop_speech) + { + /* Calculate the size of the speech file */ + speech_size = (stop_speech - start_speech)<<1; + + /* save the model in flash */ + if (ffs_write(ffs_fd, (void *)start_speech, speech_size) <= EFFS_OK) + { + audio_sr_error_trace(AUDIO_ENTITY_SPEECH_NO_SAVED); + } + } + else + // Position 2: + // [XXXXXXXXXXXX..............XXXXXXXXXXXXX] + // ^ ^ ^ ^ + // | | | | + // start_buffer stop_speech start_speech stop_buffer + { + /* Calculate the size of the speech file */ + speech_size = (stop_buffer - start_speech)<<1; + + /* save the model in flash */ + if (ffs_write(ffs_fd, (void *)start_speech, speech_size) <= EFFS_OK) + { + audio_sr_error_trace(AUDIO_ENTITY_SPEECH_NO_SAVED); + } + + /* Calculate the size of the speech file */ + speech_size = (stop_speech - start_buffer)<<1; + + /* save the model in flash */ + if (ffs_write(ffs_fd, (void *)start_speech, speech_size) <= EFFS_OK) + { + audio_sr_error_trace(AUDIO_ENTITY_SPEECH_NO_SAVED); + } + } + // Write the end VM mask + speech_size = SC_VM_END_MASK; + if (ffs_write(ffs_fd, (void *)(&speech_size), 2) <= EFFS_OK) + { + audio_sr_error_trace(AUDIO_ENTITY_MODEL_NO_SAVED); + } + + /* close the speech file flash */ + if (ffs_close(ffs_fd) != EFFS_OK) + { + audio_sr_error_trace(AUDIO_ENTITY_MODEL_NO_SAVED); + } + #endif // OP_RIV_AUDIO + } + + /*-------------------------------------------------------*/ + /* Cust_srback_load_model() */ + /*-------------------------------------------------------*/ + /* */ + /* Parameters : database */ + /* index */ + /* RAM_address */ + /* */ + /* Return : none */ + /* */ + /* Description : load the model into the API. */ + /* */ + /*-------------------------------------------------------*/ + void Cust_srback_load_model (UWORD8 database, UWORD8 index, API *RAM_address) + { + #if (AUDIO_SIMULATION) || (AUDIO_L1_STANDALONE) + UWORD16 model_size; + UWORD16 *ptr_src; + UWORD8 frame_size; + + // initialize the pointer to the database + ptr_src = sr_mmi_database[database][index].model; + + // look the size of the model in model frame unit (16 words unit) + model_size = *ptr_src++; + + // save the header of the model + *RAM_address++ = model_size; + + 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++ = *ptr_src++; + frame_size--; + } + model_size--; + } + #endif + + #if (OP_RIV_AUDIO == 1) + char *p_model_path; + T_FFS_FD ffs_fd; + UWORD8 i; + + if (p_audio_gbl_var->speech_reco.sr_reco.state !=AUDIO_SR_RECO_IDLE ) + { + p_model_path = p_audio_gbl_var->speech_reco.sr_reco.p_database; + } + else + if (p_audio_gbl_var->speech_reco.sr_update.state != AUDIO_SR_UPDATE_IDLE) + { + p_model_path = p_audio_gbl_var->speech_reco.sr_update.p_database; + } + + /* reach the path of the corresponding model */ + for (i=0; i<index; i++) + { + p_model_path += AUDIO_PATH_NAME_MAX_SIZE; + } + + /* open the model file flash */ + ffs_fd = ffs_open(p_model_path, FFS_O_RDONLY); + if ( ffs_fd <= 0) + { + audio_sr_error_trace(AUDIO_ENTITY_MODEL_NO_LOAD); + return; + } + + /* download the model to the API buffer */ + if (ffs_read(ffs_fd, (void *)RAM_address, (SC_SR_MODEL_API_SIZE<<1)) <= EFFS_OK) + { + audio_sr_error_trace(AUDIO_ENTITY_MODEL_NO_LOAD); + } + + /* close the model file flash */ + if (ffs_close(ffs_fd) != EFFS_OK) + { + audio_sr_error_trace(AUDIO_ENTITY_MODEL_NO_LOAD); + } + #endif // OP_RIV_AUDIO + } + #endif // SPEECH_RECO + + /*-------------------------------------------------------*/ + /* Cust_get_pointer */ + /*-------------------------------------------------------*/ + /* */ + /* Parameters : ptr */ + /* buffer_size */ + /* session_id */ + /* */ + /* Return : error_id : */ + /* DATA_AVAILABLE: 0, no error occured */ + /* SESSION_ERROR: 1, wrong session id */ + /* POINTER_ERROR: 2, wrong ptr */ + /* DATA_AVAIL_ERROR: 3, no more data */ + /* available */ + /* DATA_LAST: 4, last buffer available */ + /* buffer_size */ + /* ptr */ + /* */ + /* Description : */ + /* The L1 calls this function to request new data buffer */ + /* (requested size: buffer_size). This function returns */ + /* the description of the new data buffer */ + /* (start address: ptr and the size: buffer_size) */ + /* Moreover, the L1 indicates the position of the last */ + /* data used via the ptr argument. */ + /* Note that this function can be returns an error. */ + /* */ + /*-------------------------------------------------------*/ + UWORD8 Cust_get_pointer (UWORD16 **ptr, UWORD16 *buffer_size, UWORD8 session_id) + { + #if (AUDIO_SIMULATION) || (AUDIO_L1_STANDALONE) + + UWORD8 database_id, word_index; + + switch (session_id & 0x0F) + { + #if (MELODY_E1) + // Melody E1 0 + case 0: + { + if (*ptr == NULL) + { + *ptr = (UWORD16 *)&melody_0; + *buffer_size = SC_MELODY_0_SCORE_SIZE>>1; + } + else + { + *buffer_size = SC_MELODY_0_SCORE_SIZE>>1; + } + + return(DATA_AVAILABLE); + } +//omaps00090550 break; + + // Melody E1 1 + case 1: + { + if (*ptr == NULL) + { + *ptr = (UWORD16 *)&melody_1; + *buffer_size = SC_MELODY_1_SCORE_SIZE>>1; + } + else + { + *buffer_size = SC_MELODY_1_SCORE_SIZE>>1; + } + + return(DATA_AVAILABLE); + } +//omaps00090550 break; + #endif // MELODY_E1 + #if (VOICE_MEMO) + // Voice memo play + case 2: + { + if (*ptr == NULL) + { + *ptr = (UWORD16 *)&voice_memo_buffer; + *buffer_size = SC_VM_BUFFER_SIZE>>1; + } + else + { + *buffer_size = (SC_VM_BUFFER_SIZE>>1) + 1; + } + + return(DATA_AVAILABLE); + } +//omaps00090550 break; + + // Voice memo record + case 3: + { + if (*ptr == NULL) + { + *ptr = (UWORD16 *)&voice_memo_buffer; + *buffer_size = SC_VM_BUFFER_SIZE>>1; + } + else + { + *buffer_size = (SC_VM_BUFFER_SIZE>>1) + 1; + } + + return(DATA_AVAILABLE); + } +//omaps00090550 break; + #endif // VOICE_MEMO + #if (SPEECH_RECO) + case 4: + { + database_id = 0; + word_index = (session_id & 0xF0)>>4; + *ptr = (UWORD16 *)&(sr_mmi_database[database_id][word_index].speech); + + *buffer_size = SC_SR_MMI_DB_SPEECH_SIZE; + + return(DATA_AVAILABLE); + } + break; + + case 5: + { + database_id = 1; + word_index = (session_id & 0xF0)>>4; + *ptr = (UWORD16 *)&(sr_mmi_database[database_id][word_index].speech); + + *buffer_size = SC_SR_MMI_DB_SPEECH_SIZE; + + return(DATA_AVAILABLE); + } + break; + #endif // SPEECH_RECO + #if (MELODY_E2 && FIR) + // Melody E2 + // Tchaikowski + case 6: + { + if (*ptr == NULL) + { + *ptr = (UWORD16 *)&Tchaikowski_danse_russe; + *buffer_size = TCHAIKOWSKI_DANSE_RUSSE>>1; + } + else + { + *buffer_size = TCHAIKOWSKI_DANSE_RUSSE>>1; + } + + return(DATA_AVAILABLE); + } + break; + + // Small melody + case 7: + { + if (*ptr == NULL) + { + *ptr = (UWORD16 *)&Small_melody_E2; + *buffer_size = SMALL_MELODY_E2>>1; + } + else + { + *buffer_size = SMALL_MELODY_E2>>1; + } + + return(DATA_AVAILABLE); + } + break; + + // CPU load + case 8: + { + if (*ptr == NULL) + { + *ptr = (UWORD16 *)&Cpu_load_E2; + *buffer_size = CPU_LOAD_E2>>1; + } + else + { + *buffer_size = CPU_LOAD_E2>>1; + } + + return(DATA_AVAILABLE); + } + break; + + // USA hymn + case 9: + { + if (*ptr == NULL) + { + *ptr = (UWORD16 *)&Usa_E2; + *buffer_size = USA_E2>>1; + } + else + { + *buffer_size = USA_E2>>1; + } + + return(DATA_AVAILABLE); + } + break; + #endif // MELODY_E2 + #if (L1_VOICE_MEMO_AMR) + // Voice memo amr play + case 10: + { + if (*ptr == NULL) + { + *ptr = (UWORD16 *)&voice_memo_buffer; + *buffer_size = SC_VM_BUFFER_SIZE>>1; + } + else + { + *buffer_size = (SC_VM_BUFFER_SIZE>>1) + 1; + } + + return(DATA_AVAILABLE); + } +//omaps00090550 break; + + // Voice memo record + case 11: + { + if (*ptr == NULL) + { + *ptr = (UWORD16 *)&voice_memo_buffer; + *buffer_size = SC_VM_BUFFER_SIZE>>1; + } + else + { + *buffer_size = (SC_VM_BUFFER_SIZE>>1) + 1; + } + + return(DATA_AVAILABLE); + } +//omaps00090550 break; + #endif // L1_VOICE_MEMO_AMR + + #if (L1_MIDI == 1) + // MIDI + case 12: + { + extern struct MIDI_FILE midi_file; + UWORD8 **ptr_char=(UWORD8 **)ptr; + static UWORD8 *last_ptr; + + if(*ptr_char==NULL) + { + midi_file_offset=0; + *ptr_char=&(midi_file.midi_file_buffer[0]); + last_ptr=*ptr_char; + + // All MIDI file available due to SMF1 format constraints + // For SMF0, *buffer_size should be set to MIDI_BUFFER_SIZE + *buffer_size=midi_file.midi_file_size; + return DATA_LAST; + } + else + { + *buffer_size=MIDI_BUFFER_SIZE; + *ptr_char=last_ptr+MIDI_BUFFER_SIZE; + + // Check if pointer is out of bounds + if(*ptr_char > &(midi_file.midi_file_buffer[0])+midi_file.midi_file_size-1) + { + *ptr_char=&(midi_file.midi_file_buffer[0]); + return DATA_AVAIL_ERROR; + } + + // Check if it's the last valid buffer + if((*ptr_char+*buffer_size) > &(midi_file.midi_file_buffer[0])+midi_file.midi_file_size-1) + { + *buffer_size=MIDI_BUFFER_SIZE-(UWORD16)(*ptr_char+MIDI_BUFFER_SIZE-&(midi_file.midi_file_buffer[0])-midi_file.midi_file_size+1); + + // Update offset in the MIDI file + midi_file_offset+=*ptr_char-last_ptr; + + last_ptr=*ptr_char; + + return DATA_LAST; + } + else + { + // Update offset in the MIDI file + midi_file_offset+=*ptr_char-last_ptr; + + last_ptr=*ptr_char; + + return DATA_AVAILABLE; + } + } + } + #endif // L1_MIDI + +#if L1_PCM_EXTRACTION + case 13: + { + *ptr = (UWORD16 *)&pcm_download_buffer; + *buffer_size = SC_PCM_DOWNLOAD_BUFFER_SIZE; + return DATA_AVAILABLE; + } +//omaps00090550 break; + + case 14: + { + *ptr = (UWORD16 *)&pcm_upload_buffer; + *buffer_size = SC_PCM_UPLOAD_BUFFER_SIZE; + return DATA_AVAILABLE; + } +//omaps00090550 break; +#endif /* L1_PCM_EXTRACTION */ + default: + { + return(SESSION_ERROR); + } +//omaps00090550 break; + } + #endif + + #if (OP_RIV_AUDIO == 1) + + #if (MELODY_E1) || (VOICE_MEMO) || (MELODY_E2) || (L1_VOICE_MEMO_AMR) || (L1_EXT_AUDIO_MGT) + UWORD8 index_l1, *current_ptr_8; + UWORD16 *current_ptr, *size_ptr, *end_ptr; + UWORD32 current, end; + T_AUDIO_FFS_SESSION *p_session; + + #if (L1_AUDIO_DRIVER == 1) + T_AUDIO_DRIVER_SESSION *p_driver_session; + UINT8 channel_id; + xSignalHeaderRec *msg; + + /* special handling for features in driver */ + if ((session_id == AUDIO_VM_AMR_RECORD_SESSION_ID) || + (session_id == AUDIO_VM_AMR_PLAY_SESSION_ID)) + { + channel_id = 0; + /* find active channel_id associated to session_id */ + while ( (channel_id < AUDIO_DRIVER_MAX_CHANNEL)&& + ((p_audio_gbl_var->audio_driver_session[channel_id].session_info.state == AUDIO_DRIVER_CHANNEL_WAIT_INIT)|| + (p_audio_gbl_var->audio_driver_session[channel_id].session_req.session_id != session_id)) ) + { + channel_id++; + } + /* get driver session */ + p_driver_session = &(p_audio_gbl_var->audio_driver_session[channel_id]); + + /* first buffer, index_l1 = 0 */ + if (*ptr == NULL) + { + *ptr = (UWORD16 *)(p_driver_session->session_info.buffer[0].p_start_pointer); + *buffer_size = (p_driver_session->session_info.buffer[0].size >> 1); + + return(DATA_AVAILABLE); + } + /* following buffers */ + else + { + /* prepare notification */ + msg = os_alloc_sig(sizeof(T_L1_AUDIO_DRIVER_IND)); + DEBUGMSG(status,NU_ALLOC_ERR) + msg->SignalCode = L1_AUDIO_DRIVER_IND; + ((T_L1_AUDIO_DRIVER_IND *)msg->SigP)->channel_id = channel_id; + ((T_L1_AUDIO_DRIVER_IND *)msg->SigP)->p_buffer = NULL; + + /* fill message with current buffer for record */ + index_l1 = p_driver_session->session_info.index_l1; + if (session_id == AUDIO_VM_AMR_RECORD_SESSION_ID) + ((T_L1_AUDIO_DRIVER_IND *)msg->SigP)->p_buffer = + (UWORD16 *)p_driver_session->session_info.buffer[index_l1].p_start_pointer; + + /* give new buffer = index_l1++ % nb_buffer */ + p_driver_session->session_info.index_l1++; + if ((p_driver_session->session_info.index_l1) == (p_driver_session->session_req.nb_buffer)) + p_driver_session->session_info.index_l1 =(UINT8)( 0);//omaps + + /* Update new current buffer parameters */ + index_l1 = (UWORD8)(p_driver_session->session_info.index_l1);//oamps + *ptr = (UWORD16 *)(p_driver_session->session_info.buffer[index_l1].p_start_pointer); + *buffer_size = (p_driver_session->session_info.buffer[index_l1].size >> 1); + + // Send confirmation message... + os_send_sig(msg, L1C1_QUEUE); + DEBUGMSG(status,NU_SEND_QUEUE_ERR) + + return (DATA_AVAILABLE); + } + } + /* Other features */ + else + { + #endif // L1_AUDIO_DRIVER + p_session = &(p_audio_gbl_var->audio_ffs_session[session_id]); + + switch (p_session->session_info.cust_get_pointer_state) + { + case AUDIO_CUST_GET_POINTER_INIT: + { + /* the first buffer, the index_l1 is already OK so the index_l1 doesn't change */ + index_l1 = + p_session->session_info.index_l1; + *ptr = + (UWORD16 *)(p_session->session_info.buffer[index_l1].p_start_pointer); + *buffer_size = + (p_session->session_info.buffer[index_l1].size>>1); + + + p_session->session_info.cust_get_pointer_state = + AUDIO_CUST_GET_POINTER_NORMAL; + break; + } + case AUDIO_CUST_GET_POINTER_NORMAL: + { + /* in loopback mode, when the melody restarts, the L1 pointer management is different */ + if ( (*buffer_size == 0) && + (p_session->session_req.loop_mode == TRUE) ) + { + p_session->session_info.cust_get_pointer_state = + AUDIO_CUST_GET_POINTER_LOOP; + break; + } + + /* The index_l1 needs to be changed */ + p_session->session_info.index_l1++; + if (p_session->session_info.index_l1 + == AUDIO_MAX_FFS_BUFFER_PER_SESSION) + { + p_session->session_info.index_l1 = 0; + } + + index_l1 = + p_session->session_info.index_l1; + *ptr = + (UWORD16 *)(p_session->session_info.buffer[index_l1].p_start_pointer); + *buffer_size = + (p_session->session_info.buffer[index_l1].size>>1); + + break; + } + case AUDIO_CUST_GET_POINTER_LOOP: + { + /* in loopback mode, the next melody data is contiguous to the first */ + /* if it's the end of the buffer , we use the next buffer */ + index_l1 = + p_session->session_info.index_l1; + + current_ptr = (UWORD16 *)(*ptr); + current_ptr_8 = (UWORD8 *)(*ptr); + end_ptr = (UWORD16 *)(p_session->session_info.buffer[index_l1].p_stop_pointer); + + if ( current_ptr >= end_ptr ) + { + p_session->session_info.index_l1++; + if (p_session->session_info.index_l1 + == AUDIO_MAX_FFS_BUFFER_PER_SESSION) + { + p_session->session_info.index_l1 = 0; + } + + index_l1 = + p_session->session_info.index_l1; + *ptr = + (UWORD16 *)(p_session->session_info.buffer[index_l1].p_start_pointer); + *buffer_size = + (p_session->session_info.buffer[index_l1].size>>1); + } + else + { + // Realign the pointer to the next 16 bit in case of melody E2 + current = (UWORD32)current_ptr_8; + if (current & 0x01) + { + current_ptr_8++; + *ptr = (UWORD16 *)current_ptr_8; + } + + end = (UWORD32)end_ptr; + current = (UWORD32)current_ptr; + + *buffer_size = (UWORD16)((end-current)>>1); + } + + p_session->session_info.cust_get_pointer_state = + AUDIO_CUST_GET_POINTER_NORMAL; + break; + } + } /* switch(p_session->session_info.cust_get_pointer_state) */ + + return(DATA_AVAILABLE); + #if (L1_AUDIO_DRIVER == 1) + } // added + #endif + #endif // MELODY_E1 || VOICE_MEMO || MELODY_E2 + #endif // OP_RIV_AUDIO + } + +#if (AUDIO_SIMULATION) || (AUDIO_L1_STANDALONE) +/*-------------------------------------------------------*/ +/* Cust_get_next_buffer_status */ +/*-------------------------------------------------------*/ +/* */ +/* Parameters : */ +/* */ +/* Return : */ +/* */ +/* Description : */ +/* */ +/*-------------------------------------------------------*/ +UWORD8 Cust_get_next_buffer_status(void) +{ + return (FALSE); +} + +#endif + +#if (AUDIO_SIMULATION) || (AUDIO_L1_STANDALONE) +/*-------------------------------------------------------*/ +/* Cust_get_pointer_next_buffer */ +/*-------------------------------------------------------*/ +/* */ +/* Parameters : ptr */ +/* buffer_size */ +/* session_id */ +/* */ +/* Return : error_id : */ +/* DATA_AVAILABLE: 0, no error occured */ +/* SESSION_ERROR: 1, wrong session id */ +/* POINTER_ERROR: 2, wrong ptr */ +/* DATA_AVAIL_ERROR: 3, no more data */ +/* available */ +/* DATA_LAST: 4, returned buffer is the */ +/* last */ +/* buffer_size */ +/* ptr */ +/* */ +/* Description : */ +/* This function acts the same as Cust_get_pointer() but */ +/* does not send notification to upper layers to free */ +/* current buffer */ +/* */ +/*-------------------------------------------------------*/ +UWORD8 Cust_get_pointer_next_buffer(UWORD16 **ptr, + UWORD16 *buffer_size, + UWORD8 session_id) +{ +#if (L1_MP3 == 1) + extern UWORD32 mp3_file_size; +#endif +#if (L1_AAC == 1) + extern UWORD32 aac_file_size; +#endif + + switch(session_id&0x0F) + { +#if (L1_MP3 == 1) + case 13: + { + if(*ptr==NULL) + { + // Reset flag + Cust_get_pointer_mp3_buffer_last=FALSE; + + // Set pointer to first buffer with corresponding size + mp3_tempbuf_idx=0; + *ptr=mp3_tempbuf0; + *buffer_size=C_MP3_L1STANDALONE_BUFFER_SIZE; + + Cust_get_pointer_mp3_last_buffer_size=C_MP3_L1STANDALONE_BUFFER_SIZE; + +#if (CODE_VERSION == NOT_SIMULATION) + if(mp3_file_size<C_MP3_L1STANDALONE_BUFFER_SIZE) + { + *buffer_size=(UWORD16)mp3_file_size; + Cust_get_pointer_mp3_buffer_last=TRUE; + return DATA_LAST; + } +#endif + + return DATA_AVAILABLE; + } + else + { + switch(mp3_tempbuf_idx) + { + case 0: + *ptr=mp3_tempbuf1; + break; + + case 1: + *ptr=mp3_tempbuf0; + break; + } + + // Swap buffer index + mp3_tempbuf_idx^=1; + + *buffer_size=Cust_get_pointer_mp3_last_buffer_size; + + if(Cust_get_pointer_mp3_buffer_last==FALSE) + return DATA_AVAILABLE; + else + { + if(l1a_l1s_com.mp3_task.parameters.loopback==TRUE) + Cust_get_pointer_mp3_buffer_last=FALSE; + + return DATA_LAST; + } + } + } +//omaps00090550 break; +#endif // L1_MP3 + +#if (L1_AAC == 1) + case 14: // session id for AAC + { + if(*ptr==NULL) + { + // Reset flag + Cust_get_pointer_aac_buffer_last=FALSE; + + // Set pointer to first buffer with corresponding size + aac_tempbuf_idx=0; + *ptr=aac_tempbuf0; + *buffer_size=C_AAC_L1STANDALONE_BUFFER_SIZE; + + Cust_get_pointer_aac_last_buffer_size=C_AAC_L1STANDALONE_BUFFER_SIZE; + +#if (CODE_VERSION == NOT_SIMULATION) + if(aac_file_size<C_AAC_L1STANDALONE_BUFFER_SIZE) + { + *buffer_size=(UWORD16)aac_file_size; + Cust_get_pointer_aac_buffer_last=TRUE; + return DATA_LAST; + } +#endif + + return DATA_AVAILABLE; + } + else + { + switch(aac_tempbuf_idx) + { + case 0: + *ptr=aac_tempbuf1; + break; + + case 1: + *ptr=aac_tempbuf0; + break; + } + + // Swap buffer index + aac_tempbuf_idx^=1; + + *buffer_size=Cust_get_pointer_aac_last_buffer_size; + + if(Cust_get_pointer_aac_buffer_last==FALSE) + return DATA_AVAILABLE; + else + { + if(l1a_l1s_com.aac_task.parameters.loopback==TRUE) + Cust_get_pointer_aac_buffer_last=FALSE; + + return DATA_LAST; + } + } + } +//omaps00090550 break; +#endif // L1_AAC + + default: + { + return SESSION_ERROR; + } +//omaps00090550 break; + } +} +#endif // (AUDIO_SIMULATION) || (AUDIO_L1_STANDALONE) + + +#if (AUDIO_SIMULATION) || (AUDIO_L1_STANDALONE) +/*------------------------------------------------------------------*/ +/* Cust_get_pointer_notify */ +/*------------------------------------------------------------------*/ +/* */ +/* Parameters : ptr */ +/* session_id */ +/* */ +/* Return : n/a */ +/* */ +/* Description : */ +/* This function sends notification to upper layers to */ +/* fill next buffer. */ +/* This function should be used with Cust_get_pointer_next_buffer() */ +/* */ +/*------------------------------------------------------------------*/ +void Cust_get_pointer_notify(UWORD8 session_id) +{ + switch(session_id&0x0F) + { +#if (L1_MP3 == 1) + case 13: + { +#if (CODE_VERSION == NOT_SIMULATION) + UWORD32 size; + UWORD8 *dst; + extern UWORD32 mp3_file_size; + + // Check if file is ending + if(mp3_file_offset+C_MP3_L1STANDALONE_BUFFER_SIZE > mp3_file_size) + { + size=mp3_file_size-mp3_file_offset; + Cust_get_pointer_mp3_buffer_last=TRUE; + } + else + { + size=C_MP3_L1STANDALONE_BUFFER_SIZE; + Cust_get_pointer_mp3_buffer_last=FALSE; + } + + switch(mp3_tempbuf_idx) + { + case 0: + { + // L1 is working on buffer 0 -> fill buffer 1 + dst=(UWORD8 *)mp3_tempbuf1; + } + break; + + case 1: + { + // L1 is working on buffer 1 -> fill buffer 0 + dst=(UWORD8 *)mp3_tempbuf0; + } + break; + } + + memcpy(dst,(UWORD8 *)mp3_file+mp3_file_offset,size); + + // Update MP3 read offset + mp3_file_offset+=C_MP3_L1STANDALONE_BUFFER_SIZE; + + // Rewind if loopback mode is on + if((l1a_l1s_com.mp3_task.parameters.loopback==TRUE) && + (Cust_get_pointer_mp3_buffer_last==TRUE)) + mp3_file_offset=0; + + // Keep track of buffer size + Cust_get_pointer_mp3_last_buffer_size=(UWORD16)size; + +#else // CODE_VERSION == NOT_SIMULATION + UWORD16 i; + UWORD8 *dst; + switch(mp3_tempbuf_idx) + { + case 0: + dst=(UWORD8 *)mp3_tempbuf1; + break; + case 1: + dst=(UWORD8 *)mp3_tempbuf0; + break; + } + for(i=0; i<C_MP3_L1STANDALONE_BUFFER_SIZE/2; i++) + { + dst[2*i] =0x12; + dst[2*i+1]=0x24; + } +#endif + } + break; +#endif // L1_MP3 + +#if (L1_AAC == 1) + case 14: + { +#if (CODE_VERSION == NOT_SIMULATION) + UWORD32 size; + UWORD8 *dst; + extern UWORD32 aac_file_size; + + // Check if file is ending + if(aac_file_offset+C_AAC_L1STANDALONE_BUFFER_SIZE > aac_file_size) + { + size=aac_file_size-aac_file_offset; + Cust_get_pointer_aac_buffer_last=TRUE; + } + else + { + size=C_AAC_L1STANDALONE_BUFFER_SIZE; + Cust_get_pointer_aac_buffer_last=FALSE; + } + + switch(aac_tempbuf_idx) + { + case 0: + { + // L1 is working on buffer 0 -> fill buffer 1 + dst=(UWORD8 *)aac_tempbuf1; + } + break; + + case 1: + { + // L1 is working on buffer 1 -> fill buffer 0 + dst=(UWORD8 *)aac_tempbuf0; + } + break; + } + + memcpy(dst,(UWORD8 *)aac_file+aac_file_offset,size); + + // Update AAC read offset + aac_file_offset+=C_AAC_L1STANDALONE_BUFFER_SIZE; + + // Rewind if loopback mode is on + if((l1a_l1s_com.aac_task.parameters.loopback==TRUE) && + (Cust_get_pointer_aac_buffer_last==TRUE)) + aac_file_offset=0; + + // Keep track of buffer size + Cust_get_pointer_aac_last_buffer_size=(UWORD16)size; + +#else // CODE_VERSION == NOT_SIMULATION + UWORD16 i; + UWORD8 *dst; + switch(aac_tempbuf_idx) + { + case 0: + dst=(UWORD8 *)aac_tempbuf1; + break; + case 1: + dst=(UWORD8 *)aac_tempbuf0; + break; + } + for(i=0; i<C_AAC_L1STANDALONE_BUFFER_SIZE/2; i++) + { + dst[2*i] =0x10; + dst[2*i+1]=0x20; + } +#endif + } + break; +#endif // L1_AAC + + } // switch(session_id&0x0F) +} +#endif // (AUDIO_SIMULATION) || (AUDIO_L1_STANDALONE) + + + #if (MELODY_E2 && FIR) + /*-------------------------------------------------------*/ + /* Cust_audio_melody_E2_load_instrument */ + /*-------------------------------------------------------*/ + /* */ + /* Parameters : customer_instrument_id: */ + /* Identifier of the instrument */ + /* API_address */ + /* address where the insturment */ + /* is downloaded */ + /* allowed_size */ + /* maximum size of the instrument */ + /* */ + /* Return : instrument_size : */ + /* size of the insturment downloaded in */ + /* 16-bit word */ + /* */ + /* Description : */ + /* The audio background task calls this function to */ + /* request to the MMI to download a new instrument */ + /* description at the API_address. */ + /* */ + /*-------------------------------------------------------*/ + UWORD16 Cust_audio_melody_E2_load_instrument (UWORD8 customer_instrument_id, + API *API_address, + UWORD16 allowed_size) + { + #if (AUDIO_SIMULATION) || (AUDIO_L1_STANDALONE) + UWORD16 instrument_size = 0, i, *instrument_ptr; + + // default.lsi file: + // 0 piano31 0x0 + // 1 piano15 0x1 + // 2 pia_811 0x2 + // 3 eba_2536 0x3 + // 4 tsax_255 0x4 + // 5 asax_124 0x5 + // 6 clar_121 0x6 + // 7 clar_130 0x7 + // 8 stdr_515 0x8 + // 9 timp_661 0x9 + // 10 agog_406 0xA + // 11 wood_110 0xB + // 12 vib_3836 0xC + // 13 xylo_120 0xD + // 14 xylo_315 0xE + // 15 xylo_516 0xF + // 16 kali_215 0x10 + // 17 viol_231 0x11 + // 18 viol_215 0x12 + // 19 viol_211 0x13 + // 20 viol_108 0x14 + // 21 flut_436 0x15 + // 22 flut_308 0x16 + // 23 porg_131 0x17 + // 24 acco_211 0x18 + // 25 stng_231 0x19 + // 26 stng_058 0x1A + // 27 ldsa_131 0x1B + // 28 sin7 0x1C + // 29 egu_3036 0x1D + // 30 jgui_215 0x1E + // 31 banj_315 0x1F + // 32 trum_231 0x20 + // 33 tromb31 0x21 + // 34 cho_2116 0x22 + // 35 vooh_331 0x23 + // 36 crc_1210 0x24 + // 37 chc_1210 0x25 + // 38 ohc_1610 0x26 + // 39 lbon_121 0x27 + // 40 esn_0210 0x28 + // 41 crc_0210 0x29 + // 42 ric_0210 0x2A + // 43 bdm_0122 0x2B + // 44 vib_0415 0x2C + // 45 ngu_0343 0x2D + // 46 sgu_0230 0x2E + // 47 xyl_0315 0x2F + + switch (customer_instrument_id) + { + case 0: + // Piano31.mwa + { + instrument_size = MELODY_E2_PIANO31_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_piano31[0]); + break; + } + case 1: + // Piano15.mwa + { + instrument_size = MELODY_E2_PIANO15_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_piano15[0]); + break; + } + case 2: + // Pia_811.mwa + { + instrument_size = MELODY_E2_PIA_811_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_pia_811[0]); + break; + } + case 3: + // eba_2536.mwa + { + instrument_size = MELODY_E2_EBA_2536_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_eba_2536[0]); + break; + } + case 4: + // tsax_255.mwa + { + instrument_size = MELODY_E2_TSAX_255_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_tsax_255[0]); + break; + } + case 5: + // asax_124.mwa + { + instrument_size = MELODY_E2_ASAX_124_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_asax_124[0]); + break; + } + case 6: + // clar_121.mwa + { + instrument_size = MELODY_E2_CLAR_121_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_clar_121[0]); + break; + } + case 7: + // clar_130.mwa + { + instrument_size = MELODY_E2_CLAR_130_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_clar_130[0]); + break; + } + case 8: + // stdr_515.mwa + { + instrument_size = MELODY_E2_STDR_515_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_stdr_515[0]); + break; + } + case 9: + // timp_661.mwa + { + instrument_size = MELODY_E2_TIMP_661_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_timp_661[0]); + break; + } + case 10: + // agog_406.mwa + { + instrument_size = MELODY_E2_AGOG_406_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_agog_406[0]); + break; + } + case 11: + // wood_110.mwa + { + instrument_size = MELODY_E2_WOOD_110_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_wood_110[0]); + break; + } + case 12: + // vib_3836.mwa + { + instrument_size = MELODY_E2_VIB_3836_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_vib_3836[0]); + break; + } + case 13: + // xylo_120.mwa + { + instrument_size = MELODY_E2_XYLO_120_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_xylo_120[0]); + break; + } + case 14: + // xylo_315.mwa + { + instrument_size = MELODY_E2_XYLO_315_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_xylo_315[0]); + break; + } + case 15: + // xylo_516.mwa + { + instrument_size = MELODY_E2_XYLO_516_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_xylo_516[0]); + break; + } + case 16: + // kali_215.mwa + { + instrument_size = MELODY_E2_KALI_215_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_kali_215[0]); + break; + } + case 17: + // viol_231 + { + instrument_size = MELODY_E2_VIOL_231_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_viol_231[0]); + break; + } + case 18: + // viol_215.mwa + { + instrument_size = MELODY_E2_VIOL_215_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_viol_215[0]); + break; + } + case 19: + // viol_211.mwa + { + instrument_size = MELODY_E2_VIOL_211_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_viol_211[0]); + break; + } + case 20: + // viol_108.mwa + { + instrument_size = MELODY_E2_VIOL_108_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_viol_108[0]); + break; + } + case 21: + // flut_436 + { + instrument_size = MELODY_E2_FLUT_436_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_flut_436[0]); + break; + } + case 22: + // flut_308.mwa + { + instrument_size = MELODY_E2_FLUT_308_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_flut_308[0]); + break; + } + case 23: + // porg_131 + { + instrument_size = MELODY_E2_PORG_131_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_porg_131[0]); + break; + } + case 24: + // acco_211.mwa + { + instrument_size = MELODY_E2_ACCO_211_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_acco_211[0]); + break; + } + case 25: + // stng_231 + { + instrument_size = MELODY_E2_STNG_231_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_stng_231[0]); + break; + } + case 26: + // stng_058.mwa + { + instrument_size = MELODY_E2_STNG_058_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_stng_058[0]); + break; + } + case 27: + // ldsa_131 + { + instrument_size = MELODY_E2_LDSA_131_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_ldsa_131[0]); + break; + } + case 28: + // sin7.mwa + { + instrument_size = MELODY_E2_SIN7_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_sin7[0]); + break; + } + case 29: + // Egu_3036.mwa + { + instrument_size = MELODY_E2_EGU_3036_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_egu_3036[0]); + break; + } + case 30: + // Jgui_215.mwa + { + instrument_size = MELODY_E2_JGUI_215_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_jgui_215[0]); + break; + } + case 31: + // Banj_315.mwa + { + instrument_size = MELODY_E2_BANJ_315_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_banj_315[0]); + break; + } + + case 32: + // trum_231 + { + instrument_size = MELODY_E2_TRUM_231_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_trum_231[0]); + break; + } + case 33: + // tromb31 + { + instrument_size = MELODY_E2_TROMB31_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_tromb31[0]); + break; + } + case 34: + // cho_2116 + { + instrument_size = MELODY_E2_CHO_2116_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_cho_2116[0]); + break; + } + case 35: + // vooh_331.mwa + { + instrument_size = MELODY_E2_VOOH_331_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_vooh_331[0]); + break; + } + case 36: + // crc_1210.mwa + { + instrument_size = MELODY_E2_CRC_1210_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_crc_1210[0]); + break; + } + case 37: + // chc_1210.mwa + { + instrument_size = MELODY_E2_CHC_1210_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_chc_1210[0]); + break; + } + case 38: + // ohc_1610 + { + instrument_size = MELODY_E2_OHC_1610_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_ohc_1610[0]); + break; + } + case 39: + // lbon_121 + { + instrument_size = MELODY_E2_LBON_121_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_lbon_121[0]); + break; + } + case 40: + // esn_0210 + { + instrument_size = MELODY_E2_ESN_0210_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_esn_0210[0]); + break; + } + case 41: + // crc_0210 + { + instrument_size = MELODY_E2_CRC_0210_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_crc_0210[0]); + break; + } + case 42: + // ric_0210 + { + instrument_size = MELODY_E2_RIC_0210_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_ric_0210[0]); + break; + } + case 43: + // bdm_0122 + { + instrument_size = MELODY_E2_BDM_0122_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_bdm_0122[0]); + break; + } + case 44: + // vib_0415 + { + instrument_size = MELODY_E2_VIB_0415_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_vib_0415[0]); + break; + } + case 45: + // ngu_0343 + { + instrument_size = MELODY_E2_NGU_0343_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_ngu_0343[0]); + break; + } + case 46: + // sgu_0230 + { + instrument_size = MELODY_E2_SGU_0230_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_sgu_0230[0]); + break; + } + case 47: + // xyl_0315 + { + instrument_size = MELODY_E2_XYL_0315_MWA_SIZE; + instrument_ptr = (UWORD16 *)(&melody_E2_xyl_0315[0]); + break; + } + } + + i = instrument_size; + while ( (i != 0) && + (l1a_l1s_com.melody0_e2_task.parameters.emergency_stop == FALSE) ) + { + *API_address++ = *instrument_ptr++; + i--; + } + + return(instrument_size); + #endif // (AUDIO_SIMULATION) || (AUDIO_L1_STANDALONE) + + #if (OP_RIV_AUDIO == 1) + #ifndef _WINDOWS + T_FFS_FD ffs_fd_1, ffs_fd_2; + T_FFS_STAT stat; + + /* Nb of instruments in the .lsi file */ + INT8 i = 0; + INT16 instrument_id = -1; + + /* basic structure of the .lsi file */ + T_AUDIO_MELODY_E2_ID_NAME file_E2; + + /**** Find the size of the .lsi file ****/ + /* the .lsi file is stores into the flash */ + /* check if the .lsi file exists */ + + ffs_fd_1 = ffs_open(p_audio_gbl_var->melody_E2_load_file_instruments.instrument_file_name, + FFS_O_RDONLY ); + + if (ffs_fd_1 < EFFS_OK) + { + audio_melody_E2_error_trace(AUDIO_ENTITY_LOAD_FILE_INSTR_ERROR); + return (0); + } + + /* find the .mwa file */ + while ( (i < p_audio_gbl_var->melody_E2_load_file_instruments.nb_of_instruments) && + (customer_instrument_id != instrument_id)) + { + /* Load the instruments file from the FFS */ + if ( (ffs_read ( ffs_fd_1, + (&file_E2), + (sizeof(INT8) + AUDIO_PATH_NAME_MAX_SIZE))) < EFFS_OK ) + { + AUDIO_SEND_TRACE("AUDIO MELODY E2: impossible to load the .lsi file", RV_TRACE_LEVEL_ERROR); + + /* Close the file */ + ffs_close(ffs_fd_1); + + return (0); + } + + instrument_id = file_E2.id; + } + /* Close the file */ + ffs_close(ffs_fd_1); + + if (i == p_audio_gbl_var->melody_E2_load_file_instruments.nb_of_instruments) + { + AUDIO_SEND_TRACE("AUDIO MELODY E2: the instrument doesn't exist in the .lsi file", RV_TRACE_LEVEL_ERROR); + + return (0); + } + + /* Open the corresponding .mwa file */ + ffs_fd_2 = ffs_open( file_E2.melody_name, + FFS_O_RDONLY ); + if (ffs_fd_2 < EFFS_OK) + { + AUDIO_SEND_TRACE("AUDIO MELODY E2: impossible to open the .mwa file instruments", RV_TRACE_LEVEL_ERROR); + + /* Close the .mwa file */ + ffs_close(ffs_fd_2); + + return (0); + } + + /* download the instrument description */ + ffs_stat(file_E2.melody_name,&stat); + + /* check if the file contains some data */ + if (stat.size ==0) + { + /* the file doesn't contains data */ + /* an error is generated */ + audio_melody_E2_error_trace(AUDIO_ENTITY_FILE_ERROR); + + /* Close the .mwa file */ + ffs_close(ffs_fd_2); + + return(0); + } + + /* check if there's enough memory in the API for this instrument */ + if (allowed_size < (stat.size>>1)) + { + /* an error is generated */ + audio_melody_E2_error_trace(AUDIO_ERROR_INSTRUMENT_SIZE); + + /* Close the .mwa file */ + ffs_close(ffs_fd_2); + + return(0); + } + + ffs_read ( ffs_fd_2, + (void *)API_address, + stat.size ); + + /* Close the file */ + ffs_close(ffs_fd_2); + + return((stat.size>>1)); + #endif //_WINDOWS + #endif // OP_RIV_AUDIO + } + #endif // MELODY_E2 + + #if (L1_EXT_AUDIO_MGT) + /*-------------------------------------------------------*/ + /* Cust_ext_audio_mgt_hisr */ + /*-------------------------------------------------------*/ + /* */ + /* Parameters : none */ + /* */ + /* Return : none */ + /* */ + /* Description : */ + /* handle the DMA interrupt in order to request a new */ + /* buffer */ + /* */ + /*-------------------------------------------------------*/ + void Cust_ext_audio_mgt_hisr() + { + UWORD8 error_id = 0; + UWORD16 requested_size = l1a_l1s_com.stereopath_drv_task.parameters.frame_number*2; + + error_id = Cust_get_pointer((UWORD16 **)&l1a_l1s_com.stereopath_drv_task.parameters.source_buffer_address, + &requested_size, + l1s.ext_audio_mgt.session_id); + + } + #endif + +#if 0 /* FreeCalypso: removing functions not present in TCS211 */ + void l1a_bt_audio_noti_process() + { + UINT8 channel_id=0; + void *p_message = NULL; //omaps00090550 + T_RVF_MB_STATUS mb_status; //omaps00090550 + T_AUDIO_DRIVER_SESSION *p_session; + T_RV_RETURN *return_path; + /* find active channel_id associated to session_id */ + while ( (channel_id < AUDIO_DRIVER_MAX_CHANNEL)&& + ((p_audio_gbl_var->audio_driver_session[channel_id].session_info.state == AUDIO_DRIVER_CHANNEL_WAIT_INIT)|| + (p_audio_gbl_var->audio_driver_session[channel_id].session_req.session_id != AUDIO_EXT_MIDI_SESSION_ID)) ) + { + channel_id++; + } + /* get driver session */ + + p_session = &(p_audio_gbl_var->audio_driver_session[channel_id]); + p_session->session_info.index_l1=1-p_session->session_info.index_l1; + 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 = AUDIO_DRIVER_NOTIFICATION_MSG; + ((T_AUDIO_DRIVER_NOTIFICATION *)p_message)->channel_id = channel_id; + ((T_AUDIO_DRIVER_NOTIFICATION *)p_message)->p_buffer = NULL; + + /* 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); + } + + } +//NAVC start/stop/read energy +// Parameters :d_navc_start_stop_read // 1=start,2=stop,3=read energy +// UWORD32 d_navc_ctrl_status_energy_val +// 0=action not performed,1=action perf, xxx-value +// Description : this function will called to start/stop the NAVC and also to read the energy value during call +//The bit map of d_navc_ctrl_status is as follows. +// Bit 0: Start command: If 1 NAVC start. Set to 1 by MCU , Reset by DSp after module start Bit 1: Stop command : +// If 1 NAVC stop. Set to 1 by MCU , Reset by DSP after module stop. Bit 15: Status: Set and reset by DSP. If 1 +// module is active. If 0 module is not active. + + + UWORD32 Cust_navc_ctrl_status(UWORD8 d_navc_start_stop_read) + { + UWORD32 d_navc_ctrl_status_energy_val=0; + + switch (d_navc_start_stop_read) + { + case 1: /* Start NAVC */ + { + if((l1s_dsp_com.dsp_ndb_ptr->d_navc_ctrl_status & 0x8000)==0)l1s_dsp_com.dsp_ndb_ptr->d_navc_ctrl_status |= 0x01; //check 15th bit and if not active-put the last bit to 1 to start + d_navc_ctrl_status_energy_val=1; //indicates action performed + } + break; + case 2: /* Stop NAVC */ + { + if((l1s_dsp_com.dsp_ndb_ptr->d_navc_ctrl_status & 0x8000)==0x8000)l1s_dsp_com.dsp_ndb_ptr->d_navc_ctrl_status |= 0x02; //check 15th bit and if active-put the last bit to 1 to start + d_navc_ctrl_status_energy_val=1; //indicates action performed + } + break; + case 3: /* NAVC read energy */ + { + if((l1s_dsp_com.dsp_ndb_ptr->d_navc_ctrl_status & 0x8000) == 0x8000)//check 15th bit and if active- read the value-- + { + d_navc_ctrl_status_energy_val = l1s_dsp_com.dsp_ndb_ptr->d_vad_noise_ene_ndb[0]; //MSB part + d_navc_ctrl_status_energy_val= (d_navc_ctrl_status_energy_val<<16)|(l1s_dsp_com.dsp_ndb_ptr->d_vad_noise_ene_ndb[1]); //MSB <<16 | LSB - indicates the energy value + } + } + break; + /*intended fall through */ + default: + break; + + + } +#if (L1_NAVC_TRACE == 1) //to see the NAVC trace + l1_trace_navc(d_navc_start_stop_read,d_navc_ctrl_status_energy_val); +#endif + + return (d_navc_ctrl_status_energy_val); + } +#endif + +#endif // AUDIO_TASK== 1