| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | // Copyright 2021 yuzu Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "shader_recompiler/backend/spirv/emit_spirv.h"
 | 
					
						
							|  |  |  | #include "shader_recompiler/frontend/ir/modifiers.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Shader::Backend::SPIRV { | 
					
						
							|  |  |  | namespace { | 
					
						
							|  |  |  | Id Decorate(EmitContext& ctx, IR::Inst* inst, Id op) { | 
					
						
							|  |  |  |     const auto flags{inst->Flags<IR::FpControl>()}; | 
					
						
							|  |  |  |     if (flags.no_contraction) { | 
					
						
							|  |  |  |         ctx.Decorate(op, spv::Decoration::NoContraction); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return op; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // Anonymous namespace
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-21 17:50:14 -03:00
										 |  |  | Id EmitFPAbs16(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpFAbs(ctx.F16[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-21 17:50:14 -03:00
										 |  |  | Id EmitFPAbs32(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpFAbs(ctx.F32[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-21 17:50:14 -03:00
										 |  |  | Id EmitFPAbs64(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpFAbs(ctx.F64[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | Id EmitFPAdd16(EmitContext& ctx, IR::Inst* inst, Id a, Id b) { | 
					
						
							| 
									
										
										
										
											2021-02-16 04:10:22 -03:00
										 |  |  |     return Decorate(ctx, inst, ctx.OpFAdd(ctx.F16[1], a, b)); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | Id EmitFPAdd32(EmitContext& ctx, IR::Inst* inst, Id a, Id b) { | 
					
						
							| 
									
										
										
										
											2021-02-16 04:10:22 -03:00
										 |  |  |     return Decorate(ctx, inst, ctx.OpFAdd(ctx.F32[1], a, b)); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | Id EmitFPAdd64(EmitContext& ctx, IR::Inst* inst, Id a, Id b) { | 
					
						
							| 
									
										
										
										
											2021-02-16 04:10:22 -03:00
										 |  |  |     return Decorate(ctx, inst, ctx.OpFAdd(ctx.F64[1], a, b)); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | Id EmitFPFma16(EmitContext& ctx, IR::Inst* inst, Id a, Id b, Id c) { | 
					
						
							| 
									
										
										
										
											2021-02-16 04:10:22 -03:00
										 |  |  |     return Decorate(ctx, inst, ctx.OpFma(ctx.F16[1], a, b, c)); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | Id EmitFPFma32(EmitContext& ctx, IR::Inst* inst, Id a, Id b, Id c) { | 
					
						
							| 
									
										
										
										
											2021-02-16 04:10:22 -03:00
										 |  |  |     return Decorate(ctx, inst, ctx.OpFma(ctx.F32[1], a, b, c)); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | Id EmitFPFma64(EmitContext& ctx, IR::Inst* inst, Id a, Id b, Id c) { | 
					
						
							| 
									
										
										
										
											2021-02-16 04:10:22 -03:00
										 |  |  |     return Decorate(ctx, inst, ctx.OpFma(ctx.F64[1], a, b, c)); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPMax32(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPMax64(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPMin32(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPMin64(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | Id EmitFPMul16(EmitContext& ctx, IR::Inst* inst, Id a, Id b) { | 
					
						
							| 
									
										
										
										
											2021-02-16 04:10:22 -03:00
										 |  |  |     return Decorate(ctx, inst, ctx.OpFMul(ctx.F16[1], a, b)); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | Id EmitFPMul32(EmitContext& ctx, IR::Inst* inst, Id a, Id b) { | 
					
						
							| 
									
										
										
										
											2021-02-16 04:10:22 -03:00
										 |  |  |     return Decorate(ctx, inst, ctx.OpFMul(ctx.F32[1], a, b)); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | Id EmitFPMul64(EmitContext& ctx, IR::Inst* inst, Id a, Id b) { | 
					
						
							| 
									
										
										
										
											2021-02-16 04:10:22 -03:00
										 |  |  |     return Decorate(ctx, inst, ctx.OpFMul(ctx.F64[1], a, b)); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-21 17:50:14 -03:00
										 |  |  | Id EmitFPNeg16(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpFNegate(ctx.F16[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-21 17:50:14 -03:00
										 |  |  | Id EmitFPNeg32(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpFNegate(ctx.F32[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-21 17:50:14 -03:00
										 |  |  | Id EmitFPNeg64(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpFNegate(ctx.F64[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPRecip32(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPRecip64(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPRecipSqrt32(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPRecipSqrt64(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPSqrt(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPSin(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPSinNotReduced(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPExp2(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPExp2NotReduced(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPCos(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPCosNotReduced(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-17 00:59:28 -03:00
										 |  |  | void EmitFPLog2(EmitContext&) { | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  |     throw NotImplementedException("SPIR-V Instruction"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-21 17:50:14 -03:00
										 |  |  | Id EmitFPSaturate16(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     const Id zero{ctx.Constant(ctx.F16[1], u16{0})}; | 
					
						
							|  |  |  |     const Id one{ctx.Constant(ctx.F16[1], u16{0x3c00})}; | 
					
						
							|  |  |  |     return ctx.OpFClamp(ctx.F32[1], value, zero, one); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-21 17:50:14 -03:00
										 |  |  | Id EmitFPSaturate32(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     const Id zero{ctx.Constant(ctx.F32[1], f32{0.0})}; | 
					
						
							|  |  |  |     const Id one{ctx.Constant(ctx.F32[1], f32{1.0})}; | 
					
						
							|  |  |  |     return ctx.OpFClamp(ctx.F32[1], value, zero, one); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-21 17:50:14 -03:00
										 |  |  | Id EmitFPSaturate64(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     const Id zero{ctx.Constant(ctx.F64[1], f64{0.0})}; | 
					
						
							|  |  |  |     const Id one{ctx.Constant(ctx.F64[1], f64{1.0})}; | 
					
						
							|  |  |  |     return ctx.OpFClamp(ctx.F64[1], value, zero, one); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 18:10:18 -03:00
										 |  |  | Id EmitFPRoundEven16(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpRoundEven(ctx.F16[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 18:10:18 -03:00
										 |  |  | Id EmitFPRoundEven32(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpRoundEven(ctx.F32[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 18:10:18 -03:00
										 |  |  | Id EmitFPRoundEven64(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpRoundEven(ctx.F64[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 18:10:18 -03:00
										 |  |  | Id EmitFPFloor16(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpFloor(ctx.F16[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 18:10:18 -03:00
										 |  |  | Id EmitFPFloor32(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpFloor(ctx.F32[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 18:10:18 -03:00
										 |  |  | Id EmitFPFloor64(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpFloor(ctx.F64[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 18:10:18 -03:00
										 |  |  | Id EmitFPCeil16(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpCeil(ctx.F16[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 18:10:18 -03:00
										 |  |  | Id EmitFPCeil32(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpCeil(ctx.F32[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 18:10:18 -03:00
										 |  |  | Id EmitFPCeil64(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpCeil(ctx.F64[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 18:10:18 -03:00
										 |  |  | Id EmitFPTrunc16(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpTrunc(ctx.F16[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 18:10:18 -03:00
										 |  |  | Id EmitFPTrunc32(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpTrunc(ctx.F32[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 18:10:18 -03:00
										 |  |  | Id EmitFPTrunc64(EmitContext& ctx, Id value) { | 
					
						
							|  |  |  |     return ctx.OpTrunc(ctx.F64[1], value); | 
					
						
							| 
									
										
										
										
											2021-02-08 02:54:35 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace Shader::Backend::SPIRV
 |