mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-12 18:35:35 +00:00
[902/906] context: implement glGetStringi handling for GL core contexts/GLES3
This commit is contained in:
parent
c3146c0d48
commit
ea0c6b3f70
2 changed files with 36 additions and 3 deletions
|
@ -163,3 +163,12 @@ GST_GL_EXT_FUNCTION (void, ColorMaterial,
|
||||||
GST_GL_EXT_FUNCTION (void, ShadeModel,
|
GST_GL_EXT_FUNCTION (void, ShadeModel,
|
||||||
(GLenum value))
|
(GLenum value))
|
||||||
GST_GL_EXT_END ()
|
GST_GL_EXT_END ()
|
||||||
|
|
||||||
|
GST_GL_EXT_BEGIN (gl3,
|
||||||
|
3, 1,
|
||||||
|
GST_GL_API_GLES3, /* not in GLES */
|
||||||
|
"\0",
|
||||||
|
"\0")
|
||||||
|
GST_GL_EXT_FUNCTION (const GLubyte*, GetStringi,
|
||||||
|
(GLenum name, GLint index))
|
||||||
|
GST_GL_EXT_END ()
|
||||||
|
|
|
@ -652,6 +652,22 @@ _unlock_create_thread (GstGLContext * context)
|
||||||
g_mutex_unlock (&context->priv->render_lock);
|
g_mutex_unlock (&context->priv->render_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gchar *
|
||||||
|
_build_extension_string (GstGLContext * context)
|
||||||
|
{
|
||||||
|
const GstGLFuncs *gl = context->gl_vtable;
|
||||||
|
GString *exts = g_string_sized_new (1024);
|
||||||
|
int i, n;
|
||||||
|
|
||||||
|
gl->GetIntegerv (GL_NUM_EXTENSIONS, &n);
|
||||||
|
|
||||||
|
for (i = 0; i < n; i++) {
|
||||||
|
g_string_append_printf (exts, "%s ", gl->GetStringi (GL_EXTENSIONS, i));
|
||||||
|
}
|
||||||
|
|
||||||
|
return exts->str;
|
||||||
|
}
|
||||||
|
|
||||||
//gboolean
|
//gboolean
|
||||||
//gst_gl_context_create (GstGLContext * context, GstGLContext * other_context, GError ** error)
|
//gst_gl_context_create (GstGLContext * context, GstGLContext * other_context, GError ** error)
|
||||||
static gpointer
|
static gpointer
|
||||||
|
@ -667,7 +683,7 @@ gst_gl_context_create_thread (GstGLContext * context)
|
||||||
gchar *api_string;
|
gchar *api_string;
|
||||||
gchar *compiled_api_s;
|
gchar *compiled_api_s;
|
||||||
gchar *user_api_string;
|
gchar *user_api_string;
|
||||||
const gchar *user_choice;
|
const gchar *user_choice, *extensions;
|
||||||
GError **error;
|
GError **error;
|
||||||
GstGLContext *other_context;
|
GstGLContext *other_context;
|
||||||
|
|
||||||
|
@ -757,6 +773,8 @@ gst_gl_context_create_thread (GstGLContext * context)
|
||||||
|
|
||||||
gl->GetError = gst_gl_context_get_proc_address (context, "glGetError");
|
gl->GetError = gst_gl_context_get_proc_address (context, "glGetError");
|
||||||
gl->GetString = gst_gl_context_get_proc_address (context, "glGetString");
|
gl->GetString = gst_gl_context_get_proc_address (context, "glGetString");
|
||||||
|
gl->GetStringi = gst_gl_context_get_proc_address (context, "glGetStringi");
|
||||||
|
gl->GetIntegerv = gst_gl_context_get_proc_address (context, "glGetIntegerv");
|
||||||
|
|
||||||
if (!gl->GetError || !gl->GetString) {
|
if (!gl->GetError || !gl->GetString) {
|
||||||
g_set_error (error, GST_GL_CONTEXT_ERROR, GST_GL_CONTEXT_ERROR_FAILED,
|
g_set_error (error, GST_GL_CONTEXT_ERROR, GST_GL_CONTEXT_ERROR_FAILED,
|
||||||
|
@ -773,8 +791,14 @@ gst_gl_context_create_thread (GstGLContext * context)
|
||||||
if (!ret)
|
if (!ret)
|
||||||
goto failure;
|
goto failure;
|
||||||
|
|
||||||
_gst_gl_feature_check_ext_functions (context, gl_major, gl_minor,
|
/* GL core contexts and GLES3 */
|
||||||
(const gchar *) gl->GetString (GL_EXTENSIONS));
|
if (gl->GetIntegerv && gl->GetStringi) {
|
||||||
|
extensions = _build_extension_string (context);
|
||||||
|
} else {
|
||||||
|
extensions = (const gchar *) gl->GetString (GL_EXTENSIONS);
|
||||||
|
}
|
||||||
|
|
||||||
|
_gst_gl_feature_check_ext_functions (context, gl_major, gl_minor, extensions);
|
||||||
|
|
||||||
context->priv->alive = TRUE;
|
context->priv->alive = TRUE;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue