forked from eden-emu/eden
		
	opengl: Declare fragment outputs even if they are not used
Fixes Ori and the Blind Forest's menu on GLASM. For some reason (probably high level optimizations) it is not sanitized on SPIR-V for OpenGL. Vulkan is unaffected by this change.
This commit is contained in:
		
							parent
							
								
									a7e9756671
								
							
						
					
					
						commit
						916ca74324
					
				
					 6 changed files with 18 additions and 10 deletions
				
			
		|  | @ -117,13 +117,9 @@ EmitContext::EmitContext(IR::Program& program, Bindings& bindings, const Profile | |||
|                 index, index); | ||||
|         } | ||||
|     } | ||||
|     for (size_t index = 0; index < info.stores_frag_color.size(); ++index) { | ||||
|         if (!info.stores_frag_color[index]) { | ||||
|             continue; | ||||
|         } | ||||
|         if (index == 0) { | ||||
|             Add("OUTPUT frag_color0=result.color;"); | ||||
|         } else { | ||||
|     if (stage == Stage::Fragment) { | ||||
|         Add("OUTPUT frag_color0=result.color;"); | ||||
|         for (size_t index = 1; index < info.stores_frag_color.size(); ++index) { | ||||
|             Add("OUTPUT frag_color{}=result.color[{}];", index, index); | ||||
|         } | ||||
|     } | ||||
|  |  | |||
|  | @ -298,8 +298,7 @@ void SetupOptions(const IR::Program& program, const Profile& profile, | |||
|     if (stage == Stage::Fragment && runtime_info.force_early_z != 0) { | ||||
|         header += "OPTION NV_early_fragment_tests;"; | ||||
|     } | ||||
|     const auto non_zero_frag_colors{info.stores_frag_color | std::views::drop(1)}; | ||||
|     if (std::ranges::find(non_zero_frag_colors, true) != non_zero_frag_colors.end()) { | ||||
|     if (stage == Stage::Fragment) { | ||||
|         header += "OPTION ARB_draw_buffers;"; | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -1320,7 +1320,7 @@ void EmitContext::DefineOutputs(const IR::Program& program) { | |||
|         break; | ||||
|     case Stage::Fragment: | ||||
|         for (u32 index = 0; index < 8; ++index) { | ||||
|             if (!info.stores_frag_color[index]) { | ||||
|             if (!info.stores_frag_color[index] && !profile.need_declared_frag_colors) { | ||||
|                 continue; | ||||
|             } | ||||
|             frag_color[index] = DefineOutput(*this, F32[4], std::nullopt); | ||||
|  |  | |||
|  | @ -84,7 +84,11 @@ struct Profile { | |||
|     bool support_int64_atomics{}; | ||||
| 
 | ||||
|     bool warp_size_potentially_larger_than_guest{}; | ||||
| 
 | ||||
|     bool lower_left_origin_mode{}; | ||||
|     /// Fragment outputs have to be declared even if they are not written to avoid undefined values.
 | ||||
|     /// See Ori and the Blind Forest's main menu for reference.
 | ||||
|     bool need_declared_frag_colors{}; | ||||
| 
 | ||||
|     /// OpFClamp is broken and OpFMax + OpFMin should be used instead
 | ||||
|     bool has_broken_spirv_clamp{}; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 ReinUsesLisp
						ReinUsesLisp