| 
									
										
										
										
											2022-04-23 04:59:50 -04:00
										 |  |  | // SPDX-FileCopyrightText: Copyright 2021 yuzu Emulator Project
 | 
					
						
							|  |  |  | // SPDX-License-Identifier: GPL-2.0-or-later
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | #include <cstring>
 | 
					
						
							|  |  |  | #include <type_traits>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | #include "shader_recompiler/frontend/ir/attribute.h"
 | 
					
						
							|  |  |  | #include "shader_recompiler/frontend/ir/basic_block.h"
 | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | #include "shader_recompiler/frontend/ir/modifiers.h"
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | #include "shader_recompiler/frontend/ir/value.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Shader::IR { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class IREmitter { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2021-02-11 16:39:06 -03:00
										 |  |  |     explicit IREmitter(Block& block_) : block{&block_}, insertion_point{block->end()} {} | 
					
						
							| 
									
										
										
										
											2021-02-05 05:58:02 -03:00
										 |  |  |     explicit IREmitter(Block& block_, Block::iterator insertion_point_) | 
					
						
							| 
									
										
										
										
											2021-02-11 16:39:06 -03:00
										 |  |  |         : block{&block_}, insertion_point{insertion_point_} {} | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-11 16:39:06 -03:00
										 |  |  |     Block* block; | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] U1 Imm1(bool value) const; | 
					
						
							|  |  |  |     [[nodiscard]] U8 Imm8(u8 value) const; | 
					
						
							|  |  |  |     [[nodiscard]] U16 Imm16(u16 value) const; | 
					
						
							|  |  |  |     [[nodiscard]] U32 Imm32(u32 value) const; | 
					
						
							|  |  |  |     [[nodiscard]] U32 Imm32(s32 value) const; | 
					
						
							| 
									
										
										
										
											2021-02-05 19:19:36 -03:00
										 |  |  |     [[nodiscard]] F32 Imm32(f32 value) const; | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  |     [[nodiscard]] U64 Imm64(u64 value) const; | 
					
						
							| 
									
										
										
										
											2021-03-20 05:04:12 -03:00
										 |  |  |     [[nodiscard]] U64 Imm64(s64 value) const; | 
					
						
							| 
									
										
										
										
											2021-02-05 19:19:36 -03:00
										 |  |  |     [[nodiscard]] F64 Imm64(f64 value) const; | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-18 02:04:22 -03:00
										 |  |  |     U1 ConditionRef(const U1& value); | 
					
						
							|  |  |  |     void Reference(const Value& value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-14 04:48:46 -03:00
										 |  |  |     void PhiMove(IR::Inst& phi, const Value& value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-24 01:33:45 -03:00
										 |  |  |     void Prologue(); | 
					
						
							|  |  |  |     void Epilogue(); | 
					
						
							| 
									
										
										
										
											2021-05-14 00:40:54 -03:00
										 |  |  |     void DemoteToHelperInvocation(); | 
					
						
							| 
									
										
										
										
											2021-04-12 03:48:15 -03:00
										 |  |  |     void EmitVertex(const U32& stream); | 
					
						
							|  |  |  |     void EndPrimitive(const U32& stream); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  |     [[nodiscard]] U32 GetReg(IR::Reg reg); | 
					
						
							|  |  |  |     void SetReg(IR::Reg reg, const U32& value); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] U1 GetPred(IR::Pred pred, bool is_negated = false); | 
					
						
							|  |  |  |     void SetPred(IR::Pred pred, const U1& value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-11 16:39:06 -03:00
										 |  |  |     [[nodiscard]] U1 GetGotoVariable(u32 id); | 
					
						
							|  |  |  |     void SetGotoVariable(u32 id, const U1& value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-27 22:30:24 +01:00
										 |  |  |     [[nodiscard]] U32 GetIndirectBranchVariable(); | 
					
						
							|  |  |  |     void SetIndirectBranchVariable(const U32& value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  |     [[nodiscard]] U32 GetCbuf(const U32& binding, const U32& byte_offset); | 
					
						
							| 
									
										
										
										
											2021-04-04 02:31:09 -03:00
										 |  |  |     [[nodiscard]] Value GetCbuf(const U32& binding, const U32& byte_offset, size_t bitsize, | 
					
						
							|  |  |  |                                 bool is_signed); | 
					
						
							| 
									
										
										
										
											2021-03-09 17:14:57 -03:00
										 |  |  |     [[nodiscard]] F32 GetFloatCbuf(const U32& binding, const U32& byte_offset); | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] U1 GetZFlag(); | 
					
						
							|  |  |  |     [[nodiscard]] U1 GetSFlag(); | 
					
						
							|  |  |  |     [[nodiscard]] U1 GetCFlag(); | 
					
						
							|  |  |  |     [[nodiscard]] U1 GetOFlag(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void SetZFlag(const U1& value); | 
					
						
							|  |  |  |     void SetSFlag(const U1& value); | 
					
						
							|  |  |  |     void SetCFlag(const U1& value); | 
					
						
							|  |  |  |     void SetOFlag(const U1& value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-11 16:39:06 -03:00
										 |  |  |     [[nodiscard]] U1 Condition(IR::Condition cond); | 
					
						
							| 
									
										
										
										
											2021-03-17 00:53:53 -04:00
										 |  |  |     [[nodiscard]] U1 GetFlowTestResult(FlowTest test); | 
					
						
							| 
									
										
										
										
											2021-02-11 16:39:06 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 19:19:36 -03:00
										 |  |  |     [[nodiscard]] F32 GetAttribute(IR::Attribute attribute); | 
					
						
							| 
									
										
										
										
											2021-04-12 19:41:22 -03:00
										 |  |  |     [[nodiscard]] F32 GetAttribute(IR::Attribute attribute, const U32& vertex); | 
					
						
							| 
									
										
										
										
											2022-11-09 17:58:10 +01:00
										 |  |  |     [[nodiscard]] U32 GetAttributeU32(IR::Attribute attribute); | 
					
						
							|  |  |  |     [[nodiscard]] U32 GetAttributeU32(IR::Attribute attribute, const U32& vertex); | 
					
						
							| 
									
										
										
										
											2021-04-12 19:41:22 -03:00
										 |  |  |     void SetAttribute(IR::Attribute attribute, const F32& value, const U32& vertex); | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-05 04:03:12 +02:00
										 |  |  |     [[nodiscard]] F32 GetAttributeIndexed(const U32& phys_address); | 
					
						
							| 
									
										
										
										
											2021-04-12 19:41:22 -03:00
										 |  |  |     [[nodiscard]] F32 GetAttributeIndexed(const U32& phys_address, const U32& vertex); | 
					
						
							|  |  |  |     void SetAttributeIndexed(const U32& phys_address, const F32& value, const U32& vertex); | 
					
						
							| 
									
										
										
										
											2021-04-04 06:47:14 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-15 22:46:11 -03:00
										 |  |  |     [[nodiscard]] F32 GetPatch(Patch patch); | 
					
						
							|  |  |  |     void SetPatch(Patch patch, const F32& value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-19 19:28:31 -03:00
										 |  |  |     void SetFragColor(u32 index, u32 component, const F32& value); | 
					
						
							| 
									
										
										
										
											2021-04-16 18:47:26 -03:00
										 |  |  |     void SetSampleMask(const U32& value); | 
					
						
							| 
									
										
										
										
											2021-03-19 19:28:31 -03:00
										 |  |  |     void SetFragDepth(const F32& value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  |     [[nodiscard]] U32 WorkgroupIdX(); | 
					
						
							|  |  |  |     [[nodiscard]] U32 WorkgroupIdY(); | 
					
						
							|  |  |  |     [[nodiscard]] U32 WorkgroupIdZ(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-23 04:28:34 -03:00
										 |  |  |     [[nodiscard]] Value LocalInvocationId(); | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  |     [[nodiscard]] U32 LocalInvocationIdX(); | 
					
						
							|  |  |  |     [[nodiscard]] U32 LocalInvocationIdY(); | 
					
						
							|  |  |  |     [[nodiscard]] U32 LocalInvocationIdZ(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-15 22:46:11 -03:00
										 |  |  |     [[nodiscard]] U32 InvocationId(); | 
					
						
							| 
									
										
										
										
											2022-10-30 19:59:11 +08:00
										 |  |  |     [[nodiscard]] U32 InvocationInfo(); | 
					
						
							| 
									
										
										
										
											2021-04-16 17:22:59 -03:00
										 |  |  |     [[nodiscard]] U32 SampleId(); | 
					
						
							| 
									
										
										
										
											2021-04-11 19:16:12 -03:00
										 |  |  |     [[nodiscard]] U1 IsHelperInvocation(); | 
					
						
							| 
									
										
										
										
											2021-04-16 23:52:58 +02:00
										 |  |  |     [[nodiscard]] F32 YDirection(); | 
					
						
							| 
									
										
										
										
											2021-04-11 19:16:12 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-21 22:24:33 -03:00
										 |  |  |     [[nodiscard]] F32 ResolutionDownFactor(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-01 22:05:11 +08:00
										 |  |  |     [[nodiscard]] F32 RenderAreaWidth(); | 
					
						
							|  |  |  |     [[nodiscard]] F32 RenderAreaHeight(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-02 23:05:47 +02:00
										 |  |  |     [[nodiscard]] U32 LaneId(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  |     [[nodiscard]] U32 LoadGlobalU8(const U64& address); | 
					
						
							|  |  |  |     [[nodiscard]] U32 LoadGlobalS8(const U64& address); | 
					
						
							|  |  |  |     [[nodiscard]] U32 LoadGlobalU16(const U64& address); | 
					
						
							|  |  |  |     [[nodiscard]] U32 LoadGlobalS16(const U64& address); | 
					
						
							|  |  |  |     [[nodiscard]] U32 LoadGlobal32(const U64& address); | 
					
						
							|  |  |  |     [[nodiscard]] Value LoadGlobal64(const U64& address); | 
					
						
							|  |  |  |     [[nodiscard]] Value LoadGlobal128(const U64& address); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  |     void WriteGlobalU8(const U64& address, const U32& value); | 
					
						
							|  |  |  |     void WriteGlobalS8(const U64& address, const U32& value); | 
					
						
							|  |  |  |     void WriteGlobalU16(const U64& address, const U32& value); | 
					
						
							|  |  |  |     void WriteGlobalS16(const U64& address, const U32& value); | 
					
						
							|  |  |  |     void WriteGlobal32(const U64& address, const U32& value); | 
					
						
							|  |  |  |     void WriteGlobal64(const U64& address, const IR::Value& vector); | 
					
						
							|  |  |  |     void WriteGlobal128(const U64& address, const IR::Value& vector); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-28 19:53:34 -03:00
										 |  |  |     [[nodiscard]] U32 LoadLocal(const U32& word_offset); | 
					
						
							|  |  |  |     void WriteLocal(const U32& word_offset, const U32& value); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] Value LoadShared(int bit_size, bool is_signed, const U32& offset); | 
					
						
							|  |  |  |     void WriteShared(int bit_size, const U32& offset, const Value& value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  |     [[nodiscard]] U1 GetZeroFromOp(const Value& op); | 
					
						
							|  |  |  |     [[nodiscard]] U1 GetSignFromOp(const Value& op); | 
					
						
							|  |  |  |     [[nodiscard]] U1 GetCarryFromOp(const Value& op); | 
					
						
							|  |  |  |     [[nodiscard]] U1 GetOverflowFromOp(const Value& op); | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  |     [[nodiscard]] U1 GetSparseFromOp(const Value& op); | 
					
						
							| 
									
										
										
										
											2021-03-25 11:31:37 -04:00
										 |  |  |     [[nodiscard]] U1 GetInBoundsFromOp(const Value& op); | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 19:19:36 -03:00
										 |  |  |     [[nodiscard]] Value CompositeConstruct(const Value& e1, const Value& e2); | 
					
						
							|  |  |  |     [[nodiscard]] Value CompositeConstruct(const Value& e1, const Value& e2, const Value& e3); | 
					
						
							|  |  |  |     [[nodiscard]] Value CompositeConstruct(const Value& e1, const Value& e2, const Value& e3, | 
					
						
							|  |  |  |                                            const Value& e4); | 
					
						
							|  |  |  |     [[nodiscard]] Value CompositeExtract(const Value& vector, size_t element); | 
					
						
							| 
									
										
										
										
											2021-03-03 03:07:19 -03:00
										 |  |  |     [[nodiscard]] Value CompositeInsert(const Value& vector, const Value& object, size_t element); | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-22 22:59:16 -03:00
										 |  |  |     [[nodiscard]] Value Select(const U1& condition, const Value& true_value, | 
					
						
							|  |  |  |                                const Value& false_value); | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-17 03:21:03 -03:00
										 |  |  |     void Barrier(); | 
					
						
							|  |  |  |     void WorkgroupMemoryBarrier(); | 
					
						
							|  |  |  |     void DeviceMemoryBarrier(); | 
					
						
							| 
									
										
										
										
											2021-04-02 19:27:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 19:19:36 -03:00
										 |  |  |     template <typename Dest, typename Source> | 
					
						
							|  |  |  |     [[nodiscard]] Dest BitCast(const Source& value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  |     [[nodiscard]] U64 PackUint2x32(const Value& vector); | 
					
						
							|  |  |  |     [[nodiscard]] Value UnpackUint2x32(const U64& value); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] U32 PackFloat2x16(const Value& vector); | 
					
						
							|  |  |  |     [[nodiscard]] Value UnpackFloat2x16(const U32& value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-15 04:54:43 -03:00
										 |  |  |     [[nodiscard]] U32 PackHalf2x16(const Value& vector); | 
					
						
							|  |  |  |     [[nodiscard]] Value UnpackHalf2x16(const U32& value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 19:19:36 -03:00
										 |  |  |     [[nodiscard]] F64 PackDouble2x32(const Value& vector); | 
					
						
							|  |  |  |     [[nodiscard]] Value UnpackDouble2x32(const F64& value); | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 19:19:36 -03:00
										 |  |  |     [[nodiscard]] F16F32F64 FPAdd(const F16F32F64& a, const F16F32F64& b, FpControl control = {}); | 
					
						
							|  |  |  |     [[nodiscard]] F16F32F64 FPMul(const F16F32F64& a, const F16F32F64& b, FpControl control = {}); | 
					
						
							|  |  |  |     [[nodiscard]] F16F32F64 FPFma(const F16F32F64& a, const F16F32F64& b, const F16F32F64& c, | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  |                                   FpControl control = {}); | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 19:19:36 -03:00
										 |  |  |     [[nodiscard]] F16F32F64 FPAbs(const F16F32F64& value); | 
					
						
							|  |  |  |     [[nodiscard]] F16F32F64 FPNeg(const F16F32F64& value); | 
					
						
							|  |  |  |     [[nodiscard]] F16F32F64 FPAbsNeg(const F16F32F64& value, bool abs, bool neg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-22 22:59:16 -03:00
										 |  |  |     [[nodiscard]] F32 FPCos(const F32& value); | 
					
						
							|  |  |  |     [[nodiscard]] F32 FPSin(const F32& value); | 
					
						
							|  |  |  |     [[nodiscard]] F32 FPExp2(const F32& value); | 
					
						
							| 
									
										
										
										
											2021-02-05 19:19:36 -03:00
										 |  |  |     [[nodiscard]] F32 FPLog2(const F32& value); | 
					
						
							|  |  |  |     [[nodiscard]] F32F64 FPRecip(const F32F64& value); | 
					
						
							|  |  |  |     [[nodiscard]] F32F64 FPRecipSqrt(const F32F64& value); | 
					
						
							|  |  |  |     [[nodiscard]] F32 FPSqrt(const F32& value); | 
					
						
							|  |  |  |     [[nodiscard]] F16F32F64 FPSaturate(const F16F32F64& value); | 
					
						
							| 
									
										
										
										
											2021-03-25 11:31:37 -04:00
										 |  |  |     [[nodiscard]] F16F32F64 FPClamp(const F16F32F64& value, const F16F32F64& min_value, | 
					
						
							|  |  |  |                                     const F16F32F64& max_value); | 
					
						
							| 
									
										
										
										
											2021-02-20 03:30:13 -03:00
										 |  |  |     [[nodiscard]] F16F32F64 FPRoundEven(const F16F32F64& value, FpControl control = {}); | 
					
						
							|  |  |  |     [[nodiscard]] F16F32F64 FPFloor(const F16F32F64& value, FpControl control = {}); | 
					
						
							|  |  |  |     [[nodiscard]] F16F32F64 FPCeil(const F16F32F64& value, FpControl control = {}); | 
					
						
							|  |  |  |     [[nodiscard]] F16F32F64 FPTrunc(const F16F32F64& value, FpControl control = {}); | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-10 22:42:17 -05:00
										 |  |  |     [[nodiscard]] U1 FPEqual(const F16F32F64& lhs, const F16F32F64& rhs, FpControl control = {}, | 
					
						
							|  |  |  |                              bool ordered = true); | 
					
						
							|  |  |  |     [[nodiscard]] U1 FPNotEqual(const F16F32F64& lhs, const F16F32F64& rhs, FpControl control = {}, | 
					
						
							|  |  |  |                                 bool ordered = true); | 
					
						
							|  |  |  |     [[nodiscard]] U1 FPLessThan(const F16F32F64& lhs, const F16F32F64& rhs, FpControl control = {}, | 
					
						
							|  |  |  |                                 bool ordered = true); | 
					
						
							|  |  |  |     [[nodiscard]] U1 FPGreaterThan(const F16F32F64& lhs, const F16F32F64& rhs, | 
					
						
							|  |  |  |                                    FpControl control = {}, bool ordered = true); | 
					
						
							| 
									
										
										
										
											2021-02-22 22:59:16 -03:00
										 |  |  |     [[nodiscard]] U1 FPLessThanEqual(const F16F32F64& lhs, const F16F32F64& rhs, | 
					
						
							| 
									
										
										
										
											2021-03-10 22:42:17 -05:00
										 |  |  |                                      FpControl control = {}, bool ordered = true); | 
					
						
							| 
									
										
										
										
											2021-02-22 22:59:16 -03:00
										 |  |  |     [[nodiscard]] U1 FPGreaterThanEqual(const F16F32F64& lhs, const F16F32F64& rhs, | 
					
						
							| 
									
										
										
										
											2021-03-10 22:42:17 -05:00
										 |  |  |                                         FpControl control = {}, bool ordered = true); | 
					
						
							| 
									
										
										
										
											2021-03-21 00:42:56 -03:00
										 |  |  |     [[nodiscard]] U1 FPIsNan(const F16F32F64& value); | 
					
						
							|  |  |  |     [[nodiscard]] U1 FPOrdered(const F16F32F64& lhs, const F16F32F64& rhs); | 
					
						
							|  |  |  |     [[nodiscard]] U1 FPUnordered(const F16F32F64& lhs, const F16F32F64& rhs); | 
					
						
							| 
									
										
										
										
											2021-03-14 01:23:56 -05:00
										 |  |  |     [[nodiscard]] F32F64 FPMax(const F32F64& lhs, const F32F64& rhs, FpControl control = {}); | 
					
						
							|  |  |  |     [[nodiscard]] F32F64 FPMin(const F32F64& lhs, const F32F64& rhs, FpControl control = {}); | 
					
						
							| 
									
										
										
										
											2021-02-22 22:59:16 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  |     [[nodiscard]] U32U64 IAdd(const U32U64& a, const U32U64& b); | 
					
						
							| 
									
										
										
										
											2021-02-05 05:58:02 -03:00
										 |  |  |     [[nodiscard]] U32U64 ISub(const U32U64& a, const U32U64& b); | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  |     [[nodiscard]] U32 IMul(const U32& a, const U32& b); | 
					
						
							| 
									
										
										
										
											2021-07-25 21:27:21 -03:00
										 |  |  |     [[nodiscard]] U32 IDiv(const U32& a, const U32& b, bool is_signed = false); | 
					
						
							| 
									
										
										
										
											2021-03-05 01:15:16 -05:00
										 |  |  |     [[nodiscard]] U32U64 INeg(const U32U64& value); | 
					
						
							| 
									
										
										
										
											2021-06-22 18:28:21 -03:00
										 |  |  |     [[nodiscard]] U32 IAbs(const U32& value); | 
					
						
							| 
									
										
										
										
											2021-03-07 14:48:03 -05:00
										 |  |  |     [[nodiscard]] U32U64 ShiftLeftLogical(const U32U64& base, const U32& shift); | 
					
						
							| 
									
										
										
										
											2021-03-05 01:15:16 -05:00
										 |  |  |     [[nodiscard]] U32U64 ShiftRightLogical(const U32U64& base, const U32& shift); | 
					
						
							| 
									
										
										
										
											2021-03-07 14:48:03 -05:00
										 |  |  |     [[nodiscard]] U32U64 ShiftRightArithmetic(const U32U64& base, const U32& shift); | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  |     [[nodiscard]] U32 BitwiseAnd(const U32& a, const U32& b); | 
					
						
							|  |  |  |     [[nodiscard]] U32 BitwiseOr(const U32& a, const U32& b); | 
					
						
							|  |  |  |     [[nodiscard]] U32 BitwiseXor(const U32& a, const U32& b); | 
					
						
							|  |  |  |     [[nodiscard]] U32 BitFieldInsert(const U32& base, const U32& insert, const U32& offset, | 
					
						
							|  |  |  |                                      const U32& count); | 
					
						
							|  |  |  |     [[nodiscard]] U32 BitFieldExtract(const U32& base, const U32& offset, const U32& count, | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  |                                       bool is_signed = false); | 
					
						
							| 
									
										
										
										
											2021-02-25 00:46:40 -05:00
										 |  |  |     [[nodiscard]] U32 BitReverse(const U32& value); | 
					
						
							| 
									
										
										
										
											2021-02-26 21:41:46 -05:00
										 |  |  |     [[nodiscard]] U32 BitCount(const U32& value); | 
					
						
							| 
									
										
										
										
											2021-03-01 15:58:16 -05:00
										 |  |  |     [[nodiscard]] U32 BitwiseNot(const U32& value); | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-01 15:58:16 -05:00
										 |  |  |     [[nodiscard]] U32 FindSMsb(const U32& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32 FindUMsb(const U32& value); | 
					
						
							| 
									
										
										
										
											2021-02-28 23:33:53 -05:00
										 |  |  |     [[nodiscard]] U32 SMin(const U32& a, const U32& b); | 
					
						
							|  |  |  |     [[nodiscard]] U32 UMin(const U32& a, const U32& b); | 
					
						
							| 
									
										
										
										
											2021-03-27 19:47:00 -04:00
										 |  |  |     [[nodiscard]] U32 IMin(const U32& a, const U32& b, bool is_signed); | 
					
						
							| 
									
										
										
										
											2021-02-28 23:33:53 -05:00
										 |  |  |     [[nodiscard]] U32 SMax(const U32& a, const U32& b); | 
					
						
							|  |  |  |     [[nodiscard]] U32 UMax(const U32& a, const U32& b); | 
					
						
							| 
									
										
										
										
											2021-03-27 19:47:00 -04:00
										 |  |  |     [[nodiscard]] U32 IMax(const U32& a, const U32& b, bool is_signed); | 
					
						
							| 
									
										
										
										
											2021-03-27 23:01:28 -04:00
										 |  |  |     [[nodiscard]] U32 SClamp(const U32& value, const U32& min, const U32& max); | 
					
						
							|  |  |  |     [[nodiscard]] U32 UClamp(const U32& value, const U32& min, const U32& max); | 
					
						
							| 
									
										
										
										
											2021-02-28 23:33:53 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  |     [[nodiscard]] U1 ILessThan(const U32& lhs, const U32& rhs, bool is_signed); | 
					
						
							| 
									
										
										
										
											2021-03-20 05:04:12 -03:00
										 |  |  |     [[nodiscard]] U1 IEqual(const U32U64& lhs, const U32U64& rhs); | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  |     [[nodiscard]] U1 ILessThanEqual(const U32& lhs, const U32& rhs, bool is_signed); | 
					
						
							|  |  |  |     [[nodiscard]] U1 IGreaterThan(const U32& lhs, const U32& rhs, bool is_signed); | 
					
						
							|  |  |  |     [[nodiscard]] U1 INotEqual(const U32& lhs, const U32& rhs); | 
					
						
							|  |  |  |     [[nodiscard]] U1 IGreaterThanEqual(const U32& lhs, const U32& rhs, bool is_signed); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-11 02:07:02 -04:00
										 |  |  |     [[nodiscard]] U32 SharedAtomicIAdd(const U32& pointer_offset, const U32& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SharedAtomicSMin(const U32& pointer_offset, const U32& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SharedAtomicUMin(const U32& pointer_offset, const U32& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SharedAtomicIMin(const U32& pointer_offset, const U32& value, bool is_signed); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SharedAtomicSMax(const U32& pointer_offset, const U32& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SharedAtomicUMax(const U32& pointer_offset, const U32& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SharedAtomicIMax(const U32& pointer_offset, const U32& value, bool is_signed); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SharedAtomicInc(const U32& pointer_offset, const U32& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SharedAtomicDec(const U32& pointer_offset, const U32& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SharedAtomicAnd(const U32& pointer_offset, const U32& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SharedAtomicOr(const U32& pointer_offset, const U32& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SharedAtomicXor(const U32& pointer_offset, const U32& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 SharedAtomicExchange(const U32& pointer_offset, const U32U64& value); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 GlobalAtomicIAdd(const U64& pointer_offset, const U32U64& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 GlobalAtomicSMin(const U64& pointer_offset, const U32U64& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 GlobalAtomicUMin(const U64& pointer_offset, const U32U64& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 GlobalAtomicIMin(const U64& pointer_offset, const U32U64& value, | 
					
						
							|  |  |  |                                           bool is_signed); | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 GlobalAtomicSMax(const U64& pointer_offset, const U32U64& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 GlobalAtomicUMax(const U64& pointer_offset, const U32U64& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 GlobalAtomicIMax(const U64& pointer_offset, const U32U64& value, | 
					
						
							|  |  |  |                                           bool is_signed); | 
					
						
							|  |  |  |     [[nodiscard]] U32 GlobalAtomicInc(const U64& pointer_offset, const U32& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32 GlobalAtomicDec(const U64& pointer_offset, const U32& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 GlobalAtomicAnd(const U64& pointer_offset, const U32U64& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 GlobalAtomicOr(const U64& pointer_offset, const U32U64& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 GlobalAtomicXor(const U64& pointer_offset, const U32U64& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 GlobalAtomicExchange(const U64& pointer_offset, const U32U64& value); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] F32 GlobalAtomicF32Add(const U64& pointer_offset, const Value& value, | 
					
						
							|  |  |  |                                          const FpControl control = {}); | 
					
						
							|  |  |  |     [[nodiscard]] Value GlobalAtomicF16x2Add(const U64& pointer_offset, const Value& value, | 
					
						
							|  |  |  |                                              const FpControl control = {}); | 
					
						
							|  |  |  |     [[nodiscard]] Value GlobalAtomicF16x2Min(const U64& pointer_offset, const Value& value, | 
					
						
							|  |  |  |                                              const FpControl control = {}); | 
					
						
							|  |  |  |     [[nodiscard]] Value GlobalAtomicF16x2Max(const U64& pointer_offset, const Value& value, | 
					
						
							|  |  |  |                                              const FpControl control = {}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  |     [[nodiscard]] U1 LogicalOr(const U1& a, const U1& b); | 
					
						
							|  |  |  |     [[nodiscard]] U1 LogicalAnd(const U1& a, const U1& b); | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  |     [[nodiscard]] U1 LogicalXor(const U1& a, const U1& b); | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  |     [[nodiscard]] U1 LogicalNot(const U1& value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 19:19:36 -03:00
										 |  |  |     [[nodiscard]] U32U64 ConvertFToS(size_t bitsize, const F16F32F64& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 ConvertFToU(size_t bitsize, const F16F32F64& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32U64 ConvertFToI(size_t bitsize, bool is_signed, const F16F32F64& value); | 
					
						
							| 
									
										
										
										
											2021-05-10 03:55:09 -03:00
										 |  |  |     [[nodiscard]] F16F32F64 ConvertSToF(size_t dest_bitsize, size_t src_bitsize, const Value& value, | 
					
						
							|  |  |  |                                         FpControl control = {}); | 
					
						
							|  |  |  |     [[nodiscard]] F16F32F64 ConvertUToF(size_t dest_bitsize, size_t src_bitsize, const Value& value, | 
					
						
							|  |  |  |                                         FpControl control = {}); | 
					
						
							| 
									
										
										
										
											2021-03-20 05:04:12 -03:00
										 |  |  |     [[nodiscard]] F16F32F64 ConvertIToF(size_t dest_bitsize, size_t src_bitsize, bool is_signed, | 
					
						
							| 
									
										
										
										
											2021-05-10 03:55:09 -03:00
										 |  |  |                                         const Value& value, FpControl control = {}); | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-03 03:07:19 -03:00
										 |  |  |     [[nodiscard]] U32U64 UConvert(size_t result_bitsize, const U32U64& value); | 
					
						
							| 
									
										
										
										
											2021-03-21 09:32:16 +01:00
										 |  |  |     [[nodiscard]] F16F32F64 FPConvert(size_t result_bitsize, const F16F32F64& value, | 
					
						
							|  |  |  |                                       FpControl control = {}); | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  |     [[nodiscard]] Value ImageSampleImplicitLod(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                                const F32& bias, const Value& offset, | 
					
						
							|  |  |  |                                                const F32& lod_clamp, TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageSampleExplicitLod(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                                const F32& lod, const Value& offset, | 
					
						
							| 
									
										
										
										
											2021-05-17 02:52:01 -03:00
										 |  |  |                                                TextureInstInfo info); | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  |     [[nodiscard]] F32 ImageSampleDrefImplicitLod(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                                  const F32& dref, const F32& bias, | 
					
						
							|  |  |  |                                                  const Value& offset, const F32& lod_clamp, | 
					
						
							|  |  |  |                                                  TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] F32 ImageSampleDrefExplicitLod(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                                  const F32& dref, const F32& lod, | 
					
						
							| 
									
										
										
										
											2021-05-17 02:52:01 -03:00
										 |  |  |                                                  const Value& offset, TextureInstInfo info); | 
					
						
							| 
									
										
										
										
											2022-08-10 10:10:32 +08:00
										 |  |  |     [[nodiscard]] Value ImageQueryDimension(const Value& handle, const IR::U32& lod, | 
					
						
							| 
									
										
										
										
											2023-01-28 16:09:58 -05:00
										 |  |  |                                             const IR::U1& skip_mips); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageQueryDimension(const Value& handle, const IR::U32& lod, | 
					
						
							|  |  |  |                                             const IR::U1& skip_mips, TextureInstInfo info); | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-28 21:25:08 +02:00
										 |  |  |     [[nodiscard]] Value ImageQueryLod(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                       TextureInstInfo info); | 
					
						
							| 
									
										
										
										
											2021-03-24 23:41:55 +01:00
										 |  |  |     [[nodiscard]] Value ImageGather(const Value& handle, const Value& coords, const Value& offset, | 
					
						
							|  |  |  |                                     const Value& offset2, TextureInstInfo info); | 
					
						
							| 
									
										
										
										
											2021-03-26 19:24:50 +01:00
										 |  |  |     [[nodiscard]] Value ImageGatherDref(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                         const Value& offset, const Value& offset2, const F32& dref, | 
					
						
							|  |  |  |                                         TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageFetch(const Value& handle, const Value& coords, const Value& offset, | 
					
						
							|  |  |  |                                    const U32& lod, const U32& multisampling, TextureInstInfo info); | 
					
						
							| 
									
										
										
										
											2021-03-29 02:00:43 +02:00
										 |  |  |     [[nodiscard]] Value ImageGradient(const Value& handle, const Value& coords, | 
					
						
							| 
									
										
										
										
											2023-11-18 07:39:47 -05:00
										 |  |  |                                       const Value& derivatives, const Value& offset, | 
					
						
							| 
									
										
										
										
											2021-03-29 02:00:43 +02:00
										 |  |  |                                       const F32& lod_clamp, TextureInstInfo info); | 
					
						
							| 
									
										
										
										
											2021-04-09 01:45:39 -03:00
										 |  |  |     [[nodiscard]] Value ImageRead(const Value& handle, const Value& coords, TextureInstInfo info); | 
					
						
							| 
									
										
										
										
											2021-07-26 04:11:13 -04:00
										 |  |  |     void ImageWrite(const Value& handle, const Value& coords, const Value& color, | 
					
						
							|  |  |  |                     TextureInstInfo info); | 
					
						
							| 
									
										
										
										
											2021-03-29 02:00:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-23 17:47:54 -04:00
										 |  |  |     [[nodiscard]] Value ImageAtomicIAdd(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                         const Value& value, TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageAtomicSMin(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                         const Value& value, TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageAtomicUMin(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                         const Value& value, TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageAtomicIMin(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                         const Value& value, bool is_signed, TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageAtomicSMax(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                         const Value& value, TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageAtomicUMax(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                         const Value& value, TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageAtomicIMax(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                         const Value& value, bool is_signed, TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageAtomicInc(const Value& handle, const Value& coords, const Value& value, | 
					
						
							|  |  |  |                                        TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageAtomicDec(const Value& handle, const Value& coords, const Value& value, | 
					
						
							|  |  |  |                                        TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageAtomicAnd(const Value& handle, const Value& coords, const Value& value, | 
					
						
							|  |  |  |                                        TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageAtomicOr(const Value& handle, const Value& coords, const Value& value, | 
					
						
							|  |  |  |                                       TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageAtomicXor(const Value& handle, const Value& coords, const Value& value, | 
					
						
							|  |  |  |                                        TextureInstInfo info); | 
					
						
							|  |  |  |     [[nodiscard]] Value ImageAtomicExchange(const Value& handle, const Value& coords, | 
					
						
							|  |  |  |                                             const Value& value, TextureInstInfo info); | 
					
						
							| 
									
										
										
										
											2021-07-25 22:04:53 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] U1 IsTextureScaled(const U32& index); | 
					
						
							| 
									
										
										
										
											2021-08-01 18:57:45 -03:00
										 |  |  |     [[nodiscard]] U1 IsImageScaled(const U32& index); | 
					
						
							| 
									
										
										
										
											2021-07-25 22:04:53 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-23 20:27:17 -04:00
										 |  |  |     [[nodiscard]] U1 VoteAll(const U1& value); | 
					
						
							|  |  |  |     [[nodiscard]] U1 VoteAny(const U1& value); | 
					
						
							|  |  |  |     [[nodiscard]] U1 VoteEqual(const U1& value); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SubgroupBallot(const U1& value); | 
					
						
							| 
									
										
										
										
											2021-04-04 05:17:17 -03:00
										 |  |  |     [[nodiscard]] U32 SubgroupEqMask(); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SubgroupLtMask(); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SubgroupLeMask(); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SubgroupGtMask(); | 
					
						
							|  |  |  |     [[nodiscard]] U32 SubgroupGeMask(); | 
					
						
							| 
									
										
										
										
											2021-03-25 11:31:37 -04:00
										 |  |  |     [[nodiscard]] U32 ShuffleIndex(const IR::U32& value, const IR::U32& index, const IR::U32& clamp, | 
					
						
							|  |  |  |                                    const IR::U32& seg_mask); | 
					
						
							|  |  |  |     [[nodiscard]] U32 ShuffleUp(const IR::U32& value, const IR::U32& index, const IR::U32& clamp, | 
					
						
							|  |  |  |                                 const IR::U32& seg_mask); | 
					
						
							|  |  |  |     [[nodiscard]] U32 ShuffleDown(const IR::U32& value, const IR::U32& index, const IR::U32& clamp, | 
					
						
							|  |  |  |                                   const IR::U32& seg_mask); | 
					
						
							|  |  |  |     [[nodiscard]] U32 ShuffleButterfly(const IR::U32& value, const IR::U32& index, | 
					
						
							|  |  |  |                                        const IR::U32& clamp, const IR::U32& seg_mask); | 
					
						
							| 
									
										
										
										
											2021-03-28 22:23:45 -04:00
										 |  |  |     [[nodiscard]] F32 FSwizzleAdd(const F32& a, const F32& b, const U32& swizzle, | 
					
						
							|  |  |  |                                   FpControl control = {}); | 
					
						
							| 
									
										
										
										
											2021-03-23 20:27:17 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-17 11:56:45 +02:00
										 |  |  |     [[nodiscard]] F32 DPdxFine(const F32& a); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] F32 DPdyFine(const F32& a); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-17 12:51:43 +02:00
										 |  |  |     [[nodiscard]] F32 DPdxCoarse(const F32& a); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     [[nodiscard]] F32 DPdyCoarse(const F32& a); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | private: | 
					
						
							|  |  |  |     IR::Block::iterator insertion_point; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     template <typename T = Value, typename... Args> | 
					
						
							|  |  |  |     T Inst(Opcode op, Args... args) { | 
					
						
							| 
									
										
										
										
											2021-02-11 16:39:06 -03:00
										 |  |  |         auto it{block->PrependNewInst(insertion_point, op, {Value{args}...})}; | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  |         return T{Value{&*it}}; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     template <typename T> | 
					
						
							| 
									
										
										
										
											2023-01-29 13:54:13 -07:00
										 |  |  |         requires(sizeof(T) <= sizeof(u32) && std::is_trivially_copyable_v<T>) | 
					
						
							|  |  |  |     struct Flags { | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  |         Flags() = default; | 
					
						
							|  |  |  |         Flags(T proxy_) : proxy{proxy_} {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         T proxy; | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     template <typename T = Value, typename FlagType, typename... Args> | 
					
						
							|  |  |  |     T Inst(Opcode op, Flags<FlagType> flags, Args... args) { | 
					
						
							| 
									
										
										
										
											2021-02-14 22:46:40 -03:00
										 |  |  |         u32 raw_flags{}; | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  |         std::memcpy(&raw_flags, &flags.proxy, sizeof(flags.proxy)); | 
					
						
							| 
									
										
										
										
											2021-02-11 16:39:06 -03:00
										 |  |  |         auto it{block->PrependNewInst(insertion_point, op, {Value{args}...}, raw_flags)}; | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  |         return T{Value{&*it}}; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace Shader::IR
 |