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"
37 #ifdef EGL_KHR_reusable_sync
41 * "Base" class for device driver syncs.
45 /* A sync is a display resource */
46 _EGLResource Resource
;
50 EGLenum SyncCondition
;
55 _eglInitSync(_EGLSync
*sync
, _EGLDisplay
*dpy
, EGLenum type
,
56 const EGLint
*attrib_list
);
60 _eglGetSyncAttribKHR(_EGLDriver
*drv
, _EGLDisplay
*dpy
, _EGLSync
*sync
,
61 EGLint attribute
, EGLint
*value
);
65 * Increment reference count for the sync.
67 static INLINE _EGLSync
*
68 _eglGetSync(_EGLSync
*sync
)
71 _eglGetResource(&sync
->Resource
);
77 * Decrement reference count for the sync.
79 static INLINE EGLBoolean
80 _eglPutSync(_EGLSync
*sync
)
82 return (sync
) ? _eglPutResource(&sync
->Resource
) : EGL_FALSE
;
87 * Link a sync to its display and return the handle of the link.
88 * The handle can be passed to client directly.
90 static INLINE EGLSyncKHR
91 _eglLinkSync(_EGLSync
*sync
)
93 _eglLinkResource(&sync
->Resource
, _EGL_RESOURCE_SYNC
);
94 return (EGLSyncKHR
) sync
;
99 * Unlink a linked sync from its display.
102 _eglUnlinkSync(_EGLSync
*sync
)
104 _eglUnlinkResource(&sync
->Resource
, _EGL_RESOURCE_SYNC
);
109 * Lookup a handle to find the linked sync.
110 * Return NULL if the handle has no corresponding linked sync.
112 static INLINE _EGLSync
*
113 _eglLookupSync(EGLSyncKHR handle
, _EGLDisplay
*dpy
)
115 _EGLSync
*sync
= (_EGLSync
*) handle
;
116 if (!dpy
|| !_eglCheckResource((void *) sync
, _EGL_RESOURCE_SYNC
, dpy
))
123 * Return the handle of a linked sync, or EGL_NO_SYNC_KHR.
125 static INLINE EGLSyncKHR
126 _eglGetSyncHandle(_EGLSync
*sync
)
128 _EGLResource
*res
= (_EGLResource
*) sync
;
129 return (res
&& _eglIsResourceLinked(res
)) ?
130 (EGLSyncKHR
) sync
: EGL_NO_SYNC_KHR
;
134 #endif /* EGL_KHR_reusable_sync */
137 #endif /* EGLSYNC_INCLUDED */