/*
* Copyright 2001-2008 Texas Instruments - http://www.ti.com/
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*
* ======== sync.h ========
* DSP-BIOS Bridge driver support functions for TI OMAP processors.
* Purpose:
* Provide synchronization services.
*
* Public Functions:
* SYNC_CloseEvent
* SYNC_DeleteCS
* SYNC_EnterCS
* SYNC_Exit
* SYNC_Init
* SYNC_InitializeCS
* SYNC_LeaveCS
* SYNC_OpenEvent
* SYNC_PostMessage
* SYNC_ResetEvent
* SYNC_SetEvent
* SYNC_WaitOnEvent
* SYNC_WaitOnMultipleEvents
*
*! Revision History:
*! ================
*! 05-Oct-2000 jeh Added SYNC_WaitOnMultipleEvents().
*! 01-Dec-1999 ag: Added #define SYNC_MAXNAMELENGTH.
*! 04-Nov-1999 kc: Added critical section functions and objects to SYNC.
*! 29-Oct-1999 kc: Cleaned up for code review.
*! 24-Sep-1999 kc: Added WinCE notes.
*! 20-Oct-1997 gp: Removed unused SYNC_ critical section and must complete fxns
*! Added SYNC_HOBJECT, SYNC_ATTRS, and object validation, and
*! merged SYNC_DestroyEvent into SYNC_CloseEvent, and merged
*! SYNC_CreateEvent into SYNC_OpenEvent.
*! 07-Oct-1997 gp: Added SYNC_Create/DestroyEvent (for NT testing).
*! 06-Oct-1997 gp: Added SYNC_OpenEvent.
*! 03-Jun-1997 gp: Added SYNC_{Begin|End}CritSection() functions.
*! 03-Jan-1997 gp: Added SYNC_INFINITE define.
*! 05-Aug-1996 gp: Created.
*/
#ifndef _SYNC_H
#define _SYNC_H
#ifdef __cplusplus
extern "C" {
#endif
#include <dspapi.h>
/* Special timeout value indicating an infinite wait: */
#define SYNC_INFINITE 0xffffffff
/* Maximum string length of a named event */
#define SYNC_MAXNAMELENGTH 32
/* Generic SYNC object: */
struct SYNC_OBJECT;
/*typedef struct SYNC_OBJECT *SYNC_HOBJECT;*/
/* Generic SYNC CS object: */
struct SYNC_CSOBJECT;
/*typedef struct SYNC_CSOBJECT *SYNC_HCSOBJECT;*/
/* Used SYNC_CSOBJECT instead of SYNC_DPCCSOBJECT to avoid warnings */
/*typedef struct SYNC_CSOBJECT *SYNC_HDPCCSOBJECT;*/
/* SYNC object attributes: */
struct SYNC_ATTRS {
HANDLE hUserEvent; /* Platform's User Mode synch. object. */
HANDLE hKernelEvent; /* Platform's Kernel Mode sync. object. */
DWORD dwReserved1; /* For future expansion. */
DWORD dwReserved2; /* For future expansion. */
} ;
/*
* ======== SYNC_CloseEvent ========
* Purpose:
* Close this event handle, freeing resources allocated in SYNC_OpenEvent
* if necessary.
* Parameters:
* hEvent: Handle to a synchronization event, created/opened in
* SYNC_OpenEvent.
* Returns:
* DSP_SOK: Success;
* DSP_EFAIL: Failed to close event handle.
* DSP_EHANDLE: Invalid handle.
* Requires:
* SYNC initialized.
* Ensures:
* Any subsequent usage of hEvent would be invalid.
*/
extern DSP_STATUS SYNC_CloseEvent(IN struct SYNC_OBJECT* hEvent);
/*
* ======== SYNC_DeleteCS ========
* Purpose:
* Delete a critical section.
* Parameters:
* hCSObj: critical section handle.
* Returns:
* DSP_SOK: Success.
* DSP_EHANDLE: Invalid handle.
* Requires:
* Ensures:
*/
extern DSP_STATUS SYNC_DeleteCS(IN struct SYNC_CSOBJECT* hCSObj);
/*
* ======== SYNC_EnterCS ========
* Purpose:
* Enter the critical section.
* Parameters:
* hCSObj: critical section handle.
* Returns:
* DSP_SOK: Success.
* DSP_EHANDLE: Invalid handle.
* Requires:
* Ensures:
*/
extern DSP_STATUS SYNC_EnterCS(IN struct SYNC_CSOBJECT* hCSObj);
/*
* ======== SYNC_Exit ========
* Purpose:
* Discontinue usage of module; free resources when reference count
* reaches 0.
* Parameters:
* Returns:
* Requires:
* SYNC initialized.
* Ensures:
* Resources used by module are freed when cRef reaches zero.
*/
extern VOID SYNC_Exit();
/*
* ======== SYNC_Init ========
* Purpose:
* Initializes private state of SYNC module.
* Parameters:
* Returns:
* TRUE if initialized; FALSE if error occured.
* Requires:
* Ensures:
* SYNC initialized.
*/
extern bool SYNC_Init();
/*
* ======== SYNC_InitializeCS ========
* Purpose:
* Initialize the critical section.
* Parameters:
* hCSObj: critical section handle.
* Returns:
* DSP_SOK: Success.
* DSP_EMEMORY: Out of memory.
* Requires:
* Ensures:
*/
extern DSP_STATUS SYNC_InitializeCS(OUT struct SYNC_CSOBJECT* * phCSObj);
/*
* ======== SYNC_InitializeDPCCS ========
* Purpose:
* Initialize the critical section between process context and DPC.
* Parameters:
* hCSObj: critical section handle.
* Returns:
* DSP_SOK: Success.
* DSP_EMEMORY: Out of memory.
* Requires:
* Ensures:
*/
extern DSP_STATUS SYNC_InitializeDPCCS(OUT struct SYNC_CSOBJECT** phCSObj);
/*
* ======== SYNC_LeaveCS ========
* Purpose:
* Leave the critical section.
* Parameters:
* hCSObj: critical section handle.
* Returns:
* DSP_SOK: Success.
* DSP_EHANDLE: Invalid handle.
* Requires:
* Ensures:
*/
extern DSP_STATUS SYNC_LeaveCS(IN struct SYNC_CSOBJECT* hCSObj);
/*
* ======== SYNC_OpenEvent ========
* Purpose:
* Create/open and initialize an event object for thread synchronization,
* which is initially in the non-signalled state.
* Parameters:
* phEvent: Pointer to location to receive the event object handle.
* pAttrs: Pointer to SYNC_ATTRS object containing initial SYNC
* SYNC_OBJECT attributes. If this pointer is NULL, then
* SYNC_OpenEvent will create and manage an OS specific
* syncronization object.
* pAttrs->hUserEvent: Platform's User Mode synchronization object.
*
* The behaviour of the SYNC methods depend on the value of
* the hUserEvent attr:
*
* 1. (hUserEvent == NULL):
* A user mode event is created.
* 2. (hUserEvent != NULL):
* A user mode event is supplied by the caller of SYNC_OpenEvent().
* Returns:
* DSP_SOK: Success.
* DSP_EFAIL: Unable to create user mode event.
* DSP_EMEMORY: Insufficient memory.
* DSP_EINVALIDARG SYNC_ATTRS values are invalid.
* Requires:
* - SYNC initialized.
* - phEvent != NULL.
* Ensures:
* If function succeeded, pEvent->hEvent must be a valid event handle.
*/
extern DSP_STATUS SYNC_OpenEvent(OUT struct SYNC_OBJECT* * phEvent,
IN OPTIONAL struct SYNC_ATTRS * pAttrs);
/*
* ========= SYNC_PostMessage ========
* Purpose:
* To post a windows message
* Parameters:
* hWindow: Handle to the window
* uMsg: Message to be posted
* Returns:
* DSP_SOK: Success
* DSP_EFAIL: Post message failed
* DSP_EHANDLE: Invalid Window handle
* Requires:
* SYNC initialized
* Ensures
*/
extern DSP_STATUS SYNC_PostMessage(IN HANDLE hWindow, IN UINT uMsg);
/*
* ======== SYNC_ResetEvent ========
* Purpose:
* Reset a syncronization event object state to non-signalled.
* Parameters:
* hEvent: Handle to a sync event.
* Returns:
* DSP_SOK: Success;
* DSP_EFAIL: Failed to reset event.
* DSP_EHANDLE: Invalid handle.
* Requires:
* SYNC initialized.
* Ensures:
*/
extern DSP_STATUS SYNC_ResetEvent(IN struct SYNC_OBJECT* hEvent);
/*
* ======== SYNC_SetEvent ========
* Purpose:
* Signal the event. Will unblock one waiting thread.
* Parameters:
* hEvent: Handle to an event object.
* Returns:
* DSP_SOK: Success.
* DSP_EFAIL: Failed to signal event.
* DSP_EHANDLE: Invalid handle.
* Requires:
* SYNC initialized.
* Ensures:
*/
extern DSP_STATUS SYNC_SetEvent(IN struct SYNC_OBJECT* hEvent);
/*
* ======== SYNC_WaitOnEvent ========
* Purpose:
* Wait for an event to be signalled, up to the specified timeout.
* Parameters:
* hEvent: Handle to an event object.
* dwTimeOut: The time-out interval, in milliseconds.
* The function returns if the interval elapses, even if
* the object's state is nonsignaled.
* If zero, the function tests the object's state and
* returns immediately.
* If SYNC_INFINITE, the function's time-out interval
* never elapses.
* Returns:
* DSP_SOK: The object was signalled.
* DSP_EHANDLE: Invalid handle.
* SYNC_E_FAIL: Wait failed, possibly because the process terminated.
* SYNC_E_TIMEOUT: Timeout expired while waiting for event to be signalled.
* Requires:
* Ensures:
*/
extern DSP_STATUS SYNC_WaitOnEvent(IN struct SYNC_OBJECT* hEvent,
IN DWORD dwTimeOut);
/*
* ======== SYNC_WaitOnMultipleEvents ========
* Purpose:
* Wait for any of an array of events to be signalled, up to the
* specified timeout.
* Note: dwTimeOut must be SYNC_INFINITE to signal infinite wait.
* Parameters:
* hSyncEvents: Array of handles to event objects.
* uCount: Number of event handles.
* dwTimeOut: The time-out interval, in milliseconds.
* The function returns if the interval elapses, even if
* no event is signalled.
* If zero, the function tests the object's state and
* returns immediately.
* If SYNC_INFINITE, the function's time-out interval
* never elapses.
* puIndex: Location to store index of event that was signalled.
* Returns:
* DSP_SOK: The object was signalled.
* SYNC_E_FAIL: Wait failed, possibly because the process terminated.
* SYNC_E_TIMEOUT: Timeout expired before event was signalled.
* DSP_EMEMORY: Memory allocation failed.
* Requires:
* Ensures:
*/
extern DSP_STATUS SYNC_WaitOnMultipleEvents(IN struct SYNC_OBJECT**
hSyncEvents, IN UINT uCount,
IN DWORD dwTimeout,
OUT UINT * puIndex);
#ifdef __cplusplus
}
#endif
#endif /* _SYNC_H */