Fixed frame length discrepancy between ASIT and decoder.
[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/Task.h>
46 #include "audioStreamProc_params.h"
47 #include "audioStreamProc_patchs.h"
48 #include "audioStreamProc_config.h"
49 #include "audioStreamProc_master.h"
50 #include "statusOp_common.h"
51 #include "ioPhy.h"
52 #include "ioBuff.h"
53 #include "ioData.h"
55 // Global debug counter */
56 extern Uint32 gTaskAsipCnt; // debug counter for ASP task
58 struct PAF_ASIT_Params;
59 struct PAF_ASIT_Patchs;
60 struct PAF_ASIT_Config;
62 // Audio Stream Input Task (ASIT) parameters, functions
63 typedef struct PAF_ASIT_Fxns {
64     Int (*initPhase[8]) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *);
65     //Int (*initFrame0) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *, Int);
66     //Int (*initFrame1) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *, Int, Int);
67     Int (*passProcessing) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int);
68     //Int (*passProcessingCopy) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *);
69     Int (*autoProcessing) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int, ALG_Handle);
70     Int (*decodeProcessing) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int);    
71     Int (*decodeCommand) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *);
72     //Int (*encodeCommand) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *);
73     Int (*decodeInit) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int);
74     Int (*decodeInfo) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int, Int);
75     Int (*decodeInfo1) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int, Int);
76     Int (*decodeInfo2) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int, Int);
77     //Int (*decodeCont) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *, ALG_Handle *, Int, Int);
78     Int (*decodeDecode) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int, Int, Int);
79     //Int (*decodeStream) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *, Int, Int);
80     //Int (*decodeEncode) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *, Int, Int);
81     Int (*decodeFinalTest) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int, Int);    
82     Int (*decodeComplete) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, ALG_Handle *, Int, Int);
83     Int (*selectDevices) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *);
84     Int (*sourceDecode) (const struct PAF_ASIT_Params *, const struct PAF_ASIT_Patchs *, struct PAF_ASIT_Config *, Int);    
85     //Int (*startOutput) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *);
86     //Int (*stopOutput) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *);
87     //Int (*setCheckRateX) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *, Int);
88     //Int (*streamChainFunction) (const struct PAF_AST_Params *, const struct PAF_AST_Patchs *, struct PAF_AST_Config *, Int, Int, Int);
89     Int (*deviceAllocate) (SIO_Handle *, int, int, int, Ptr);
90     Int (*deviceSelect) (SIO_Handle *, int, int, Ptr);
91     Int (*computeFrameLength) (Int, Int, Int);
92     Int (*updateInputStatus) (SIO_Handle, PAF_InpBufStatus *, PAF_InpBufConfig *);
93     //Int (*copy) (Uns, PAF_InpBufConfig *, Uns, PAF_OutBufConfig *);
95     // For RAM_report
96     Void (*headerPrint)();
97     Int  (*allocPrint)(const PAF_ALG_AllocInit *pInit, Int sizeofInit, PAF_IALG_Config *p);
98     Void (*commonPrint)(IALG_MemRec common[], PAF_IALG_Config *p);
99     Void (*bufMemPrint)(Int z, Int size, Int heapId, Int bufType);
100     Void (*memStatusPrint)(
101         CString header, 
102         HeapMem_Handle hInternalHeap, 
103         HeapMem_Handle hInternal1Heap, 
104         HeapMem_Handle hExternalHeap, 
105         HeapMem_Handle hInternal1HeapShm, 
106         HeapMem_Handle hExternalHeapShm, 
107         HeapMem_Handle hExternalNoncachedHeapShm);
108 } PAF_ASIT_Fxns;
110 // Audio Stream Input Task (ASIT) parameters
111 typedef struct PAF_ASIT_Params {
112     const PAF_ASIT_Fxns *fxns;
113     struct {
114         SmInt master;
115         SmInt inputs;
116         SmInt input1;
117         SmInt inputN;
118         SmInt decodes;
119         SmInt decode1;
120         SmInt decodeN;
121         SmInt streams;
122         SmInt stream1; /* unused */
123         SmInt streamN; /* unused */
124         SmInt encodes;
125         SmInt encode1;
126         SmInt encodeN;
127         SmInt outputs;
128         SmInt output1;
129         SmInt outputN;
130     } zone;
131     const SmInt *inputsFromDecodes;
132     const SmInt *outputsFromEncodes;
133     struct {
134         int *pHeapIdIntern;             // INT memory heap ID
135         int *pHeapIdExtern;             // EXT memory heap ID
136         int *pHeapIdInpbuf;             // IB buffer heap ID
137         int *pHeapIdOutbuf;             // OB buffer heap ID
138         int *pHeapIdFrmbuf;             // Frame buffer heap ID
139         int *pHeapIdIntern1;            // INT1 memory heap ID
140         int *pHeapIdInt1Shm;            // INT1 SHared Memory heap ID
141         int *pHeapIdExtShm;             // EXT SHared Memory heap ID
142         int *pHeapIdExtNonCachedShm;    // EXT Non-Cached SHared Memory heap ID
143         int clear; 
144     } heap;
145     struct {
146         const IALG_MemSpace *space;
147     } common;
148     const LgInt *z_rx_bufsiz;
149     const LgInt *z_tx_bufsiz;
150     const SmInt *z_numchan;
151     MdInt framelength;
152     const PAF_AudioFunctions *pAudioFrameFunctions;
153     const struct PAF_ASP_ChainFxns *pChainFxns;
154     const PAF_InpBufStatus *pInpBufStatus;
155     const PAF_DecodeStatus * const *z_pDecodeStatus;
156     const PAF_OutBufStatus *pOutBufStatus;
157     const PAF_EncodeStatus * const *z_pEncodeStatus;
158     const PAF_VolumeStatus *pVolumeStatus;
159     const PAF_ASP_AlgKey *pDecAlgKey;
160     const PAF_ASP_AlgKey *pEncAlgKey;
161     const PAF_ASP_SioMap *pDecSioMap;
162     const SmInt *streamsFromDecodes;
163     const SmInt *streamsFromEncodes;
164     const MdInt maxFramelength;
165     const SmInt *streamOrder;
166     const PAF_ASP_LinkInit * const (*i_inpLinkInit);
167     const PAF_ASP_LinkInit * const (*i_outLinkInit);
168     const PAF_ASP_outNumBufMap *  const (*poutNumBufMap);
169     const PAF_MetadataBufStatus *pMetadataBufStatus;
170     const PAF_AudioFrameBufStatus *pAudioFrameBufStatus;
171     const PAF_AST_DecOpCircBufStatus * const *z_pDecOpCircBufStatus;    
172 } PAF_ASIT_Params;
174 // Audio Stream Input Task (ASIT) patchs
175 typedef struct PAF_ASIT_Patchs {
176     const PAF_SIO_ParamsN * devinp;
177     //const PAF_SIO_ParamsN * devout;
178     //const PAF_ASP_LinkInit * const (*i_decLinkInit);
179     //const PAF_ASP_LinkInit * const (*i_aspLinkInit)[GEARS];
180     //const PAF_ASP_LinkInit * const (*i_encLinkInit);
181 } PAF_ASIT_Patchs;
183 enum {
184     ASIP_NO_ERR,
185     ASIP_ERR_AUTO_DETECION,
186     ASIP_ERR_NO_MATCHING_SOURCE,
187     ASIP_ERR_SWITCH_TO_PCM,
188     ASIP_ERR_D10_CFG,
189     ASIP_ERR_MCASP_CFG,
190     ASIP_ERR_INPUT_CFG,
191     ASIP_ERR_DECODE_INIT,
192     ASIP_ERR_DECODE_COMMAND,
193     ASIP_ERR_DECODE_INFO1,
194     ASIP_ERR_DECODE_INFO2,
195     ASIP_ERR_DECODE_DATA,
196     ASIP_ERR_DECODE_FINAL,
197     ASIP_ERR_DECODE_COMPLETE,
198     ASIP_ERR_DECODE_MSG,
199     ASIP_ERR_DECODE_QUIT,
200     ASIP_ERR_ABORT
201 };
203 enum {
204     ASIT_NO_ERR,
205     ASIT_ERR_AUTO_DETECION,
206     ASIT_ERR_NO_MATCHING_SOURCE,
207     ASIT_ERR_SWITCH_TO_PCM,
208     ASIT_ERR_D10_CFG,
209     ASIT_ERR_MCASP_CFG,
210     ASIT_ERR_INPUT_CFG,
211     ASIT_ERR_DECODE_INIT,
212     ASIT_ERR_DECODE_COMMAND,
213     ASIT_ERR_DECODE_INFO1,
214     ASIT_ERR_DECODE_INFO2,
215     ASIT_ERR_DECODE_DATA,
216     ASIT_ERR_DECODE_FINAL,
217     ASIT_ERR_DECODE_COMPLETE,
218     ASIT_ERR_DECODE_MSG,
219     ASIT_ERR_DECODE_QUIT,
220     ASIT_ERR_ABORT
221 };
223 #define DEC_MSGMSK_INPDATA   0x1
224 #define DEC_MSGMSK_INFOACK   0x2
225 #define DEC_MSGMSK_DECACK    0x4
228 // Input I/O structure
229 typedef struct PAF_AST_InpIO {
230     ioPhyHandle_t        hIoPhy;     /* handle to I/O physical layer */
231     ioBuffHandle_t       hIoBuff;    /* handle to I/O buffer management */
232     ioDataHandle_t       hIoData;    /* handle to I/O data processing */
233     Ptr                  hMcaspChan;
234     const void           *pRxParams; /* pointer to D10 Rx Params */
236     Int sourceSelect;
237     Int sourceProgram;
239     Int       preSyncState;
240     Int       numPrimeXfers;
241     Int       mcaspXferErr;
242 /*
243     void     *mcaspRxBuf1;
244     void     *mcaspRxBuf2;
245     uint32_t  mcaspRxSize1;
246     uint32_t  mcaspRxSize2;
247     Int       mcaspRxtwoXfers;
248 */
249     // debugging counters
250     //uint32_t numXferStart;
251     //uint32_t numXferFinish;
252     //uint32_t numXferInterm;
253     uint32_t numInputOverrun;
254     uint32_t numUnderflow;
255     uint32_t numAsipRestart;
256     uint32_t numAsipDecodeQuit;
257     uint32_t numFrameReceived;
258     uint32_t numPcmFrameReceived;
260     size_t         phyXferSize;
261     int_fast32_t   pcmSwitchHangOver;
262     uint_least16_t asipState;
263     uint_least16_t asipProcState;
264     bool           buffReadComplete;
265     bool           swapData;
266 } PAF_AST_IoInp;
268 // Decoder structure
269 typedef struct asipDecProc_s {
270     Int state;
271     Int frame;
272     Int block;
274     Int initDone;
275 } asipDecProc_t;
277 // Audio Stream Input Task (ASIT) configuration
278 typedef struct PAF_ASIT_Config {
279     Task_Handle taskHandle;      // ASIT handle
280     ACP_Handle acp;              // ASIT local ACP handle
281     PAF_ASPM_Config  *pAspmCfg;  // ASIT/ASOT shared configuration
282     PAF_AST_Config   *pAstCfg;   // ASIT/ASOT/ASDT shared configuration
283     PAF_AST_IoInp    *pIoInp;
284     asipDecProc_t    inpDec;
285 } PAF_ASIT_Config;
288 //   Purpose:   Audio Stream Input Task Function for initialization of data pointers
289 //              by allocation of memory.
290 Int 
291 PAF_ASIT_initPhaseMalloc(
292     const PAF_ASIT_Params *pP, 
293     const PAF_ASIT_Patchs *pQ, 
294     PAF_ASIT_Config *pAsitCfg
295 );
297 //   Purpose:   Audio Stream Input Task Function for initialization of data values
298 //              from parameters.
299 Int
300 PAF_ASIT_initPhaseConfig(
301     const PAF_ASIT_Params *pP, 
302     const PAF_ASIT_Patchs *pQ, 
303     PAF_ASIT_Config *pAsitCfg
304 );
306 //   Purpose:   Audio Stream Input Task Function for initialization of ACP by
307 //              instantiation of the algorithm.
308 Int
309 PAF_ASIT_initPhaseAcpAlg(
310     const PAF_ASIT_Params *pP, 
311     const PAF_ASIT_Patchs *pQ, 
312     PAF_ASIT_Config *pAsitCfg
313 );
315 //   (***) FL: re-visit this, ASIT/ASOT currently consider common memory independently.
316 //             Should simultaneously consider all algs in ASIT/ASOT.
317 //   Purpose:   Audio Stream Input Task Function for allocation of common memory.
318 Int
319 PAF_ASIT_initPhaseCommon(
320     const PAF_ASIT_Params *pP, 
321     const PAF_ASIT_Patchs *pQ, 
322     PAF_ASIT_Config *pAsitCfg
323 );
325 //   Purpose:   Audio Stream Input Task Function for initialization of ASP algorithms.
326 Int
327 PAF_ASIT_initPhaseAspAlg(
328     const PAF_ASIT_Params *pP, 
329     const PAF_ASIT_Patchs *pQ, 
330     PAF_ASIT_Config *pAsitCfg
331 );
333 //   Purpose:   Audio Stream Input Task Function for initialization of data values
334 //              from parameters for Algorithm Keys.
335 Int
336 PAF_ASIT_initPhaseAlgKey(
337     const PAF_ASIT_Params *pP, 
338     const PAF_ASIT_Patchs *pQ, 
339     PAF_ASIT_Config *pAsitCfg
340 );
342 //   Purpose:   Audio Stream Input Task Function for initialization of Decoder Output Circular Buffer.
343 Int
344 PAF_ASIT_initPhaseDecOpCircBuf(
345     const PAF_ASIT_Params *pP, 
346     const PAF_ASIT_Patchs *pQ, 
347     PAF_ASIT_Config *pAsitCfg
348 );
350 //   Purpose:   Audio Stream Input Task Function for initialization of Input Devices.
351 Int
352 PAF_ASIT_initPhaseDevice(
353     const PAF_ASIT_Params *pP, 
354     const PAF_ASIT_Patchs *pQ, 
355     PAF_ASIT_Config *pAsitCfg
356 );
358 //   Purpose:   Audio Stream Input Task Function for initialization of Output Init-Sync.
359 Int
360 PAF_ASIT_initPhaseOutIS(
361     const PAF_ASIT_Params *pP, 
362     const PAF_ASIT_Patchs *pQ, 
363     PAF_ASIT_Config *pAsdtCfg
364 );
367 #if 0
368 //   Purpose:   Audio Stream Task Function for initialization or reinitiali-
369 //              zation of the Audio Frame(s) by loading of data values of a
370 //              time-varying nature.
371 Int
372 PAF_AST_initFrame1(
373     const PAF_ASIT_Params *pP, 
374     const PAF_ASIT_Patchs *pQ, 
375     PAF_AST_Config *pAsitCfg, 
376     Int z, 
377     Int apply
378 );
379 #endif
381 //   Purpose:   Audio Stream Task Function for processing audio data to
382 //              determine the input type without output.
383 Int
384 PAF_ASIT_autoProcessing(
385     const PAF_ASIT_Params *pP, 
386     const PAF_ASIT_Patchs *pQ, 
387     PAF_ASIT_Config *pAsitCfg, 
388     Int inputTypeSelect, 
389     ALG_Handle pcmAlgMaster);
391 //   Purpose:   Audio Stream Input Task Function for processing audio data.
392 //
393 Int
394 PAF_ASIT_decodeProcessing(
395     const PAF_ASIT_Params *pP, 
396     const PAF_ASIT_Patchs *pQ, 
397     PAF_ASIT_Config *pAsitCfg, 
398     Int sourceSelect
399 );
401 //   Purpose:   Decoding Function for processing Decode Commands.
402 Int
403 PAF_ASIT_decodeCommand(
404     const PAF_ASIT_Params *pP, 
405     const PAF_ASIT_Patchs *pQ, 
406     PAF_ASIT_Config *pAsitCfg
407 );
409 //   Purpose:   Decoding Function for reinitializing the decoding process.
410 Int
411 PAF_ASIT_decodeInit(
412     const PAF_ASIT_Params *pP, 
413     const PAF_ASIT_Patchs *pQ, 
414     PAF_ASIT_Config *pAsitCfg, 
415     Int sourceSelect
416 );
418 //   Purpose:   Decoding Function for processing information in a manner that
419 //              is common for both initial and subsequent frames of input data.
420 Int
421 PAF_ASIT_decodeInfo(
422     const PAF_ASIT_Params *pP, 
423     const PAF_ASIT_Patchs *pQ, 
424     PAF_ASIT_Config *pAsitCfg, 
425     Int frame, 
426     Int block
427 );
429 //   Purpose:   Decoding Function for processing information in a manner that
430 //              is unique to initial frames of input data.
431 Int
432 PAF_ASIT_decodeInfo1(
433     const PAF_ASIT_Params *pP, 
434     const PAF_ASIT_Patchs *pQ, 
435     PAF_ASIT_Config *pAsitCfg, 
436     Int frame, 
437     Int block
438 );
440 //   Purpose:   Decoding Function for processing information in a manner that
441 //              is unique to frames of input data other than the initial one.
442 Int
443 PAF_ASIT_decodeInfo2(
444     const PAF_ASIT_Params *pP, 
445     const PAF_ASIT_Patchs *pQ, 
446     PAF_ASIT_Config *pAsitCfg, 
447     Int frame, 
448     Int block
449 );
451 #if 0
452 //   Purpose:   Decoding Function for processing that occurs subsequent to
453 //              information processing but antecedent to timing processing
454 //              for frames of input data other than the initial one.
455 Int
456 PAF_AST_decodeCont(
457     const PAF_ASIT_Params *pP, 
458     const PAF_ASIT_Patchs *pQ, 
459     PAF_ASIT_Config *pAsitCfg, 
460     ALG_Handle decAlg[], 
461     Int frame, 
462     Int block
463 );
464 #endif
466 //   Purpose:   Decoding Function for processing of input data by the
467 //              Decode Algorithm.
468 Int
469 PAF_ASIT_decodeDecode(
470     const PAF_ASIT_Params *pP, 
471     const PAF_ASIT_Patchs *pQ, 
472     PAF_ASIT_Config *pAsitCfg, 
473     Int sourceSelect, 
474     Int frame, 
475     Int block
476 );
478 //   Purpose:   Decoding Function for determining whether processing of the
479 //              current frame is complete.
480 Int
481 PAF_ASIT_decodeFinalTest(
482     const PAF_ASIT_Params *pP, 
483     const PAF_ASIT_Patchs *pQ, 
484     PAF_ASIT_Config *pAsitCfg, 
485     Int frame, 
486     Int block
487 );
489 //   Purpose:   Decoding Function for terminating the decoding process.
490 Int
491 PAF_ASIT_decodeComplete(
492     const PAF_ASIT_Params *pP, 
493     const PAF_ASIT_Patchs *pQ, 
494     PAF_ASIT_Config *pAsitCfg, 
495     ALG_Handle decAlg[], 
496     Int frame, 
497     Int block
498 );
500 //   Purpose:   Audio Stream Input Task Function for selecting the devices used
501 //              for input.
502 Int
503 PAF_ASIT_selectDevices(
504     const PAF_ASIT_Params *pP, 
505     const PAF_ASIT_Patchs *pQ, 
506     PAF_ASIT_Config *pAsitCfg
507 );
509 //   Purpose:   Audio Stream Input Task Function for selecting the sources used
510 //              for decoding of input to output.
511 Int
512 PAF_ASIT_sourceDecode(
513     const PAF_ASIT_Params *pP, 
514     const PAF_ASIT_Patchs *pQ, 
515     PAF_ASIT_Config *pAsitCfg, 
516     Int x
517 );
519 //   Purpose:   Decoding Function for terminating output.
520 Int
521 PAF_AST_stopOutput(
522     const PAF_ASIT_Params *pP, 
523     const PAF_ASIT_Patchs *pQ, 
524     PAF_ASIT_Config *pAsitCfg
525 );
527 //   Purpose:   Common Function for processing algorithm chains.
528 Int
529 PAF_AST_streamChainFunction(
530     const PAF_ASIT_Params *pP, 
531     const PAF_ASIT_Patchs *pQ, 
532     PAF_ASIT_Config *pAsitCfg, 
533     Int iChainFrameFxns, 
534     Int abortOnError, 
535     Int logArg
536 );
538 //   Purpose:   writing 8-bit integer to shared memeory
539 static inline
540 sharedMemWriteInt8(
541         volatile XDAS_Int8 *address, /* address to write to */
542         Int8 value,                  /* value to write to the adddress */
543         Int gateIdx)                 /* GateMP Index, defined in statusOp_common.h */
545 #ifdef NON_CACHE_STATUS
546         statusOp_write((void *)address, (void *)&value, sizeof(Int8), gateIdx);
547 #else
548         *address = value;
549 #endif
552 //   Purpose:   read 8-bit integer from shared memeory
553 static inline Int8               /* return the value read in the shared memory */
554 sharedMemReadInt8(
555         volatile XDAS_Int8 *address, /* address to read from */
556         Int gateIdx)                 /* GateMP Index, defined in statusOp_common.h */
558 #ifdef NON_CACHE_STATUS
559         Int8 tempVar;
560         statusOp_read((void *)&tempVar, (void *)address, sizeof(Int8), gateIdx);
562         return tempVar;
563 #else
564         return(*address);
565 #endif
568 //   Purpose:   writing 32-bit integer to shared memeory
569 static inline sharedMemWriteInt(volatile XDAS_Int32 *address, Int value, Int gateIdx)
571 #ifdef NON_CACHE_STATUS
572         statusOp_write((void *)address, (void *)&value, sizeof(Int), gateIdx);
573 #else
574         *address = value;
575 #endif
578 //   Purpose:   read 32-bit integer from shared memeory
579 static inline Int sharedMemReadInt(volatile XDAS_Int32 *address, Int gateIdx)
581 #ifdef NON_CACHE_STATUS
582         Int tempVar;
583         statusOp_read((void *)&tempVar, (void *)address, sizeof(Int), gateIdx);
585         return tempVar;
586 #else
587         return(*address);
588 #endif
591 Int asipUpdateInputStatus(const void *pRxParams, PAF_InpBufStatus *pStatus,
592                           PAF_InpBufConfig *pInpBuf);
593 /*
594 Int asipDecodeInit(
595         const PAF_ASIT_Params *pP,
596         PAF_ASIT_Config *pAsitCfg,
597         Int sourceSelect);
598 */
599 Int asipDecodeProcessing(
600         const PAF_ASIT_Params *pP,
601         const PAF_ASIT_Patchs *pQ,
602         PAF_ASIT_Config *pAsitCfg,
603         Int sourceSelect);
605 Int decDecodeInit(
606         const PAF_ASIT_Params *pP,
607         PAF_ASIT_Config *pAsitCfg,
608         Int sourceSelect);
609 Int getFrameLengthSourceSel(
610         const PAF_ASIT_Params *pP,
611         Int8 sourceSelect);
613 Int rxDecodePcm(PAF_AST_IoInp  *pInp);
615 Int rxDecodeBitStream(PAF_AST_IoInp  *pInp);
617 Int rxDecodePlayZero(PAF_AST_IoInp  *pInp);
619 #endif /* _ASIP_H_ */