Tested McASP configuration for I/O shortcut HDMIStereo.
[processor-sdk/performance-audio-sr.git] / pasdk / test_dsp / framework / audioStreamInpProc.h
2 /*
3 Copyright (c) 2017, Texas Instruments Incorporated - http://www.ti.com/
4 All rights reserved.
6 * Redistribution and use in source and binary forms, with or without 
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 *
13 * Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the
16 * distribution.
17 *
18 * Neither the name of Texas Instruments Incorporated nor the names of
19 * its contributors may be used to endorse or promote products derived
20 * from this software without specific prior written permission.
21 *
22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
25 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
26 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
27 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
28 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
29 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
30 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
31 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
32 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33 *
34 */
36 /*
37  *  ======== audioStreamInpProc.h ========
38  */
40 #ifndef _ASIP_H_
41 #define _ASIP_H_
42  
43 #include <xdc/std.h>
44 #include <ti/sysbios/knl/Event.h>
45 #include <ti/sysbios/knl/Task.h>
47 #include "aspMsg_master.h"
48 #include "audioStreamProc_params.h"
49 #include "audioStreamProc_patchs.h"
50 #include "audioStreamProc_config.h"
51 #include "audioStreamProc_master.h"
52 #include "statusOp_common.h"
53 #include "ioPhy.h"
54 #include "ioBuff.h"
55 #include "ioData.h"
57 struct PAF_ASIT_Params;
58 struct PAF_ASIT_Patchs;
59 struct PAF_ASIT_Config;
61 // Audio Stream Input Task (ASIT) parameters, functions
62 typedef struct PAF_ASIT_Fxns {
63     Int (*initPhase[8]) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *);
64     //Int (*initFrame0) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *, Int);
65     //Int (*initFrame1) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *, Int, Int);
66     Int (*passProcessing) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int);
67     //Int (*passProcessingCopy) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *);
68     Int (*autoProcessing) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int, ALG_Handle);
69     Int (*decodeProcessing) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int);    
70     Int (*decodeCommand) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *);
71     Int (*decodeInit) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int);
72     Int (*decodeInfo) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int, Int);
73     Int (*decodeInfo1) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int, Int);
74     Int (*decodeInfo2) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int, Int);
75     //Int (*decodeCont) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *, ALG_Handle *, Int, Int);
76     Int (*decodeDecode) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int, Int, Int);
77     Int (*decodeFinalTest) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int, Int);    
78     Int (*decodeComplete) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, ALG_Handle *, Int, Int);
79     Int (*selectDevices) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *);
80     Int (*sourceDecode) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int);    
81     Int (*deviceAllocate) (SIO_Handle *, int, int, int, Ptr);
82     Int (*deviceSelect) (SIO_Handle *, int, int, Ptr);
83     Int (*computeFrameLength) (Int, Int, Int);
84     Int (*updateInputStatus) (SIO_Handle, PAF_InpBufStatus *, PAF_InpBufConfig *);
85     //Int (*copy) (Uns, PAF_InpBufConfig *, Uns, PAF_OutBufConfig *);
87     // For RAM_report
88     Void (*headerPrint)();
89     Int  (*allocPrint)(const PAF_ALG_AllocInit *pInit, Int sizeofInit, PAF_IALG_Config *p);
90     Void (*commonPrint)(IALG_MemRec common[], PAF_IALG_Config *p);
91     Void (*bufMemPrint)(Int z, Int size, Int heapId, Int bufType);
92     Void (*memStatusPrint)(
93         CString header, 
94         HeapMem_Handle hInternalHeap, 
95         HeapMem_Handle hInternal1Heap, 
96         HeapMem_Handle hExternalHeap, 
97         HeapMem_Handle hInternal1HeapShm, 
98         HeapMem_Handle hExternalHeapShm, 
99         HeapMem_Handle hExternalNoncachedHeapShm);
100 } PAF_ASIT_Fxns;
102 // Audio Stream Input Task (ASIT) parameters
103 typedef struct PAF_ASIT_Params {
104     const PAF_ASIT_Fxns *fxns;
105     struct {
106         SmInt master;
107         SmInt inputs;
108         SmInt input1;
109         SmInt inputN;
110         SmInt decodes;
111         SmInt decode1;
112         SmInt decodeN;
113         SmInt streams;
114         SmInt stream1; /* unused */
115         SmInt streamN; /* unused */
116         SmInt encodes;
117         SmInt encode1;
118         SmInt encodeN;
119         SmInt outputs;
120         SmInt output1;
121         SmInt outputN;
122     } zone;
123     const SmInt *inputsFromDecodes;
124     const SmInt *outputsFromEncodes;
125     struct {
126         int *pHeapIdIntern;             // INT memory heap ID
127         int *pHeapIdExtern;             // EXT memory heap ID
128         int *pHeapIdInpbuf;             // IB buffer heap ID
129         int *pHeapIdOutbuf;             // OB buffer heap ID
130         int *pHeapIdFrmbuf;             // Frame buffer heap ID
131         int *pHeapIdIntern1;            // INT1 memory heap ID
132         int *pHeapIdInt1Shm;            // INT1 SHared Memory heap ID
133         int *pHeapIdExtShm;             // EXT SHared Memory heap ID
134         int *pHeapIdExtNonCachedShm;    // EXT Non-Cached SHared Memory heap ID
135         int clear; 
136     } heap;
137     struct {
138         const IALG_MemSpace *space;
139     } common;
140     const LgInt *z_rx_bufsiz;
141     const LgInt *z_tx_bufsiz;
142     const SmInt *z_numchan;
143     MdInt framelength;
144     const PAF_AudioFunctions *pAudioFrameFunctions;
145     const struct PAF_ASP_ChainFxns *pChainFxns;
146     const PAF_InpBufStatus *pInpBufStatus;
147     const PAF_DecodeStatus * const *z_pDecodeStatus;
148     const PAF_OutBufStatus *pOutBufStatus;
149     const PAF_EncodeStatus * const *z_pEncodeStatus;
150     const PAF_VolumeStatus *pVolumeStatus;
151     const PAF_ASP_AlgKey *pDecAlgKey;
152     const PAF_ASP_AlgKey *pEncAlgKey;
153     const PAF_ASP_SioMap *pDecSioMap;
154     const SmInt *streamsFromDecodes;
155     const SmInt *streamsFromEncodes;
156     const MdInt maxFramelength;
157     const SmInt *streamOrder;
158     const PAF_ASP_LinkInit * const (*i_inpLinkInit);
159     const PAF_ASP_LinkInit * const (*i_outLinkInit);
160     const PAF_ASP_outNumBufMap *  const (*poutNumBufMap);
161     const PAF_MetadataBufStatus *pMetadataBufStatus;
162     const PAF_AudioFrameBufStatus *pAudioFrameBufStatus;
163     const PAF_AST_DecOpCircBufStatus * const *z_pDecOpCircBufStatus;    
164 } PAF_ASIT_Params;
166 // Audio Stream Input Task (ASIT) patchs
167 typedef struct PAF_ASIT_Patchs {
168     const PAF_SIO_ParamsN * devinp;
169     //const PAF_SIO_ParamsN * devout;
170     //const PAF_ASP_LinkInit * const (*i_decLinkInit);
171     //const PAF_ASP_LinkInit * const (*i_aspLinkInit)[GEARS];
172     //const PAF_ASP_LinkInit * const (*i_encLinkInit);
173 } PAF_ASIT_Patchs;
175 enum {
176     ASIP_NO_ERR,
177     ASIP_ERR_AUTO_DETECION,
178     ASIP_ERR_NO_MATCHING_SOURCE,
179     ASIP_ERR_SWITCH_TO_PCM,
180     ASIP_ERR_D10_CFG,
181     ASIP_ERR_MCASP_CFG,
182     ASIP_ERR_INPUT_CFG,
183     ASIP_ERR_DECODE_INIT,
184     ASIP_ERR_DECODE_COMMAND,
185     ASIP_ERR_DECODE_INFO1,
186     ASIP_ERR_DECODE_INFO2,
187     ASIP_ERR_DECODE_DATA,
188     ASIP_ERR_DECODE_FINAL,
189     ASIP_ERR_DECODE_COMPLETE,
190     ASIP_ERR_DECODE_MSG,
191     ASIP_ERR_DECODE_QUIT,
192     ASIP_ERR_ABORT
193 };
196 enum {
197     ASIT_RESET,
198     ASIT_SOURCE_DETECTION,
199     ASIT_PCM_TRANSITION,
200     ASIT_DECODE_PROCESSING
201 };
203 enum {
204     ASIT_NO_ERR,
205     ASIT_ERR_IOBUFF_INIT,
206     ASIT_ERR_IODATA_INIT,
207     ASIT_ERR_IOPYH_INIT,
208     ASIT_ERR_INPDATA_PROC,
209     ASIT_ERR_INPBUF_UNDERFLOW,
210     ASIT_ERR_AUTO_DETECION,
211     ASIT_ERR_NO_MATCHING_SOURCE,
212     ASIT_ERR_SWITCH_TO_PCM,
213     ASIT_ERR_D10_CFG,
214     ASIT_ERR_MCASP_CFG,
215     ASIT_ERR_INPUT_CFG,
216     ASIT_ERR_DECODE_INIT,
217     ASIT_ERR_DECODE,
218     ASIT_ERR_DECODE_COMMAND,
219     ASIT_ERR_DECODE_INFO1,
220     ASIT_ERR_DECODE_INFO2,
221     ASIT_ERR_DECODE_DATA,
222     ASIT_ERR_DECODE_FINAL,
223     ASIT_ERR_DECODE_COMPLETE,
224     ASIT_ERR_DECODE_MSG,
225     ASIT_ERR_DECODE_QUIT,
226     ASIP_ERR_DECODE_ABORT,
227     ASIT_ERR_EVENTS,
228     ASIT_ERR_ABORT
229 };
231 enum {
232     DEC_NO_ERR,
233     DEC_ERR_SOURCE_NONE,
234     DEC_ERR_ASPERR_ABORT,
235     DEC_ERR_ASPERR_QUIT,
236     DEC_ERR_WRONG_MSG,
237     DEC_ERR_INFO_SNDMSG,
238     DEC_ERR_INFO_ACKMSG,
239     DEC_ERR_DECODE_SNDMSG,
240     DEC_ERR_DECODE_ACKMSG,
241     DEC_ERR_DECODE_FINAL,
242     DEC_ERR_COMPLETE_MSG
243 };
246 #define DEC_MSGMSK_INPDATA   0x1 // Input data message
247 #define DEC_MSGMSK_RXACK     0x2 // Receive acknowledge message
248 #define DEC_MSGMSK_INFOACK   0x4 // temp, will be removed
249 #define DEC_MSGMSK_DECACK    0x8 // temp, will be removed
252 // Input I/O structure
253 typedef struct PAF_AST_InpIO {
254     ioPhyHandle_t        hIoPhy;     /* handle to I/O physical layer */
255     ioBuffHandle_t       hIoBuff;    /* handle to I/O buffer management */
256     ioDataHandle_t       hIoData;    /* handle to I/O data processing */
257     Ptr                  hMcaspChan; /* handle to McASP LLD channel */
258     const void           *pRxParams; /* pointer to D10 Rx Params */
260     Int sourceSelect;
261     Int sourceProgram;
263     Int stride;
264     Int       preSyncState;
265     Int       numPrimeXfers;
266     Int       mcaspXferErr;
267 /*
268     void     *mcaspRxBuf1;
269     void     *mcaspRxBuf2;
270     uint32_t  mcaspRxSize1;
271     uint32_t  mcaspRxSize2;
272     Int       mcaspRxtwoXfers;
273 */
274     // debugging counters
275     //uint32_t numXferStart;
276     //uint32_t numXferFinish;
277     //uint32_t numXferInterm;
278     uint32_t numInputOverrun;
279     uint32_t numUnderflow;
280     uint32_t numAsitRestart;
281     uint32_t numAsitDecodeQuit;
282     uint32_t numFrameReceived;
283     uint32_t numPcmFrameReceived;
285     size_t         phyXferSize;
286     int_fast32_t   pcmSwitchHangOver;
287     uint_least16_t asipState;
288     //uint_least16_t asipProcState;
289     bool           buffReadComplete;
290     bool           swapData;
291     bool           firstTimeInit;
292 } PAF_AST_IoInp;
294 // Decoder structure
295 typedef struct asipDecProc_s {
296     Int state;
297     Int frame;
298     Int block;
300     Int majorAuFound;
301     Int initDone;
302     Int decodeAckDelayed;
303 } asipDecProc_t;
305 // Audio Stream Input Task (ASIT) configuration
306 typedef struct PAF_ASIT_Config {
307     Task_Handle taskHandle;             // ASIT handle
308     ACP_Handle acp;                     // ASIT local ACP handle
309     AspMsgMaster_Handle hAspMsgMaster;  // ASIT message master handle
310     PAF_ASPM_Config *pAspmCfg;          // ASIT/ASOT shared configuration
311     PAF_AST_Config *pAstCfg;            // ASIT/ASOT/ASDT shared configuration
312     PAF_AST_IoInp *pIoInp;              // ASIT IO configuration
313     asipDecProc_t inpDec;
314 } PAF_ASIT_Config;
317 // ASIT event IDs
318 #define ASIT_EVTMSK_NONE        0x0
319 #define ASIT_EVTMSK_INPDATA     0x1 // Input data (Rx McASP EDMA) event
320 #define ASIT_EVTMSK_RXACK       0x2 // Receive acknowledge (IPC MessageQ) message event
321 #define ASIT_EVTMSK_INFOACK     0x4 // temp, will be removed
322 #define ASIT_EVTMSK_DECACK      0x8 // temp, will be removed
324 // ASIT event handle
325 extern Event_Handle gAsitEvtHandle;
327 // ASIT Sync event handle
328 extern SyncEvent_Handle gAsitSyncEvtHandle;
330 // ASIT ASP messaging
331 #define ASIT_ASP_MSG_HEAP_ID        ( 0 )                           // ASIT message master heap Id
332 #define ASIT_ASP_MSG_MASTER_NUMSGS  ( ASP_MSG_MASTER_DEF_NUMMSGS )  // ASIT message master number of messages
334 // ASIT configuration
335 extern PAF_ASIT_Config gPAF_ASIT_config;
338 //   Purpose:   Audio Stream Input Task Function for initialization of data pointers
339 //              by allocation of memory.
340 Int 
341 PAF_ASIT_initPhaseMalloc(
342     const PAF_ASIT_Params *pP, 
343     const PAF_ASIT_Patchs *pQ, 
344     PAF_ASIT_Config *pAsitCfg
345 );
347 //   Purpose:   Audio Stream Input Task Function for initialization of data values
348 //              from parameters.
349 Int
350 PAF_ASIT_initPhaseConfig(
351     const PAF_ASIT_Params *pP, 
352     const PAF_ASIT_Patchs *pQ, 
353     PAF_ASIT_Config *pAsitCfg
354 );
356 //   Purpose:   Audio Stream Input Task Function for initialization of ACP by
357 //              instantiation of the algorithm.
358 Int
359 PAF_ASIT_initPhaseAcpAlg(
360     const PAF_ASIT_Params *pP, 
361     const PAF_ASIT_Patchs *pQ, 
362     PAF_ASIT_Config *pAsitCfg
363 );
365 //   Purpose:   Audio Stream Input Task Function for allocation of common memory.
366 Int
367 PAF_ASIT_initPhaseCommon(
368     const PAF_ASIT_Params *pP, 
369     const PAF_ASIT_Patchs *pQ, 
370     PAF_ASIT_Config *pAsitCfg
371 );
373 //   Purpose:   Audio Stream Input Task Function for initialization of ASP algorithms.
374 Int
375 PAF_ASIT_initPhaseAspAlg(
376     const PAF_ASIT_Params *pP, 
377     const PAF_ASIT_Patchs *pQ, 
378     PAF_ASIT_Config *pAsitCfg
379 );
381 //   Purpose:   Audio Stream Input Task Function for initialization of data values
382 //              from parameters for Algorithm Keys.
383 Int
384 PAF_ASIT_initPhaseAlgKey(
385     const PAF_ASIT_Params *pP, 
386     const PAF_ASIT_Patchs *pQ, 
387     PAF_ASIT_Config *pAsitCfg
388 );
390 //   Purpose:   Audio Stream Input Task Function for initialization of Decoder Output Circular Buffer.
391 Int
392 PAF_ASIT_initPhaseDecOpCircBuf(
393     const PAF_ASIT_Params *pP, 
394     const PAF_ASIT_Patchs *pQ, 
395     PAF_ASIT_Config *pAsitCfg
396 );
398 //   Purpose:   Audio Stream Input Task Function for initialization of Input Devices.
399 Int
400 PAF_ASIT_initPhaseDevice(
401     const PAF_ASIT_Params *pP, 
402     const PAF_ASIT_Patchs *pQ, 
403     PAF_ASIT_Config *pAsitCfg
404 );
406 //   Purpose:   Audio Stream Input Task Function for initialization of Output Init-Sync.
407 Int
408 PAF_ASIT_initPhaseOutIS(
409     const PAF_ASIT_Params *pP, 
410     const PAF_ASIT_Patchs *pQ, 
411     PAF_ASIT_Config *pAsdtCfg
412 );
415 #if 0
416 //   Purpose:   Audio Stream Task Function for initialization or reinitiali-
417 //              zation of the Audio Frame(s) by loading of data values of a
418 //              time-varying nature.
419 Int
420 PAF_AST_initFrame1(
421     const PAF_ASIT_Params *pP, 
422     const PAF_ASIT_Patchs *pQ, 
423     PAF_AST_Config *pAsitCfg, 
424     Int z, 
425     Int apply
426 );
427 #endif
429 //   Purpose:   Audio Stream Task Function for processing audio data to
430 //              determine the input type without output.
431 Int
432 PAF_ASIT_autoProcessing(
433     const PAF_ASIT_Params *pP, 
434     const PAF_ASIT_Patchs *pQ, 
435     PAF_ASIT_Config *pAsitCfg, 
436     Int inputTypeSelect, 
437     ALG_Handle pcmAlgMaster);
439 //   Purpose:   Audio Stream Input Task Function for processing audio data.
440 //
441 Int
442 PAF_ASIT_decodeProcessing(
443     const PAF_ASIT_Params *pP, 
444     const PAF_ASIT_Patchs *pQ, 
445     PAF_ASIT_Config *pAsitCfg, 
446     Int sourceSelect
447 );
449 //   Purpose:   Decoding Function for processing Decode Commands.
450 Int
451 PAF_ASIT_decodeCommand(
452     const PAF_ASIT_Params *pP, 
453     const PAF_ASIT_Patchs *pQ, 
454     PAF_ASIT_Config *pAsitCfg
455 );
457 //   Purpose:   Decoding Function for reinitializing the decoding process.
458 Int
459 PAF_ASIT_decodeInit(
460     const PAF_ASIT_Params *pP, 
461     const PAF_ASIT_Patchs *pQ, 
462     PAF_ASIT_Config *pAsitCfg, 
463     Int sourceSelect
464 );
466 //   Purpose:   Decoding Function for processing information in a manner that
467 //              is common for both initial and subsequent frames of input data.
468 Int
469 PAF_ASIT_decodeInfo(
470     const PAF_ASIT_Params *pP, 
471     const PAF_ASIT_Patchs *pQ, 
472     PAF_ASIT_Config *pAsitCfg, 
473     Int frame, 
474     Int block
475 );
477 //   Purpose:   Decoding Function for processing information in a manner that
478 //              is unique to initial frames of input data.
479 Int
480 PAF_ASIT_decodeInfo1(
481     const PAF_ASIT_Params *pP, 
482     const PAF_ASIT_Patchs *pQ, 
483     PAF_ASIT_Config *pAsitCfg, 
484     Int frame, 
485     Int block
486 );
488 //   Purpose:   Decoding Function for processing information in a manner that
489 //              is unique to frames of input data other than the initial one.
490 Int
491 PAF_ASIT_decodeInfo2(
492     const PAF_ASIT_Params *pP, 
493     const PAF_ASIT_Patchs *pQ, 
494     PAF_ASIT_Config *pAsitCfg, 
495     Int frame, 
496     Int block
497 );
499 #if 0
500 //   Purpose:   Decoding Function for processing that occurs subsequent to
501 //              information processing but antecedent to timing processing
502 //              for frames of input data other than the initial one.
503 Int
504 PAF_AST_decodeCont(
505     const PAF_ASIT_Params *pP, 
506     const PAF_ASIT_Patchs *pQ, 
507     PAF_ASIT_Config *pAsitCfg, 
508     ALG_Handle decAlg[], 
509     Int frame, 
510     Int block
511 );
512 #endif
514 //   Purpose:   Decoding Function for processing of input data by the
515 //              Decode Algorithm.
516 Int
517 PAF_ASIT_decodeDecode(
518     const PAF_ASIT_Params *pP, 
519     const PAF_ASIT_Patchs *pQ, 
520     PAF_ASIT_Config *pAsitCfg, 
521     Int sourceSelect, 
522     Int frame, 
523     Int block
524 );
526 //   Purpose:   Decoding Function for determining whether processing of the
527 //              current frame is complete.
528 Int
529 PAF_ASIT_decodeFinalTest(
530     const PAF_ASIT_Params *pP, 
531     const PAF_ASIT_Patchs *pQ, 
532     PAF_ASIT_Config *pAsitCfg, 
533     Int frame, 
534     Int block
535 );
537 //   Purpose:   Decoding Function for terminating the decoding process.
538 Int
539 PAF_ASIT_decodeComplete(
540     const PAF_ASIT_Params *pP, 
541     const PAF_ASIT_Patchs *pQ, 
542     PAF_ASIT_Config *pAsitCfg, 
543     ALG_Handle decAlg[], 
544     Int frame, 
545     Int block
546 );
548 //   Purpose:   Audio Stream Input Task Function for selecting the devices used
549 //              for input.
550 Int
551 PAF_ASIT_selectDevices(
552     const PAF_ASIT_Params *pP, 
553     const PAF_ASIT_Patchs *pQ, 
554     PAF_ASIT_Config *pAsitCfg
555 );
557 //   Purpose:   Audio Stream Input Task Function for selecting the sources used
558 //              for decoding of input to output.
559 Int
560 PAF_ASIT_sourceDecode(
561     const PAF_ASIT_Params *pP, 
562     const PAF_ASIT_Patchs *pQ, 
563     PAF_ASIT_Config *pAsitCfg, 
564     Int x
565 );
567 //   Purpose:   Common Function for processing algorithm chains.
568 Int
569 PAF_AST_streamChainFunction(
570     const PAF_ASIT_Params *pP, 
571     const PAF_ASIT_Patchs *pQ, 
572     PAF_ASIT_Config *pAsitCfg, 
573     Int iChainFrameFxns, 
574     Int abortOnError, 
575     Int logArg
576 );
578 //   Purpose:   writing 8-bit integer to shared memeory
579 static inline
580 sharedMemWriteInt8(
581         volatile XDAS_Int8 *address, /* address to write to */
582         Int8 value,                  /* value to write to the adddress */
583         Int gateIdx)                 /* GateMP Index, defined in statusOp_common.h */
585 #ifdef NON_CACHE_STATUS
586         statusOp_write((void *)address, (void *)&value, sizeof(Int8), gateIdx);
587 #else
588         *address = value;
589 #endif
592 //   Purpose:   read 8-bit integer from shared memeory
593 static inline Int8               /* return the value read in the shared memory */
594 sharedMemReadInt8(
595         volatile XDAS_Int8 *address, /* address to read from */
596         Int gateIdx)                 /* GateMP Index, defined in statusOp_common.h */
598 #ifdef NON_CACHE_STATUS
599         Int8 tempVar;
600         statusOp_read((void *)&tempVar, (void *)address, sizeof(Int8), gateIdx);
602         return tempVar;
603 #else
604         return(*address);
605 #endif
608 //   Purpose:   writing 32-bit integer to shared memeory
609 static inline sharedMemWriteInt(volatile XDAS_Int32 *address, Int value, Int gateIdx)
611 #ifdef NON_CACHE_STATUS
612         statusOp_write((void *)address, (void *)&value, sizeof(Int), gateIdx);
613 #else
614         *address = value;
615 #endif
618 //   Purpose:   read 32-bit integer from shared memeory
619 static inline Int sharedMemReadInt(volatile XDAS_Int32 *address, Int gateIdx)
621 #ifdef NON_CACHE_STATUS
622         Int tempVar;
623         statusOp_read((void *)&tempVar, (void *)address, sizeof(Int), gateIdx);
625         return tempVar;
626 #else
627         return(*address);
628 #endif
631 Int asitUpdateInputStatus(const void *pRxParams, PAF_InpBufStatus *pStatus,
632                           PAF_InpBufConfig *pInpBuf);
633 /*
634 Int asipDecodeInit(
635         const PAF_ASIT_Params *pP,
636         PAF_ASIT_Config *pAsitCfg,
637         Int sourceSelect);
638 */
639 /*Int asipDecodeProcessing(
640         const PAF_ASIT_Params *pP,
641         const PAF_ASIT_Patchs *pQ,
642         PAF_ASIT_Config *pAsitCfg,
643         Int sourceSelect);*/
644 Int asitDecodeProcessing(const PAF_ASIT_Params *pP,
645                          const PAF_ASIT_Patchs *pQ,
646                          PAF_ASIT_Config       *pAsitCfg,
647                          UInt asitEvents);
649 Int decDecodeInit(
650         const PAF_ASIT_Params *pP,
651         PAF_ASIT_Config *pAsitCfg,
652         Int sourceSelect);
654 Int decDecodeFsm(
655         const PAF_ASIT_Params *pP,
656         const PAF_ASIT_Patchs *pQ,
657         PAF_ASIT_Config *pAsitCfg,
658         Int sourceSelect,
659         UInt decMsg);
661 Int getFrameLengthSourceSel(
662         const PAF_ASIT_Params *pP,
663         Int8 sourceSelect);
665 Int rxDecodePcm(PAF_AST_IoInp  *pInp);
667 Int rxDecodeBitStream(PAF_AST_IoInp  *pInp);
669 Int rxDecodePlayZero(PAF_AST_IoInp  *pInp);
672 #endif /* _ASIP_H_ */