mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-23 15:48:23 +00:00
[713/906] shader: make it possible to create the object in a non-GL thread
This commit is contained in:
parent
ef6b1ca760
commit
d7f5cac7ce
1 changed files with 8 additions and 10 deletions
|
@ -350,13 +350,6 @@ gst_gl_shader_new (GstGLDisplay * display)
|
||||||
shader = g_object_new (GST_GL_TYPE_SHADER, NULL);
|
shader = g_object_new (GST_GL_TYPE_SHADER, NULL);
|
||||||
shader->display = gst_object_ref (display);
|
shader->display = gst_object_ref (display);
|
||||||
|
|
||||||
if (!_fill_vtable (shader, display))
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
shader->priv->program_handle = shader->priv->vtable.CreateProgram ();
|
|
||||||
|
|
||||||
GST_TRACE ("shader initialized %u", shader->priv->program_handle);
|
|
||||||
|
|
||||||
return shader;
|
return shader;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -386,6 +379,13 @@ gst_gl_shader_compile (GstGLShader * shader, GError ** error)
|
||||||
if (priv->compiled)
|
if (priv->compiled)
|
||||||
return priv->compiled;
|
return priv->compiled;
|
||||||
|
|
||||||
|
if (!_fill_vtable (shader, shader->display))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
shader->priv->program_handle = shader->priv->vtable.CreateProgram ();
|
||||||
|
|
||||||
|
GST_TRACE ("shader created %u", shader->priv->program_handle);
|
||||||
|
|
||||||
g_return_val_if_fail (priv->program_handle, FALSE);
|
g_return_val_if_fail (priv->program_handle, FALSE);
|
||||||
|
|
||||||
if (priv->vertex_src) {
|
if (priv->vertex_src) {
|
||||||
|
@ -480,9 +480,7 @@ gst_gl_shader_release (GstGLShader * shader)
|
||||||
|
|
||||||
priv = shader->priv;
|
priv = shader->priv;
|
||||||
|
|
||||||
g_return_if_fail (priv->program_handle);
|
if (!priv->compiled || !priv->program_handle)
|
||||||
|
|
||||||
if (!priv->compiled)
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (priv->vertex_handle) { /* not needed but nvidia doesn't care to respect the spec */
|
if (priv->vertex_handle) { /* not needed but nvidia doesn't care to respect the spec */
|
||||||
|
|
Loading…
Reference in a new issue