You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
260 lines
9.5 KiB
260 lines
9.5 KiB
3 years ago
|
From 110d69c8245bb2bc1f0cf183dcdd6ba636973bfc Mon Sep 17 00:00:00 2001
|
||
|
From: Niklas Haas <git@haasn.dev>
|
||
|
Date: Tue, 18 Jan 2022 16:47:22 +0100
|
||
|
Subject: [PATCH 1/4] Revert "opengl: vout_helper: use pl_gpu_dummy for
|
||
|
shaders"
|
||
|
|
||
|
This reverts commit 2437484d7684a4661048df1e095484a276bbea0b.
|
||
|
|
||
|
The referenced commit is not a good way of fixing the issue described in
|
||
|
its commit message. Attaching a dummy GPU to the pl_shader makes the
|
||
|
shader think a GPU is actually available, and can lead to e.g. the use
|
||
|
of a dither texture (which VLC has no mapping code for, and would thus
|
||
|
result in a shader compilation error).
|
||
|
|
||
|
All of the queried limits are also irrelevant for the way we use shaders
|
||
|
in this code, since they only affect GPU resources (which we can't use)
|
||
|
or texture sampling (which we don't use).
|
||
|
|
||
|
Fixes #26503 by removing the conflicting code
|
||
|
---
|
||
|
modules/video_output/opengl/converter.h | 1 -
|
||
|
modules/video_output/opengl/vout_helper.c | 78 +----------------------
|
||
|
2 files changed, 2 insertions(+), 77 deletions(-)
|
||
|
|
||
|
diff --git a/modules/video_output/opengl/converter.h b/modules/video_output/opengl/converter.h
|
||
|
index f8f0c12024..b69807f8cd 100644
|
||
|
--- a/modules/video_output/opengl/converter.h
|
||
|
+++ b/modules/video_output/opengl/converter.h
|
||
|
@@ -340,7 +340,6 @@ struct opengl_tex_converter_t
|
||
|
bool yuv_color;
|
||
|
GLfloat yuv_coefficients[16];
|
||
|
|
||
|
- const struct pl_gpu *pl_gpu;
|
||
|
struct pl_shader *pl_sh;
|
||
|
const struct pl_shader_res *pl_sh_res;
|
||
|
|
||
|
diff --git a/modules/video_output/opengl/vout_helper.c b/modules/video_output/opengl/vout_helper.c
|
||
|
index bf07c1c03f..711a14b7ae 100644
|
||
|
--- a/modules/video_output/opengl/vout_helper.c
|
||
|
+++ b/modules/video_output/opengl/vout_helper.c
|
||
|
@@ -44,12 +44,6 @@
|
||
|
#include "vout_helper.h"
|
||
|
#include "internal.h"
|
||
|
|
||
|
-#if HAVE_LIBPLACEBO
|
||
|
-#if PL_API_VER >= 18
|
||
|
-#include <libplacebo/dummy.h>
|
||
|
-#endif
|
||
|
-#endif
|
||
|
-
|
||
|
#ifndef GL_CLAMP_TO_EDGE
|
||
|
# define GL_CLAMP_TO_EDGE 0x812F
|
||
|
#endif
|
||
|
@@ -576,10 +570,6 @@ opengl_deinit_program(vout_display_opengl_t *vgl, struct prgm *prgm)
|
||
|
|
||
|
#ifdef HAVE_LIBPLACEBO
|
||
|
FREENULL(tc->uloc.pl_vars);
|
||
|
-#if PL_API_VER >= 18
|
||
|
- if (tc->pl_gpu)
|
||
|
- pl_gpu_dummy_destroy(&tc->pl_gpu);
|
||
|
-#endif
|
||
|
if (tc->pl_ctx)
|
||
|
pl_context_destroy(&tc->pl_ctx);
|
||
|
#endif
|
||
|
@@ -632,78 +622,14 @@ opengl_init_program(vout_display_opengl_t *vgl, struct prgm *prgm,
|
||
|
// create the main libplacebo context
|
||
|
if (!subpics)
|
||
|
{
|
||
|
-#if PL_API_VER >= 18
|
||
|
- struct pl_gpu_dummy_params gpu_dummy_params = {
|
||
|
- .caps = PL_GPU_CAP_INPUT_VARIABLES,
|
||
|
- .glsl = (struct pl_glsl_desc) {
|
||
|
-#ifdef USE_OPENGL_ES2
|
||
|
- .version = 100,
|
||
|
- .gles = true,
|
||
|
-#else
|
||
|
- .version = 120,
|
||
|
-#endif
|
||
|
- .vulkan = false,
|
||
|
- },
|
||
|
- .limits = { 0 }
|
||
|
- };
|
||
|
-#endif
|
||
|
-
|
||
|
- const opengl_vtable_t *vt = tc->vt;
|
||
|
-
|
||
|
-#if PL_API_VER >= 18
|
||
|
- vt->GetIntegerv(GL_MAX_TEXTURE_SIZE,
|
||
|
- (GLint *)&gpu_dummy_params.limits.max_tex_1d_dim);
|
||
|
- gpu_dummy_params.limits.max_tex_2d_dim = gpu_dummy_params.limits.max_tex_1d_dim;
|
||
|
-#ifndef USE_OPENGL_ES2
|
||
|
- vt->GetIntegerv(GL_MAX_3D_TEXTURE_SIZE,
|
||
|
- (GLint *)&gpu_dummy_params.limits.max_tex_3d_dim);
|
||
|
- vt->GetIntegerv(GL_MAX_UNIFORM_BLOCK_SIZE,
|
||
|
- (GLint *)&gpu_dummy_params.limits.max_ubo_size);
|
||
|
- vt->GetIntegerv(GL_MAX_SHADER_STORAGE_BLOCK_SIZE,
|
||
|
- (GLint *)&gpu_dummy_params.limits.max_ssbo_size);
|
||
|
- vt->GetIntegerv(GL_MIN_PROGRAM_TEXTURE_GATHER_OFFSET_ARB,
|
||
|
- (GLint *)&gpu_dummy_params.limits.min_gather_offset);
|
||
|
- vt->GetIntegerv(GL_MAX_PROGRAM_TEXTURE_GATHER_OFFSET_ARB,
|
||
|
- (GLint *)&gpu_dummy_params.limits.max_gather_offset);
|
||
|
- vt->GetIntegerv(GL_MAX_COMPUTE_SHARED_MEMORY_SIZE,
|
||
|
- (GLint *)&gpu_dummy_params.limits.max_shmem_size);
|
||
|
- vt->GetIntegerv(GL_MAX_COMPUTE_WORK_GROUP_INVOCATIONS,
|
||
|
- (GLint *)&gpu_dummy_params.limits.max_group_threads);
|
||
|
- if (vt->GetIntegeri_v != NULL)
|
||
|
- {
|
||
|
- for (int i = 0; i < 3; i++)
|
||
|
- {
|
||
|
- vt->GetIntegeri_v(GL_MAX_COMPUTE_WORK_GROUP_COUNT, i,
|
||
|
- (GLint *)&gpu_dummy_params.limits.max_dispatch[i]);
|
||
|
- vt->GetIntegeri_v(GL_MAX_COMPUTE_WORK_GROUP_SIZE, i,
|
||
|
- (GLint *)&gpu_dummy_params.limits.max_group_size[i]);
|
||
|
- }
|
||
|
- }
|
||
|
-#endif
|
||
|
-#endif
|
||
|
-
|
||
|
- /* Drain potential errors, non-existing variables will be set to zero */
|
||
|
- while (vt->GetError() != GL_NO_ERROR) {}
|
||
|
-
|
||
|
tc->pl_ctx = pl_context_create(PL_API_VER, &(struct pl_context_params) {
|
||
|
.log_cb = log_cb,
|
||
|
.log_priv = tc,
|
||
|
.log_level = PL_LOG_INFO,
|
||
|
});
|
||
|
-
|
||
|
if (tc->pl_ctx) {
|
||
|
-#if PL_API_VER >= 18
|
||
|
- /* pl_gpu = NULL is not fatal but might generate incorrect shaders
|
||
|
- * depending or more recent GLSL version than VLC shaders. */
|
||
|
- tc->pl_gpu = pl_gpu_dummy_create(tc->pl_ctx, &gpu_dummy_params);
|
||
|
-
|
||
|
- struct pl_shader_params shader_params = {
|
||
|
- .gpu = tc->pl_gpu,
|
||
|
- };
|
||
|
-#endif
|
||
|
-
|
||
|
# if PL_API_VER >= 20
|
||
|
- tc->pl_sh = pl_shader_alloc(tc->pl_ctx, &shader_params);
|
||
|
+ tc->pl_sh = pl_shader_alloc(tc->pl_ctx, NULL);
|
||
|
# elif PL_API_VER >= 6
|
||
|
tc->pl_sh = pl_shader_alloc(tc->pl_ctx, NULL, 0);
|
||
|
# else
|
||
|
@@ -861,7 +787,7 @@ vout_display_opengl_t *vout_display_opengl_New(video_format_t *fmt,
|
||
|
GET_PROC_ADDR_CORE(GetError);
|
||
|
GET_PROC_ADDR_CORE(GetIntegerv);
|
||
|
#ifndef USE_OPENGL_ES2
|
||
|
- GET_PROC_ADDR_OPTIONAL(GetIntegeri_v);
|
||
|
+ GET_PROC_ADDR_CORE(GetIntegeri_v);
|
||
|
#endif
|
||
|
GET_PROC_ADDR_CORE(GetString);
|
||
|
GET_PROC_ADDR_CORE(PixelStorei);
|
||
|
--
|
||
|
GitLab
|
||
|
|
||
|
|
||
|
From 6d145e38c03d4ffa5b6bff31e358a5ca6ceb3461 Mon Sep 17 00:00:00 2001
|
||
|
From: Niklas Haas <git@haasn.dev>
|
||
|
Date: Tue, 18 Jan 2022 17:07:25 +0100
|
||
|
Subject: [PATCH 2/4] opengl: vout_helper: use pl_shader_params.glsl
|
||
|
|
||
|
This is the proper way to limit the GLSL version when using standalone
|
||
|
shaders without an associated GPU backend.
|
||
|
---
|
||
|
modules/video_output/opengl/vout_helper.c | 5 ++++-
|
||
|
1 file changed, 4 insertions(+), 1 deletion(-)
|
||
|
|
||
|
diff --git a/modules/video_output/opengl/vout_helper.c b/modules/video_output/opengl/vout_helper.c
|
||
|
index 711a14b7ae..a98621a859 100644
|
||
|
--- a/modules/video_output/opengl/vout_helper.c
|
||
|
+++ b/modules/video_output/opengl/vout_helper.c
|
||
|
@@ -629,7 +629,10 @@ opengl_init_program(vout_display_opengl_t *vgl, struct prgm *prgm,
|
||
|
});
|
||
|
if (tc->pl_ctx) {
|
||
|
# if PL_API_VER >= 20
|
||
|
- tc->pl_sh = pl_shader_alloc(tc->pl_ctx, NULL);
|
||
|
+ tc->pl_sh = pl_shader_alloc(tc->pl_ctx, &(struct pl_shader_params) {
|
||
|
+ .glsl.version = tc->glsl_version,
|
||
|
+ .glsl.gles = tc->is_gles,
|
||
|
+ });
|
||
|
# elif PL_API_VER >= 6
|
||
|
tc->pl_sh = pl_shader_alloc(tc->pl_ctx, NULL, 0);
|
||
|
# else
|
||
|
--
|
||
|
GitLab
|
||
|
|
||
|
|
||
|
From 645cbd6fac5bd07d1c973be9fc048b0f329c087c Mon Sep 17 00:00:00 2001
|
||
|
From: Niklas Haas <git@haasn.dev>
|
||
|
Date: Tue, 18 Jan 2022 17:19:27 +0100
|
||
|
Subject: [PATCH 3/4] opengl: don't error on no-op libplacebo shader
|
||
|
|
||
|
See 6efc345d81a12
|
||
|
---
|
||
|
modules/video_output/opengl/fragment_shaders.c | 4 ++--
|
||
|
1 file changed, 2 insertions(+), 2 deletions(-)
|
||
|
|
||
|
diff --git a/modules/video_output/opengl/fragment_shaders.c b/modules/video_output/opengl/fragment_shaders.c
|
||
|
index e0b98732ca..ecf7226f0e 100644
|
||
|
--- a/modules/video_output/opengl/fragment_shaders.c
|
||
|
+++ b/modules/video_output/opengl/fragment_shaders.c
|
||
|
@@ -765,8 +765,8 @@ opengl_fragment_shader_init_impl(opengl_tex_converter_t *tc, GLenum tex_target,
|
||
|
}
|
||
|
|
||
|
#ifdef HAVE_LIBPLACEBO
|
||
|
- if (tc->pl_sh_res) {
|
||
|
- const struct pl_shader_res *res = tc->pl_sh_res;
|
||
|
+ const struct pl_shader_res *res = tc->pl_sh_res;
|
||
|
+ if (res && res->input != PL_SHADER_SIG_NONE) {
|
||
|
assert(res->input == PL_SHADER_SIG_COLOR);
|
||
|
assert(res->output == PL_SHADER_SIG_COLOR);
|
||
|
ADDF(" result = %s(result);\n", res->name);
|
||
|
--
|
||
|
GitLab
|
||
|
|
||
|
|
||
|
From 37bf74e6645d3023c1ebcbd81ffae1e552d3a73e Mon Sep 17 00:00:00 2001
|
||
|
From: Niklas Haas <git@haasn.dev>
|
||
|
Date: Tue, 18 Jan 2022 18:03:48 +0100
|
||
|
Subject: [PATCH 4/4] opengl: drop unneeded GetIntegeri_v
|
||
|
|
||
|
This causes issues on some platforms, and we don't need it
|
||
|
---
|
||
|
modules/video_output/opengl/converter.h | 3 ---
|
||
|
modules/video_output/opengl/vout_helper.c | 3 ---
|
||
|
2 files changed, 6 deletions(-)
|
||
|
|
||
|
diff --git a/modules/video_output/opengl/converter.h b/modules/video_output/opengl/converter.h
|
||
|
index b69807f8cd..7000e1f38e 100644
|
||
|
--- a/modules/video_output/opengl/converter.h
|
||
|
+++ b/modules/video_output/opengl/converter.h
|
||
|
@@ -167,9 +167,6 @@ typedef struct {
|
||
|
PFNGLGENTEXTURESPROC GenTextures;
|
||
|
PFNGLGETERRORPROC GetError;
|
||
|
PFNGLGETINTEGERVPROC GetIntegerv;
|
||
|
-#ifndef USE_OPENGL_ES2
|
||
|
- PFNGLGETINTEGERIVPROC GetIntegeri_v;
|
||
|
-#endif
|
||
|
PFNGLGETSTRINGPROC GetString;
|
||
|
PFNGLPIXELSTOREIPROC PixelStorei;
|
||
|
PFNGLTEXIMAGE2DPROC TexImage2D;
|
||
|
diff --git a/modules/video_output/opengl/vout_helper.c b/modules/video_output/opengl/vout_helper.c
|
||
|
index a98621a859..13d65e04c8 100644
|
||
|
--- a/modules/video_output/opengl/vout_helper.c
|
||
|
+++ b/modules/video_output/opengl/vout_helper.c
|
||
|
@@ -789,9 +789,6 @@ vout_display_opengl_t *vout_display_opengl_New(video_format_t *fmt,
|
||
|
GET_PROC_ADDR_CORE(GenTextures);
|
||
|
GET_PROC_ADDR_CORE(GetError);
|
||
|
GET_PROC_ADDR_CORE(GetIntegerv);
|
||
|
-#ifndef USE_OPENGL_ES2
|
||
|
- GET_PROC_ADDR_CORE(GetIntegeri_v);
|
||
|
-#endif
|
||
|
GET_PROC_ADDR_CORE(GetString);
|
||
|
GET_PROC_ADDR_CORE(PixelStorei);
|
||
|
GET_PROC_ADDR_CORE(TexImage2D);
|
||
|
--
|
||
|
GitLab
|
||
|
|