forked from eden-emu/eden
		
	shader: Implement DMNMX, DSET, DSETP
This commit is contained in:
		
							parent
							
								
									1665e72c9e
								
							
						
					
					
						commit
						1a8e8498a4
					
				
					 16 changed files with 210 additions and 59 deletions
				
			
		|  | @ -152,24 +152,7 @@ void DefineEntryPoint(Environment& env, EmitContext& ctx, Id main) { | |||
| 
 | ||||
| void SetupDenormControl(const Profile& profile, const IR::Program& program, EmitContext& ctx, | ||||
|                         Id main_func) { | ||||
|     if (!profile.support_float_controls) { | ||||
|         return; | ||||
|     } | ||||
|     const Info& info{program.info}; | ||||
|     if (!info.uses_fp32_denorms_flush && !info.uses_fp32_denorms_preserve && | ||||
|         !info.uses_fp16_denorms_flush && !info.uses_fp16_denorms_preserve) { | ||||
|         return; | ||||
|     } | ||||
|     ctx.AddExtension("SPV_KHR_float_controls"); | ||||
| 
 | ||||
|     if (info.uses_fp16 && profile.support_fp16_signed_zero_nan_preserve) { | ||||
|         ctx.AddCapability(spv::Capability::SignedZeroInfNanPreserve); | ||||
|         ctx.AddExecutionMode(main_func, spv::ExecutionMode::SignedZeroInfNanPreserve, 16U); | ||||
|     } | ||||
|     if (profile.support_fp32_signed_zero_nan_preserve) { | ||||
|         ctx.AddCapability(spv::Capability::SignedZeroInfNanPreserve); | ||||
|         ctx.AddExecutionMode(main_func, spv::ExecutionMode::SignedZeroInfNanPreserve, 32U); | ||||
|     } | ||||
|     if (info.uses_fp32_denorms_flush && info.uses_fp32_denorms_preserve) { | ||||
|         // LOG_ERROR(HW_GPU, "Fp32 denorm flush and preserve on the same shader");
 | ||||
|     } else if (info.uses_fp32_denorms_flush) { | ||||
|  | @ -210,6 +193,22 @@ void SetupDenormControl(const Profile& profile, const IR::Program& program, Emit | |||
|     } | ||||
| } | ||||
| 
 | ||||
| void SetupSignedNanCapabilities(const Profile& profile, const IR::Program& program, | ||||
|                                 EmitContext& ctx, Id main_func) { | ||||
|     if (program.info.uses_fp16 && profile.support_fp16_signed_zero_nan_preserve) { | ||||
|         ctx.AddCapability(spv::Capability::SignedZeroInfNanPreserve); | ||||
|         ctx.AddExecutionMode(main_func, spv::ExecutionMode::SignedZeroInfNanPreserve, 16U); | ||||
|     } | ||||
|     if (profile.support_fp32_signed_zero_nan_preserve) { | ||||
|         ctx.AddCapability(spv::Capability::SignedZeroInfNanPreserve); | ||||
|         ctx.AddExecutionMode(main_func, spv::ExecutionMode::SignedZeroInfNanPreserve, 32U); | ||||
|     } | ||||
|     if (program.info.uses_fp64 && profile.support_fp64_signed_zero_nan_preserve) { | ||||
|         ctx.AddCapability(spv::Capability::SignedZeroInfNanPreserve); | ||||
|         ctx.AddExecutionMode(main_func, spv::ExecutionMode::SignedZeroInfNanPreserve, 64U); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void SetupCapabilities(const Profile& profile, const Info& info, EmitContext& ctx) { | ||||
|     if (info.uses_sampled_1d) { | ||||
|         ctx.AddCapability(spv::Capability::Sampled1D); | ||||
|  | @ -260,7 +259,11 @@ std::vector<u32> EmitSPIRV(const Profile& profile, Environment& env, IR::Program | |||
|     EmitContext ctx{profile, program, binding}; | ||||
|     const Id main{DefineMain(ctx, program)}; | ||||
|     DefineEntryPoint(env, ctx, main); | ||||
|     SetupDenormControl(profile, program, ctx, main); | ||||
|     if (profile.support_float_controls) { | ||||
|         ctx.AddExtension("SPV_KHR_float_controls"); | ||||
|         SetupDenormControl(profile, program, ctx, main); | ||||
|         SetupSignedNanCapabilities(profile, program, ctx, main); | ||||
|     } | ||||
|     SetupCapabilities(profile, program.info, ctx); | ||||
|     return ctx.Assemble(); | ||||
| } | ||||
|  |  | |||
|  | @ -136,6 +136,7 @@ Id EmitSelectU32(EmitContext& ctx, Id cond, Id true_value, Id false_value); | |||
| Id EmitSelectU64(EmitContext& ctx, Id cond, Id true_value, Id false_value); | ||||
| Id EmitSelectF16(EmitContext& ctx, Id cond, Id true_value, Id false_value); | ||||
| Id EmitSelectF32(EmitContext& ctx, Id cond, Id true_value, Id false_value); | ||||
| Id EmitSelectF64(EmitContext& ctx, Id cond, Id true_value, Id false_value); | ||||
| void EmitBitCastU16F16(EmitContext& ctx); | ||||
| Id EmitBitCastU32F32(EmitContext& ctx, Id value); | ||||
| void EmitBitCastU64F64(EmitContext& ctx); | ||||
|  |  | |||
|  | @ -35,4 +35,8 @@ Id EmitSelectF32(EmitContext& ctx, Id cond, Id true_value, Id false_value) { | |||
|     return ctx.OpSelect(ctx.F32[1], cond, true_value, false_value); | ||||
| } | ||||
| 
 | ||||
| Id EmitSelectF64(EmitContext& ctx, Id cond, Id true_value, Id false_value) { | ||||
|     return ctx.OpSelect(ctx.F64[1], cond, true_value, false_value); | ||||
| } | ||||
| 
 | ||||
| } // namespace Shader::Backend::SPIRV
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 ameerj
						ameerj