From afe707bc187b9bc6189f22001e6524a05d79a400 Mon Sep 17 00:00:00 2001 From: Jules Blok Date: Thu, 27 Oct 2016 21:59:12 +0200 Subject: [PATCH] DriverDetails: Disable dual-source blending on AMD OGL drivers. --- Source/Core/VideoBackends/OGL/Render.cpp | 5 +++-- Source/Core/VideoCommon/DriverDetails.cpp | 2 ++ Source/Core/VideoCommon/DriverDetails.h | 8 ++++++++ 3 files changed, 13 insertions(+), 2 deletions(-) diff --git a/Source/Core/VideoBackends/OGL/Render.cpp b/Source/Core/VideoBackends/OGL/Render.cpp index 3fa0cc1e66..f1e263d8db 100644 --- a/Source/Core/VideoBackends/OGL/Render.cpp +++ b/Source/Core/VideoBackends/OGL/Render.cpp @@ -444,8 +444,9 @@ Renderer::Renderer() g_Config.backend_info.AdapterName = g_ogl_config.gl_renderer; g_Config.backend_info.bSupportsDualSourceBlend = - GLExtensions::Supports("GL_ARB_blend_func_extended") || - GLExtensions::Supports("GL_EXT_blend_func_extended"); + (GLExtensions::Supports("GL_ARB_blend_func_extended") || + GLExtensions::Supports("GL_EXT_blend_func_extended")) && + !DriverDetails::HasBug(DriverDetails::BUG_BROKEN_DUAL_SOURCE_BLENDING); g_Config.backend_info.bSupportsPrimitiveRestart = !DriverDetails::HasBug(DriverDetails::BUG_PRIMITIVERESTART) && ((GLExtensions::Version() >= 310) || GLExtensions::Supports("GL_NV_primitive_restart")); diff --git a/Source/Core/VideoCommon/DriverDetails.cpp b/Source/Core/VideoCommon/DriverDetails.cpp index 645360d791..9e25a6565d 100644 --- a/Source/Core/VideoCommon/DriverDetails.cpp +++ b/Source/Core/VideoCommon/DriverDetails.cpp @@ -86,6 +86,8 @@ static BugInfo m_known_bugs[] = { -1.0, true}, {API_VULKAN, OS_ALL, VENDOR_ATI, DRIVER_ATI, Family::UNKNOWN, BUG_BROKEN_FRAGMENT_SHADER_INDEX_DECORATION, -1.0, -1.0, true}, + {API_OPENGL, OS_WINDOWS, VENDOR_ATI, DRIVER_ATI, Family::UNKNOWN, + BUG_BROKEN_DUAL_SOURCE_BLENDING, -1.0, -1.0, true}, }; static std::map m_bugs; diff --git a/Source/Core/VideoCommon/DriverDetails.h b/Source/Core/VideoCommon/DriverDetails.h index ebf38886be..de4a33c88d 100644 --- a/Source/Core/VideoCommon/DriverDetails.h +++ b/Source/Core/VideoCommon/DriverDetails.h @@ -230,6 +230,14 @@ enum Bug // the driver to fail to create graphics pipelines. The workaround for this is to specify the // index as a MRT location instead, or omit the binding completely. BUG_BROKEN_FRAGMENT_SHADER_INDEX_DECORATION, + + // Bug: Dual-source outputs from fragment shaders are broken on AMD OpenGL drivers + // Started Version: -1 + // Ended Version: -1 + // Fragment shaders that specify dual-source outputs, cause the driver to crash + // sometimes this happens in the kernel mode part of the driver resulting in a BSOD. + // Disable dual-source blending support for now. + BUG_BROKEN_DUAL_SOURCE_BLENDING, }; // Initializes our internal vendor, device family, and driver version