57e6a9f2a8
Remove functions that are not used at all, also remove the dependencies of this functions like struct members, comments and calls. Signed-off-by: Armando Uribe <x0095078@ti.com> Signed-off-by: Omar Ramirez Luna <omar.ramirez@ti.com>
343 lines
11 KiB
C
343 lines
11 KiB
C
/*
|
|
* strm.h
|
|
*
|
|
* DSP-BIOS Bridge driver support functions for TI OMAP processors.
|
|
*
|
|
* DSPBridge Stream Manager.
|
|
*
|
|
* Copyright (C) 2005-2006 Texas Instruments, Inc.
|
|
*
|
|
* This package is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* THIS PACKAGE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
|
|
* IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
|
|
* WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
|
|
*/
|
|
|
|
#ifndef STRM_
|
|
#define STRM_
|
|
|
|
#include <dspbridge/dev.h>
|
|
|
|
#include <dspbridge/strmdefs.h>
|
|
#include <dspbridge/proc.h>
|
|
|
|
/*
|
|
* ======== strm_allocate_buffer ========
|
|
* Purpose:
|
|
* Allocate data buffer(s) for use with a stream.
|
|
* Parameter:
|
|
* strmres: Stream resource info handle returned from strm_open().
|
|
* usize: Size (GPP bytes) of the buffer(s).
|
|
* num_bufs: Number of buffers to allocate.
|
|
* ap_buffer: Array to hold buffer addresses.
|
|
* Returns:
|
|
* 0: Success.
|
|
* -EFAULT: Invalid stream_obj.
|
|
* -ENOMEM: Insufficient memory.
|
|
* -EPERM: Failure occurred, unable to allocate buffers.
|
|
* -EINVAL: usize must be > 0 bytes.
|
|
* Requires:
|
|
* strm_init(void) called.
|
|
* ap_buffer != NULL.
|
|
* Ensures:
|
|
*/
|
|
extern int strm_allocate_buffer(struct strm_res_object *strmres,
|
|
u32 usize,
|
|
u8 **ap_buffer,
|
|
u32 num_bufs,
|
|
struct process_context *pr_ctxt);
|
|
|
|
/*
|
|
* ======== strm_close ========
|
|
* Purpose:
|
|
* Close a stream opened with strm_open().
|
|
* Parameter:
|
|
* strmres: Stream resource info handle returned from strm_open().
|
|
* Returns:
|
|
* 0: Success.
|
|
* -EFAULT: Invalid stream_obj.
|
|
* -EPIPE: Some data buffers issued to the stream have not
|
|
* been reclaimed.
|
|
* -EPERM: Failure to close stream.
|
|
* Requires:
|
|
* strm_init(void) called.
|
|
* Ensures:
|
|
*/
|
|
extern int strm_close(struct strm_res_object *strmres,
|
|
struct process_context *pr_ctxt);
|
|
|
|
/*
|
|
* ======== strm_create ========
|
|
* Purpose:
|
|
* Create a STRM manager object. This object holds information about the
|
|
* device needed to open streams.
|
|
* Parameters:
|
|
* strm_man: Location to store handle to STRM manager object on
|
|
* output.
|
|
* dev_obj: Device for this processor.
|
|
* Returns:
|
|
* 0: Success;
|
|
* -ENOMEM: Insufficient memory for requested resources.
|
|
* -EPERM: General failure.
|
|
* Requires:
|
|
* strm_init(void) called.
|
|
* strm_man != NULL.
|
|
* dev_obj != NULL.
|
|
* Ensures:
|
|
* 0: Valid *strm_man.
|
|
* error: *strm_man == NULL.
|
|
*/
|
|
extern int strm_create(struct strm_mgr **strm_man,
|
|
struct dev_object *dev_obj);
|
|
|
|
/*
|
|
* ======== strm_delete ========
|
|
* Purpose:
|
|
* Delete the STRM Object.
|
|
* Parameters:
|
|
* strm_mgr_obj: Handle to STRM manager object from strm_create.
|
|
* Returns:
|
|
* Requires:
|
|
* strm_init(void) called.
|
|
* Valid strm_mgr_obj.
|
|
* Ensures:
|
|
* strm_mgr_obj is not valid.
|
|
*/
|
|
extern void strm_delete(struct strm_mgr *strm_mgr_obj);
|
|
|
|
/*
|
|
* ======== strm_exit ========
|
|
* Purpose:
|
|
* Discontinue usage of STRM module.
|
|
* Parameters:
|
|
* Returns:
|
|
* Requires:
|
|
* strm_init(void) successfully called before.
|
|
* Ensures:
|
|
*/
|
|
extern void strm_exit(void);
|
|
|
|
/*
|
|
* ======== strm_free_buffer ========
|
|
* Purpose:
|
|
* Free buffer(s) allocated with strm_allocate_buffer.
|
|
* Parameter:
|
|
* strmres: Stream resource info handle returned from strm_open().
|
|
* ap_buffer: Array containing buffer addresses.
|
|
* num_bufs: Number of buffers to be freed.
|
|
* Returns:
|
|
* 0: Success.
|
|
* -EFAULT: Invalid stream handle.
|
|
* -EPERM: Failure occurred, unable to free buffers.
|
|
* Requires:
|
|
* strm_init(void) called.
|
|
* ap_buffer != NULL.
|
|
* Ensures:
|
|
*/
|
|
extern int strm_free_buffer(struct strm_res_object *strmres,
|
|
u8 **ap_buffer, u32 num_bufs,
|
|
struct process_context *pr_ctxt);
|
|
|
|
/*
|
|
* ======== strm_get_info ========
|
|
* Purpose:
|
|
* Get information about a stream. User's dsp_streaminfo is contained
|
|
* in stream_info struct. stream_info also contains Bridge private info.
|
|
* Parameters:
|
|
* stream_obj: Stream handle returned from strm_open().
|
|
* stream_info: Location to store stream info on output.
|
|
* uSteamInfoSize: Size of user's dsp_streaminfo structure.
|
|
* Returns:
|
|
* 0: Success.
|
|
* -EFAULT: Invalid stream_obj.
|
|
* -EINVAL: stream_info_size < sizeof(dsp_streaminfo).
|
|
* -EPERM: Unable to get stream info.
|
|
* Requires:
|
|
* strm_init(void) called.
|
|
* stream_info != NULL.
|
|
* Ensures:
|
|
*/
|
|
extern int strm_get_info(struct strm_object *stream_obj,
|
|
struct stream_info *stream_info,
|
|
u32 stream_info_size);
|
|
|
|
/*
|
|
* ======== strm_idle ========
|
|
* Purpose:
|
|
* Idle a stream and optionally flush output data buffers.
|
|
* If this is an output stream and flush_data is TRUE, all data currently
|
|
* enqueued will be discarded.
|
|
* If this is an output stream and flush_data is FALSE, this function
|
|
* will block until all currently buffered data is output, or the timeout
|
|
* specified has been reached.
|
|
* After a successful call to strm_idle(), all buffers can immediately
|
|
* be reclaimed.
|
|
* Parameters:
|
|
* stream_obj: Stream handle returned from strm_open().
|
|
* flush_data: If TRUE, discard output buffers.
|
|
* Returns:
|
|
* 0: Success.
|
|
* -EFAULT: Invalid stream_obj.
|
|
* -ETIME: A timeout occurred before the stream could be idled.
|
|
* -EPERM: Unable to idle stream.
|
|
* Requires:
|
|
* strm_init(void) called.
|
|
* Ensures:
|
|
*/
|
|
extern int strm_idle(struct strm_object *stream_obj, bool flush_data);
|
|
|
|
/*
|
|
* ======== strm_init ========
|
|
* Purpose:
|
|
* Initialize the STRM module.
|
|
* Parameters:
|
|
* Returns:
|
|
* TRUE if initialization succeeded, FALSE otherwise.
|
|
* Requires:
|
|
* Ensures:
|
|
*/
|
|
extern bool strm_init(void);
|
|
|
|
/*
|
|
* ======== strm_issue ========
|
|
* Purpose:
|
|
* Send a buffer of data to a stream.
|
|
* Parameters:
|
|
* stream_obj: Stream handle returned from strm_open().
|
|
* pbuf: Pointer to buffer of data to be sent to the stream.
|
|
* ul_bytes: Number of bytes of data in the buffer.
|
|
* ul_buf_size: Actual buffer size in bytes.
|
|
* dw_arg: A user argument that travels with the buffer.
|
|
* Returns:
|
|
* 0: Success.
|
|
* -EFAULT: Invalid stream_obj.
|
|
* -ENOSR: The stream is full.
|
|
* -EPERM: Failure occurred, unable to issue buffer.
|
|
* Requires:
|
|
* strm_init(void) called.
|
|
* pbuf != NULL.
|
|
* Ensures:
|
|
*/
|
|
extern int strm_issue(struct strm_object *stream_obj, u8 * pbuf,
|
|
u32 ul_bytes, u32 ul_buf_size, u32 dw_arg);
|
|
|
|
/*
|
|
* ======== strm_open ========
|
|
* Purpose:
|
|
* Open a stream for sending/receiving data buffers to/from a task of
|
|
* DAIS socket node on the DSP.
|
|
* Parameters:
|
|
* hnode: Node handle returned from node_allocate().
|
|
* dir: DSP_TONODE or DSP_FROMNODE.
|
|
* index: Stream index.
|
|
* pattr: Pointer to structure containing attributes to be
|
|
* applied to stream. Cannot be NULL.
|
|
* strmres: Location to store stream resuorce info handle on output.
|
|
* Returns:
|
|
* 0: Success.
|
|
* -EFAULT: Invalid hnode.
|
|
* -EPERM: Invalid direction.
|
|
* hnode is not a task or DAIS socket node.
|
|
* Unable to open stream.
|
|
* -EINVAL: Invalid index.
|
|
* Requires:
|
|
* strm_init(void) called.
|
|
* strmres != NULL.
|
|
* pattr != NULL.
|
|
* Ensures:
|
|
* 0: *strmres is valid.
|
|
* error: *strmres == NULL.
|
|
*/
|
|
extern int strm_open(struct node_object *hnode, u32 dir,
|
|
u32 index, struct strm_attr *pattr,
|
|
struct strm_res_object **strmres,
|
|
struct process_context *pr_ctxt);
|
|
|
|
/*
|
|
* ======== strm_reclaim ========
|
|
* Purpose:
|
|
* Request a buffer back from a stream.
|
|
* Parameters:
|
|
* stream_obj: Stream handle returned from strm_open().
|
|
* buf_ptr: Location to store pointer to reclaimed buffer.
|
|
* nbytes: Location where number of bytes of data in the
|
|
* buffer will be written.
|
|
* buff_size: Location where actual buffer size will be written.
|
|
* pdw_arg: Location where user argument that travels with
|
|
* the buffer will be written.
|
|
* Returns:
|
|
* 0: Success.
|
|
* -EFAULT: Invalid stream_obj.
|
|
* -ETIME: A timeout occurred before a buffer could be
|
|
* retrieved.
|
|
* -EPERM: Failure occurred, unable to reclaim buffer.
|
|
* Requires:
|
|
* strm_init(void) called.
|
|
* buf_ptr != NULL.
|
|
* nbytes != NULL.
|
|
* pdw_arg != NULL.
|
|
* Ensures:
|
|
*/
|
|
extern int strm_reclaim(struct strm_object *stream_obj,
|
|
u8 **buf_ptr, u32 * nbytes,
|
|
u32 *buff_size, u32 *pdw_arg);
|
|
|
|
/*
|
|
* ======== strm_register_notify ========
|
|
* Purpose:
|
|
* Register to be notified on specific events for this stream.
|
|
* Parameters:
|
|
* stream_obj: Stream handle returned by strm_open().
|
|
* event_mask: Mask of types of events to be notified about.
|
|
* notify_type: Type of notification to be sent.
|
|
* hnotification: Handle to be used for notification.
|
|
* Returns:
|
|
* 0: Success.
|
|
* -EFAULT: Invalid stream_obj.
|
|
* -ENOMEM: Insufficient memory on GPP.
|
|
* -EINVAL: event_mask is invalid.
|
|
* -ENOSYS: Notification type specified by notify_type is not
|
|
* supported.
|
|
* Requires:
|
|
* strm_init(void) called.
|
|
* hnotification != NULL.
|
|
* Ensures:
|
|
*/
|
|
extern int strm_register_notify(struct strm_object *stream_obj,
|
|
u32 event_mask, u32 notify_type,
|
|
struct dsp_notification
|
|
*hnotification);
|
|
|
|
/*
|
|
* ======== strm_select ========
|
|
* Purpose:
|
|
* Select a ready stream.
|
|
* Parameters:
|
|
* strm_tab: Array of stream handles returned from strm_open().
|
|
* strms: Number of stream handles in array.
|
|
* pmask: Location to store mask of ready streams on output.
|
|
* utimeout: Timeout value (milliseconds).
|
|
* Returns:
|
|
* 0: Success.
|
|
* -EDOM: strms out of range.
|
|
|
|
* -EFAULT: Invalid stream handle in array.
|
|
* -ETIME: A timeout occurred before a stream became ready.
|
|
* -EPERM: Failure occurred, unable to select a stream.
|
|
* Requires:
|
|
* strm_init(void) called.
|
|
* strm_tab != NULL.
|
|
* strms > 0.
|
|
* pmask != NULL.
|
|
* Ensures:
|
|
* 0: *pmask != 0 || utimeout == 0.
|
|
* Error: *pmask == 0.
|
|
*/
|
|
extern int strm_select(struct strm_object **strm_tab,
|
|
u32 strms, u32 *pmask, u32 utimeout);
|
|
|
|
#endif /* STRM_ */
|