forked from eden-emu/eden
		
	shader: Move loop safety tests to code emission
This commit is contained in:
		
							parent
							
								
									e57f54e582
								
							
						
					
					
						commit
						04c1dca457
					
				
					 16 changed files with 54 additions and 108 deletions
				
			
		|  | @ -153,6 +153,8 @@ public: | |||
|     std::vector<TextureImageDefinition> images; | ||||
|     std::array<std::array<GenericElementInfo, 4>, 32> output_generics{}; | ||||
| 
 | ||||
|     u32 num_safety_loop_vars{}; | ||||
| 
 | ||||
|     bool uses_y_direction{}; | ||||
|     bool uses_cc_carry{}; | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,6 +6,7 @@ | |||
| #include <string> | ||||
| 
 | ||||
| #include "common/alignment.h" | ||||
| #include "common/settings.h" | ||||
| #include "shader_recompiler/backend/glsl/emit_context.h" | ||||
| #include "shader_recompiler/backend/glsl/emit_glsl.h" | ||||
| #include "shader_recompiler/backend/glsl/emit_glsl_instructions.h" | ||||
|  | @ -156,7 +157,12 @@ void EmitCode(EmitContext& ctx, const IR::Program& program) { | |||
|             ctx.Add("for(;;){{"); | ||||
|             break; | ||||
|         case IR::AbstractSyntaxNode::Type::Repeat: | ||||
|             ctx.Add("if(!{}){{break;}}}}", ctx.var_alloc.Consume(node.data.repeat.cond)); | ||||
|             if (Settings::values.disable_shader_loop_safety_checks) { | ||||
|                 ctx.Add("if(!{}){{break;}}}}", ctx.var_alloc.Consume(node.data.repeat.cond)); | ||||
|             } else { | ||||
|                 ctx.Add("if(--loop{}<0 || !{}){{break;}}}}", ctx.num_safety_loop_vars++, | ||||
|                         ctx.var_alloc.Consume(node.data.repeat.cond)); | ||||
|             } | ||||
|             break; | ||||
|         default: | ||||
|             throw NotImplementedException("AbstractSyntaxNode Type {}", node.type); | ||||
|  | @ -198,6 +204,9 @@ void DefineVariables(const EmitContext& ctx, std::string& header) { | |||
|                                   ctx.var_alloc.Representation(index, type), type_name); | ||||
|         } | ||||
|     } | ||||
|     for (u32 i = 0; i < ctx.num_safety_loop_vars; ++i) { | ||||
|         header += fmt::format("int loop{}=0x2000;", i); | ||||
|     } | ||||
| } | ||||
| } // Anonymous namespace
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -44,8 +44,6 @@ void EmitSetGotoVariable(EmitContext& ctx); | |||
| void EmitGetGotoVariable(EmitContext& ctx); | ||||
| void EmitSetIndirectBranchVariable(EmitContext& ctx); | ||||
| void EmitGetIndirectBranchVariable(EmitContext& ctx); | ||||
| void EmitSetLoopSafetyVariable(EmitContext& ctx); | ||||
| void EmitGetLoopSafetyVariable(EmitContext& ctx); | ||||
| void EmitGetCbufU8(EmitContext& ctx, IR::Inst& inst, const IR::Value& binding, | ||||
|                    const IR::Value& offset); | ||||
| void EmitGetCbufS8(EmitContext& ctx, IR::Inst& inst, const IR::Value& binding, | ||||
|  |  | |||
|  | @ -46,14 +46,6 @@ void EmitGetIndirectBranchVariable(EmitContext& ctx) { | |||
|     NotImplemented(); | ||||
| } | ||||
| 
 | ||||
| void EmitSetLoopSafetyVariable(EmitContext& ctx) { | ||||
|     NotImplemented(); | ||||
| } | ||||
| 
 | ||||
| void EmitGetLoopSafetyVariable(EmitContext& ctx) { | ||||
|     NotImplemented(); | ||||
| } | ||||
| 
 | ||||
| void EmitGetZFlag(EmitContext& ctx) { | ||||
|     NotImplemented(); | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 ReinUsesLisp
						ReinUsesLisp