2a3cb65b7ba16a1f8b5f1c155cca0afd8754dfa6
[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 // Input I/O structure
204 typedef struct PAF_AST_InpIO {
205     ioPhyHandle_t        hIoPhy;     /* handle to I/O physical layer */
206     ioBuffHandle_t       hIoBuff;    /* handle to I/O buffer management */
207     ioDataHandle_t       hIoData;    /* handle to I/O data processing */
208     Ptr                  hMcaspChan;
209     const void           *pRxParams; /* pointer to D10 Rx Params */
211     Int sourceSelect;
212     Int sourceProgram;
214     Int       preSyncState;
215     Int       numPrimeXfers;
216     Int       mcaspXferErr;
217 /*
218     void     *mcaspRxBuf1;
219     void     *mcaspRxBuf2;
220     uint32_t  mcaspRxSize1;
221     uint32_t  mcaspRxSize2;
222     Int       mcaspRxtwoXfers;
223 */
224     // debugging counters
225     //uint32_t numXferStart;
226     //uint32_t numXferFinish;
227     //uint32_t numXferInterm;
228     uint32_t numInputOverrun;
229     uint32_t numUnderflow;
230     uint32_t numAsipRestart;
231     uint32_t numAsipDecodeQuit;
232     uint32_t numFrameReceived;
233     uint32_t numPcmFrameReceived;
235     size_t         phyXferSize;
236     int_fast32_t   switchHangOver;
237     uint_least16_t asipState;
238     uint_least16_t asipProcState;
239     bool           buffReadComplete;
240     bool           swapData;
241 } PAF_AST_IoInp;
243 // Decoder structure
244 typedef struct asipDecProc_s {
245     Int state;
246     Int frame;
247     Int block;
249     Int initDone;
250 } asipDecProc_t;
252 // Audio Stream Input Task (ASIT) configuration
253 typedef struct PAF_ASIT_Config {
254     Task_Handle taskHandle;      // ASIT handle
255     ACP_Handle acp;              // ASIT local ACP handle
256     PAF_ASPM_Config  *pAspmCfg;  // ASIT/ASOT shared configuration
257     PAF_AST_Config   *pAstCfg;   // ASIT/ASOT/ASDT shared configuration
258     PAF_AST_IoInp    *pIoInp;
259     asipDecProc_t    inpDec;
260 } PAF_ASIT_Config;
263 //   Purpose:   Audio Stream Input Task Function for initialization of data pointers
264 //              by allocation of memory.
265 Int 
266 PAF_ASIT_initPhaseMalloc(
267     const PAF_ASIT_Params *pP, 
268     const PAF_ASIT_Patchs *pQ, 
269     PAF_ASIT_Config *pAsitCfg
270 );
272 //   Purpose:   Audio Stream Input Task Function for initialization of data values
273 //              from parameters.
274 Int
275 PAF_ASIT_initPhaseConfig(
276     const PAF_ASIT_Params *pP, 
277     const PAF_ASIT_Patchs *pQ, 
278     PAF_ASIT_Config *pAsitCfg
279 );
281 //   Purpose:   Audio Stream Input Task Function for initialization of ACP by
282 //              instantiation of the algorithm.
283 Int
284 PAF_ASIT_initPhaseAcpAlg(
285     const PAF_ASIT_Params *pP, 
286     const PAF_ASIT_Patchs *pQ, 
287     PAF_ASIT_Config *pAsitCfg
288 );
290 //   (***) FL: re-visit this, ASIT/ASOT currently consider common memory independently.
291 //             Should simultaneously consider all algs in ASIT/ASOT.
292 //   Purpose:   Audio Stream Input Task Function for allocation of common memory.
293 Int
294 PAF_ASIT_initPhaseCommon(
295     const PAF_ASIT_Params *pP, 
296     const PAF_ASIT_Patchs *pQ, 
297     PAF_ASIT_Config *pAsitCfg
298 );
300 //   Purpose:   Audio Stream Input Task Function for initialization of ASP algorithms.
301 Int
302 PAF_ASIT_initPhaseAspAlg(
303     const PAF_ASIT_Params *pP, 
304     const PAF_ASIT_Patchs *pQ, 
305     PAF_ASIT_Config *pAsitCfg
306 );
308 //   Purpose:   Audio Stream Input Task Function for initialization of data values
309 //              from parameters for Algorithm Keys.
310 Int
311 PAF_ASIT_initPhaseAlgKey(
312     const PAF_ASIT_Params *pP, 
313     const PAF_ASIT_Patchs *pQ, 
314     PAF_ASIT_Config *pAsitCfg
315 );
317 //   Purpose:   Audio Stream Input Task Function for initialization of Decoder Output Circular Buffer.
318 Int
319 PAF_ASIT_initPhaseDecOpCircBuf(
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 Input Devices.
326 Int
327 PAF_ASIT_initPhaseDevice(
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 Output Init-Sync.
334 Int
335 PAF_ASIT_initPhaseOutIS(
336     const PAF_ASIT_Params *pP, 
337     const PAF_ASIT_Patchs *pQ, 
338     PAF_ASIT_Config *pAsdtCfg
339 );
342 #if 0
343 //   Purpose:   Audio Stream Task Function for initialization or reinitiali-
344 //              zation of the Audio Frame(s) by loading of data values of a
345 //              time-varying nature.
346 Int
347 PAF_AST_initFrame1(
348     const PAF_ASIT_Params *pP, 
349     const PAF_ASIT_Patchs *pQ, 
350     PAF_AST_Config *pAsitCfg, 
351     Int z, 
352     Int apply
353 );
354 #endif
356 //   Purpose:   Audio Stream Task Function for processing audio data to
357 //              determine the input type without output.
358 Int
359 PAF_ASIT_autoProcessing(
360     const PAF_ASIT_Params *pP, 
361     const PAF_ASIT_Patchs *pQ, 
362     PAF_ASIT_Config *pAsitCfg, 
363     Int inputTypeSelect, 
364     ALG_Handle pcmAlgMaster);
366 //   Purpose:   Audio Stream Input Task Function for processing audio data.
367 //
368 Int
369 PAF_ASIT_decodeProcessing(
370     const PAF_ASIT_Params *pP, 
371     const PAF_ASIT_Patchs *pQ, 
372     PAF_ASIT_Config *pAsitCfg, 
373     Int sourceSelect
374 );
376 //   Purpose:   Decoding Function for processing Decode Commands.
377 Int
378 PAF_ASIT_decodeCommand(
379     const PAF_ASIT_Params *pP, 
380     const PAF_ASIT_Patchs *pQ, 
381     PAF_ASIT_Config *pAsitCfg
382 );
384 //   Purpose:   Decoding Function for reinitializing the decoding process.
385 Int
386 PAF_ASIT_decodeInit(
387     const PAF_ASIT_Params *pP, 
388     const PAF_ASIT_Patchs *pQ, 
389     PAF_ASIT_Config *pAsitCfg, 
390     Int sourceSelect
391 );
393 //   Purpose:   Decoding Function for processing information in a manner that
394 //              is common for both initial and subsequent frames of input data.
395 Int
396 PAF_ASIT_decodeInfo(
397     const PAF_ASIT_Params *pP, 
398     const PAF_ASIT_Patchs *pQ, 
399     PAF_ASIT_Config *pAsitCfg, 
400     Int frame, 
401     Int block
402 );
404 //   Purpose:   Decoding Function for processing information in a manner that
405 //              is unique to initial frames of input data.
406 Int
407 PAF_ASIT_decodeInfo1(
408     const PAF_ASIT_Params *pP, 
409     const PAF_ASIT_Patchs *pQ, 
410     PAF_ASIT_Config *pAsitCfg, 
411     Int frame, 
412     Int block
413 );
415 //   Purpose:   Decoding Function for processing information in a manner that
416 //              is unique to frames of input data other than the initial one.
417 Int
418 PAF_ASIT_decodeInfo2(
419     const PAF_ASIT_Params *pP, 
420     const PAF_ASIT_Patchs *pQ, 
421     PAF_ASIT_Config *pAsitCfg, 
422     Int frame, 
423     Int block
424 );
426 #if 0
427 //   Purpose:   Decoding Function for processing that occurs subsequent to
428 //              information processing but antecedent to timing processing
429 //              for frames of input data other than the initial one.
430 Int
431 PAF_AST_decodeCont(
432     const PAF_ASIT_Params *pP, 
433     const PAF_ASIT_Patchs *pQ, 
434     PAF_ASIT_Config *pAsitCfg, 
435     ALG_Handle decAlg[], 
436     Int frame, 
437     Int block
438 );
439 #endif
441 //   Purpose:   Decoding Function for processing of input data by the
442 //              Decode Algorithm.
443 Int
444 PAF_ASIT_decodeDecode(
445     const PAF_ASIT_Params *pP, 
446     const PAF_ASIT_Patchs *pQ, 
447     PAF_ASIT_Config *pAsitCfg, 
448     Int sourceSelect, 
449     Int frame, 
450     Int block
451 );
453 //   Purpose:   Decoding Function for determining whether processing of the
454 //              current frame is complete.
455 Int
456 PAF_ASIT_decodeFinalTest(
457     const PAF_ASIT_Params *pP, 
458     const PAF_ASIT_Patchs *pQ, 
459     PAF_ASIT_Config *pAsitCfg, 
460     Int frame, 
461     Int block
462 );
464 //   Purpose:   Decoding Function for terminating the decoding process.
465 Int
466 PAF_ASIT_decodeComplete(
467     const PAF_ASIT_Params *pP, 
468     const PAF_ASIT_Patchs *pQ, 
469     PAF_ASIT_Config *pAsitCfg, 
470     ALG_Handle decAlg[], 
471     Int frame, 
472     Int block
473 );
475 //   Purpose:   Audio Stream Input Task Function for selecting the devices used
476 //              for input.
477 Int
478 PAF_ASIT_selectDevices(
479     const PAF_ASIT_Params *pP, 
480     const PAF_ASIT_Patchs *pQ, 
481     PAF_ASIT_Config *pAsitCfg
482 );
484 //   Purpose:   Audio Stream Input Task Function for selecting the sources used
485 //              for decoding of input to output.
486 Int
487 PAF_ASIT_sourceDecode(
488     const PAF_ASIT_Params *pP, 
489     const PAF_ASIT_Patchs *pQ, 
490     PAF_ASIT_Config *pAsitCfg, 
491     Int x
492 );
494 //   Purpose:   Decoding Function for terminating output.
495 Int
496 PAF_AST_stopOutput(
497     const PAF_ASIT_Params *pP, 
498     const PAF_ASIT_Patchs *pQ, 
499     PAF_ASIT_Config *pAsitCfg
500 );
502 //   Purpose:   Common Function for processing algorithm chains.
503 Int
504 PAF_AST_streamChainFunction(
505     const PAF_ASIT_Params *pP, 
506     const PAF_ASIT_Patchs *pQ, 
507     PAF_ASIT_Config *pAsitCfg, 
508     Int iChainFrameFxns, 
509     Int abortOnError, 
510     Int logArg
511 );
513 //   Purpose:   writing 8-bit integer to shared memeory
514 static inline
515 sharedMemWriteInt8(
516         volatile XDAS_Int8 *address, /* address to write to */
517         Int8 value,                  /* value to write to the adddress */
518         Int gateIdx)                 /* GateMP Index, defined in statusOp_common.h */
520 #ifdef NON_CACHE_STATUS
521         statusOp_write((void *)address, (void *)&value, sizeof(Int8), gateIdx);
522 #else
523         *address = value;
524 #endif
527 //   Purpose:   read 8-bit integer from shared memeory
528 static inline Int8               /* return the value read in the shared memory */
529 sharedMemReadInt8(
530         volatile XDAS_Int8 *address, /* address to read from */
531         Int gateIdx)                 /* GateMP Index, defined in statusOp_common.h */
533 #ifdef NON_CACHE_STATUS
534         Int8 tempVar;
535         statusOp_read((void *)&tempVar, (void *)address, sizeof(Int8), gateIdx);
537         return tempVar;
538 #else
539         return(*address);
540 #endif
543 //   Purpose:   writing 32-bit integer to shared memeory
544 static inline sharedMemWriteInt(volatile XDAS_Int32 *address, Int value, Int gateIdx)
546 #ifdef NON_CACHE_STATUS
547         statusOp_write((void *)address, (void *)&value, sizeof(Int), gateIdx);
548 #else
549         *address = value;
550 #endif
553 //   Purpose:   read 32-bit integer from shared memeory
554 static inline Int sharedMemReadInt(volatile XDAS_Int32 *address, Int gateIdx)
556 #ifdef NON_CACHE_STATUS
557         Int tempVar;
558         statusOp_read((void *)&tempVar, (void *)address, sizeof(Int), gateIdx);
560         return tempVar;
561 #else
562         return(*address);
563 #endif
566 Int asipUpdateInputStatus(const void *pRxParams, PAF_InpBufStatus *pStatus,
567                           PAF_InpBufConfig *pInpBuf);
568 /*
569 Int asipDecodeInit(
570         const PAF_ASIT_Params *pP,
571         PAF_ASIT_Config *pAsitCfg,
572         Int sourceSelect);
573 */
574 Int asipDecodeProcessing(
575         const PAF_ASIT_Params *pP,
576         const PAF_ASIT_Patchs *pQ,
577         PAF_ASIT_Config *pAsitCfg,
578         Int sourceSelect);
580 Int rxDecodePcm(PAF_AST_IoInp  *pInp);
582 Int rxDecodeBitStream(PAF_AST_IoInp  *pInp);
584 Int rxDecodePlayZero(PAF_AST_IoInp  *pInp);
586 #endif /* _ASIP_H_ */