mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-13 19:05:37 +00:00
gl/memory: implement GL_EXT_texture_rg support
Which is used by default over the Luminance formats due to it being color renderable with fbos (and deprecation/removal with GL 3.x). https://bugzilla.gnome.org/show_bug.cgi?id=729750 https://bugzilla.gnome.org/show_bug.cgi?id=704222 https://bugzilla.gnome.org/show_bug.cgi?id=728890
This commit is contained in:
parent
4435c1c289
commit
132a233f7b
4 changed files with 68 additions and 23 deletions
|
@ -694,6 +694,9 @@ _YUV_to_RGB (GstGLColorConvert * convert)
|
||||||
GstVideoFormat out_format = GST_VIDEO_INFO_FORMAT (&convert->out_info);
|
GstVideoFormat out_format = GST_VIDEO_INFO_FORMAT (&convert->out_info);
|
||||||
const gchar *out_format_str = gst_video_format_to_string (out_format);
|
const gchar *out_format_str = gst_video_format_to_string (out_format);
|
||||||
gchar *pixel_order = _RGB_pixel_order ("rgba", out_format_str);
|
gchar *pixel_order = _RGB_pixel_order ("rgba", out_format_str);
|
||||||
|
gboolean texture_rg =
|
||||||
|
gst_gl_context_check_feature (convert->context, "GL_EXT_texture_rg")
|
||||||
|
|| gst_gl_context_check_feature (convert->context, "GL_ARB_texture_rg");
|
||||||
|
|
||||||
info->out_n_textures = 1;
|
info->out_n_textures = 1;
|
||||||
|
|
||||||
|
@ -737,21 +740,29 @@ _YUV_to_RGB (GstGLColorConvert * convert)
|
||||||
GST_VIDEO_INFO_PLANE_STRIDE (&convert->in_info, 0));
|
GST_VIDEO_INFO_PLANE_STRIDE (&convert->in_info, 0));
|
||||||
break;
|
break;
|
||||||
case GST_VIDEO_FORMAT_NV12:
|
case GST_VIDEO_FORMAT_NV12:
|
||||||
info->frag_prog = g_strdup_printf (frag_NV12_NV21_to_RGB, 'r', 'a',
|
{
|
||||||
|
char val2 = texture_rg ? 'g' : 'a';
|
||||||
|
info->frag_prog = g_strdup_printf (frag_NV12_NV21_to_RGB, 'r', val2,
|
||||||
pixel_order[0], pixel_order[1], pixel_order[2], pixel_order[3]);
|
pixel_order[0], pixel_order[1], pixel_order[2], pixel_order[3]);
|
||||||
info->in_n_textures = 2;
|
info->in_n_textures = 2;
|
||||||
info->shader_tex_names[0] = "Ytex";
|
info->shader_tex_names[0] = "Ytex";
|
||||||
info->shader_tex_names[1] = "UVtex";
|
info->shader_tex_names[1] = "UVtex";
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case GST_VIDEO_FORMAT_NV21:
|
case GST_VIDEO_FORMAT_NV21:
|
||||||
info->frag_prog = g_strdup_printf (frag_NV12_NV21_to_RGB, 'a', 'r',
|
{
|
||||||
|
char val2 = texture_rg ? 'g' : 'a';
|
||||||
|
info->frag_prog = g_strdup_printf (frag_NV12_NV21_to_RGB, val2, 'r',
|
||||||
pixel_order[0], pixel_order[1], pixel_order[2], pixel_order[3]);
|
pixel_order[0], pixel_order[1], pixel_order[2], pixel_order[3]);
|
||||||
info->in_n_textures = 2;
|
info->in_n_textures = 2;
|
||||||
info->shader_tex_names[0] = "Ytex";
|
info->shader_tex_names[0] = "Ytex";
|
||||||
info->shader_tex_names[1] = "UVtex";
|
info->shader_tex_names[1] = "UVtex";
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case GST_VIDEO_FORMAT_UYVY:
|
case GST_VIDEO_FORMAT_UYVY:
|
||||||
info->frag_prog = g_strdup_printf (frag_YUY2_UYVY_to_RGB, 'a', 'r', 'b',
|
{
|
||||||
|
char y_val = texture_rg ? 'g' : 'a';
|
||||||
|
info->frag_prog = g_strdup_printf (frag_YUY2_UYVY_to_RGB, y_val, 'r', 'b',
|
||||||
pixel_order[0], pixel_order[1], pixel_order[2], pixel_order[3]);
|
pixel_order[0], pixel_order[1], pixel_order[2], pixel_order[3]);
|
||||||
info->in_n_textures = 1;
|
info->in_n_textures = 1;
|
||||||
info->shader_tex_names[0] = "Ytex";
|
info->shader_tex_names[0] = "Ytex";
|
||||||
|
@ -763,6 +774,7 @@ _YUV_to_RGB (GstGLColorConvert * convert)
|
||||||
GST_VIDEO_INFO_HEIGHT (&convert->in_info),
|
GST_VIDEO_INFO_HEIGHT (&convert->in_info),
|
||||||
GST_VIDEO_INFO_PLANE_STRIDE (&convert->in_info, 0));
|
GST_VIDEO_INFO_PLANE_STRIDE (&convert->in_info, 0));
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -885,6 +897,9 @@ _GRAY_to_RGB (GstGLColorConvert * convert)
|
||||||
GstVideoFormat out_format = GST_VIDEO_INFO_FORMAT (&convert->out_info);
|
GstVideoFormat out_format = GST_VIDEO_INFO_FORMAT (&convert->out_info);
|
||||||
const gchar *out_format_str = gst_video_format_to_string (out_format);
|
const gchar *out_format_str = gst_video_format_to_string (out_format);
|
||||||
gchar *pixel_order = _RGB_pixel_order ("rgba", out_format_str);
|
gchar *pixel_order = _RGB_pixel_order ("rgba", out_format_str);
|
||||||
|
gboolean texture_rg =
|
||||||
|
gst_gl_context_check_feature (convert->context, "GL_EXT_texture_rg")
|
||||||
|
|| gst_gl_context_check_feature (convert->context, "GL_ARB_texture_rg");
|
||||||
|
|
||||||
info->in_n_textures = 1;
|
info->in_n_textures = 1;
|
||||||
info->out_n_textures = 1;
|
info->out_n_textures = 1;
|
||||||
|
@ -893,16 +908,22 @@ _GRAY_to_RGB (GstGLColorConvert * convert)
|
||||||
switch (GST_VIDEO_INFO_FORMAT (&convert->in_info)) {
|
switch (GST_VIDEO_INFO_FORMAT (&convert->in_info)) {
|
||||||
case GST_VIDEO_FORMAT_GRAY8:
|
case GST_VIDEO_FORMAT_GRAY8:
|
||||||
info->frag_prog = g_strdup_printf (frag_REORDER, "", pixel_order[0],
|
info->frag_prog = g_strdup_printf (frag_REORDER, "", pixel_order[0],
|
||||||
pixel_order[1], pixel_order[2], pixel_order[3]);
|
pixel_order[0], pixel_order[0], pixel_order[3]);
|
||||||
break;
|
break;
|
||||||
case GST_VIDEO_FORMAT_GRAY16_LE:
|
case GST_VIDEO_FORMAT_GRAY16_LE:
|
||||||
info->frag_prog = g_strdup_printf (frag_COMPOSE, 'a', 'r',
|
{
|
||||||
|
char val2 = texture_rg ? 'g' : 'a';
|
||||||
|
info->frag_prog = g_strdup_printf (frag_COMPOSE, val2, 'r',
|
||||||
pixel_order[0], pixel_order[1], pixel_order[2], pixel_order[3]);
|
pixel_order[0], pixel_order[1], pixel_order[2], pixel_order[3]);
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case GST_VIDEO_FORMAT_GRAY16_BE:
|
case GST_VIDEO_FORMAT_GRAY16_BE:
|
||||||
info->frag_prog = g_strdup_printf (frag_COMPOSE, 'r', 'a',
|
{
|
||||||
|
char val2 = texture_rg ? 'g' : 'a';
|
||||||
|
info->frag_prog = g_strdup_printf (frag_COMPOSE, 'r', val2,
|
||||||
pixel_order[0], pixel_order[1], pixel_order[2], pixel_order[3]);
|
pixel_order[0], pixel_order[1], pixel_order[2], pixel_order[3]);
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -181,8 +181,14 @@ _gl_texture_type_n_bytes (GstVideoGLTextureType tex_format)
|
||||||
}
|
}
|
||||||
|
|
||||||
GstVideoGLTextureType
|
GstVideoGLTextureType
|
||||||
gst_gl_texture_type_from_format (GstVideoFormat v_format, guint plane)
|
gst_gl_texture_type_from_format (GstGLContext * context,
|
||||||
|
GstVideoFormat v_format, guint plane)
|
||||||
{
|
{
|
||||||
|
gboolean texture_rg =
|
||||||
|
gst_gl_context_check_feature (context, "GL_EXT_texture_rg")
|
||||||
|
|| gst_gl_context_check_feature (context, "GL_ARB_texture_rg");
|
||||||
|
guint n_plane_components;
|
||||||
|
|
||||||
switch (v_format) {
|
switch (v_format) {
|
||||||
case GST_VIDEO_FORMAT_RGBx:
|
case GST_VIDEO_FORMAT_RGBx:
|
||||||
case GST_VIDEO_FORMAT_BGRx:
|
case GST_VIDEO_FORMAT_BGRx:
|
||||||
|
@ -193,40 +199,56 @@ gst_gl_texture_type_from_format (GstVideoFormat v_format, guint plane)
|
||||||
case GST_VIDEO_FORMAT_ARGB:
|
case GST_VIDEO_FORMAT_ARGB:
|
||||||
case GST_VIDEO_FORMAT_ABGR:
|
case GST_VIDEO_FORMAT_ABGR:
|
||||||
case GST_VIDEO_FORMAT_AYUV:
|
case GST_VIDEO_FORMAT_AYUV:
|
||||||
return GST_VIDEO_GL_TEXTURE_TYPE_RGBA;
|
n_plane_components = 4;
|
||||||
break;
|
break;
|
||||||
case GST_VIDEO_FORMAT_RGB:
|
case GST_VIDEO_FORMAT_RGB:
|
||||||
case GST_VIDEO_FORMAT_BGR:
|
case GST_VIDEO_FORMAT_BGR:
|
||||||
return GST_VIDEO_GL_TEXTURE_TYPE_RGB;
|
n_plane_components = 3;
|
||||||
break;
|
|
||||||
case GST_VIDEO_FORMAT_GRAY8:
|
|
||||||
return GST_VIDEO_GL_TEXTURE_TYPE_LUMINANCE;
|
|
||||||
break;
|
break;
|
||||||
case GST_VIDEO_FORMAT_GRAY16_BE:
|
case GST_VIDEO_FORMAT_GRAY16_BE:
|
||||||
case GST_VIDEO_FORMAT_GRAY16_LE:
|
case GST_VIDEO_FORMAT_GRAY16_LE:
|
||||||
return GST_VIDEO_GL_TEXTURE_TYPE_LUMINANCE_ALPHA;
|
|
||||||
break;
|
|
||||||
case GST_VIDEO_FORMAT_YUY2:
|
case GST_VIDEO_FORMAT_YUY2:
|
||||||
case GST_VIDEO_FORMAT_UYVY:
|
case GST_VIDEO_FORMAT_UYVY:
|
||||||
return GST_VIDEO_GL_TEXTURE_TYPE_LUMINANCE_ALPHA;
|
n_plane_components = 2;
|
||||||
break;
|
break;
|
||||||
case GST_VIDEO_FORMAT_NV12:
|
case GST_VIDEO_FORMAT_NV12:
|
||||||
case GST_VIDEO_FORMAT_NV21:
|
case GST_VIDEO_FORMAT_NV21:
|
||||||
if (plane == 0)
|
n_plane_components = plane == 0 ? 1 : 2;
|
||||||
return GST_VIDEO_GL_TEXTURE_TYPE_LUMINANCE;
|
|
||||||
return GST_VIDEO_GL_TEXTURE_TYPE_LUMINANCE_ALPHA;
|
|
||||||
break;
|
break;
|
||||||
|
case GST_VIDEO_FORMAT_GRAY8:
|
||||||
case GST_VIDEO_FORMAT_Y444:
|
case GST_VIDEO_FORMAT_Y444:
|
||||||
case GST_VIDEO_FORMAT_Y42B:
|
case GST_VIDEO_FORMAT_Y42B:
|
||||||
case GST_VIDEO_FORMAT_Y41B:
|
case GST_VIDEO_FORMAT_Y41B:
|
||||||
case GST_VIDEO_FORMAT_I420:
|
case GST_VIDEO_FORMAT_I420:
|
||||||
case GST_VIDEO_FORMAT_YV12:
|
case GST_VIDEO_FORMAT_YV12:
|
||||||
return GST_VIDEO_GL_TEXTURE_TYPE_LUMINANCE;
|
n_plane_components = 1;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
n_plane_components = 4;
|
||||||
|
g_assert_not_reached ();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (n_plane_components) {
|
||||||
|
case 4:
|
||||||
|
return GST_VIDEO_GL_TEXTURE_TYPE_RGBA;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
return GST_VIDEO_GL_TEXTURE_TYPE_RGB;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
return texture_rg ? GST_VIDEO_GL_TEXTURE_TYPE_RG :
|
||||||
|
GST_VIDEO_GL_TEXTURE_TYPE_LUMINANCE_ALPHA;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
return texture_rg ? GST_VIDEO_GL_TEXTURE_TYPE_R :
|
||||||
|
GST_VIDEO_GL_TEXTURE_TYPE_LUMINANCE;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
g_assert_not_reached ();
|
g_assert_not_reached ();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return GST_VIDEO_GL_TEXTURE_TYPE_RGBA;
|
return GST_VIDEO_GL_TEXTURE_TYPE_RGBA;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1041,7 +1063,8 @@ gst_gl_memory_setup_buffer (GstGLContext * context, GstVideoInfo * info,
|
||||||
|
|
||||||
for (i = 0; i < n_mem; i++) {
|
for (i = 0; i < n_mem; i++) {
|
||||||
tex_type =
|
tex_type =
|
||||||
gst_gl_texture_type_from_format (GST_VIDEO_INFO_FORMAT (info), i);
|
gst_gl_texture_type_from_format (context, GST_VIDEO_INFO_FORMAT (info),
|
||||||
|
i);
|
||||||
gl_mem[i] =
|
gl_mem[i] =
|
||||||
(GstGLMemory *) gst_gl_memory_alloc (context, tex_type,
|
(GstGLMemory *) gst_gl_memory_alloc (context, tex_type,
|
||||||
_get_plane_width (info, i), _get_plane_height (info, i),
|
_get_plane_width (info, i), _get_plane_height (info, i),
|
||||||
|
@ -1079,7 +1102,8 @@ gst_gl_memory_setup_wrapped (GstGLContext * context, GstVideoInfo * info,
|
||||||
|
|
||||||
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (info); i++) {
|
for (i = 0; i < GST_VIDEO_INFO_N_PLANES (info); i++) {
|
||||||
tex_type =
|
tex_type =
|
||||||
gst_gl_texture_type_from_format (GST_VIDEO_INFO_FORMAT (info), i);
|
gst_gl_texture_type_from_format (context, GST_VIDEO_INFO_FORMAT (info),
|
||||||
|
i);
|
||||||
|
|
||||||
textures[i] = (GstGLMemory *) gst_gl_memory_wrapped (context, tex_type,
|
textures[i] = (GstGLMemory *) gst_gl_memory_wrapped (context, tex_type,
|
||||||
_get_plane_width (info, i), _get_plane_height (info, i),
|
_get_plane_width (info, i), _get_plane_height (info, i),
|
||||||
|
|
|
@ -173,7 +173,7 @@ gboolean gst_gl_memory_setup_wrapped (GstGLContext * context, GstVideoInfo
|
||||||
gpointer data[GST_VIDEO_MAX_PLANES],
|
gpointer data[GST_VIDEO_MAX_PLANES],
|
||||||
GstGLMemory *textures[GST_VIDEO_MAX_PLANES]);
|
GstGLMemory *textures[GST_VIDEO_MAX_PLANES]);
|
||||||
|
|
||||||
GstVideoGLTextureType gst_gl_texture_type_from_format (GstVideoFormat v_format, guint plane);
|
GstVideoGLTextureType gst_gl_texture_type_from_format (GstGLContext *context, GstVideoFormat v_format, guint plane);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GstGLAllocator
|
* GstGLAllocator
|
||||||
|
|
|
@ -568,7 +568,7 @@ gst_gl_upload_add_video_gl_texture_upload_meta (GstGLUpload * upload,
|
||||||
upload->priv->buffer = buffer;
|
upload->priv->buffer = buffer;
|
||||||
|
|
||||||
for (i = 0; i < GST_VIDEO_MAX_PLANES; i++) {
|
for (i = 0; i < GST_VIDEO_MAX_PLANES; i++) {
|
||||||
texture_types[i] = gst_gl_texture_type_from_format (v_meta->format, i);
|
texture_types[i] = gst_gl_texture_type_from_format (upload->context, v_meta->format, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
gst_buffer_add_video_gl_texture_upload_meta (buffer,
|
gst_buffer_add_video_gl_texture_upload_meta (buffer,
|
||||||
|
|
Loading…
Reference in a new issue