summaryrefslogtreecommitdiff
path: root/src/shader_recompiler/frontend/maxwell/translate_program.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/shader_recompiler/frontend/maxwell/translate_program.cpp')
-rw-r--r--src/shader_recompiler/frontend/maxwell/translate_program.cpp8
1 files changed, 5 insertions, 3 deletions
diff --git a/src/shader_recompiler/frontend/maxwell/translate_program.cpp b/src/shader_recompiler/frontend/maxwell/translate_program.cpp
index e52170e3e..5250509c1 100644
--- a/src/shader_recompiler/frontend/maxwell/translate_program.cpp
+++ b/src/shader_recompiler/frontend/maxwell/translate_program.cpp
@@ -13,6 +13,7 @@
13#include "shader_recompiler/frontend/maxwell/structured_control_flow.h" 13#include "shader_recompiler/frontend/maxwell/structured_control_flow.h"
14#include "shader_recompiler/frontend/maxwell/translate/translate.h" 14#include "shader_recompiler/frontend/maxwell/translate/translate.h"
15#include "shader_recompiler/frontend/maxwell/translate_program.h" 15#include "shader_recompiler/frontend/maxwell/translate_program.h"
16#include "shader_recompiler/host_translate_info.h"
16#include "shader_recompiler/ir_opt/passes.h" 17#include "shader_recompiler/ir_opt/passes.h"
17 18
18namespace Shader::Maxwell { 19namespace Shader::Maxwell {
@@ -120,7 +121,7 @@ void AddNVNStorageBuffers(IR::Program& program) {
120} // Anonymous namespace 121} // Anonymous namespace
121 122
122IR::Program TranslateProgram(ObjectPool<IR::Inst>& inst_pool, ObjectPool<IR::Block>& block_pool, 123IR::Program TranslateProgram(ObjectPool<IR::Inst>& inst_pool, ObjectPool<IR::Block>& block_pool,
123 Environment& env, Flow::CFG& cfg) { 124 Environment& env, Flow::CFG& cfg, const HostTranslateInfo& host_info) {
124 IR::Program program; 125 IR::Program program;
125 program.syntax_list = BuildASL(inst_pool, block_pool, env, cfg); 126 program.syntax_list = BuildASL(inst_pool, block_pool, env, cfg);
126 program.blocks = GenerateBlocks(program.syntax_list); 127 program.blocks = GenerateBlocks(program.syntax_list);
@@ -150,8 +151,9 @@ IR::Program TranslateProgram(ObjectPool<IR::Inst>& inst_pool, ObjectPool<IR::Blo
150 RemoveUnreachableBlocks(program); 151 RemoveUnreachableBlocks(program);
151 152
152 // Replace instructions before the SSA rewrite 153 // Replace instructions before the SSA rewrite
153 Optimization::LowerFp16ToFp32(program); 154 if (!host_info.support_float16) {
154 155 Optimization::LowerFp16ToFp32(program);
156 }
155 Optimization::SsaRewritePass(program); 157 Optimization::SsaRewritePass(program);
156 158
157 Optimization::GlobalMemoryToStorageBufferPass(program); 159 Optimization::GlobalMemoryToStorageBufferPass(program);