From c01d0cf5e40251dc47da7d108434d18851081ca7 Mon Sep 17 00:00:00 2001 From: Crementif <26669564+Crementif@users.noreply.github.com> Date: Wed, 19 Jun 2019 08:15:00 +0200 Subject: [PATCH] [BotW] Add AMD crash workaround Workaround made by Exzap, helped by darkemaste and some other folks --- .../15bc7edf9de2ed30_0000000000000000_vs.txt | 61 ++++++++++++++++ .../24838b84d15a1da1_0000000000000000_vs.txt | 72 +++++++++++++++++++ .../83a697d61a3b9202_0000000000000000_vs.txt | 61 ++++++++++++++++ .../BreathOfTheWild_AMD_ShaderCrash/rules.txt | 6 ++ 4 files changed, 200 insertions(+) create mode 100644 Workarounds/BreathOfTheWild_AMD_ShaderCrash/15bc7edf9de2ed30_0000000000000000_vs.txt create mode 100644 Workarounds/BreathOfTheWild_AMD_ShaderCrash/24838b84d15a1da1_0000000000000000_vs.txt create mode 100644 Workarounds/BreathOfTheWild_AMD_ShaderCrash/83a697d61a3b9202_0000000000000000_vs.txt create mode 100644 Workarounds/BreathOfTheWild_AMD_ShaderCrash/rules.txt diff --git a/Workarounds/BreathOfTheWild_AMD_ShaderCrash/15bc7edf9de2ed30_0000000000000000_vs.txt b/Workarounds/BreathOfTheWild_AMD_ShaderCrash/15bc7edf9de2ed30_0000000000000000_vs.txt new file mode 100644 index 00000000..22770bc8 --- /dev/null +++ b/Workarounds/BreathOfTheWild_AMD_ShaderCrash/15bc7edf9de2ed30_0000000000000000_vs.txt @@ -0,0 +1,61 @@ +#version 420 +#extension GL_ARB_texture_gather : enable +#extension GL_ARB_separate_shader_objects : enable +#extension GL_ARB_shading_language_packing : enable +// shader 15bc7edf9de2ed30 +layout(binding = 6, std140) +uniform uniformBlockVS6 +{ +vec4 uf_blockVS6[1024]; +}; + + +layout(binding = 7, std140) +uniform uniformBlockVS7 +{ +vec4 uf_blockVS7[1024]; +}; + + +layout(binding = 8, std140) +uniform uniformBlockVS8 +{ +vec4 uf_blockVS8[1024]; +}; + + +layout(binding = 11, std140) +uniform uniformBlockVS11 +{ +vec4 uf_blockVS11[1024]; +}; + + +layout(binding = 45) uniform sampler2D textureUnitVS13; +layout(location = 0) in uvec4 attrDataSem0; +layout(location = 1) in uvec4 attrDataSem1; +layout(location = 2) in uvec4 attrDataSem2; +layout(location = 3) in uvec4 attrDataSem3; +layout(location = 4) in uvec4 attrDataSem4; +layout(location = 5) in uvec4 attrDataSem5; +layout(location = 6) in uvec4 attrDataSem6; +layout(location = 7) in uvec4 attrDataSem7; +out gl_PerVertex +{ + vec4 gl_Position; + float gl_PointSize; +}; +int clampFI32(int v) +{ +if( v == 0x7FFFFFFF ) + return floatBitsToInt(1.0); +else if( v == 0xFFFFFFFF ) + return floatBitsToInt(0.0); +return floatBitsToInt(clamp(intBitsToFloat(v), 0.0, 1.0)); +} +float mul_nonIEEE(float a, float b){ return min(a*b,min(abs(a)*3.40282347E+38F,abs(b)*3.40282347E+38F)); } +void main() +{ +// export +gl_Position = vec4(0.0); +} diff --git a/Workarounds/BreathOfTheWild_AMD_ShaderCrash/24838b84d15a1da1_0000000000000000_vs.txt b/Workarounds/BreathOfTheWild_AMD_ShaderCrash/24838b84d15a1da1_0000000000000000_vs.txt new file mode 100644 index 00000000..f64ec631 --- /dev/null +++ b/Workarounds/BreathOfTheWild_AMD_ShaderCrash/24838b84d15a1da1_0000000000000000_vs.txt @@ -0,0 +1,72 @@ +#version 420 +#extension GL_ARB_texture_gather : enable +#extension GL_ARB_separate_shader_objects : enable +#extension GL_ARB_shading_language_packing : enable +// shader 24838b84d15a1da1 +layout(binding = 6, std140) +uniform uniformBlockVS6 +{ +vec4 uf_blockVS6[1024]; +}; + + +layout(binding = 7, std140) +uniform uniformBlockVS7 +{ +vec4 uf_blockVS7[1024]; +}; + + +layout(binding = 8, std140) +uniform uniformBlockVS8 +{ +vec4 uf_blockVS8[1024]; +}; + + +layout(binding = 11, std140) +uniform uniformBlockVS11 +{ +vec4 uf_blockVS11[1024]; +}; + + +layout(binding = 13, std140) +uniform uniformBlockVS13 +{ +vec4 uf_blockVS13[1024]; +}; + + +layout(binding = 40) uniform sampler2D textureUnitVS8; +layout(binding = 45) uniform sampler2D textureUnitVS13; +layout(location = 0) in uvec4 attrDataSem0; +layout(location = 1) in uvec4 attrDataSem1; +layout(location = 2) in uvec4 attrDataSem2; +layout(location = 3) in uvec4 attrDataSem3; +layout(location = 4) in uvec4 attrDataSem4; +layout(location = 5) in uvec4 attrDataSem5; +layout(location = 6) in uvec4 attrDataSem6; +layout(location = 7) in uvec4 attrDataSem7; +layout(location = 8) in uvec4 attrDataSem8; +layout(location = 9) in uvec4 attrDataSem9; +layout(location = 10) in uvec4 attrDataSem10; +out gl_PerVertex +{ + vec4 gl_Position; + float gl_PointSize; +}; +int clampFI32(int v) +{ +if( v == 0x7FFFFFFF ) + return floatBitsToInt(1.0); +else if( v == 0xFFFFFFFF ) + return floatBitsToInt(0.0); +return floatBitsToInt(clamp(intBitsToFloat(v), 0.0, 1.0)); +} +float mul_nonIEEE(float a, float b){ return min(a*b,min(abs(a)*3.40282347E+38F,abs(b)*3.40282347E+38F)); } +void main() +{ +// export +gl_Position = vec4(0.0); +} diff --git a/Workarounds/BreathOfTheWild_AMD_ShaderCrash/83a697d61a3b9202_0000000000000000_vs.txt b/Workarounds/BreathOfTheWild_AMD_ShaderCrash/83a697d61a3b9202_0000000000000000_vs.txt new file mode 100644 index 00000000..bcb568e3 --- /dev/null +++ b/Workarounds/BreathOfTheWild_AMD_ShaderCrash/83a697d61a3b9202_0000000000000000_vs.txt @@ -0,0 +1,61 @@ +#version 420 +#extension GL_ARB_texture_gather : enable +#extension GL_ARB_separate_shader_objects : enable +#extension GL_ARB_shading_language_packing : enable +// shader 83a697d61a3b9202 +layout(binding = 6, std140) +uniform uniformBlockVS6 +{ +vec4 uf_blockVS6[1024]; +}; + + +layout(binding = 7, std140) +uniform uniformBlockVS7 +{ +vec4 uf_blockVS7[1024]; +}; + + +layout(binding = 8, std140) +uniform uniformBlockVS8 +{ +vec4 uf_blockVS8[1024]; +}; + + +layout(binding = 11, std140) +uniform uniformBlockVS11 +{ +vec4 uf_blockVS11[1024]; +}; + + +layout(binding = 45) uniform sampler2D textureUnitVS13; +layout(location = 0) in uvec4 attrDataSem0; +layout(location = 1) in uvec4 attrDataSem1; +layout(location = 2) in uvec4 attrDataSem2; +layout(location = 3) in uvec4 attrDataSem3; +layout(location = 4) in uvec4 attrDataSem4; +layout(location = 5) in uvec4 attrDataSem5; +layout(location = 6) in uvec4 attrDataSem6; +layout(location = 7) in uvec4 attrDataSem7; +out gl_PerVertex +{ + vec4 gl_Position; + float gl_PointSize; +}; +int clampFI32(int v) +{ +if( v == 0x7FFFFFFF ) + return floatBitsToInt(1.0); +else if( v == 0xFFFFFFFF ) + return floatBitsToInt(0.0); +return floatBitsToInt(clamp(intBitsToFloat(v), 0.0, 1.0)); +} +float mul_nonIEEE(float a, float b){ return min(a*b,min(abs(a)*3.40282347E+38F,abs(b)*3.40282347E+38F)); } +void main() +{ +// export +gl_Position = vec4(0.0); +} diff --git a/Workarounds/BreathOfTheWild_AMD_ShaderCrash/rules.txt b/Workarounds/BreathOfTheWild_AMD_ShaderCrash/rules.txt new file mode 100644 index 00000000..ba7f6685 --- /dev/null +++ b/Workarounds/BreathOfTheWild_AMD_ShaderCrash/rules.txt @@ -0,0 +1,6 @@ +[Definition] +titleIds = 00050000101C9300,00050000101C9400,00050000101C9500 +name = "Workaround for AMD crashes" +path = "The Legend of Zelda: Breath of the Wild/Workarounds/GPU specific workarounds/AMD Crash" +description = Workaround for a shader related crash on AMD drivers. Required for Cemu 1.15.8 and above. +version = 3 \ No newline at end of file