| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | // Copyright 2021 yuzu Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | //     opcode name,                                         return type,    arg1 type,      arg2 type,      arg3 type,      arg4 type,      arg4 type,      ...
 | 
					
						
							|  |  |  | OPCODE(Phi,                                                 Opaque,                                                                                         ) | 
					
						
							|  |  |  | OPCODE(Identity,                                            Opaque,         Opaque,                                                                         ) | 
					
						
							|  |  |  | OPCODE(Void,                                                Void,                                                                                           ) | 
					
						
							| 
									
										
										
										
											2021-05-18 02:04:22 -03:00
										 |  |  | OPCODE(ConditionRef,                                        U1,             U1,                                                                             ) | 
					
						
							|  |  |  | OPCODE(Reference,                                           Void,           Opaque,                                                                         ) | 
					
						
							| 
									
										
										
										
											2021-05-14 04:48:46 -03:00
										 |  |  | OPCODE(PhiMove,                                             Void,           Opaque,         Opaque,                                                         ) | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-14 00:40:54 -03:00
										 |  |  | // Special operations
 | 
					
						
							|  |  |  | OPCODE(Prologue,                                            Void,                                                                                           ) | 
					
						
							|  |  |  | OPCODE(Epilogue,                                            Void,                                                                                           ) | 
					
						
							| 
									
										
										
										
											2021-04-19 01:03:38 +02:00
										 |  |  | OPCODE(Join,                                                Void,                                                                                           ) | 
					
						
							| 
									
										
										
										
											2021-05-14 00:40:54 -03:00
										 |  |  | OPCODE(DemoteToHelperInvocation,                            Void,                                                                                           ) | 
					
						
							|  |  |  | OPCODE(EmitVertex,                                          Void,           U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(EndPrimitive,                                        Void,           U32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-24 01:33:45 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-02 19:27:30 +02:00
										 |  |  | // Barriers
 | 
					
						
							| 
									
										
										
										
											2021-04-04 03:04:48 -03:00
										 |  |  | OPCODE(Barrier,                                             Void,                                                                                           ) | 
					
						
							| 
									
										
										
										
											2021-04-17 03:21:03 -03:00
										 |  |  | OPCODE(WorkgroupMemoryBarrier,                              Void,                                                                                           ) | 
					
						
							|  |  |  | OPCODE(DeviceMemoryBarrier,                                 Void,                                                                                           ) | 
					
						
							| 
									
										
										
										
											2021-04-02 19:27:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | // Context getters/setters
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(GetRegister,                                         U32,            Reg,                                                                            ) | 
					
						
							|  |  |  | OPCODE(SetRegister,                                         Void,           Reg,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GetPred,                                             U1,             Pred,                                                                           ) | 
					
						
							|  |  |  | OPCODE(SetPred,                                             Void,           Pred,           U1,                                                             ) | 
					
						
							|  |  |  | OPCODE(GetGotoVariable,                                     U1,             U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(SetGotoVariable,                                     Void,           U32,            U1,                                                             ) | 
					
						
							| 
									
										
										
										
											2021-03-27 22:30:24 +01:00
										 |  |  | OPCODE(GetIndirectBranchVariable,                           U32,                                                                                            ) | 
					
						
							|  |  |  | OPCODE(SetIndirectBranchVariable,                           Void,           U32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-09 17:14:57 -03:00
										 |  |  | OPCODE(GetCbufU8,                                           U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GetCbufS8,                                           U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GetCbufU16,                                          U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GetCbufS16,                                          U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GetCbufU32,                                          U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GetCbufF32,                                          F32,            U32,            U32,                                                            ) | 
					
						
							| 
									
										
										
										
											2021-04-04 02:31:09 -03:00
										 |  |  | OPCODE(GetCbufU32x2,                                        U32x2,          U32,            U32,                                                            ) | 
					
						
							| 
									
										
										
										
											2021-04-12 19:41:22 -03:00
										 |  |  | OPCODE(GetAttribute,                                        F32,            Attribute,      U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SetAttribute,                                        Void,           Attribute,      F32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(GetAttributeIndexed,                                 F32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SetAttributeIndexed,                                 Void,           U32,            F32,            U32,                                            ) | 
					
						
							| 
									
										
										
										
											2021-04-15 22:46:11 -03:00
										 |  |  | OPCODE(GetPatch,                                            F32,            Patch,                                                                          ) | 
					
						
							|  |  |  | OPCODE(SetPatch,                                            Void,           Patch,          F32,                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-19 19:28:31 -03:00
										 |  |  | OPCODE(SetFragColor,                                        Void,           U32,            U32,            F32,                                            ) | 
					
						
							| 
									
										
										
										
											2021-04-16 18:47:26 -03:00
										 |  |  | OPCODE(SetSampleMask,                                       Void,           U32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-19 19:28:31 -03:00
										 |  |  | OPCODE(SetFragDepth,                                        Void,           F32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(GetZFlag,                                            U1,             Void,                                                                           ) | 
					
						
							|  |  |  | OPCODE(GetSFlag,                                            U1,             Void,                                                                           ) | 
					
						
							|  |  |  | OPCODE(GetCFlag,                                            U1,             Void,                                                                           ) | 
					
						
							|  |  |  | OPCODE(GetOFlag,                                            U1,             Void,                                                                           ) | 
					
						
							|  |  |  | OPCODE(SetZFlag,                                            Void,           U1,                                                                             ) | 
					
						
							|  |  |  | OPCODE(SetSFlag,                                            Void,           U1,                                                                             ) | 
					
						
							|  |  |  | OPCODE(SetCFlag,                                            Void,           U1,                                                                             ) | 
					
						
							|  |  |  | OPCODE(SetOFlag,                                            Void,           U1,                                                                             ) | 
					
						
							|  |  |  | OPCODE(WorkgroupId,                                         U32x3,                                                                                          ) | 
					
						
							|  |  |  | OPCODE(LocalInvocationId,                                   U32x3,                                                                                          ) | 
					
						
							| 
									
										
										
										
											2021-04-15 22:46:11 -03:00
										 |  |  | OPCODE(InvocationId,                                        U32,                                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-04-16 17:22:59 -03:00
										 |  |  | OPCODE(SampleId,                                            U32,                                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-04-11 19:16:12 -03:00
										 |  |  | OPCODE(IsHelperInvocation,                                  U1,                                                                                             ) | 
					
						
							| 
									
										
										
										
											2021-04-16 23:52:58 +02:00
										 |  |  | OPCODE(YDirection,                                          F32,                                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-07-21 22:24:33 -03:00
										 |  |  | OPCODE(ResolutionDownFactor,                                F32,                                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-02 21:07:00 -03:00
										 |  |  | // Undefined
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(UndefU1,                                             U1,                                                                                             ) | 
					
						
							|  |  |  | OPCODE(UndefU8,                                             U8,                                                                                             ) | 
					
						
							|  |  |  | OPCODE(UndefU16,                                            U16,                                                                                            ) | 
					
						
							|  |  |  | OPCODE(UndefU32,                                            U32,                                                                                            ) | 
					
						
							|  |  |  | OPCODE(UndefU64,                                            U64,                                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-02-02 21:07:00 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | // Memory operations
 | 
					
						
							| 
									
										
										
										
											2021-07-04 00:34:53 -04:00
										 |  |  | OPCODE(LoadGlobalU8,                                        U32,            Opaque,                                                                         ) | 
					
						
							|  |  |  | OPCODE(LoadGlobalS8,                                        U32,            Opaque,                                                                         ) | 
					
						
							|  |  |  | OPCODE(LoadGlobalU16,                                       U32,            Opaque,                                                                         ) | 
					
						
							|  |  |  | OPCODE(LoadGlobalS16,                                       U32,            Opaque,                                                                         ) | 
					
						
							|  |  |  | OPCODE(LoadGlobal32,                                        U32,            Opaque,                                                                         ) | 
					
						
							|  |  |  | OPCODE(LoadGlobal64,                                        U32x2,          Opaque,                                                                         ) | 
					
						
							|  |  |  | OPCODE(LoadGlobal128,                                       U32x4,          Opaque,                                                                         ) | 
					
						
							|  |  |  | OPCODE(WriteGlobalU8,                                       Void,           Opaque,         U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(WriteGlobalS8,                                       Void,           Opaque,         U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(WriteGlobalU16,                                      Void,           Opaque,         U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(WriteGlobalS16,                                      Void,           Opaque,         U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(WriteGlobal32,                                       Void,           Opaque,         U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(WriteGlobal64,                                       Void,           Opaque,         U32x2,                                                          ) | 
					
						
							|  |  |  | OPCODE(WriteGlobal128,                                      Void,           Opaque,         U32x4,                                                          ) | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-05 05:58:02 -03:00
										 |  |  | // Storage buffer operations
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(LoadStorageU8,                                       U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(LoadStorageS8,                                       U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(LoadStorageU16,                                      U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(LoadStorageS16,                                      U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(LoadStorage32,                                       U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(LoadStorage64,                                       U32x2,          U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(LoadStorage128,                                      U32x4,          U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(WriteStorageU8,                                      Void,           U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(WriteStorageS8,                                      Void,           U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(WriteStorageU16,                                     Void,           U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(WriteStorageS16,                                     Void,           U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(WriteStorage32,                                      Void,           U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(WriteStorage64,                                      Void,           U32,            U32,            U32x2,                                          ) | 
					
						
							|  |  |  | OPCODE(WriteStorage128,                                     Void,           U32,            U32,            U32x4,                                          ) | 
					
						
							| 
									
										
										
										
											2021-02-05 05:58:02 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-28 19:53:34 -03:00
										 |  |  | // Local memory operations
 | 
					
						
							|  |  |  | OPCODE(LoadLocal,                                           U32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(WriteLocal,                                          Void,           U32,            U32,                                                            ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Shared memory operations
 | 
					
						
							|  |  |  | OPCODE(LoadSharedU8,                                        U32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(LoadSharedS8,                                        U32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(LoadSharedU16,                                       U32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(LoadSharedS16,                                       U32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(LoadSharedU32,                                       U32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(LoadSharedU64,                                       U32x2,          U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(LoadSharedU128,                                      U32x4,          U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(WriteSharedU8,                                       Void,           U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(WriteSharedU16,                                      Void,           U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(WriteSharedU32,                                      Void,           U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(WriteSharedU64,                                      Void,           U32,            U32x2,                                                          ) | 
					
						
							|  |  |  | OPCODE(WriteSharedU128,                                     Void,           U32,            U32x4,                                                          ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | // Vector utility
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(CompositeConstructU32x2,                             U32x2,          U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeConstructU32x3,                             U32x3,          U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeConstructU32x4,                             U32x4,          U32,            U32,            U32,            U32,                            ) | 
					
						
							|  |  |  | OPCODE(CompositeExtractU32x2,                               U32,            U32x2,          U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeExtractU32x3,                               U32,            U32x3,          U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeExtractU32x4,                               U32,            U32x4,          U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeInsertU32x2,                                U32x2,          U32x2,          U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeInsertU32x3,                                U32x3,          U32x3,          U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeInsertU32x4,                                U32x4,          U32x4,          U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeConstructF16x2,                             F16x2,          F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeConstructF16x3,                             F16x3,          F16,            F16,            F16,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeConstructF16x4,                             F16x4,          F16,            F16,            F16,            F16,                            ) | 
					
						
							|  |  |  | OPCODE(CompositeExtractF16x2,                               F16,            F16x2,          U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeExtractF16x3,                               F16,            F16x3,          U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeExtractF16x4,                               F16,            F16x4,          U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeInsertF16x2,                                F16x2,          F16x2,          F16,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeInsertF16x3,                                F16x3,          F16x3,          F16,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeInsertF16x4,                                F16x4,          F16x4,          F16,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeConstructF32x2,                             F32x2,          F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeConstructF32x3,                             F32x3,          F32,            F32,            F32,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeConstructF32x4,                             F32x4,          F32,            F32,            F32,            F32,                            ) | 
					
						
							|  |  |  | OPCODE(CompositeExtractF32x2,                               F32,            F32x2,          U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeExtractF32x3,                               F32,            F32x3,          U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeExtractF32x4,                               F32,            F32x4,          U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeInsertF32x2,                                F32x2,          F32x2,          F32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeInsertF32x3,                                F32x3,          F32x3,          F32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeInsertF32x4,                                F32x4,          F32x4,          F32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeConstructF64x2,                             F64x2,          F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeConstructF64x3,                             F64x3,          F64,            F64,            F64,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeConstructF64x4,                             F64x4,          F64,            F64,            F64,            F64,                            ) | 
					
						
							|  |  |  | OPCODE(CompositeExtractF64x2,                               F64,            F64x2,          U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeExtractF64x3,                               F64,            F64x3,          U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeExtractF64x4,                               F64,            F64x4,          U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeInsertF64x2,                                F64x2,          F64x2,          F64,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeInsertF64x3,                                F64x3,          F64x3,          F64,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(CompositeInsertF64x4,                                F64x4,          F64x4,          F64,            U32,                                            ) | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | // Select operations
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(SelectU1,                                            U1,             U1,             U1,             U1,                                             ) | 
					
						
							|  |  |  | OPCODE(SelectU8,                                            U8,             U1,             U8,             U8,                                             ) | 
					
						
							|  |  |  | OPCODE(SelectU16,                                           U16,            U1,             U16,            U16,                                            ) | 
					
						
							|  |  |  | OPCODE(SelectU32,                                           U32,            U1,             U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(SelectU64,                                           U64,            U1,             U64,            U64,                                            ) | 
					
						
							|  |  |  | OPCODE(SelectF16,                                           F16,            U1,             F16,            F16,                                            ) | 
					
						
							|  |  |  | OPCODE(SelectF32,                                           F32,            U1,             F32,            F32,                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-21 19:28:37 -04:00
										 |  |  | OPCODE(SelectF64,                                           F64,            U1,             F64,            F64,                                            ) | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | // Bitwise conversions
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(BitCastU16F16,                                       U16,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(BitCastU32F32,                                       U32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(BitCastU64F64,                                       U64,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(BitCastF16U16,                                       F16,            U16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(BitCastF32U32,                                       F32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(BitCastF64U64,                                       F64,            U64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(PackUint2x32,                                        U64,            U32x2,                                                                          ) | 
					
						
							|  |  |  | OPCODE(UnpackUint2x32,                                      U32x2,          U64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(PackFloat2x16,                                       U32,            F16x2,                                                                          ) | 
					
						
							|  |  |  | OPCODE(UnpackFloat2x16,                                     F16x2,          U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(PackHalf2x16,                                        U32,            F32x2,                                                                          ) | 
					
						
							|  |  |  | OPCODE(UnpackHalf2x16,                                      F32x2,          U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(PackDouble2x32,                                      F64,            U32x2,                                                                          ) | 
					
						
							|  |  |  | OPCODE(UnpackDouble2x32,                                    U32x2,          F64,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Pseudo-operation, handled specially at final emit
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(GetZeroFromOp,                                       U1,             Opaque,                                                                         ) | 
					
						
							|  |  |  | OPCODE(GetSignFromOp,                                       U1,             Opaque,                                                                         ) | 
					
						
							|  |  |  | OPCODE(GetCarryFromOp,                                      U1,             Opaque,                                                                         ) | 
					
						
							|  |  |  | OPCODE(GetOverflowFromOp,                                   U1,             Opaque,                                                                         ) | 
					
						
							|  |  |  | OPCODE(GetSparseFromOp,                                     U1,             Opaque,                                                                         ) | 
					
						
							| 
									
										
										
										
											2021-03-25 11:31:37 -04:00
										 |  |  | OPCODE(GetInBoundsFromOp,                                   U1,             Opaque,                                                                         ) | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Floating-point operations
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(FPAbs16,                                             F16,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPAbs32,                                             F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPAbs64,                                             F64,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPAdd16,                                             F16,            F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPAdd32,                                             F32,            F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPAdd64,                                             F64,            F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPFma16,                                             F16,            F16,            F16,            F16,                                            ) | 
					
						
							|  |  |  | OPCODE(FPFma32,                                             F32,            F32,            F32,            F32,                                            ) | 
					
						
							|  |  |  | OPCODE(FPFma64,                                             F64,            F64,            F64,            F64,                                            ) | 
					
						
							|  |  |  | OPCODE(FPMax32,                                             F32,            F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPMax64,                                             F64,            F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPMin32,                                             F32,            F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPMin64,                                             F64,            F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPMul16,                                             F16,            F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPMul32,                                             F32,            F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPMul64,                                             F64,            F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPNeg16,                                             F16,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPNeg32,                                             F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPNeg64,                                             F64,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPRecip32,                                           F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPRecip64,                                           F64,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPRecipSqrt32,                                       F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPRecipSqrt64,                                       F64,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPSqrt,                                              F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPSin,                                               F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPExp2,                                              F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPCos,                                               F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPLog2,                                              F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPSaturate16,                                        F16,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPSaturate32,                                        F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPSaturate64,                                        F64,            F64,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-24 00:02:30 +01:00
										 |  |  | OPCODE(FPClamp16,                                           F16,            F16,            F16,            F16,                                            ) | 
					
						
							|  |  |  | OPCODE(FPClamp32,                                           F32,            F32,            F32,            F32,                                            ) | 
					
						
							|  |  |  | OPCODE(FPClamp64,                                           F64,            F64,            F64,            F64,                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(FPRoundEven16,                                       F16,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPRoundEven32,                                       F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPRoundEven64,                                       F64,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPFloor16,                                           F16,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPFloor32,                                           F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPFloor64,                                           F64,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPCeil16,                                            F16,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPCeil32,                                            F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPCeil64,                                            F64,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPTrunc16,                                           F16,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPTrunc32,                                           F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FPTrunc64,                                           F64,            F64,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(FPOrdEqual16,                                        U1,             F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdEqual32,                                        U1,             F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdEqual64,                                        U1,             F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordEqual16,                                      U1,             F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordEqual32,                                      U1,             F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordEqual64,                                      U1,             F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdNotEqual16,                                     U1,             F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdNotEqual32,                                     U1,             F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdNotEqual64,                                     U1,             F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordNotEqual16,                                   U1,             F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordNotEqual32,                                   U1,             F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordNotEqual64,                                   U1,             F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdLessThan16,                                     U1,             F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdLessThan32,                                     U1,             F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdLessThan64,                                     U1,             F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordLessThan16,                                   U1,             F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordLessThan32,                                   U1,             F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordLessThan64,                                   U1,             F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdGreaterThan16,                                  U1,             F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdGreaterThan32,                                  U1,             F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdGreaterThan64,                                  U1,             F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordGreaterThan16,                                U1,             F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordGreaterThan32,                                U1,             F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordGreaterThan64,                                U1,             F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdLessThanEqual16,                                U1,             F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdLessThanEqual32,                                U1,             F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdLessThanEqual64,                                U1,             F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordLessThanEqual16,                              U1,             F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordLessThanEqual32,                              U1,             F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordLessThanEqual64,                              U1,             F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdGreaterThanEqual16,                             U1,             F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdGreaterThanEqual32,                             U1,             F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPOrdGreaterThanEqual64,                             U1,             F64,            F64,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordGreaterThanEqual16,                           U1,             F16,            F16,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordGreaterThanEqual32,                           U1,             F32,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(FPUnordGreaterThanEqual64,                           U1,             F64,            F64,                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-21 00:42:56 -03:00
										 |  |  | OPCODE(FPIsNan16,                                           U1,             F16,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-10 22:42:17 -05:00
										 |  |  | OPCODE(FPIsNan32,                                           U1,             F32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-21 00:42:56 -03:00
										 |  |  | OPCODE(FPIsNan64,                                           U1,             F64,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-02-22 22:59:16 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | // Integer operations
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(IAdd32,                                              U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(IAdd64,                                              U64,            U64,            U64,                                                            ) | 
					
						
							|  |  |  | OPCODE(ISub32,                                              U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(ISub64,                                              U64,            U64,            U64,                                                            ) | 
					
						
							|  |  |  | OPCODE(IMul32,                                              U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(INeg32,                                              U32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(INeg64,                                              U64,            U64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(IAbs32,                                              U32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ShiftLeftLogical32,                                  U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(ShiftLeftLogical64,                                  U64,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(ShiftRightLogical32,                                 U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(ShiftRightLogical64,                                 U64,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(ShiftRightArithmetic32,                              U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(ShiftRightArithmetic64,                              U64,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(BitwiseAnd32,                                        U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(BitwiseOr32,                                         U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(BitwiseXor32,                                        U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(BitFieldInsert,                                      U32,            U32,            U32,            U32,            U32,                            ) | 
					
						
							|  |  |  | OPCODE(BitFieldSExtract,                                    U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(BitFieldUExtract,                                    U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(BitReverse32,                                        U32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(BitCount32,                                          U32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(BitwiseNot32,                                        U32,            U32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(FindSMsb32,                                          U32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(FindUMsb32,                                          U32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(SMin32,                                              U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(UMin32,                                              U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SMax32,                                              U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(UMax32,                                              U32,            U32,            U32,                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-27 23:01:28 -04:00
										 |  |  | OPCODE(SClamp32,                                            U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(UClamp32,                                            U32,            U32,            U32,            U32,                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(SLessThan,                                           U1,             U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(ULessThan,                                           U1,             U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(IEqual,                                              U1,             U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SLessThanEqual,                                      U1,             U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(ULessThanEqual,                                      U1,             U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SGreaterThan,                                        U1,             U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(UGreaterThan,                                        U1,             U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(INotEqual,                                           U1,             U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SGreaterThanEqual,                                   U1,             U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(UGreaterThanEqual,                                   U1,             U32,            U32,                                                            ) | 
					
						
							| 
									
										
										
										
											2021-04-11 02:07:02 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Atomic operations
 | 
					
						
							|  |  |  | OPCODE(SharedAtomicIAdd32,                                  U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SharedAtomicSMin32,                                  U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SharedAtomicUMin32,                                  U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SharedAtomicSMax32,                                  U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SharedAtomicUMax32,                                  U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SharedAtomicInc32,                                   U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SharedAtomicDec32,                                   U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SharedAtomicAnd32,                                   U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SharedAtomicOr32,                                    U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SharedAtomicXor32,                                   U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SharedAtomicExchange32,                              U32,            U32,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(SharedAtomicExchange64,                              U64,            U32,            U64,                                                            ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | OPCODE(GlobalAtomicIAdd32,                                  U32,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicSMin32,                                  U32,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicUMin32,                                  U32,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicSMax32,                                  U32,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicUMax32,                                  U32,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicInc32,                                   U32,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicDec32,                                   U32,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicAnd32,                                   U32,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicOr32,                                    U32,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicXor32,                                   U32,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicExchange32,                              U32,            U64,            U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicIAdd64,                                  U64,            U64,            U64,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicSMin64,                                  U64,            U64,            U64,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicUMin64,                                  U64,            U64,            U64,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicSMax64,                                  U64,            U64,            U64,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicUMax64,                                  U64,            U64,            U64,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicAnd64,                                   U64,            U64,            U64,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicOr64,                                    U64,            U64,            U64,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicXor64,                                   U64,            U64,            U64,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicExchange64,                              U64,            U64,            U64,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicAddF32,                                  F32,            U64,            F32,                                                            ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicAddF16x2,                                U32,            U64,            F16x2,                                                          ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicAddF32x2,                                U32,            U64,            F32x2,                                                          ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicMinF16x2,                                U32,            U64,            F16x2,                                                          ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicMinF32x2,                                U32,            U64,            F32x2,                                                          ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicMaxF16x2,                                U32,            U64,            F16x2,                                                          ) | 
					
						
							|  |  |  | OPCODE(GlobalAtomicMaxF32x2,                                U32,            U64,            F32x2,                                                          ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | OPCODE(StorageAtomicIAdd32,                                 U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicSMin32,                                 U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicUMin32,                                 U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicSMax32,                                 U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicUMax32,                                 U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicInc32,                                  U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicDec32,                                  U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicAnd32,                                  U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicOr32,                                   U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicXor32,                                  U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicExchange32,                             U32,            U32,            U32,            U32,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicIAdd64,                                 U64,            U32,            U32,            U64,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicSMin64,                                 U64,            U32,            U32,            U64,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicUMin64,                                 U64,            U32,            U32,            U64,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicSMax64,                                 U64,            U32,            U32,            U64,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicUMax64,                                 U64,            U32,            U32,            U64,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicAnd64,                                  U64,            U32,            U32,            U64,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicOr64,                                   U64,            U32,            U32,            U64,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicXor64,                                  U64,            U32,            U32,            U64,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicExchange64,                             U64,            U32,            U32,            U64,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicAddF32,                                 F32,            U32,            U32,            F32,                                            ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicAddF16x2,                               U32,            U32,            U32,            F16x2,                                          ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicAddF32x2,                               U32,            U32,            U32,            F32x2,                                          ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicMinF16x2,                               U32,            U32,            U32,            F16x2,                                          ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicMinF32x2,                               U32,            U32,            U32,            F32x2,                                          ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicMaxF16x2,                               U32,            U32,            U32,            F16x2,                                          ) | 
					
						
							|  |  |  | OPCODE(StorageAtomicMaxF32x2,                               U32,            U32,            U32,            F32x2,                                          ) | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Logical operations
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(LogicalOr,                                           U1,             U1,             U1,                                                             ) | 
					
						
							|  |  |  | OPCODE(LogicalAnd,                                          U1,             U1,             U1,                                                             ) | 
					
						
							|  |  |  | OPCODE(LogicalXor,                                          U1,             U1,             U1,                                                             ) | 
					
						
							|  |  |  | OPCODE(LogicalNot,                                          U1,             U1,                                                                             ) | 
					
						
							| 
									
										
										
										
											2021-01-09 03:30:07 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Conversion operations
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(ConvertS16F16,                                       U32,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertS16F32,                                       U32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertS16F64,                                       U32,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertS32F16,                                       U32,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertS32F32,                                       U32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertS32F64,                                       U32,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertS64F16,                                       U64,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertS64F32,                                       U64,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertS64F64,                                       U64,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertU16F16,                                       U32,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertU16F32,                                       U32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertU16F64,                                       U32,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertU32F16,                                       U32,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertU32F32,                                       U32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertU32F64,                                       U32,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertU64F16,                                       U64,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertU64F32,                                       U64,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertU64F64,                                       U64,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertU64U32,                                       U64,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertU32U64,                                       U32,            U64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF16F32,                                       F16,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF32F16,                                       F32,            F16,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF32F64,                                       F32,            F64,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF64F32,                                       F64,            F32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-20 05:04:12 -03:00
										 |  |  | OPCODE(ConvertF16S8,                                        F16,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF16S16,                                       F16,            U32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(ConvertF16S32,                                       F16,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF16S64,                                       F16,            U64,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-20 05:04:12 -03:00
										 |  |  | OPCODE(ConvertF16U8,                                        F16,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF16U16,                                       F16,            U32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(ConvertF16U32,                                       F16,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF16U64,                                       F16,            U64,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-20 05:04:12 -03:00
										 |  |  | OPCODE(ConvertF32S8,                                        F32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF32S16,                                       F32,            U32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(ConvertF32S32,                                       F32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF32S64,                                       F32,            U64,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-20 05:04:12 -03:00
										 |  |  | OPCODE(ConvertF32U8,                                        F32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF32U16,                                       F32,            U32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(ConvertF32U32,                                       F32,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF32U64,                                       F32,            U64,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-20 05:04:12 -03:00
										 |  |  | OPCODE(ConvertF64S8,                                        F64,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF64S16,                                       F64,            U32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(ConvertF64S32,                                       F64,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF64S64,                                       F64,            U64,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-20 05:04:12 -03:00
										 |  |  | OPCODE(ConvertF64U8,                                        F64,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF64U16,                                       F64,            U32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | OPCODE(ConvertF64U32,                                       F64,            U32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(ConvertF64U64,                                       F64,            U64,                                                                            ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Image operations
 | 
					
						
							|  |  |  | OPCODE(BindlessImageSampleImplicitLod,                      F32x4,          U32,            Opaque,         Opaque,         Opaque,                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageSampleExplicitLod,                      F32x4,          U32,            Opaque,         Opaque,         Opaque,                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageSampleDrefImplicitLod,                  F32,            U32,            Opaque,         F32,            Opaque,         Opaque,         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageSampleDrefExplicitLod,                  F32,            U32,            Opaque,         F32,            Opaque,         Opaque,         ) | 
					
						
							| 
									
										
										
										
											2021-03-24 23:41:55 +01:00
										 |  |  | OPCODE(BindlessImageGather,                                 F32x4,          U32,            Opaque,         Opaque,         Opaque,                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageGatherDref,                             F32x4,          U32,            Opaque,         Opaque,         Opaque,         F32,            ) | 
					
						
							| 
									
										
										
										
											2021-03-29 01:08:25 -03:00
										 |  |  | OPCODE(BindlessImageFetch,                                  F32x4,          U32,            Opaque,         Opaque,         U32,            Opaque,         ) | 
					
						
							| 
									
										
										
										
											2021-03-26 18:45:38 -03:00
										 |  |  | OPCODE(BindlessImageQueryDimensions,                        U32x4,          U32,            U32,                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-28 19:47:52 +02:00
										 |  |  | OPCODE(BindlessImageQueryLod,                               F32x4,          U32,            Opaque,                                                         ) | 
					
						
							| 
									
										
										
										
											2021-03-29 02:00:43 +02:00
										 |  |  | OPCODE(BindlessImageGradient,                               F32x4,          U32,            Opaque,         Opaque,         Opaque,         Opaque,         ) | 
					
						
							| 
									
										
										
										
											2021-04-09 01:45:39 -03:00
										 |  |  | OPCODE(BindlessImageRead,                                   U32x4,          U32,            Opaque,                                                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageWrite,                                  Void,           U32,            Opaque,         U32x4,                                          ) | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | OPCODE(BoundImageSampleImplicitLod,                         F32x4,          U32,            Opaque,         Opaque,         Opaque,                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageSampleExplicitLod,                         F32x4,          U32,            Opaque,         Opaque,         Opaque,                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageSampleDrefImplicitLod,                     F32,            U32,            Opaque,         F32,            Opaque,         Opaque,         ) | 
					
						
							|  |  |  | OPCODE(BoundImageSampleDrefExplicitLod,                     F32,            U32,            Opaque,         F32,            Opaque,         Opaque,         ) | 
					
						
							| 
									
										
										
										
											2021-03-24 23:41:55 +01:00
										 |  |  | OPCODE(BoundImageGather,                                    F32x4,          U32,            Opaque,         Opaque,         Opaque,                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageGatherDref,                                F32x4,          U32,            Opaque,         Opaque,         Opaque,         F32,            ) | 
					
						
							| 
									
										
										
										
											2021-03-29 01:08:25 -03:00
										 |  |  | OPCODE(BoundImageFetch,                                     F32x4,          U32,            Opaque,         Opaque,         U32,            Opaque,         ) | 
					
						
							| 
									
										
										
										
											2021-03-26 18:45:38 -03:00
										 |  |  | OPCODE(BoundImageQueryDimensions,                           U32x4,          U32,            U32,                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-28 19:47:52 +02:00
										 |  |  | OPCODE(BoundImageQueryLod,                                  F32x4,          U32,            Opaque,                                                         ) | 
					
						
							| 
									
										
										
										
											2021-03-29 02:00:43 +02:00
										 |  |  | OPCODE(BoundImageGradient,                                  F32x4,          U32,            Opaque,         Opaque,         Opaque,         Opaque,         ) | 
					
						
							| 
									
										
										
										
											2021-04-09 01:45:39 -03:00
										 |  |  | OPCODE(BoundImageRead,                                      U32x4,          U32,            Opaque,                                                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageWrite,                                     Void,           U32,            Opaque,         U32x4,                                          ) | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-22 16:17:59 -03:00
										 |  |  | OPCODE(ImageSampleImplicitLod,                              F32x4,          Opaque,         Opaque,         Opaque,         Opaque,                         ) | 
					
						
							|  |  |  | OPCODE(ImageSampleExplicitLod,                              F32x4,          Opaque,         Opaque,         Opaque,         Opaque,                         ) | 
					
						
							|  |  |  | OPCODE(ImageSampleDrefImplicitLod,                          F32,            Opaque,         Opaque,         F32,            Opaque,         Opaque,         ) | 
					
						
							|  |  |  | OPCODE(ImageSampleDrefExplicitLod,                          F32,            Opaque,         Opaque,         F32,            Opaque,         Opaque,         ) | 
					
						
							|  |  |  | OPCODE(ImageGather,                                         F32x4,          Opaque,         Opaque,         Opaque,         Opaque,                         ) | 
					
						
							|  |  |  | OPCODE(ImageGatherDref,                                     F32x4,          Opaque,         Opaque,         Opaque,         Opaque,         F32,            ) | 
					
						
							|  |  |  | OPCODE(ImageFetch,                                          F32x4,          Opaque,         Opaque,         Opaque,         U32,            Opaque,         ) | 
					
						
							|  |  |  | OPCODE(ImageQueryDimensions,                                U32x4,          Opaque,         U32,                                                            ) | 
					
						
							|  |  |  | OPCODE(ImageQueryLod,                                       F32x4,          Opaque,         Opaque,                                                         ) | 
					
						
							|  |  |  | OPCODE(ImageGradient,                                       F32x4,          Opaque,         Opaque,         Opaque,         Opaque,         Opaque,         ) | 
					
						
							|  |  |  | OPCODE(ImageRead,                                           U32x4,          Opaque,         Opaque,                                                         ) | 
					
						
							|  |  |  | OPCODE(ImageWrite,                                          Void,           Opaque,         Opaque,         U32x4,                                          ) | 
					
						
							| 
									
										
										
										
											2021-03-23 20:27:17 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-23 17:47:54 -04:00
										 |  |  | // Atomic Image operations
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | OPCODE(BindlessImageAtomicIAdd32,                           U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageAtomicSMin32,                           U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageAtomicUMin32,                           U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageAtomicSMax32,                           U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageAtomicUMax32,                           U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageAtomicInc32,                            U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageAtomicDec32,                            U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageAtomicAnd32,                            U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageAtomicOr32,                             U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageAtomicXor32,                            U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BindlessImageAtomicExchange32,                       U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | OPCODE(BoundImageAtomicIAdd32,                              U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageAtomicSMin32,                              U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageAtomicUMin32,                              U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageAtomicSMax32,                              U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageAtomicUMax32,                              U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageAtomicInc32,                               U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageAtomicDec32,                               U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageAtomicAnd32,                               U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageAtomicOr32,                                U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageAtomicXor32,                               U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | OPCODE(BoundImageAtomicExchange32,                          U32,            U32,            Opaque,            U32,                                         ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | OPCODE(ImageAtomicIAdd32,                                   U32,            Opaque,            Opaque,            U32,                                      ) | 
					
						
							|  |  |  | OPCODE(ImageAtomicSMin32,                                   U32,            Opaque,            Opaque,            U32,                                      ) | 
					
						
							|  |  |  | OPCODE(ImageAtomicUMin32,                                   U32,            Opaque,            Opaque,            U32,                                      ) | 
					
						
							|  |  |  | OPCODE(ImageAtomicSMax32,                                   U32,            Opaque,            Opaque,            U32,                                      ) | 
					
						
							|  |  |  | OPCODE(ImageAtomicUMax32,                                   U32,            Opaque,            Opaque,            U32,                                      ) | 
					
						
							|  |  |  | OPCODE(ImageAtomicInc32,                                    U32,            Opaque,            Opaque,            U32,                                      ) | 
					
						
							|  |  |  | OPCODE(ImageAtomicDec32,                                    U32,            Opaque,            Opaque,            U32,                                      ) | 
					
						
							|  |  |  | OPCODE(ImageAtomicAnd32,                                    U32,            Opaque,            Opaque,            U32,                                      ) | 
					
						
							|  |  |  | OPCODE(ImageAtomicOr32,                                     U32,            Opaque,            Opaque,            U32,                                      ) | 
					
						
							|  |  |  | OPCODE(ImageAtomicXor32,                                    U32,            Opaque,            Opaque,            U32,                                      ) | 
					
						
							|  |  |  | OPCODE(ImageAtomicExchange32,                               U32,            Opaque,            Opaque,            U32,                                      ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-25 11:31:37 -04:00
										 |  |  | // Warp operations
 | 
					
						
							| 
									
										
										
										
											2021-04-11 02:22:20 -03:00
										 |  |  | OPCODE(LaneId,                                              U32,                                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-23 20:27:17 -04:00
										 |  |  | OPCODE(VoteAll,                                             U1,             U1,                                                                             ) | 
					
						
							|  |  |  | OPCODE(VoteAny,                                             U1,             U1,                                                                             ) | 
					
						
							|  |  |  | OPCODE(VoteEqual,                                           U1,             U1,                                                                             ) | 
					
						
							|  |  |  | OPCODE(SubgroupBallot,                                      U32,            U1,                                                                             ) | 
					
						
							| 
									
										
										
										
											2021-04-04 05:17:17 -03:00
										 |  |  | OPCODE(SubgroupEqMask,                                      U32,                                                                                            ) | 
					
						
							|  |  |  | OPCODE(SubgroupLtMask,                                      U32,                                                                                            ) | 
					
						
							|  |  |  | OPCODE(SubgroupLeMask,                                      U32,                                                                                            ) | 
					
						
							|  |  |  | OPCODE(SubgroupGtMask,                                      U32,                                                                                            ) | 
					
						
							|  |  |  | OPCODE(SubgroupGeMask,                                      U32,                                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-03-25 11:31:37 -04:00
										 |  |  | OPCODE(ShuffleIndex,                                        U32,            U32,            U32,            U32,            U32,                            ) | 
					
						
							|  |  |  | OPCODE(ShuffleUp,                                           U32,            U32,            U32,            U32,            U32,                            ) | 
					
						
							|  |  |  | OPCODE(ShuffleDown,                                         U32,            U32,            U32,            U32,            U32,                            ) | 
					
						
							|  |  |  | OPCODE(ShuffleButterfly,                                    U32,            U32,            U32,            U32,            U32,                            ) | 
					
						
							| 
									
										
										
										
											2021-03-28 22:23:45 -04:00
										 |  |  | OPCODE(FSwizzleAdd,                                         F32,            F32,            F32,            U32,                                            ) | 
					
						
							| 
									
										
										
										
											2021-04-17 11:56:45 +02:00
										 |  |  | OPCODE(DPdxFine,                                            F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(DPdyFine,                                            F32,            F32,                                                                            ) | 
					
						
							| 
									
										
										
										
											2021-04-17 12:51:43 +02:00
										 |  |  | OPCODE(DPdxCoarse,                                          F32,            F32,                                                                            ) | 
					
						
							|  |  |  | OPCODE(DPdyCoarse,                                          F32,            F32,                                                                            ) |