[vlc-devel] [PATCH 05/41] opengl: expose npot support in gl_api
Romain Vimont
rom1v at videolabs.io
Fri Feb 7 17:41:51 CET 2020
Expose in vlc_gl_api whether it supports non-power of 2 textures.
---
modules/video_output/opengl/gl_api.c | 5 +++++
modules/video_output/opengl/gl_api.h | 3 +++
modules/video_output/opengl/renderer.c | 4 ++--
modules/video_output/opengl/renderer.h | 4 +---
modules/video_output/opengl/sub_renderer.c | 7 ++-----
modules/video_output/opengl/sub_renderer.h | 3 +--
modules/video_output/opengl/vout_helper.c | 17 ++---------------
7 files changed, 16 insertions(+), 27 deletions(-)
diff --git a/modules/video_output/opengl/gl_api.c b/modules/video_output/opengl/gl_api.c
index 7caec86406..b9ba45f0a2 100644
--- a/modules/video_output/opengl/gl_api.c
+++ b/modules/video_output/opengl/gl_api.c
@@ -141,8 +141,13 @@ vlc_gl_api_Init(struct vlc_gl_api *api, vlc_gl_t *gl)
#ifdef USE_OPENGL_ES2
api->is_gles = true;
+ /* OpenGL ES 2 includes support for non-power of 2 textures by specification
+ * so checks for extensions are bound to fail. Check for OpenGL ES version instead. */
+ api->supports_npot = true;
#else
api->is_gles = false;
+ api->supports_npot = vlc_gl_StrHasToken(api->extensions, "GL_ARB_texture_non_power_of_two") ||
+ vlc_gl_StrHasToken(api->extensions, "GL_APPLE_texture_2D_limited_npot");
#endif
return VLC_SUCCESS;
diff --git a/modules/video_output/opengl/gl_api.h b/modules/video_output/opengl/gl_api.h
index e618d8d488..a769ba9a21 100644
--- a/modules/video_output/opengl/gl_api.h
+++ b/modules/video_output/opengl/gl_api.h
@@ -39,6 +39,9 @@ struct vlc_gl_api {
/* Available gl extensions (from GL_EXTENSIONS) */
const char *extensions;
+
+ /* Non-power-of-2 texture size support */
+ bool supports_npot;
};
int
diff --git a/modules/video_output/opengl/renderer.c b/modules/video_output/opengl/renderer.c
index 69332defb1..93c2ea63bf 100644
--- a/modules/video_output/opengl/renderer.c
+++ b/modules/video_output/opengl/renderer.c
@@ -324,7 +324,7 @@ vlc_gl_renderer_Delete(struct vlc_gl_renderer *renderer)
struct vlc_gl_renderer *
vlc_gl_renderer_New(vlc_gl_t *gl, const struct vlc_gl_api *api,
vlc_video_context *context, const video_format_t *fmt,
- bool supports_npot, bool b_dump_shaders)
+ bool b_dump_shaders)
{
const opengl_vtable_t *vt = &api->vt;
@@ -390,7 +390,7 @@ vlc_gl_renderer_New(vlc_gl_t *gl, const struct vlc_gl_api *api,
/ interop->texs[j].w.den;
const GLsizei h = renderer->fmt.i_visible_height * interop->texs[j].h.num
/ interop->texs[j].h.den;
- if (supports_npot) {
+ if (api->supports_npot) {
renderer->tex_width[j] = w;
renderer->tex_height[j] = h;
} else {
diff --git a/modules/video_output/opengl/renderer.h b/modules/video_output/opengl/renderer.h
index e161e7eb52..913a8c8e6e 100644
--- a/modules/video_output/opengl/renderer.h
+++ b/modules/video_output/opengl/renderer.h
@@ -158,14 +158,12 @@ struct vlc_gl_renderer
* \param api the OpenGL API
* \param context the video context
* \param fmt the video format
- * \param supports_npot indicate if the implementation supports non-power-of-2
- * texture size
* \param dump_shaders indicate if the shaders must be dumped in logs
*/
struct vlc_gl_renderer *
vlc_gl_renderer_New(vlc_gl_t *gl, const struct vlc_gl_api *api,
vlc_video_context *context, const video_format_t *fmt,
- bool supports_npot, bool dump_shaders);
+ bool dump_shaders);
/**
* Delete a renderer
diff --git a/modules/video_output/opengl/sub_renderer.c b/modules/video_output/opengl/sub_renderer.c
index a3c72ba171..a06a9826ae 100644
--- a/modules/video_output/opengl/sub_renderer.c
+++ b/modules/video_output/opengl/sub_renderer.c
@@ -65,7 +65,6 @@ struct vlc_gl_sub_renderer
struct vlc_gl_interop *interop;
- bool supports_npot;
gl_region_t *regions;
unsigned region_count;
@@ -113,8 +112,7 @@ FetchLocations(struct vlc_gl_sub_renderer *sr)
}
struct vlc_gl_sub_renderer *
-vlc_gl_sub_renderer_New(vlc_gl_t *gl, const struct vlc_gl_api *api,
- bool supports_npot)
+vlc_gl_sub_renderer_New(vlc_gl_t *gl, const struct vlc_gl_api *api)
{
const opengl_vtable_t *vt = &api->vt;
@@ -134,7 +132,6 @@ vlc_gl_sub_renderer_New(vlc_gl_t *gl, const struct vlc_gl_api *api,
sr->gl = gl;
sr->api = api;
sr->vt = vt;
- sr->supports_npot = supports_npot;
sr->region_count = 0;
sr->regions = NULL;
@@ -241,7 +238,7 @@ vlc_gl_sub_renderer_Prepare(struct vlc_gl_sub_renderer *sr, subpicture_t *subpic
glr->width = r->fmt.i_visible_width;
glr->height = r->fmt.i_visible_height;
- if (!sr->supports_npot) {
+ if (!sr->api->supports_npot) {
glr->width = vlc_align_pot(glr->width);
glr->height = vlc_align_pot(glr->height);
glr->tex_width = (float) r->fmt.i_visible_width / glr->width;
diff --git a/modules/video_output/opengl/sub_renderer.h b/modules/video_output/opengl/sub_renderer.h
index cfd1bc79d2..7b027a937b 100644
--- a/modules/video_output/opengl/sub_renderer.h
+++ b/modules/video_output/opengl/sub_renderer.h
@@ -45,8 +45,7 @@ struct vlc_gl_sub_renderer;
* texture size
*/
struct vlc_gl_sub_renderer *
-vlc_gl_sub_renderer_New(vlc_gl_t *gl, const struct vlc_gl_api *api,
- bool supports_npot);
+vlc_gl_sub_renderer_New(vlc_gl_t *gl, const struct vlc_gl_api *api);
/**
* Delete a subpictures renderer
diff --git a/modules/video_output/opengl/vout_helper.c b/modules/video_output/opengl/vout_helper.c
index 2f42a2d142..7ab97a8462 100644
--- a/modules/video_output/opengl/vout_helper.c
+++ b/modules/video_output/opengl/vout_helper.c
@@ -138,22 +138,10 @@ vout_display_opengl_t *vout_display_opengl_New(video_format_t *fmt,
(GLint)fmt->i_height > max_tex_size)
ResizeFormatToGLMaxTexSize(fmt, max_tex_size);
- /* Non-power-of-2 texture size support */
- bool supports_npot;
-#if defined(USE_OPENGL_ES2)
- /* OpenGL ES 2 includes support for non-power of 2 textures by specification
- * so checks for extensions are bound to fail. Check for OpenGL ES version instead. */
- supports_npot = true;
-#else
- supports_npot = vlc_gl_StrHasToken(extensions, "GL_ARB_texture_non_power_of_two") ||
- vlc_gl_StrHasToken(extensions, "GL_APPLE_texture_2D_limited_npot");
-#endif
-
bool b_dump_shaders = var_InheritInteger(gl, "verbose") >= 4;
struct vlc_gl_renderer *renderer = vgl->renderer =
- vlc_gl_renderer_New(gl, &vgl->api, context, fmt, supports_npot,
- b_dump_shaders);
+ vlc_gl_renderer_New(gl, &vgl->api, context, fmt, b_dump_shaders);
if (!vgl->renderer)
{
msg_Warn(gl, "Could not create renderer for %4.4s",
@@ -164,8 +152,7 @@ vout_display_opengl_t *vout_display_opengl_New(video_format_t *fmt,
GL_ASSERT_NOERROR();
- vgl->sub_renderer = vlc_gl_sub_renderer_New(gl, &vgl->api,
- supports_npot);
+ vgl->sub_renderer = vlc_gl_sub_renderer_New(gl, &vgl->api);
if (!vgl->sub_renderer)
{
msg_Err(gl, "Could not create sub renderer");
--
2.25.0
More information about the vlc-devel
mailing list