1 /**************************************************************************
3 * Copyright 2010 LunarG, Inc.
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the
8 * "Software"), to deal in the Software without restriction, including
9 * without limitation the rights to use, copy, modify, merge, publish,
10 * distribute, sub license, and/or sell copies of the Software, and to
11 * permit persons to whom the Software is furnished to do so, subject to
12 * the following conditions:
14 * The above copyright notice and this permission notice (including the
15 * next paragraph) shall be included in all copies or substantial portions
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
21 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
23 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
24 * DEALINGS IN THE SOFTWARE.
26 **************************************************************************/
29 #ifndef EGLSYNC_INCLUDED
30 #define EGLSYNC_INCLUDED
33 #include "egltypedefs.h"
34 #include "egldisplay.h"
38 * "Base" class for device driver syncs.
42 /* A sync is a display resource */
43 _EGLResource Resource
;
47 EGLenum SyncCondition
;
52 _eglInitSync(_EGLSync
*sync
, _EGLDisplay
*dpy
, EGLenum type
,
53 const EGLint
*attrib_list
);
57 _eglGetSyncAttribKHR(_EGLDriver
*drv
, _EGLDisplay
*dpy
, _EGLSync
*sync
,
58 EGLint attribute
, EGLint
*value
);
62 * Increment reference count for the sync.
64 static INLINE _EGLSync
*
65 _eglGetSync(_EGLSync
*sync
)
68 _eglGetResource(&sync
->Resource
);
74 * Decrement reference count for the sync.
76 static INLINE EGLBoolean
77 _eglPutSync(_EGLSync
*sync
)
79 return (sync
) ? _eglPutResource(&sync
->Resource
) : EGL_FALSE
;
84 * Link a sync to its display and return the handle of the link.
85 * The handle can be passed to client directly.
87 static INLINE EGLSyncKHR
88 _eglLinkSync(_EGLSync
*sync
)
90 _eglLinkResource(&sync
->Resource
, _EGL_RESOURCE_SYNC
);
91 return (EGLSyncKHR
) sync
;
96 * Unlink a linked sync from its display.
99 _eglUnlinkSync(_EGLSync
*sync
)
101 _eglUnlinkResource(&sync
->Resource
, _EGL_RESOURCE_SYNC
);
106 * Lookup a handle to find the linked sync.
107 * Return NULL if the handle has no corresponding linked sync.
109 static INLINE _EGLSync
*
110 _eglLookupSync(EGLSyncKHR handle
, _EGLDisplay
*dpy
)
112 _EGLSync
*sync
= (_EGLSync
*) handle
;
113 if (!dpy
|| !_eglCheckResource((void *) sync
, _EGL_RESOURCE_SYNC
, dpy
))
120 * Return the handle of a linked sync, or EGL_NO_SYNC_KHR.
122 static INLINE EGLSyncKHR
123 _eglGetSyncHandle(_EGLSync
*sync
)
125 _EGLResource
*res
= (_EGLResource
*) sync
;
126 return (res
&& _eglIsResourceLinked(res
)) ?
127 (EGLSyncKHR
) sync
: EGL_NO_SYNC_KHR
;
131 #endif /* EGLSYNC_INCLUDED */