/* * dspbridge/mpu_api/inc/DSPStream.h * * DSP-BIOS Bridge driver support functions for TI OMAP processors. * * Copyright (C) 2007 Texas Instruments, Inc. * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as published * by the Free Software Foundation version 2.1 of the License. * * This program is distributed .as is. WITHOUT ANY WARRANTY of any kind, * whether express or implied; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. */ /* * ======== DSPStream.h ======== * Description: * This is the header for the DSP/BIOS Bridge stream module. * * Public Functions: * DSPStream_AllocateBuffers * DSPStream_Close * DSPStream_FreeBuffers * DSPStream_GetInfo * DSPStream_Idle * DSPStream_Issue * DSPStream_Open * DSPStream_Reclaim * DSPStream_RegisterNotify * DSPStream_Select * * Notes: * *! Revision History: *! ================ *! 23-Nov-2002 gp: Comment change: uEventMask is really a "type". *! 17-Dec-2001 ag Fix return codes in DSPStream_[Issue][Reclaim] *! 12-Dec-2001 ag Added DSP_ENOTIMPL error code to DSPStream_Open(). *! 17-Nov-2001 ag Added DSP_ETRANSLATE error. *! Added bufSize param and renamed dwBytes to dwDataSize in *! DSPStream_[Issue][Reclaim](). *! 07-Jun-2001 sg: Made buffer alloc/free fxn names plural. *! 13-Feb-2001 kc: DSP/BIOS Bridge name updates. *! 27-Sep-2000 jeh Removed DSP_BUFFERATTR parameter from DSPStream_Allocate- *! Buffer(), since these have been moved to DSP_STREAMATTRIN. *! 07-Sep-2000 jeh Changed type HANDLE in DSPStream_RegisterNotify to *! DSP_HNOTIFICATION. *! 20-Jul-2000 rr: Updated to version 0.8 *! 27-Jun-2000 rr: Created from DBAPI.h */ #include <host_os.h> #ifndef DSPStream_ #define DSPStream_ #ifdef __cplusplus extern "C" { #endif /* * ======== DSPStream_AllocateBuffers ======== * Purpose: * Allocate data buffers for use with a specific stream. * Parameters: * hStream: The stream handle. * uSize: Size of the buffer * apBuffer: Ptr to location to hold array of buffers. * uNumBufs: The number of buffers to allocate of size uSize. * Returns: * DSP_SOK: Success. * DSP_EHANDLE: Invalid Stream handle. * DSP_EMEMORY: Insufficient memory * DSP_EPOINTER: Parameter apBuffer is not valid. * DSP_EALIGNMENT: Stream's alignment value not supported. * DSP_ESIZE: Illegal size. * DSP_EFAIL: General failure to allocate buffer. * Details: */ extern DBAPI DSPStream_AllocateBuffers(DSP_HSTREAM hStream, UINT uSize, OUT BYTE ** apBuffer, UINT uNumBufs); /* * ======== DSPStream_Close ======== * Purpose: * Close a stream and free the underlying stream object. * Parameters: * hStream: The stream handle. * Returns: * DSP_SOK: Success. * DSP_EHANDLE: Invalid Stream handle. * DSP_EPENDING: Not all stream buffers have been reclaimed * DSP_EFAIL: Failure to Close the Stream * Details: */ extern DBAPI DSPStream_Close(DSP_HSTREAM hStream); /* * ======== DSPStream_FreeBuffers ======== * Purpose: * Free a previously allocated stream data buffer. * Parameters: * hStream: The stream handle. * apBuffer: The array of buffers to free. * uNumBufs: The number of buffers. * Returns: * DSP_SOK: Success. * DSP_EHANDLE: Invalid Stream handle. * DSP_EPOINTER: Parameter apBuffer is not valid. * DSP_EFAIL: Failure to free the data buffers * Details: */ extern DBAPI DSPStream_FreeBuffers(DSP_HSTREAM hStream, IN BYTE ** apBuffer, UINT uNumBufs); /* * ======== DSPStream_GetInfo ======== * Purpose: * Get information about a stream. * Parameters: * hStream: The stream handle. * pStreamInfo: Ptr to the DSP_STREAMINFO structure. * uStreamInfoSize: The size of structure. * Returns: * DSP_SOK: Success. * DSP_EHANDLE: Invalid Stream handle. * DSP_EPOINTER: Parameter pStreamInfo is invalid. * DSP_ESIZE: uStreamInfoSize is too small to hold all stream * information. * DSP_EFAIL: Unable to retrieve Stream info * Details: */ extern DBAPI DSPStream_GetInfo(DSP_HSTREAM hStream, OUT struct DSP_STREAMINFO * pStreamInfo, UINT uStreamInfoSize); /* * ======== DSPStream_Idle ======== * Purpose: * Terminate I/O with a particular stream, and (optionally) * flush output data buffers. * Parameters: * hStream: The stream handle. * bFlush: Boolean flag * Returns: * DSP_SOK: Success. * DSP_EHANDLE: Invalid Stream handle. * DSP_ETIMEOUT: Time out occurred. * DSP_ERESTART: A critical error has * occurred and the DSP is being restarted. * DSP_EFAIL: Unable to Idle the stream * Details: */ extern DBAPI DSPStream_Idle(DSP_HSTREAM hStream, bool bFlush); /* * ======== DSPStream_Issue ======== * Purpose: * Send a buffer of data to a stream. * Parameters: * hStream: The stream handle. * pBuffer: Ptr to the buffer. * dwDataSize: Size of data in buffer in bytes. * dwBufSize: Size of actual buffer in bytes. * dwArg: User defined buffer context. * Returns: * DSP_SOK: Success. * DSP_EHANDLE: Invalid Stream handle. * DSP_EPOINTER: Invalid pBuffer pointer * DSP_ESTREAMFULL: The stream has been issued the maximum number * of buffers allowed in the stream at once; * buffers must be reclaimed from the stream * before any more can be issued. * DSP_EFAIL: Unable to issue the buffer. * DSP_ETRANSLATE: Unable to map shared buffer to client process. * Details: */ extern DBAPI DSPStream_Issue(DSP_HSTREAM hStream, IN BYTE * pBuffer, ULONG dwDataSize, ULONG dwBufSize, IN DWORD dwArg); /* * ======== DSPStream_Open ======== * Purpose: * Retrieve a stream handle for sending/receiving data buffers * to/from a task node on a DSP. * Parameters: * hNode: The node handle. * uDirection: Stream direction: {DSP_TONODE | DSP_FROMNODE}. * uIndex: Stream index (zero based). * pAttrIn: Ptr to the stream attributes (optional) * phStream: Ptr to location to store the stream handle. * Returns: * DSP_SOK: Success. * DSP_EPOINTER: Invalid phStream pointer. * DSP_ENODETYPE: Stream can not be opened for this node type/ * DSP_EDIRECTION: uDirection is invalid * DSP_EVALUE: uIndex is invalid, or, if pAttrIn != NULL, * pAttrIn->uSegment is invalid. * DSP_EFAIL: General failure. * DSP_ESTRMMODE: Stream mode is invalid. * DSP_EDMACHNL: DMAChnlId is invalid, if STRMMODE is LDMA or RDMA. * DSP_EHANDLE: Invalid Stream handle. * DSP_ENOTIMPL: Stream mode is not supported. * * Details: */ extern DBAPI DSPStream_Open(DSP_HNODE hNode, UINT uDirection, UINT uIndex, IN OPTIONAL struct DSP_STREAMATTRIN * pAttrIn, OUT DSP_HSTREAM * phStream); /* * ======== DSPStream_PrepareBuffer ======== * Purpose: * Prepare a buffer that was not allocated by DSPStream_AllocateBuffers * for use with a stream * Parameters: * hStream: Stream handle * uSize: Size of the allocated buffer(GPP bytes) * pBffer: Address of the Allocated buffer * Returns: * DSP_SOK: Success * DSP_EHANDLE: Invalid Stream handle * DSP_EPOINTER: Invalid pBuffer * DSP_EFAIL: Failure to Prepare a buffer */ extern DBAPI DSPStream_PrepareBuffer(DSP_HSTREAM hStream, UINT uSize, BYTE * pBuffer); /* * ======== DSPStream_Reclaim ======== * Purpose: * Request a buffer back from a stream. * Parameters: * hStream: The stream handle. * pBufPtr: Ptr to location to store stream buffer. * pDataSize: Ptr to location to store data size of the buffer. * pBufSize: Ptr to location to store actual size of the buffer. * pdwArg: Ptr to location to store user defined context. * Returns: * DSP_SOK: Success. * DSP_EHANDLE: Invalid Stream handle. * DSP_EPOINTER: One of pBufPtr or pBytes is invalid. * DSP_ETIMEOUT: Timeout waiting from I/O completion. * DSP_ERESTART: A critical error has occurred and * the DSP is being restarted. * DSP_EFAIL: Unable to Reclaim buffer. * DSP_ETRANSLATE: Unable to map shared buffer to client process. * Details: */ extern DBAPI DSPStream_Reclaim(DSP_HSTREAM hStream, OUT BYTE ** pBufPtr, OUT ULONG * pDataSize, OUT ULONG * pBufSize, OUT DWORD * pdwArg); /* * ======== DSPStream_RegisterNotify ======== * Purpose: * Register to be notified of specific events for this stream. * Parameters: * hStream: The stream handle. * uEventMask: Type of event to be notified about. * uNotifyType: Type of notification to be sent. * hNotification: Handle to be used for notification. * Returns: * DSP_SOK: Success. * DSP_EHANDLE: Invalid stream handle or invalid hNotification * DSP_EVALUE: uEventMask is invalid * DSP_ENOTIMP: Not supported as specified in uNotifyType * DSP_EFAIL: Unable to Register for notification * Details: */ extern DBAPI DSPStream_RegisterNotify(DSP_HSTREAM hStream, UINT uEventMask, UINT uNotifyType, struct DSP_NOTIFICATION* hNotification); /* * ======== DSPStream_Select ======== * Purpose: * Select a ready stream. * Parameters: * aStreamTab: Array of stream handles. * nStreams: Number of streams in array. * pMask: Pointer to the mask of ready streams. * uTimeout: Timeout value in milliseconds. * Returns: * DSP_SOK: Success. * DSP_ERANGE: nStreams is out of range * DSP_EPOINTER: Invalid aStreamTab or pMask pointer. * DSP_ETIMEOUT Timeout occured. * DSP_EFAIL: Failure to select a stream. * DSP_ERESTART: A critical error has occurred and * the DSP is being restarted. * Details: */ extern DBAPI DSPStream_Select(IN DSP_HSTREAM * aStreamTab, UINT nStreams, OUT UINT * pMask, UINT uTimeout); /* * ======== DSPStream_UnprepareBuffer ======== * Purpose: * UnPrepare a buffer that was prepared by DSPStream_PrepareBuffer * and will no longer be used with the stream * Parameters: * hStream: Stream handle * uSize: Size of the allocated buffer(GPP bytes) * pBffer: Address of the Allocated buffer * Returns: * DSP_SOK: Success * DSP_EHANDLE: Invalid Stream handle * DSP_EPOINTER: Invalid pBuffer * DSP_EFAIL: Failure to UnPrepare a buffer */ extern DBAPI DSPStream_UnprepareBuffer(DSP_HSTREAM hStream, UINT uSize, BYTE * pBuffer); #ifdef __cplusplus } #endif #endif /* DSPStream_ */