summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorlat9nq <22451773+lat9nq@users.noreply.github.com>2021-03-21 06:25:45 +0100
committerlat9nq <22451773+lat9nq@users.noreply.github.com>2021-03-21 06:25:45 +0100
commit538f097f97a5cbf350aecbdec4ed08f27693358c (patch)
tree55eeb81350f4a9f57b8349cad6d319f691786b42
parentMerge pull request #6054 from Morph1984/time-GetClockSnapshot (diff)
downloadyuzu-538f097f97a5cbf350aecbdec4ed08f27693358c.tar
yuzu-538f097f97a5cbf350aecbdec4ed08f27693358c.tar.gz
yuzu-538f097f97a5cbf350aecbdec4ed08f27693358c.tar.bz2
yuzu-538f097f97a5cbf350aecbdec4ed08f27693358c.tar.lz
yuzu-538f097f97a5cbf350aecbdec4ed08f27693358c.tar.xz
yuzu-538f097f97a5cbf350aecbdec4ed08f27693358c.tar.zst
yuzu-538f097f97a5cbf350aecbdec4ed08f27693358c.zip
-rw-r--r--src/video_core/renderer_opengl/gl_device.cpp14
1 files changed, 13 insertions, 1 deletions
diff --git a/src/video_core/renderer_opengl/gl_device.cpp b/src/video_core/renderer_opengl/gl_device.cpp
index 1ae5f1d62..ba59414a7 100644
--- a/src/video_core/renderer_opengl/gl_device.cpp
+++ b/src/video_core/renderer_opengl/gl_device.cpp
@@ -210,6 +210,12 @@ Device::Device() {
const bool is_amd = vendor == "ATI Technologies Inc.";
const bool is_intel = vendor == "Intel";
+#ifdef __linux__
+ const bool is_linux = true;
+#else
+ const bool is_linux = false;
+#endif
+
bool disable_fast_buffer_sub_data = false;
if (is_nvidia && version == "4.6.0 NVIDIA 443.24") {
LOG_WARNING(
@@ -249,7 +255,9 @@ Device::Device() {
GLAD_GL_NV_gpu_program5 && GLAD_GL_NV_compute_program5 &&
GLAD_GL_NV_transform_feedback && GLAD_GL_NV_transform_feedback2;
- use_asynchronous_shaders = Settings::values.use_asynchronous_shaders.GetValue();
+ // Blocks AMD and Intel OpenGL drivers on Windows from using asynchronous shader compilation.
+ use_asynchronous_shaders = Settings::values.use_asynchronous_shaders.GetValue() &&
+ !(is_amd || (is_intel && !is_linux));
use_driver_cache = is_nvidia;
LOG_INFO(Render_OpenGL, "Renderer_VariableAOFFI: {}", has_variable_aoffi);
@@ -261,6 +269,10 @@ Device::Device() {
if (Settings::values.use_assembly_shaders.GetValue() && !use_assembly_shaders) {
LOG_ERROR(Render_OpenGL, "Assembly shaders enabled but not supported");
}
+
+ if (Settings::values.use_asynchronous_shaders.GetValue() && !use_asynchronous_shaders) {
+ LOG_WARNING(Render_OpenGL, "Asynchronous shader compilation enabled but not supported");
+ }
}
Device::Device(std::nullptr_t) {