1 /* 2 * Copyright 2001-2008 Texas Instruments - http://www.ti.com/ 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 /* 18 * ======== sync.h ======== 19 * DSP-BIOS Bridge driver support functions for TI OMAP processors. 20 * Purpose: 21 * Provide synchronization services. 22 * 23 * Public Functions: 24 * SYNC_CloseEvent 25 * SYNC_DeleteCS 26 * SYNC_EnterCS 27 * SYNC_Exit 28 * SYNC_Init 29 * SYNC_InitializeCS 30 * SYNC_LeaveCS 31 * SYNC_OpenEvent 32 * SYNC_PostMessage 33 * SYNC_ResetEvent 34 * SYNC_SetEvent 35 * SYNC_WaitOnEvent 36 * SYNC_WaitOnMultipleEvents 37 * 38 *! Revision History: 39 *! ================ 40 *! 05-Oct-2000 jeh Added SYNC_WaitOnMultipleEvents(). 41 *! 01-Dec-1999 ag: Added #define SYNC_MAXNAMELENGTH. 42 *! 04-Nov-1999 kc: Added critical section functions and objects to SYNC. 43 *! 29-Oct-1999 kc: Cleaned up for code review. 44 *! 24-Sep-1999 kc: Added WinCE notes. 45 *! 20-Oct-1997 gp: Removed unused SYNC_ critical section and must complete fxns 46 *! Added SYNC_HOBJECT, SYNC_ATTRS, and object validation, and 47 *! merged SYNC_DestroyEvent into SYNC_CloseEvent, and merged 48 *! SYNC_CreateEvent into SYNC_OpenEvent. 49 *! 07-Oct-1997 gp: Added SYNC_Create/DestroyEvent (for NT testing). 50 *! 06-Oct-1997 gp: Added SYNC_OpenEvent. 51 *! 03-Jun-1997 gp: Added SYNC_{Begin|End}CritSection() functions. 52 *! 03-Jan-1997 gp: Added SYNC_INFINITE define. 53 *! 05-Aug-1996 gp: Created. 54 */ 55 56 #ifndef _SYNC_H 57 #define _SYNC_H 58 59 #ifdef __cplusplus 60 extern "C" { 61 #endif 62 63 #include <dspapi.h> 64 65 /* Special timeout value indicating an infinite wait: */ 66 #define SYNC_INFINITE 0xffffffff 67 68 /* Maximum string length of a named event */ 69 #define SYNC_MAXNAMELENGTH 32 70 71 /* Generic SYNC object: */ 72 struct SYNC_OBJECT; 73 /*typedef struct SYNC_OBJECT *SYNC_HOBJECT;*/ 74 75 /* Generic SYNC CS object: */ 76 struct SYNC_CSOBJECT; 77 /*typedef struct SYNC_CSOBJECT *SYNC_HCSOBJECT;*/ 78 79 /* Used SYNC_CSOBJECT instead of SYNC_DPCCSOBJECT to avoid warnings */ 80 /*typedef struct SYNC_CSOBJECT *SYNC_HDPCCSOBJECT;*/ 81 82 /* SYNC object attributes: */ 83 struct SYNC_ATTRS { 84 HANDLE hUserEvent; /* Platform's User Mode synch. object. */ 85 HANDLE hKernelEvent; /* Platform's Kernel Mode sync. object. */ 86 DWORD dwReserved1; /* For future expansion. */ 87 DWORD dwReserved2; /* For future expansion. */ 88 } ; 89 90 /* 91 * ======== SYNC_CloseEvent ======== 92 * Purpose: 93 * Close this event handle, freeing resources allocated in SYNC_OpenEvent 94 * if necessary. 95 * Parameters: 96 * hEvent: Handle to a synchronization event, created/opened in 97 * SYNC_OpenEvent. 98 * Returns: 99 * DSP_SOK: Success; 100 * DSP_EFAIL: Failed to close event handle. 101 * DSP_EHANDLE: Invalid handle. 102 * Requires: 103 * SYNC initialized. 104 * Ensures: 105 * Any subsequent usage of hEvent would be invalid. 106 */ 107 extern DSP_STATUS SYNC_CloseEvent(IN struct SYNC_OBJECT* hEvent); 108 109 /* 110 * ======== SYNC_DeleteCS ======== 111 * Purpose: 112 * Delete a critical section. 113 * Parameters: 114 * hCSObj: critical section handle. 115 * Returns: 116 * DSP_SOK: Success. 117 * DSP_EHANDLE: Invalid handle. 118 * Requires: 119 * Ensures: 120 */ 121 extern DSP_STATUS SYNC_DeleteCS(IN struct SYNC_CSOBJECT* hCSObj); 122 123 /* 124 * ======== SYNC_EnterCS ======== 125 * Purpose: 126 * Enter the critical section. 127 * Parameters: 128 * hCSObj: critical section handle. 129 * Returns: 130 * DSP_SOK: Success. 131 * DSP_EHANDLE: Invalid handle. 132 * Requires: 133 * Ensures: 134 */ 135 extern DSP_STATUS SYNC_EnterCS(IN struct SYNC_CSOBJECT* hCSObj); 136 137 /* 138 * ======== SYNC_Exit ======== 139 * Purpose: 140 * Discontinue usage of module; free resources when reference count 141 * reaches 0. 142 * Parameters: 143 * Returns: 144 * Requires: 145 * SYNC initialized. 146 * Ensures: 147 * Resources used by module are freed when cRef reaches zero. 148 */ 149 extern VOID SYNC_Exit(); 150 151 /* 152 * ======== SYNC_Init ======== 153 * Purpose: 154 * Initializes private state of SYNC module. 155 * Parameters: 156 * Returns: 157 * TRUE if initialized; FALSE if error occured. 158 * Requires: 159 * Ensures: 160 * SYNC initialized. 161 */ 162 extern bool SYNC_Init(); 163 164 /* 165 * ======== SYNC_InitializeCS ======== 166 * Purpose: 167 * Initialize the critical section. 168 * Parameters: 169 * hCSObj: critical section handle. 170 * Returns: 171 * DSP_SOK: Success. 172 * DSP_EMEMORY: Out of memory. 173 * Requires: 174 * Ensures: 175 */ 176 extern DSP_STATUS SYNC_InitializeCS(OUT struct SYNC_CSOBJECT* * phCSObj); 177 178 /* 179 * ======== SYNC_InitializeDPCCS ======== 180 * Purpose: 181 * Initialize the critical section between process context and DPC. 182 * Parameters: 183 * hCSObj: critical section handle. 184 * Returns: 185 * DSP_SOK: Success. 186 * DSP_EMEMORY: Out of memory. 187 * Requires: 188 * Ensures: 189 */ 190 extern DSP_STATUS SYNC_InitializeDPCCS(OUT struct SYNC_CSOBJECT** phCSObj); 191 192 /* 193 * ======== SYNC_LeaveCS ======== 194 * Purpose: 195 * Leave the critical section. 196 * Parameters: 197 * hCSObj: critical section handle. 198 * Returns: 199 * DSP_SOK: Success. 200 * DSP_EHANDLE: Invalid handle. 201 * Requires: 202 * Ensures: 203 */ 204 extern DSP_STATUS SYNC_LeaveCS(IN struct SYNC_CSOBJECT* hCSObj); 205 206 /* 207 * ======== SYNC_OpenEvent ======== 208 * Purpose: 209 * Create/open and initialize an event object for thread synchronization, 210 * which is initially in the non-signalled state. 211 * Parameters: 212 * phEvent: Pointer to location to receive the event object handle. 213 * pAttrs: Pointer to SYNC_ATTRS object containing initial SYNC 214 * SYNC_OBJECT attributes. If this pointer is NULL, then 215 * SYNC_OpenEvent will create and manage an OS specific 216 * syncronization object. 217 * pAttrs->hUserEvent: Platform's User Mode synchronization object. 218 * 219 * The behaviour of the SYNC methods depend on the value of 220 * the hUserEvent attr: 221 * 222 * 1. (hUserEvent == NULL): 223 * A user mode event is created. 224 * 2. (hUserEvent != NULL): 225 * A user mode event is supplied by the caller of SYNC_OpenEvent(). 226 * Returns: 227 * DSP_SOK: Success. 228 * DSP_EFAIL: Unable to create user mode event. 229 * DSP_EMEMORY: Insufficient memory. 230 * DSP_EINVALIDARG SYNC_ATTRS values are invalid. 231 * Requires: 232 * - SYNC initialized. 233 * - phEvent != NULL. 234 * Ensures: 235 * If function succeeded, pEvent->hEvent must be a valid event handle. 236 */ 237 extern DSP_STATUS SYNC_OpenEvent(OUT struct SYNC_OBJECT* * phEvent, 238 IN OPTIONAL struct SYNC_ATTRS * pAttrs); 239 240 /* 241 * ========= SYNC_PostMessage ======== 242 * Purpose: 243 * To post a windows message 244 * Parameters: 245 * hWindow: Handle to the window 246 * uMsg: Message to be posted 247 * Returns: 248 * DSP_SOK: Success 249 * DSP_EFAIL: Post message failed 250 * DSP_EHANDLE: Invalid Window handle 251 * Requires: 252 * SYNC initialized 253 * Ensures 254 */ 255 extern DSP_STATUS SYNC_PostMessage(IN HANDLE hWindow, IN UINT uMsg); 256 257 /* 258 * ======== SYNC_ResetEvent ======== 259 * Purpose: 260 * Reset a syncronization event object state to non-signalled. 261 * Parameters: 262 * hEvent: Handle to a sync event. 263 * Returns: 264 * DSP_SOK: Success; 265 * DSP_EFAIL: Failed to reset event. 266 * DSP_EHANDLE: Invalid handle. 267 * Requires: 268 * SYNC initialized. 269 * Ensures: 270 */ 271 extern DSP_STATUS SYNC_ResetEvent(IN struct SYNC_OBJECT* hEvent); 272 273 /* 274 * ======== SYNC_SetEvent ======== 275 * Purpose: 276 * Signal the event. Will unblock one waiting thread. 277 * Parameters: 278 * hEvent: Handle to an event object. 279 * Returns: 280 * DSP_SOK: Success. 281 * DSP_EFAIL: Failed to signal event. 282 * DSP_EHANDLE: Invalid handle. 283 * Requires: 284 * SYNC initialized. 285 * Ensures: 286 */ 287 extern DSP_STATUS SYNC_SetEvent(IN struct SYNC_OBJECT* hEvent); 288 289 /* 290 * ======== SYNC_WaitOnEvent ======== 291 * Purpose: 292 * Wait for an event to be signalled, up to the specified timeout. 293 * Parameters: 294 * hEvent: Handle to an event object. 295 * dwTimeOut: The time-out interval, in milliseconds. 296 * The function returns if the interval elapses, even if 297 * the object's state is nonsignaled. 298 * If zero, the function tests the object's state and 299 * returns immediately. 300 * If SYNC_INFINITE, the function's time-out interval 301 * never elapses. 302 * Returns: 303 * DSP_SOK: The object was signalled. 304 * DSP_EHANDLE: Invalid handle. 305 * SYNC_E_FAIL: Wait failed, possibly because the process terminated. 306 * SYNC_E_TIMEOUT: Timeout expired while waiting for event to be signalled. 307 * Requires: 308 * Ensures: 309 */ 310 extern DSP_STATUS SYNC_WaitOnEvent(IN struct SYNC_OBJECT* hEvent, 311 IN DWORD dwTimeOut); 312 313 /* 314 * ======== SYNC_WaitOnMultipleEvents ======== 315 * Purpose: 316 * Wait for any of an array of events to be signalled, up to the 317 * specified timeout. 318 * Note: dwTimeOut must be SYNC_INFINITE to signal infinite wait. 319 * Parameters: 320 * hSyncEvents: Array of handles to event objects. 321 * uCount: Number of event handles. 322 * dwTimeOut: The time-out interval, in milliseconds. 323 * The function returns if the interval elapses, even if 324 * no event is signalled. 325 * If zero, the function tests the object's state and 326 * returns immediately. 327 * If SYNC_INFINITE, the function's time-out interval 328 * never elapses. 329 * puIndex: Location to store index of event that was signalled. 330 * Returns: 331 * DSP_SOK: The object was signalled. 332 * SYNC_E_FAIL: Wait failed, possibly because the process terminated. 333 * SYNC_E_TIMEOUT: Timeout expired before event was signalled. 334 * DSP_EMEMORY: Memory allocation failed. 335 * Requires: 336 * Ensures: 337 */ 338 extern DSP_STATUS SYNC_WaitOnMultipleEvents(IN struct SYNC_OBJECT** 339 hSyncEvents, IN UINT uCount, 340 IN DWORD dwTimeout, 341 OUT UINT * puIndex); 342 343 344 #ifdef __cplusplus 345 } 346 #endif 347 #endif /* _SYNC_H */ 348