Merge pull request #9972 from Pokechu22/validation-layer
Recompile shaders when 'Enable API Validation Layers' is toggled
This commit is contained in:
commit
0470be5884
|
@ -199,12 +199,12 @@ void AdvancedWidget::AddDescriptions()
|
||||||
"leave this unchecked.</dolphin_emphasis>");
|
"leave this unchecked.</dolphin_emphasis>");
|
||||||
static const char TR_TEXTURE_FORMAT_DESCRIPTION[] =
|
static const char TR_TEXTURE_FORMAT_DESCRIPTION[] =
|
||||||
QT_TR_NOOP("Modifies textures to show the format they're encoded in.<br><br>May require "
|
QT_TR_NOOP("Modifies textures to show the format they're encoded in.<br><br>May require "
|
||||||
"an emulation "
|
"an emulation reset to apply.<br><br><dolphin_emphasis>If unsure, leave this "
|
||||||
"reset to apply.<br><br><dolphin_emphasis>If unsure, leave this "
|
|
||||||
"unchecked.</dolphin_emphasis>");
|
"unchecked.</dolphin_emphasis>");
|
||||||
static const char TR_VALIDATION_LAYER_DESCRIPTION[] =
|
static const char TR_VALIDATION_LAYER_DESCRIPTION[] =
|
||||||
QT_TR_NOOP("Enables validation of API calls made by the video backend, which may assist in "
|
QT_TR_NOOP("Enables validation of API calls made by the video backend, which may assist in "
|
||||||
"debugging graphical issues.<br><br><dolphin_emphasis>If unsure, leave this "
|
"debugging graphical issues. On D3D backends, this also enables debug symbols "
|
||||||
|
"for the compiled shaders.<br><br><dolphin_emphasis>If unsure, leave this "
|
||||||
"unchecked.</dolphin_emphasis>");
|
"unchecked.</dolphin_emphasis>");
|
||||||
static const char TR_DUMP_TEXTURE_DESCRIPTION[] =
|
static const char TR_DUMP_TEXTURE_DESCRIPTION[] =
|
||||||
QT_TR_NOOP("Dumps decoded game textures based on the other flags to "
|
QT_TR_NOOP("Dumps decoded game textures based on the other flags to "
|
||||||
|
@ -213,9 +213,8 @@ void AdvancedWidget::AddDescriptions()
|
||||||
static const char TR_DUMP_MIP_TEXTURE_DESCRIPTION[] = QT_TR_NOOP(
|
static const char TR_DUMP_MIP_TEXTURE_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"Whether to dump mipmapped game textures to "
|
"Whether to dump mipmapped game textures to "
|
||||||
"User/Dump/Textures/<game_id>/. This includes arbitrary mipmapped textures if "
|
"User/Dump/Textures/<game_id>/. This includes arbitrary mipmapped textures if "
|
||||||
"'Arbitrary "
|
"'Arbitrary Mipmap Detection' is enabled in Enhancements.<br><br>"
|
||||||
"Mipmap Detection' is enabled in Enhancements.<br><br><dolphin_emphasis>If unsure, leave "
|
"<dolphin_emphasis>If unsure, leave this checked.</dolphin_emphasis>");
|
||||||
"this checked.</dolphin_emphasis>");
|
|
||||||
static const char TR_DUMP_BASE_TEXTURE_DESCRIPTION[] = QT_TR_NOOP(
|
static const char TR_DUMP_BASE_TEXTURE_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"Whether to dump base game textures to "
|
"Whether to dump base game textures to "
|
||||||
"User/Dump/Textures/<game_id>/. This includes arbitrary base textures if 'Arbitrary "
|
"User/Dump/Textures/<game_id>/. This includes arbitrary base textures if 'Arbitrary "
|
||||||
|
@ -224,31 +223,26 @@ void AdvancedWidget::AddDescriptions()
|
||||||
static const char TR_LOAD_CUSTOM_TEXTURE_DESCRIPTION[] =
|
static const char TR_LOAD_CUSTOM_TEXTURE_DESCRIPTION[] =
|
||||||
QT_TR_NOOP("Loads custom textures from User/Load/Textures/<game_id>/ and "
|
QT_TR_NOOP("Loads custom textures from User/Load/Textures/<game_id>/ and "
|
||||||
"User/Load/DynamicInputTextures/<game_id>/.<br><br><dolphin_emphasis>If "
|
"User/Load/DynamicInputTextures/<game_id>/.<br><br><dolphin_emphasis>If "
|
||||||
"unsure, leave this "
|
"unsure, leave this unchecked.</dolphin_emphasis>");
|
||||||
"unchecked.</dolphin_emphasis>");
|
|
||||||
static const char TR_CACHE_CUSTOM_TEXTURE_DESCRIPTION[] = QT_TR_NOOP(
|
static const char TR_CACHE_CUSTOM_TEXTURE_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"Caches custom textures to system RAM on startup.<br><br>This can require exponentially "
|
"Caches custom textures to system RAM on startup.<br><br>This can require exponentially "
|
||||||
"more RAM but fixes possible stuttering.<br><br><dolphin_emphasis>If unsure, leave this "
|
"more RAM but fixes possible stuttering.<br><br><dolphin_emphasis>If unsure, leave this "
|
||||||
"unchecked.</dolphin_emphasis>");
|
"unchecked.</dolphin_emphasis>");
|
||||||
static const char TR_DUMP_EFB_DESCRIPTION[] =
|
static const char TR_DUMP_EFB_DESCRIPTION[] =
|
||||||
QT_TR_NOOP("Dumps the contents of EFB copies to User/Dump/Textures/.<br><br "
|
QT_TR_NOOP("Dumps the contents of EFB copies to User/Dump/Textures/.<br><br>"
|
||||||
"/><dolphin_emphasis>If unsure, leave this "
|
"<dolphin_emphasis>If unsure, leave this unchecked.</dolphin_emphasis>");
|
||||||
"unchecked.</dolphin_emphasis>");
|
|
||||||
static const char TR_DUMP_XFB_DESCRIPTION[] =
|
static const char TR_DUMP_XFB_DESCRIPTION[] =
|
||||||
QT_TR_NOOP("Dumps the contents of XFB copies to User/Dump/Textures/.<br><br "
|
QT_TR_NOOP("Dumps the contents of XFB copies to User/Dump/Textures/.<br><br>"
|
||||||
"/><dolphin_emphasis>If unsure, leave this "
|
"<dolphin_emphasis>If unsure, leave this unchecked.</dolphin_emphasis>");
|
||||||
"unchecked.</dolphin_emphasis>");
|
|
||||||
static const char TR_DISABLE_VRAM_COPIES_DESCRIPTION[] =
|
static const char TR_DISABLE_VRAM_COPIES_DESCRIPTION[] =
|
||||||
QT_TR_NOOP("Disables the VRAM copy of the EFB, forcing a round-trip to RAM. Inhibits all "
|
QT_TR_NOOP("Disables the VRAM copy of the EFB, forcing a round-trip to RAM. Inhibits all "
|
||||||
"upscaling.<br><br><dolphin_emphasis>If unsure, leave this "
|
"upscaling.<br><br><dolphin_emphasis>If unsure, leave this "
|
||||||
"unchecked.</dolphin_emphasis>");
|
"unchecked.</dolphin_emphasis>");
|
||||||
static const char TR_INTERNAL_RESOLUTION_FRAME_DUMPING_DESCRIPTION[] = QT_TR_NOOP(
|
static const char TR_INTERNAL_RESOLUTION_FRAME_DUMPING_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"Creates frame dumps and screenshots at the internal resolution of the renderer, rather than "
|
"Creates frame dumps and screenshots at the internal resolution of the renderer, rather than "
|
||||||
"the size of the window it is displayed within.<br><br>If the aspect ratio is "
|
"the size of the window it is displayed within.<br><br>If the aspect ratio is widescreen, "
|
||||||
"widescreen, the "
|
"the output image will be scaled horizontally to preserve the vertical resolution.<br><br>"
|
||||||
"output image will be scaled horizontally to preserve the vertical resolution.<br><br "
|
"<dolphin_emphasis>If unsure, leave this unchecked.</dolphin_emphasis>");
|
||||||
"/><dolphin_emphasis>If "
|
|
||||||
"unsure, leave this unchecked.</dolphin_emphasis>");
|
|
||||||
#if defined(HAVE_FFMPEG)
|
#if defined(HAVE_FFMPEG)
|
||||||
static const char TR_USE_FFV1_DESCRIPTION[] =
|
static const char TR_USE_FFV1_DESCRIPTION[] =
|
||||||
QT_TR_NOOP("Encodes frame dumps using the FFV1 codec.<br><br><dolphin_emphasis>If "
|
QT_TR_NOOP("Encodes frame dumps using the FFV1 codec.<br><br><dolphin_emphasis>If "
|
||||||
|
@ -264,9 +258,8 @@ void AdvancedWidget::AddDescriptions()
|
||||||
static const char TR_BACKEND_MULTITHREADING_DESCRIPTION[] =
|
static const char TR_BACKEND_MULTITHREADING_DESCRIPTION[] =
|
||||||
QT_TR_NOOP("Enables multithreaded command submission in backends where supported. Enabling "
|
QT_TR_NOOP("Enables multithreaded command submission in backends where supported. Enabling "
|
||||||
"this option may result in a performance improvement on systems with more than "
|
"this option may result in a performance improvement on systems with more than "
|
||||||
"two CPU cores. Currently, this is limited to the Vulkan backend.<br><br "
|
"two CPU cores. Currently, this is limited to the Vulkan backend.<br><br>"
|
||||||
"/><dolphin_emphasis>If unsure, "
|
"<dolphin_emphasis>If unsure, leave this checked.</dolphin_emphasis>");
|
||||||
"leave this checked.</dolphin_emphasis>");
|
|
||||||
static const char TR_DEFER_EFB_ACCESS_INVALIDATION_DESCRIPTION[] = QT_TR_NOOP(
|
static const char TR_DEFER_EFB_ACCESS_INVALIDATION_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"Defers invalidation of the EFB access cache until a GPU synchronization command "
|
"Defers invalidation of the EFB access cache until a GPU synchronization command "
|
||||||
"is executed. If disabled, the cache will be invalidated with every draw call. "
|
"is executed. If disabled, the cache will be invalidated with every draw call. "
|
||||||
|
|
|
@ -35,7 +35,7 @@ ShaderCache::~ShaderCache()
|
||||||
bool ShaderCache::Initialize()
|
bool ShaderCache::Initialize()
|
||||||
{
|
{
|
||||||
m_api_type = g_ActiveConfig.backend_info.api_type;
|
m_api_type = g_ActiveConfig.backend_info.api_type;
|
||||||
m_host_config = ShaderHostConfig::GetCurrent();
|
m_host_config.bits = ShaderHostConfig::GetCurrent().bits;
|
||||||
|
|
||||||
if (!CompileSharedPipelines())
|
if (!CompileSharedPipelines())
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -53,7 +53,7 @@ public:
|
||||||
void InitializeShaderCache();
|
void InitializeShaderCache();
|
||||||
|
|
||||||
// Changes the shader host config. Shaders should be reloaded afterwards.
|
// Changes the shader host config. Shaders should be reloaded afterwards.
|
||||||
void SetHostConfig(const ShaderHostConfig& host_config) { m_host_config = host_config; }
|
void SetHostConfig(const ShaderHostConfig& host_config) { m_host_config.bits = host_config.bits; }
|
||||||
|
|
||||||
// Reloads/recreates all shaders and pipelines.
|
// Reloads/recreates all shaders and pipelines.
|
||||||
void Reload();
|
void Reload();
|
||||||
|
|
|
@ -38,6 +38,7 @@ ShaderHostConfig ShaderHostConfig::GetCurrent()
|
||||||
bits.backend_shader_framebuffer_fetch = g_ActiveConfig.backend_info.bSupportsFramebufferFetch;
|
bits.backend_shader_framebuffer_fetch = g_ActiveConfig.backend_info.bSupportsFramebufferFetch;
|
||||||
bits.backend_logic_op = g_ActiveConfig.backend_info.bSupportsLogicOp;
|
bits.backend_logic_op = g_ActiveConfig.backend_info.bSupportsLogicOp;
|
||||||
bits.backend_palette_conversion = g_ActiveConfig.backend_info.bSupportsPaletteConversion;
|
bits.backend_palette_conversion = g_ActiveConfig.backend_info.bSupportsPaletteConversion;
|
||||||
|
bits.enable_validation_layer = g_ActiveConfig.bEnableValidationLayer;
|
||||||
return bits;
|
return bits;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,6 +11,7 @@
|
||||||
|
|
||||||
#include <fmt/format.h>
|
#include <fmt/format.h>
|
||||||
|
|
||||||
|
#include "Common/BitField.h"
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
#include "Common/StringUtil.h"
|
#include "Common/StringUtil.h"
|
||||||
|
|
||||||
|
@ -143,33 +144,30 @@ union ShaderHostConfig
|
||||||
{
|
{
|
||||||
u32 bits;
|
u32 bits;
|
||||||
|
|
||||||
struct
|
BitField<0, 1, bool, u32> msaa;
|
||||||
{
|
BitField<1, 1, bool, u32> ssaa;
|
||||||
u32 msaa : 1;
|
BitField<2, 1, bool, u32> stereo;
|
||||||
u32 ssaa : 1;
|
BitField<3, 1, bool, u32> wireframe;
|
||||||
u32 stereo : 1;
|
BitField<4, 1, bool, u32> per_pixel_lighting;
|
||||||
u32 wireframe : 1;
|
BitField<5, 1, bool, u32> vertex_rounding;
|
||||||
u32 per_pixel_lighting : 1;
|
BitField<6, 1, bool, u32> fast_depth_calc;
|
||||||
u32 vertex_rounding : 1;
|
BitField<7, 1, bool, u32> bounding_box;
|
||||||
u32 fast_depth_calc : 1;
|
BitField<8, 1, bool, u32> backend_dual_source_blend;
|
||||||
u32 bounding_box : 1;
|
BitField<9, 1, bool, u32> backend_geometry_shaders;
|
||||||
u32 backend_dual_source_blend : 1;
|
BitField<10, 1, bool, u32> backend_early_z;
|
||||||
u32 backend_geometry_shaders : 1;
|
BitField<11, 1, bool, u32> backend_bbox;
|
||||||
u32 backend_early_z : 1;
|
BitField<12, 1, bool, u32> backend_gs_instancing;
|
||||||
u32 backend_bbox : 1;
|
BitField<13, 1, bool, u32> backend_clip_control;
|
||||||
u32 backend_gs_instancing : 1;
|
BitField<14, 1, bool, u32> backend_ssaa;
|
||||||
u32 backend_clip_control : 1;
|
BitField<15, 1, bool, u32> backend_atomics;
|
||||||
u32 backend_ssaa : 1;
|
BitField<16, 1, bool, u32> backend_depth_clamp;
|
||||||
u32 backend_atomics : 1;
|
BitField<17, 1, bool, u32> backend_reversed_depth_range;
|
||||||
u32 backend_depth_clamp : 1;
|
BitField<18, 1, bool, u32> backend_bitfield;
|
||||||
u32 backend_reversed_depth_range : 1;
|
BitField<19, 1, bool, u32> backend_dynamic_sampler_indexing;
|
||||||
u32 backend_bitfield : 1;
|
BitField<20, 1, bool, u32> backend_shader_framebuffer_fetch;
|
||||||
u32 backend_dynamic_sampler_indexing : 1;
|
BitField<21, 1, bool, u32> backend_logic_op;
|
||||||
u32 backend_shader_framebuffer_fetch : 1;
|
BitField<22, 1, bool, u32> backend_palette_conversion;
|
||||||
u32 backend_logic_op : 1;
|
BitField<23, 1, bool, u32> enable_validation_layer;
|
||||||
u32 backend_palette_conversion : 1;
|
|
||||||
u32 pad : 9;
|
|
||||||
};
|
|
||||||
|
|
||||||
static ShaderHostConfig GetCurrent();
|
static ShaderHostConfig GetCurrent();
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue