cogl: Expose Renderer.get_proc_address
Allows to get rid of the cogl_get_proc_address Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3857>
This commit is contained in:
parent
b3ae934304
commit
9ee1a0fc34
@ -44,7 +44,6 @@
|
|||||||
#include "cogl/cogl-rectangle-map.h"
|
#include "cogl/cogl-rectangle-map.h"
|
||||||
#include "cogl/cogl-journal-private.h"
|
#include "cogl/cogl-journal-private.h"
|
||||||
#include "cogl/cogl-atlas.h"
|
#include "cogl/cogl-atlas.h"
|
||||||
#include "cogl/cogl1-context.h"
|
|
||||||
#include "cogl/cogl-sub-texture.h"
|
#include "cogl/cogl-sub-texture.h"
|
||||||
#include "cogl/driver/gl/cogl-texture-gl-private.h"
|
#include "cogl/driver/gl/cogl-texture-gl-private.h"
|
||||||
|
|
||||||
|
@ -41,7 +41,6 @@
|
|||||||
#include "cogl/cogl-texture-private.h"
|
#include "cogl/cogl-texture-private.h"
|
||||||
#include "cogl/cogl-texture-2d-private.h"
|
#include "cogl/cogl-texture-2d-private.h"
|
||||||
#include "cogl/cogl-private.h"
|
#include "cogl/cogl-private.h"
|
||||||
#include "cogl/cogl1-context.h"
|
|
||||||
|
|
||||||
static const CoglBlitMode *_cogl_blit_default_mode = NULL;
|
static const CoglBlitMode *_cogl_blit_default_mode = NULL;
|
||||||
|
|
||||||
|
@ -44,7 +44,6 @@
|
|||||||
#include "cogl/cogl-private.h"
|
#include "cogl/cogl-private.h"
|
||||||
#include "cogl/cogl-attribute-private.h"
|
#include "cogl/cogl-attribute-private.h"
|
||||||
#include "cogl/cogl-primitive-private.h"
|
#include "cogl/cogl-primitive-private.h"
|
||||||
#include "cogl/cogl1-context.h"
|
|
||||||
#include "cogl/cogl-offscreen.h"
|
#include "cogl/cogl-offscreen.h"
|
||||||
#include "cogl/cogl-matrix-stack.h"
|
#include "cogl/cogl-matrix-stack.h"
|
||||||
#include "mtk/mtk.h"
|
#include "mtk/mtk.h"
|
||||||
|
@ -45,7 +45,6 @@
|
|||||||
#include "cogl/cogl-framebuffer-private.h"
|
#include "cogl/cogl-framebuffer-private.h"
|
||||||
#include "cogl/cogl-onscreen-private.h"
|
#include "cogl/cogl-onscreen-private.h"
|
||||||
#include "cogl/cogl-attribute-private.h"
|
#include "cogl/cogl-attribute-private.h"
|
||||||
#include "cogl/cogl1-context.h"
|
|
||||||
#include "cogl/winsys/cogl-winsys-private.h"
|
#include "cogl/winsys/cogl-winsys-private.h"
|
||||||
|
|
||||||
#include <gio/gio.h>
|
#include <gio/gio.h>
|
||||||
|
@ -35,7 +35,6 @@
|
|||||||
#include "cogl/cogl-i18n-private.h"
|
#include "cogl/cogl-i18n-private.h"
|
||||||
#include "cogl/cogl-private.h"
|
#include "cogl/cogl-private.h"
|
||||||
#include "cogl/cogl-debug.h"
|
#include "cogl/cogl-debug.h"
|
||||||
#include "cogl/cogl1-context.h"
|
|
||||||
|
|
||||||
/* XXX: If you add a debug option, please also add an option
|
/* XXX: If you add a debug option, please also add an option
|
||||||
* definition to cogl-debug-options.h. This will enable us - for
|
* definition to cogl-debug-options.h. This will enable us - for
|
||||||
|
@ -143,7 +143,7 @@ _cogl_feature_check (CoglRenderer *renderer,
|
|||||||
|
|
||||||
full_function_name = g_strconcat (data->functions[func_num].name,
|
full_function_name = g_strconcat (data->functions[func_num].name,
|
||||||
suffix, NULL);
|
suffix, NULL);
|
||||||
func = _cogl_renderer_get_proc_address (renderer,
|
func = cogl_renderer_get_proc_address (renderer,
|
||||||
full_function_name);
|
full_function_name);
|
||||||
g_free (full_function_name);
|
g_free (full_function_name);
|
||||||
|
|
||||||
|
@ -46,7 +46,6 @@
|
|||||||
#include "cogl/cogl-pipeline-state-private.h"
|
#include "cogl/cogl-pipeline-state-private.h"
|
||||||
#include "cogl/cogl-primitive-private.h"
|
#include "cogl/cogl-primitive-private.h"
|
||||||
#include "cogl/cogl-offscreen.h"
|
#include "cogl/cogl-offscreen.h"
|
||||||
#include "cogl/cogl1-context.h"
|
|
||||||
#include "cogl/cogl-private.h"
|
#include "cogl/cogl-private.h"
|
||||||
#include "cogl/cogl-primitives-private.h"
|
#include "cogl/cogl-primitives-private.h"
|
||||||
#include "cogl/cogl-trace.h"
|
#include "cogl/cogl-trace.h"
|
||||||
|
@ -43,7 +43,6 @@
|
|||||||
#include "cogl/cogl-point-in-poly-private.h"
|
#include "cogl/cogl-point-in-poly-private.h"
|
||||||
#include "cogl/cogl-trace.h"
|
#include "cogl/cogl-trace.h"
|
||||||
#include "cogl/cogl-private.h"
|
#include "cogl/cogl-private.h"
|
||||||
#include "cogl/cogl1-context.h"
|
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <gmodule.h>
|
#include <gmodule.h>
|
||||||
|
@ -38,7 +38,6 @@
|
|||||||
#include "cogl/cogl-framebuffer-private.h"
|
#include "cogl/cogl-framebuffer-private.h"
|
||||||
#include "cogl/cogl-onscreen-template-private.h"
|
#include "cogl/cogl-onscreen-template-private.h"
|
||||||
#include "cogl/cogl-context-private.h"
|
#include "cogl/cogl-context-private.h"
|
||||||
#include "cogl/cogl1-context.h"
|
|
||||||
#include "cogl/cogl-closure-list-private.h"
|
#include "cogl/cogl-closure-list-private.h"
|
||||||
#include "cogl/cogl-poll-private.h"
|
#include "cogl/cogl-poll-private.h"
|
||||||
|
|
||||||
|
@ -46,7 +46,6 @@
|
|||||||
#include "cogl/cogl-profile.h"
|
#include "cogl/cogl-profile.h"
|
||||||
#include "cogl/cogl-depth-state-private.h"
|
#include "cogl/cogl-depth-state-private.h"
|
||||||
#include "cogl/cogl-snippet-private.h"
|
#include "cogl/cogl-snippet-private.h"
|
||||||
#include "cogl/cogl1-context.h"
|
|
||||||
|
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
#include <glib/gprintf.h>
|
#include <glib/gprintf.h>
|
||||||
|
@ -40,7 +40,6 @@
|
|||||||
#include "cogl/cogl-private.h"
|
#include "cogl/cogl-private.h"
|
||||||
#include "cogl/cogl-meta-texture.h"
|
#include "cogl/cogl-meta-texture.h"
|
||||||
#include "cogl/cogl-framebuffer-private.h"
|
#include "cogl/cogl-framebuffer-private.h"
|
||||||
#include "cogl/cogl1-context.h"
|
|
||||||
#include "cogl/cogl-primitives-private.h"
|
#include "cogl/cogl-primitives-private.h"
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@ -89,7 +89,3 @@ void
|
|||||||
_cogl_renderer_remove_native_filter (CoglRenderer *renderer,
|
_cogl_renderer_remove_native_filter (CoglRenderer *renderer,
|
||||||
CoglNativeFilterFunc func,
|
CoglNativeFilterFunc func,
|
||||||
void *data);
|
void *data);
|
||||||
|
|
||||||
void *
|
|
||||||
_cogl_renderer_get_proc_address (CoglRenderer *renderer,
|
|
||||||
const char *name);
|
|
||||||
|
@ -615,7 +615,7 @@ cogl_renderer_get_winsys_id (CoglRenderer *renderer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void *
|
void *
|
||||||
_cogl_renderer_get_proc_address (CoglRenderer *renderer,
|
cogl_renderer_get_proc_address (CoglRenderer *renderer,
|
||||||
const char *name)
|
const char *name)
|
||||||
{
|
{
|
||||||
const CoglWinsysVtable *winsys = _cogl_renderer_get_winsys (renderer);
|
const CoglWinsysVtable *winsys = _cogl_renderer_get_winsys (renderer);
|
||||||
|
@ -311,4 +311,24 @@ cogl_renderer_is_dma_buf_supported (CoglRenderer *renderer);
|
|||||||
COGL_EXPORT void
|
COGL_EXPORT void
|
||||||
cogl_renderer_bind_api (CoglRenderer *renderer);
|
cogl_renderer_bind_api (CoglRenderer *renderer);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* cogl_renderer_get_proc_address:
|
||||||
|
* @renderer: A #CoglRenderer.
|
||||||
|
* @name: the name of the function.
|
||||||
|
*
|
||||||
|
* Gets a pointer to a given GL or GL ES extension function. This acts
|
||||||
|
* as a wrapper around glXGetProcAddress() or whatever is the
|
||||||
|
* appropriate function for the current backend.
|
||||||
|
*
|
||||||
|
* This function should not be used to query core opengl API
|
||||||
|
* symbols since eglGetProcAddress for example doesn't allow this and
|
||||||
|
* and may return a junk pointer if you do.
|
||||||
|
*
|
||||||
|
* Return value: a pointer to the requested function or %NULL if the
|
||||||
|
* function is not available.
|
||||||
|
*/
|
||||||
|
COGL_EXPORT void *
|
||||||
|
cogl_renderer_get_proc_address (CoglRenderer *renderer,
|
||||||
|
const char *name);
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
@ -53,7 +53,6 @@
|
|||||||
#include "cogl/cogl-context-private.h"
|
#include "cogl/cogl-context-private.h"
|
||||||
#include "cogl/cogl-offscreen-private.h"
|
#include "cogl/cogl-offscreen-private.h"
|
||||||
#include "cogl/cogl-framebuffer-private.h"
|
#include "cogl/cogl-framebuffer-private.h"
|
||||||
#include "cogl/cogl1-context.h"
|
|
||||||
#include "cogl/cogl-sub-texture.h"
|
#include "cogl/cogl-sub-texture.h"
|
||||||
#include "cogl/cogl-primitive-texture.h"
|
#include "cogl/cogl-primitive-texture.h"
|
||||||
|
|
||||||
|
@ -50,18 +50,9 @@
|
|||||||
#include "cogl/cogl-framebuffer-private.h"
|
#include "cogl/cogl-framebuffer-private.h"
|
||||||
#include "cogl/cogl-renderer-private.h"
|
#include "cogl/cogl-renderer-private.h"
|
||||||
#include "cogl/cogl-private.h"
|
#include "cogl/cogl-private.h"
|
||||||
#include "cogl/cogl1-context.h"
|
|
||||||
#include "cogl/cogl-offscreen.h"
|
#include "cogl/cogl-offscreen.h"
|
||||||
#include "cogl/winsys/cogl-winsys-private.h"
|
#include "cogl/winsys/cogl-winsys-private.h"
|
||||||
|
|
||||||
GCallback
|
|
||||||
cogl_get_proc_address (const char* name)
|
|
||||||
{
|
|
||||||
_COGL_GET_CONTEXT (ctx, NULL);
|
|
||||||
|
|
||||||
return _cogl_renderer_get_proc_address (ctx->display->renderer, name);
|
|
||||||
}
|
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
_cogl_check_extension (const char *name, char * const *ext)
|
_cogl_check_extension (const char *name, char * const *ext)
|
||||||
{
|
{
|
||||||
|
@ -45,7 +45,6 @@
|
|||||||
|
|
||||||
#include "cogl/cogl-macros.h"
|
#include "cogl/cogl-macros.h"
|
||||||
|
|
||||||
#include "cogl/cogl1-context.h"
|
|
||||||
#include "cogl/cogl-bitmap.h"
|
#include "cogl/cogl-bitmap.h"
|
||||||
#include "cogl/cogl-color.h"
|
#include "cogl/cogl-color.h"
|
||||||
#include "cogl/cogl-dma-buf-handle.h"
|
#include "cogl/cogl-dma-buf-handle.h"
|
||||||
|
@ -1,66 +0,0 @@
|
|||||||
/*
|
|
||||||
* Cogl
|
|
||||||
*
|
|
||||||
* A Low Level GPU Graphics and Utilities API
|
|
||||||
*
|
|
||||||
* Copyright (C) 2010 Intel Corporation.
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person
|
|
||||||
* obtaining a copy of this software and associated documentation
|
|
||||||
* files (the "Software"), to deal in the Software without
|
|
||||||
* restriction, including without limitation the rights to use, copy,
|
|
||||||
* modify, merge, publish, distribute, sublicense, and/or sell copies
|
|
||||||
* of the Software, and to permit persons to whom the Software is
|
|
||||||
* furnished to do so, subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice shall be
|
|
||||||
* included in all copies or substantial portions of the Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
||||||
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
|
||||||
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
|
||||||
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
||||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
||||||
* SOFTWARE.
|
|
||||||
*
|
|
||||||
* Authors:
|
|
||||||
* Robert Bragg <robert@linux.intel.com>
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#if !defined(__COGL_H_INSIDE__) && !defined(COGL_COMPILATION)
|
|
||||||
#error "Only <cogl/cogl.h> can be included directly."
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "cogl/cogl-types.h"
|
|
||||||
#include "cogl/cogl-texture.h"
|
|
||||||
#include "cogl/cogl-framebuffer.h"
|
|
||||||
#include "cogl/cogl-macros.h"
|
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
|
||||||
|
|
||||||
/* Misc */
|
|
||||||
/**
|
|
||||||
* cogl_get_proc_address: (skip)
|
|
||||||
* @name: the name of the function.
|
|
||||||
*
|
|
||||||
* Gets a pointer to a given GL or GL ES extension function. This acts
|
|
||||||
* as a wrapper around glXGetProcAddress() or whatever is the
|
|
||||||
* appropriate function for the current backend.
|
|
||||||
*
|
|
||||||
* This function should not be used to query core opengl API
|
|
||||||
* symbols since eglGetProcAddress for example doesn't allow this and
|
|
||||||
* and may return a junk pointer if you do.
|
|
||||||
*
|
|
||||||
* Return value: a pointer to the requested function or %NULL if the
|
|
||||||
* function is not available.
|
|
||||||
*/
|
|
||||||
COGL_EXPORT GCallback
|
|
||||||
cogl_get_proc_address (const char *name);
|
|
||||||
|
|
||||||
|
|
||||||
G_END_DECLS
|
|
@ -429,13 +429,13 @@ _cogl_driver_update_features (CoglContext *ctx,
|
|||||||
functions because we need to use them to determine what functions
|
functions because we need to use them to determine what functions
|
||||||
we can expect */
|
we can expect */
|
||||||
ctx->glGetString =
|
ctx->glGetString =
|
||||||
(void *) _cogl_renderer_get_proc_address (ctx->display->renderer,
|
(void *) cogl_renderer_get_proc_address (ctx->display->renderer,
|
||||||
"glGetString");
|
"glGetString");
|
||||||
ctx->glGetStringi =
|
ctx->glGetStringi =
|
||||||
(void *) _cogl_renderer_get_proc_address (ctx->display->renderer,
|
(void *) cogl_renderer_get_proc_address (ctx->display->renderer,
|
||||||
"glGetStringi");
|
"glGetStringi");
|
||||||
ctx->glGetIntegerv =
|
ctx->glGetIntegerv =
|
||||||
(void *) _cogl_renderer_get_proc_address (ctx->display->renderer,
|
(void *) cogl_renderer_get_proc_address (ctx->display->renderer,
|
||||||
"glGetIntegerv");
|
"glGetIntegerv");
|
||||||
|
|
||||||
gl_extensions = _cogl_context_get_gl_extensions (ctx);
|
gl_extensions = _cogl_context_get_gl_extensions (ctx);
|
||||||
|
@ -578,10 +578,10 @@ _cogl_driver_update_features (CoglContext *context,
|
|||||||
function because we need to use it to determine what functions we
|
function because we need to use it to determine what functions we
|
||||||
can expect */
|
can expect */
|
||||||
context->glGetString =
|
context->glGetString =
|
||||||
(void *) _cogl_renderer_get_proc_address (context->display->renderer,
|
(void *) cogl_renderer_get_proc_address (context->display->renderer,
|
||||||
"glGetString");
|
"glGetString");
|
||||||
context->glGetStringi =
|
context->glGetStringi =
|
||||||
(void *) _cogl_renderer_get_proc_address (context->display->renderer,
|
(void *) cogl_renderer_get_proc_address (context->display->renderer,
|
||||||
"glGetStringi");
|
"glGetStringi");
|
||||||
|
|
||||||
gl_extensions = _cogl_context_get_gl_extensions (context);
|
gl_extensions = _cogl_context_get_gl_extensions (context);
|
||||||
|
@ -25,7 +25,6 @@ cogl_headers = [
|
|||||||
'cogl-attribute.h',
|
'cogl-attribute.h',
|
||||||
'cogl-bitmap.h',
|
'cogl-bitmap.h',
|
||||||
'cogl-color.h',
|
'cogl-color.h',
|
||||||
'cogl1-context.h',
|
|
||||||
'cogl-context.h',
|
'cogl-context.h',
|
||||||
'cogl-depth-state.h',
|
'cogl-depth-state.h',
|
||||||
'cogl-display.h',
|
'cogl-display.h',
|
||||||
|
@ -133,6 +133,8 @@ meta_compositor_x11_manage (MetaCompositor *compositor,
|
|||||||
MetaDisplay *display = meta_compositor_get_display (compositor);
|
MetaDisplay *display = meta_compositor_get_display (compositor);
|
||||||
MetaContext *context = meta_display_get_context (display);
|
MetaContext *context = meta_display_get_context (display);
|
||||||
MetaBackend *backend = meta_context_get_backend (context);
|
MetaBackend *backend = meta_context_get_backend (context);
|
||||||
|
ClutterBackend *clutter_backend = meta_backend_get_clutter_backend (backend);
|
||||||
|
CoglContext *cogl_context = clutter_backend_get_cogl_context (clutter_backend);
|
||||||
MetaX11Display *x11_display = display->x11_display;
|
MetaX11Display *x11_display = display->x11_display;
|
||||||
Display *xdisplay = meta_x11_display_get_xdisplay (x11_display);
|
Display *xdisplay = meta_x11_display_get_xdisplay (x11_display);
|
||||||
int composite_version;
|
int composite_version;
|
||||||
@ -186,7 +188,7 @@ meta_compositor_x11_manage (MetaCompositor *compositor,
|
|||||||
*/
|
*/
|
||||||
XMapWindow (xdisplay, compositor_x11->output);
|
XMapWindow (xdisplay, compositor_x11->output);
|
||||||
|
|
||||||
compositor_x11->have_x11_sync_object = meta_sync_ring_init (xdisplay);
|
compositor_x11->have_x11_sync_object = meta_sync_ring_init (cogl_context, xdisplay);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
@ -332,6 +334,9 @@ maybe_do_sync (MetaCompositor *compositor)
|
|||||||
if (compositor_x11->frame_has_updated_xsurfaces)
|
if (compositor_x11->frame_has_updated_xsurfaces)
|
||||||
{
|
{
|
||||||
MetaDisplay *display = meta_compositor_get_display (compositor);
|
MetaDisplay *display = meta_compositor_get_display (compositor);
|
||||||
|
MetaBackend *backend = meta_compositor_get_backend (compositor);
|
||||||
|
ClutterBackend *clutter_backend = meta_backend_get_clutter_backend (backend);
|
||||||
|
CoglContext *cogl_context = clutter_backend_get_cogl_context (clutter_backend);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We need to make sure that any X drawing that happens before the
|
* We need to make sure that any X drawing that happens before the
|
||||||
@ -354,7 +359,7 @@ maybe_do_sync (MetaCompositor *compositor)
|
|||||||
* at this point is sufficient to flush the GLX buffers.
|
* at this point is sufficient to flush the GLX buffers.
|
||||||
*/
|
*/
|
||||||
if (compositor_x11->have_x11_sync_object)
|
if (compositor_x11->have_x11_sync_object)
|
||||||
compositor_x11->have_x11_sync_object = meta_sync_ring_insert_wait ();
|
compositor_x11->have_x11_sync_object = meta_sync_ring_insert_wait (cogl_context);
|
||||||
else
|
else
|
||||||
XSync (display->x11_display->xdisplay, False);
|
XSync (display->x11_display->xdisplay, False);
|
||||||
}
|
}
|
||||||
@ -379,8 +384,12 @@ on_after_update (ClutterStage *stage,
|
|||||||
|
|
||||||
if (compositor_x11->frame_has_updated_xsurfaces)
|
if (compositor_x11->frame_has_updated_xsurfaces)
|
||||||
{
|
{
|
||||||
|
MetaBackend *backend = meta_compositor_get_backend (compositor);
|
||||||
|
ClutterBackend *clutter_backend = meta_backend_get_clutter_backend (backend);
|
||||||
|
CoglContext *cogl_context = clutter_backend_get_cogl_context (clutter_backend);
|
||||||
|
|
||||||
if (compositor_x11->have_x11_sync_object)
|
if (compositor_x11->have_x11_sync_object)
|
||||||
compositor_x11->have_x11_sync_object = meta_sync_ring_after_frame ();
|
compositor_x11->have_x11_sync_object = meta_sync_ring_after_frame (cogl_context);
|
||||||
|
|
||||||
compositor_x11->frame_has_updated_xsurfaces = FALSE;
|
compositor_x11->frame_has_updated_xsurfaces = FALSE;
|
||||||
}
|
}
|
||||||
|
@ -132,10 +132,11 @@ meta_sync_ring_get (void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
load_gl_symbol (const char *name,
|
load_gl_symbol (CoglContext *ctx,
|
||||||
|
const char *name,
|
||||||
void **func)
|
void **func)
|
||||||
{
|
{
|
||||||
*func = cogl_get_proc_address (name);
|
*func = cogl_renderer_get_proc_address (ctx->display->renderer, name);
|
||||||
if (!*func)
|
if (!*func)
|
||||||
{
|
{
|
||||||
meta_verbose ("MetaSyncRing: failed to resolve required GL symbol \"%s\"", name);
|
meta_verbose ("MetaSyncRing: failed to resolve required GL symbol \"%s\"", name);
|
||||||
@ -187,7 +188,7 @@ check_gl_extensions (void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
load_required_symbols (void)
|
load_required_symbols (CoglContext *ctx)
|
||||||
{
|
{
|
||||||
static gboolean success = FALSE;
|
static gboolean success = FALSE;
|
||||||
|
|
||||||
@ -199,11 +200,11 @@ load_required_symbols (void)
|
|||||||
* and dynamically loaded libGL at this point.
|
* and dynamically loaded libGL at this point.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (!load_gl_symbol ("glGetString", (void **) &meta_gl_get_string))
|
if (!load_gl_symbol (ctx, "glGetString", (void **) &meta_gl_get_string))
|
||||||
goto out;
|
goto out;
|
||||||
if (!load_gl_symbol ("glGetIntegerv", (void **) &meta_gl_get_integerv))
|
if (!load_gl_symbol (ctx, "glGetIntegerv", (void **) &meta_gl_get_integerv))
|
||||||
goto out;
|
goto out;
|
||||||
if (!load_gl_symbol ("glGetStringi", (void **) &meta_gl_get_stringi))
|
if (!load_gl_symbol (ctx, "glGetStringi", (void **) &meta_gl_get_stringi))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
if (!check_gl_extensions ())
|
if (!check_gl_extensions ())
|
||||||
@ -212,15 +213,15 @@ load_required_symbols (void)
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!load_gl_symbol ("glDeleteSync", (void **) &meta_gl_delete_sync))
|
if (!load_gl_symbol (ctx, "glDeleteSync", (void **) &meta_gl_delete_sync))
|
||||||
goto out;
|
goto out;
|
||||||
if (!load_gl_symbol ("glClientWaitSync", (void **) &meta_gl_client_wait_sync))
|
if (!load_gl_symbol (ctx, "glClientWaitSync", (void **) &meta_gl_client_wait_sync))
|
||||||
goto out;
|
goto out;
|
||||||
if (!load_gl_symbol ("glWaitSync", (void **) &meta_gl_wait_sync))
|
if (!load_gl_symbol (ctx, "glWaitSync", (void **) &meta_gl_wait_sync))
|
||||||
goto out;
|
goto out;
|
||||||
if (!load_gl_symbol ("glImportSyncEXT", (void **) &meta_gl_import_sync))
|
if (!load_gl_symbol (ctx, "glImportSyncEXT", (void **) &meta_gl_import_sync))
|
||||||
goto out;
|
goto out;
|
||||||
if (!load_gl_symbol ("glFenceSync", (void **) &meta_gl_fence_sync))
|
if (!load_gl_symbol (ctx, "glFenceSync", (void **) &meta_gl_fence_sync))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
success = TRUE;
|
success = TRUE;
|
||||||
@ -405,7 +406,8 @@ meta_sync_free (MetaSync *self)
|
|||||||
}
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
meta_sync_ring_init (Display *xdisplay)
|
meta_sync_ring_init (CoglContext *ctx,
|
||||||
|
Display *xdisplay)
|
||||||
{
|
{
|
||||||
gint major, minor;
|
gint major, minor;
|
||||||
guint i;
|
guint i;
|
||||||
@ -417,7 +419,7 @@ meta_sync_ring_init (Display *xdisplay)
|
|||||||
g_return_val_if_fail (xdisplay != NULL, FALSE);
|
g_return_val_if_fail (xdisplay != NULL, FALSE);
|
||||||
g_return_val_if_fail (ring->xdisplay == NULL, FALSE);
|
g_return_val_if_fail (ring->xdisplay == NULL, FALSE);
|
||||||
|
|
||||||
if (!load_required_symbols ())
|
if (!load_required_symbols (ctx))
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
if (!XSyncQueryExtension (xdisplay, &ring->xsync_event_base, &ring->xsync_error_base) ||
|
if (!XSyncQueryExtension (xdisplay, &ring->xsync_event_base, &ring->xsync_error_base) ||
|
||||||
@ -477,7 +479,8 @@ meta_sync_ring_destroy (void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
meta_sync_ring_reboot (Display *xdisplay)
|
meta_sync_ring_reboot (CoglContext *ctx,
|
||||||
|
Display *xdisplay)
|
||||||
{
|
{
|
||||||
MetaSyncRing *ring = meta_sync_ring_get ();
|
MetaSyncRing *ring = meta_sync_ring_get ();
|
||||||
|
|
||||||
@ -494,11 +497,11 @@ meta_sync_ring_reboot (Display *xdisplay)
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
return meta_sync_ring_init (xdisplay);
|
return meta_sync_ring_init (ctx, xdisplay);
|
||||||
}
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
meta_sync_ring_after_frame (void)
|
meta_sync_ring_after_frame (CoglContext *ctx)
|
||||||
{
|
{
|
||||||
MetaSyncRing *ring = meta_sync_ring_get ();
|
MetaSyncRing *ring = meta_sync_ring_get ();
|
||||||
|
|
||||||
@ -522,7 +525,7 @@ meta_sync_ring_after_frame (void)
|
|||||||
if (status != GL_ALREADY_SIGNALED && status != GL_CONDITION_SATISFIED)
|
if (status != GL_ALREADY_SIGNALED && status != GL_CONDITION_SATISFIED)
|
||||||
{
|
{
|
||||||
meta_warning ("MetaSyncRing: Timed out waiting for sync object.");
|
meta_warning ("MetaSyncRing: Timed out waiting for sync object.");
|
||||||
return meta_sync_ring_reboot (ring->xdisplay);
|
return meta_sync_ring_reboot (ctx, ring->xdisplay);
|
||||||
}
|
}
|
||||||
|
|
||||||
meta_sync_reset (sync_to_reset);
|
meta_sync_reset (sync_to_reset);
|
||||||
@ -541,7 +544,7 @@ meta_sync_ring_after_frame (void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
meta_sync_ring_insert_wait (void)
|
meta_sync_ring_insert_wait (CoglContext *ctx)
|
||||||
{
|
{
|
||||||
MetaSyncRing *ring = meta_sync_ring_get ();
|
MetaSyncRing *ring = meta_sync_ring_get ();
|
||||||
MetaSync *sync;
|
MetaSync *sync;
|
||||||
@ -562,7 +565,7 @@ meta_sync_ring_insert_wait (void)
|
|||||||
else if (sync->state != META_SYNC_STATE_READY)
|
else if (sync->state != META_SYNC_STATE_READY)
|
||||||
{
|
{
|
||||||
meta_warning ("MetaSyncRing: Sync object is not ready -- were events handled properly?");
|
meta_warning ("MetaSyncRing: Sync object is not ready -- were events handled properly?");
|
||||||
if (!meta_sync_ring_reboot (ring->xdisplay))
|
if (!meta_sync_ring_reboot (ctx, ring->xdisplay))
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,8 +3,11 @@
|
|||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
#include <X11/Xlib.h>
|
#include <X11/Xlib.h>
|
||||||
|
|
||||||
gboolean meta_sync_ring_init (Display *dpy);
|
#include "cogl/cogl.h"
|
||||||
|
|
||||||
|
gboolean meta_sync_ring_init (CoglContext *ctx,
|
||||||
|
Display *dpy);
|
||||||
void meta_sync_ring_destroy (void);
|
void meta_sync_ring_destroy (void);
|
||||||
gboolean meta_sync_ring_after_frame (void);
|
gboolean meta_sync_ring_after_frame (CoglContext *ctx);
|
||||||
gboolean meta_sync_ring_insert_wait (void);
|
gboolean meta_sync_ring_insert_wait (CoglContext *ctx);
|
||||||
void meta_sync_ring_handle_event (XEvent *event);
|
void meta_sync_ring_handle_event (XEvent *event);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user