From b79366344929c6e477c64a63f246c6db0766a71c Mon Sep 17 00:00:00 2001 From: Gert Wollny Date: Mon, 27 May 2019 16:31:17 +0200 Subject: [PATCH] virgl: Add driconf tweak for emulating BGRA surfaces on GLES These tweaks are used to fix rendering issues with Valve games and at least also "The Raven Remastered" when run on a GLES host. v2: Fix type in define and remove virgl from driconf option (Emil) v3: Encode tweak binary instead of using strings (Gurchetan) Signed-off-by: Gert Wollny Reviewed-by: Gurchetan Singh --- src/gallium/drivers/virgl/virgl_context.c | 2 ++ src/gallium/drivers/virgl/virgl_protocol.h | 1 + src/gallium/drivers/virgl/virgl_screen.c | 7 ++++++ src/util/00-mesa-defaults.conf | 28 +++++++++++++++++++++- src/util/xmlpool/t_options.h | 7 ++++++ 5 files changed, 44 insertions(+), 1 deletion(-) diff --git a/src/gallium/drivers/virgl/virgl_context.c b/src/gallium/drivers/virgl/virgl_context.c index cd653b70ce9..3ce131a1e06 100644 --- a/src/gallium/drivers/virgl/virgl_context.c +++ b/src/gallium/drivers/virgl/virgl_context.c @@ -1404,6 +1404,8 @@ static void virgl_get_sample_position(struct pipe_context *ctx, static void virgl_send_tweaks(struct virgl_context *vctx, struct virgl_screen *rs) { + if (rs->tweak_gles_emulate_bgra) + virgl_encode_tweak(vctx, virgl_tweak_gles_brga_emulate, 1); } struct pipe_context *virgl_context_create(struct pipe_screen *pscreen, diff --git a/src/gallium/drivers/virgl/virgl_protocol.h b/src/gallium/drivers/virgl/virgl_protocol.h index c3ad598601d..71d1703cada 100644 --- a/src/gallium/drivers/virgl/virgl_protocol.h +++ b/src/gallium/drivers/virgl/virgl_protocol.h @@ -592,6 +592,7 @@ enum virgl_context_cmd { #define VIRGL_SET_TWEAKS_VALUE 2 enum vrend_tweak_type { + virgl_tweak_gles_brga_emulate, virgl_tweak_undefined }; diff --git a/src/gallium/drivers/virgl/virgl_screen.c b/src/gallium/drivers/virgl/virgl_screen.c index 31de32f9289..54bde6f1237 100644 --- a/src/gallium/drivers/virgl/virgl_screen.c +++ b/src/gallium/drivers/virgl/virgl_screen.c @@ -27,6 +27,7 @@ #include "util/u_video.h" #include "util/u_math.h" #include "util/os_time.h" +#include "util/xmlconfig.h" #include "pipe/p_defines.h" #include "pipe/p_screen.h" @@ -36,6 +37,7 @@ #include "virgl_resource.h" #include "virgl_public.h" #include "virgl_context.h" +#include "virgl_protocol.h" int virgl_debug = 0; static const struct debug_named_value debug_options[] = { @@ -852,11 +854,16 @@ virgl_create_screen(struct virgl_winsys *vws, const struct pipe_screen_config *c { struct virgl_screen *screen = CALLOC_STRUCT(virgl_screen); + const char *VIRGL_GLES_EMULATE_BGRA = "gles_emulate_bgra"; if (!screen) return NULL; virgl_debug = debug_get_option_virgl_debug(); + if (config && config->options) { + screen->tweak_gles_emulate_bgra = + driQueryOptionb(config->options, VIRGL_GLES_EMULATE_BGRA); + } screen->vws = vws; screen->base.get_name = virgl_get_name; screen->base.get_vendor = virgl_get_vendor; diff --git a/src/util/00-mesa-defaults.conf b/src/util/00-mesa-defaults.conf index e36190f61c8..ae29d8837d5 100644 --- a/src/util/00-mesa-defaults.conf +++ b/src/util/00-mesa-defaults.conf @@ -490,4 +490,30 @@ TODO: document the other workarounds.