blob: 33abf5c0b51841319a197768dbe84ef3a23dc76e [file] [log] [blame]
rjw6c1fd8f2022-11-30 14:33:01 +08001/*****************************************************************************
2* Copyright Statement:
3* --------------------
4* This software is protected by Copyright and the information contained
5* herein is confidential. The software may not be copied and the information
6* contained herein may not be used or disclosed except with the written
7* permission of MediaTek Inc. (C) 2005
8*
9* BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
10* THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
11* RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
12* AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
13* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
14* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
15* NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
16* SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
17* SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
18* THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
19* NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
20* SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
21*
22* BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
23* LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
24* AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
25* OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
26* MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
27*
28* THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
29* WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
30* LAWS PRINCIPLES. ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
31* RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
32* THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
33*
34*****************************************************************************/
35
36/*****************************************************************************
37 *
38 * Filename:
39 * ---------
40 * PcmMixer3.c
41 *
42 * Project:
43 * --------
44 *
45 *
46 * Description:
47 * ------------
48 *
49 *
50 * Author:
51 * -------
52 * -------
53 *============================================================================
54 * HISTORY
55 * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
56 *------------------------------------------------------------------------------
57 * removed!
58 * removed!
59 * removed!
60 *
61 * removed!
62 * removed!
63 * removed!
64 * removed!
65 *
66 *------------------------------------------------------------------------------
67 * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
68 *============================================================================
69 ****************************************************************************/
70
71#include "kal_public_api.h"
72#include "kal_general_types.h"
73#include "sync_data.h"
74
75#include "kal_trace.h"
76#include "l1sp_trc.h"
77#include "event_info_utility.h" // for MODEM_WARNING_MESSAGE
78
79
80#include "am.h"
81#include "afe_def.h" // for output device setting
82#include "sp_drv.h"
83
84#include "pcmMixer3.h"
85#include "sal_exp.h"
86
87/************************** Constants ***************************************/
88#define PCMMIXER3_BUF_SIZE 640 // using in 16 bit, SWB
89
90typedef enum {
91 PCMMIXER3_STATE_IDLE = 0,
92 PCMMIXER3_STATE_RUN,
93 PCMMIXER3_STATE_CLOSING,
94}PCMMIXER3_STATE_TYPE;
95
96/*********** Structure *******************************************************/
97
98typedef struct{
99
100 PCMMIXER3_STATE_TYPE state;
101 kal_spinlockid lockId;
102
103 kal_bool ulmix;
104 kal_bool dlmix;
105
106 void (*hisrHandler)(void);
107
108 kal_uint16 aud_id;
109
110 kal_uint16 ULGain;
111 //kal_uint16 DLGain;
112
113}PcmMixer3_T;
114
115/*********** variable ********************************************************/
116
117static PcmMixer3_T gPcmMixer3;
118
119static kal_uint16 pcmMixer3Buf[PCMMIXER3_BUF_SIZE];
120static kal_uint16 pcmMixer3Buf_len;
121/*********** internal fucntion **********************************************/
122
123void pcmMixer3Hisr( void *pram )
124{
125 volatile uint16* toBuf;
126 uint16 i;
127
128 if (KAL_SPINLOCK_NOT_AVAILABLE == kal_take_spinlock(gPcmMixer3.lockId, KAL_NO_WAIT)) {
129 MD_TRC_VM_HISR_LOCK_NOT_AVALIABLE(1);
130 goto leaveHisr;
131 }
132 // handle extra notify and closing state
133 if (PCMMIXER3_STATE_RUN != gPcmMixer3.state)
134 goto leaveProc;
135
136 if(!SAL_Mixer3_IsRunning())
137 goto leaveProc;;
138
139 // gain and setting update
140 SAL_Mixer3_Config(gPcmMixer3.ULGain, gPcmMixer3.ulmix);
141 MD_TRC_MIXER3_INFO(gPcmMixer3.ULGain, gPcmMixer3.ulmix);
142 // write data
143 toBuf = SAL_Mixer3_GetBuf();
144 SAL_Mixer3_SetDataLen(pcmMixer3Buf_len);
145
146
147 for(i=0; i<pcmMixer3Buf_len; i++) {
148 toBuf[i] = pcmMixer3Buf[i];
149 }
150 Data_Sync_Barrier();
151
152
153leaveProc:
154 kal_give_spinlock(gPcmMixer3.lockId);
155
156 if( gPcmMixer3.hisrHandler != NULL) {
157 gPcmMixer3.hisrHandler();
158 }
159
160leaveHisr:
161 return;
162}
163
164
165/*===========================================================================*/
166uint16 PcmMixer3_QueryUlBufLen(void)
167{
168 return (uint16) (PCMMIXER3_BUF_SIZE);
169}
170
171/**
172 @srcBuf:
173 @len: length of sample
174*/
175void PcmMixer3_writeUlBuf(uint16 *srcBuf, uint16 len)
176{
177 if(len <= PCMMIXER3_BUF_SIZE) {
178 kal_take_spinlock(gPcmMixer3.lockId, KAL_INFINITE_WAIT);
179 kal_mem_cpy(pcmMixer3Buf, srcBuf, len*sizeof(int16));
180 pcmMixer3Buf_len = len;
181 MD_TRC_MIXER3_DATA_LENGTH(len);
182 if(0 == pcmMixer3Buf_len) {
183 pcmMixer3Buf_len = PCMMIXER3_BUF_SIZE;
184 memset(pcmMixer3Buf, 0, sizeof(kal_uint16)*PCMMIXER3_BUF_SIZE);
185 }
186 kal_give_spinlock(gPcmMixer3.lockId);
187 }
188}
189
190/**
191 @isMix: Mixer switch for uplink speech, 1 for SPH+Sound, 0 for sound only
192 @gain: Sound effect gain for uplink mixer, for 0 to 7
193*/
194void PcmMixer3_ConfigUl(kal_bool isMix, kal_int8 gain )
195{
196 MD_TRC_MIXER3_CONFIG_UL(isMix, gain);
197
198 if(gain<0) {
199 gain=0;
200 } else if (gain >7) {
201 gain=7;
202 }
203
204 if( gain == 0 )
205 gPcmMixer3.ULGain = 0;
206 else {
207 gPcmMixer3.ULGain = (kal_int16)(32767 >> (7 - gain));
208 }
209 gPcmMixer3.ulmix= isMix;
210}
211
212
213/**
214
215 The function starts the background sound playback of the media handle.
216
217 @bgSnd_hdlr: handler
218*/
219void PcmMixer3_Start(void (*mixerHisrHandler)(void))
220{
221 if(PCMMIXER3_STATE_RUN == gPcmMixer3.state) {
222 return;
223 }
224
225 MD_TRC_MIXER3_START();
226
227 gPcmMixer3.state = PCMMIXER3_STATE_IDLE;
228 memset(pcmMixer3Buf, 0, sizeof(kal_uint16)*PCMMIXER3_BUF_SIZE);
229 gPcmMixer3.hisrHandler = mixerHisrHandler;
230
231 L1Audio_SetFlag(gPcmMixer3.aud_id);
232
233 // update config to dsp
234 SAL_Mixer3_Config(gPcmMixer3.ULGain, gPcmMixer3.ulmix);
235
236 // turn on.
237 // AM_SND_PlaybackOn(); TODO:
238 SAL_Mixer3_SetInit();
239 {
240 uint32 I;
241 for( I = 0; I < 20; I++ ) {
242 if(SAL_Mixer3_IsRunning()) {
243 gPcmMixer3.state = PCMMIXER3_STATE_RUN;
244 break;
245 }
246 kal_sleep_task( AUD_1TICK(2) );
247 }
248 MODEM_WARNING_MESSAGE(I < 20, "PcmMixer3_Start: fail to wait DSP runing");
249 }
250
251
252}
253
254/*
255 * Description
256 * ---------
257 * The function stops the background sound playback of the media handle.
258 *
259 * Syntax
260 * ---------
261 * void PcmMixerStop();
262 *
263 * where
264 * hdl The media handle
265 *
266 * Return Value
267 * ---------
268 * None
269 */
270void PcmMixer3_Stop(void)
271{
272 uint32 I;
273
274 if(PCMMIXER3_STATE_RUN != gPcmMixer3.state) {
275 L1Audio_ClearFlag(gPcmMixer3.aud_id);
276 return;
277 }
278
279 // change the state before start closing
280 kal_take_spinlock(gPcmMixer3.lockId, KAL_INFINITE_WAIT);
281 gPcmMixer3.state= PCMMIXER3_STATE_CLOSING;
282 kal_give_spinlock(gPcmMixer3.lockId);
283
284 if(SAL_Mixer3_IsRunning())
285 SAL_Mixer3_SetFinal();
286 for ( I = 0; I < 20; I++ ) {
287 if ( SAL_Mixer3_IsIdle()) /* DSP returns to idle state */
288 break;
289
290 kal_sleep_task( AUD_1TICK(2) );
291 }
292 if(I>=20) {
293 DEBUG_ASSERT(0);
294 MODEM_WARNING_MESSAGE(0, "PcmMixer3_Stop: fail to stop DSP mixer2 function");
295 }
296
297 // TODO:
298 // AM_SND_PlaybackOff( true );
299 gPcmMixer3.state = PCMMIXER3_STATE_IDLE;
300
301 L1Audio_ClearFlag(gPcmMixer3.aud_id);
302}
303
304
305void PcmMixer3_Init(void)
306{
307 gPcmMixer3.lockId = kal_create_spinlock("pcmMixerLock");
308 gPcmMixer3.aud_id = L1Audio_GetAudioID();
309 L1Audio_HookHisrHandler(DP_D2C_MIXER3_UL_ID, pcmMixer3Hisr, 0);
310}
311
312