| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | // Copyright 2021 yuzu Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | #include "common/bit_field.h"
 | 
					
						
							| 
									
										
										
										
											2021-02-20 03:30:13 -03:00
										 |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | #include "shader_recompiler/shader_info.h"
 | 
					
						
							| 
									
										
										
										
											2021-02-20 03:30:13 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | namespace Shader::IR { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-14 22:46:40 -03:00
										 |  |  | enum class FmzMode : u8 { | 
					
						
							| 
									
										
										
										
											2021-02-20 03:30:13 -03:00
										 |  |  |     DontCare, // Not specified for this instruction
 | 
					
						
							|  |  |  |     FTZ,      // Flush denorms to zero, NAN is propagated (D3D11, NVN, GL, VK)
 | 
					
						
							|  |  |  |     FMZ,      // Flush denorms to zero, x * 0 == 0 (D3D9)
 | 
					
						
							|  |  |  |     None,     // Denorms are not flushed, NAN is propagated (nouveau)
 | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-14 22:46:40 -03:00
										 |  |  | enum class FpRounding : u8 { | 
					
						
							| 
									
										
										
										
											2021-02-20 03:30:13 -03:00
										 |  |  |     DontCare, // Not specified for this instruction
 | 
					
						
							|  |  |  |     RN,       // Round to nearest even,
 | 
					
						
							|  |  |  |     RM,       // Round towards negative infinity
 | 
					
						
							|  |  |  |     RP,       // Round towards positive infinity
 | 
					
						
							|  |  |  |     RZ,       // Round towards zero
 | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-02 19:27:30 +02:00
										 |  |  | enum class MemoryScope : u32 { | 
					
						
							|  |  |  |   DontCare, | 
					
						
							|  |  |  |   Warp, | 
					
						
							|  |  |  |   Workgroup, | 
					
						
							|  |  |  |   Device, | 
					
						
							|  |  |  |   System | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | struct FpControl { | 
					
						
							|  |  |  |     bool no_contraction{false}; | 
					
						
							| 
									
										
										
										
											2021-02-20 03:30:13 -03:00
										 |  |  |     FpRounding rounding{FpRounding::DontCare}; | 
					
						
							|  |  |  |     FmzMode fmz_mode{FmzMode::DontCare}; | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2021-02-14 22:46:40 -03:00
										 |  |  | static_assert(sizeof(FpControl) <= sizeof(u32)); | 
					
						
							| 
									
										
										
										
											2021-02-20 03:30:13 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-02 19:27:30 +02:00
										 |  |  | union BarrierInstInfo { | 
					
						
							|  |  |  |     u32 raw; | 
					
						
							|  |  |  |     BitField<0, 3, MemoryScope> scope; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | union TextureInstInfo { | 
					
						
							|  |  |  |     u32 raw; | 
					
						
							|  |  |  |     BitField<0, 8, TextureType> type; | 
					
						
							|  |  |  |     BitField<8, 1, u32> has_bias; | 
					
						
							| 
									
										
										
										
											2021-03-15 04:54:43 -03:00
										 |  |  |     BitField<9, 1, u32> has_lod_clamp; | 
					
						
							|  |  |  |     BitField<10, 1, u32> relaxed_precision; | 
					
						
							| 
									
										
										
										
											2021-03-24 23:41:55 +01:00
										 |  |  |     BitField<11, 2, u32> gather_component; | 
					
						
							| 
									
										
										
										
											2021-03-29 02:00:43 +02:00
										 |  |  |     BitField<13, 2, u32> num_derivates; | 
					
						
							| 
									
										
										
										
											2021-03-08 18:31:53 -03:00
										 |  |  | }; | 
					
						
							|  |  |  | static_assert(sizeof(TextureInstInfo) <= sizeof(u32)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-03 16:43:04 -03:00
										 |  |  | } // namespace Shader::IR
 |