| 
									
										
										
										
											2018-02-11 21:34:20 -05:00
										 |  |  | // Copyright 2018 yuzu Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 22:06:24 -05:00
										 |  |  | #include <array>
 | 
					
						
							| 
									
										
										
										
											2019-02-26 03:01:48 -03:00
										 |  |  | #include <bitset>
 | 
					
						
							| 
									
										
										
										
											2019-12-26 22:14:10 -03:00
										 |  |  | #include <limits>
 | 
					
						
							| 
									
										
										
										
											2019-11-26 18:52:15 -03:00
										 |  |  | #include <optional>
 | 
					
						
							| 
									
										
										
										
											2019-05-14 08:41:51 -04:00
										 |  |  | #include <type_traits>
 | 
					
						
							| 
									
										
										
										
											2018-03-16 20:32:44 -05:00
										 |  |  | #include <unordered_map>
 | 
					
						
							|  |  |  | #include <vector>
 | 
					
						
							| 
									
										
										
										
											2019-02-26 03:01:48 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-22 19:47:28 -04:00
										 |  |  | #include "common/assert.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  | #include "common/bit_field.h"
 | 
					
						
							|  |  |  | #include "common/common_funcs.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-11 21:34:20 -05:00
										 |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2018-03-26 20:45:10 -04:00
										 |  |  | #include "common/math_util.h"
 | 
					
						
							| 
									
										
										
										
											2019-09-23 14:02:02 -04:00
										 |  |  | #include "video_core/engines/const_buffer_engine_interface.h"
 | 
					
						
							| 
									
										
										
										
											2019-09-25 09:53:18 -04:00
										 |  |  | #include "video_core/engines/const_buffer_info.h"
 | 
					
						
							| 
									
										
										
										
											2019-04-22 19:27:36 -04:00
										 |  |  | #include "video_core/engines/engine_upload.h"
 | 
					
						
							| 
									
										
										
										
											2019-11-18 18:35:21 -03:00
										 |  |  | #include "video_core/engines/shader_type.h"
 | 
					
						
							| 
									
										
										
										
											2018-03-24 00:45:24 -04:00
										 |  |  | #include "video_core/gpu.h"
 | 
					
						
							| 
									
										
										
										
											2018-03-28 15:20:18 -05:00
										 |  |  | #include "video_core/macro_interpreter.h"
 | 
					
						
							| 
									
										
										
										
											2018-03-23 18:56:27 -05:00
										 |  |  | #include "video_core/textures/texture.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-11 21:34:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-15 22:05:17 -05:00
										 |  |  | namespace Core { | 
					
						
							|  |  |  | class System; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-05 18:21:15 -04:00
										 |  |  | namespace Tegra { | 
					
						
							|  |  |  | class MemoryManager; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-03 12:55:58 -04:00
										 |  |  | namespace VideoCore { | 
					
						
							|  |  |  | class RasterizerInterface; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-20 18:14:17 -04:00
										 |  |  | namespace Tegra::Engines { | 
					
						
							| 
									
										
										
										
											2018-02-11 21:34:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-23 08:44:52 -04:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * This Engine is known as GF100_3D. Documentation can be found in: | 
					
						
							|  |  |  |  * https://github.com/envytools/envytools/blob/master/rnndb/graph/gf100_3d.xml
 | 
					
						
							|  |  |  |  * https://cgit.freedesktop.org/mesa/mesa/tree/src/gallium/drivers/nouveau/nvc0/nvc0_3d.xml.h
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-13 23:13:47 -04:00
										 |  |  | #define MAXWELL3D_REG_INDEX(field_name)                                                            \
 | 
					
						
							|  |  |  |     (offsetof(Tegra::Engines::Maxwell3D::Regs, field_name) / sizeof(u32)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-23 14:02:02 -04:00
										 |  |  | class Maxwell3D final : public ConstBufferEngineInterface { | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2019-02-15 22:05:17 -05:00
										 |  |  |     explicit Maxwell3D(Core::System& system, VideoCore::RasterizerInterface& rasterizer, | 
					
						
							|  |  |  |                        MemoryManager& memory_manager); | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  |     ~Maxwell3D() = default; | 
					
						
							| 
									
										
										
										
											2018-02-11 21:34:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  |     /// Register structure of the Maxwell3D engine.
 | 
					
						
							|  |  |  |     /// TODO(Subv): This structure will need to be made bigger as more registers are discovered.
 | 
					
						
							|  |  |  |     struct Regs { | 
					
						
							| 
									
										
										
										
											2018-09-15 15:21:06 +02:00
										 |  |  |         static constexpr std::size_t NUM_REGS = 0xE00; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         static constexpr std::size_t NumRenderTargets = 8; | 
					
						
							|  |  |  |         static constexpr std::size_t NumViewports = 16; | 
					
						
							|  |  |  |         static constexpr std::size_t NumCBData = 16; | 
					
						
							|  |  |  |         static constexpr std::size_t NumVertexArrays = 32; | 
					
						
							|  |  |  |         static constexpr std::size_t NumVertexAttributes = 32; | 
					
						
							| 
									
										
										
										
											2019-04-30 00:09:51 -03:00
										 |  |  |         static constexpr std::size_t NumVaryings = 31; | 
					
						
							| 
									
										
										
										
											2019-07-12 02:01:27 -03:00
										 |  |  |         static constexpr std::size_t NumImages = 8; // TODO(Rodrigo): Investigate this number
 | 
					
						
							| 
									
										
										
										
											2018-11-29 16:13:13 -03:00
										 |  |  |         static constexpr std::size_t NumClipDistances = 8; | 
					
						
							| 
									
										
										
										
											2020-03-02 01:54:00 -03:00
										 |  |  |         static constexpr std::size_t NumTransformFeedbackBuffers = 4; | 
					
						
							| 
									
										
										
										
											2018-09-15 15:21:06 +02:00
										 |  |  |         static constexpr std::size_t MaxShaderProgram = 6; | 
					
						
							|  |  |  |         static constexpr std::size_t MaxShaderStage = 5; | 
					
						
							| 
									
										
										
										
											2018-03-17 17:06:23 -05:00
										 |  |  |         // Maximum number of const buffers per shader stage.
 | 
					
						
							| 
									
										
										
										
											2018-09-15 15:21:06 +02:00
										 |  |  |         static constexpr std::size_t MaxConstBuffers = 18; | 
					
						
							| 
									
										
										
										
											2019-07-05 23:11:58 -03:00
										 |  |  |         static constexpr std::size_t MaxConstBufferSize = 0x10000; | 
					
						
							| 
									
										
										
										
											2018-03-16 22:47:45 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-27 22:48:15 -04:00
										 |  |  |         enum class QueryOperation : u32 { | 
					
						
							|  |  |  |             Release = 0, | 
					
						
							|  |  |  |             Acquire = 1, | 
					
						
							|  |  |  |             Counter = 2, | 
					
						
							|  |  |  |             Trap = 3, | 
					
						
							| 
									
										
										
										
											2018-04-23 17:06:57 -05:00
										 |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         enum class QueryUnit : u32 { | 
					
						
							|  |  |  |             VFetch = 1, | 
					
						
							|  |  |  |             VP = 2, | 
					
						
							|  |  |  |             Rast = 4, | 
					
						
							|  |  |  |             StrmOut = 5, | 
					
						
							|  |  |  |             GP = 6, | 
					
						
							|  |  |  |             ZCull = 7, | 
					
						
							|  |  |  |             Prop = 10, | 
					
						
							|  |  |  |             Crop = 15, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         enum class QuerySelect : u32 { | 
					
						
							|  |  |  |             Zero = 0, | 
					
						
							| 
									
										
										
										
											2019-06-30 22:21:28 -04:00
										 |  |  |             TimeElapsed = 2, | 
					
						
							|  |  |  |             TransformFeedbackPrimitivesGenerated = 11, | 
					
						
							|  |  |  |             PrimitivesGenerated = 18, | 
					
						
							|  |  |  |             SamplesPassed = 21, | 
					
						
							|  |  |  |             TransformFeedbackUnknown = 26, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         struct QueryCompare { | 
					
						
							|  |  |  |             u32 initial_sequence; | 
					
						
							|  |  |  |             u32 initial_mode; | 
					
						
							|  |  |  |             u32 unknown1; | 
					
						
							|  |  |  |             u32 unknown2; | 
					
						
							|  |  |  |             u32 current_sequence; | 
					
						
							|  |  |  |             u32 current_mode; | 
					
						
							| 
									
										
										
										
											2018-04-23 17:06:57 -05:00
										 |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         enum class QuerySyncCondition : u32 { | 
					
						
							|  |  |  |             NotEqual = 0, | 
					
						
							|  |  |  |             GreaterThan = 1, | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-30 22:21:28 -04:00
										 |  |  |         enum class ConditionMode : u32 { | 
					
						
							|  |  |  |             Never = 0, | 
					
						
							|  |  |  |             Always = 1, | 
					
						
							|  |  |  |             ResNonZero = 2, | 
					
						
							|  |  |  |             Equal = 3, | 
					
						
							|  |  |  |             NotEqual = 4, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 19:23:11 -05:00
										 |  |  |         enum class ShaderProgram : u32 { | 
					
						
							|  |  |  |             VertexA = 0, | 
					
						
							|  |  |  |             VertexB = 1, | 
					
						
							|  |  |  |             TesselationControl = 2, | 
					
						
							|  |  |  |             TesselationEval = 3, | 
					
						
							|  |  |  |             Geometry = 4, | 
					
						
							|  |  |  |             Fragment = 5, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |         struct VertexAttribute { | 
					
						
							|  |  |  |             enum class Size : u32 { | 
					
						
							| 
									
										
										
										
											2018-08-11 20:36:40 -05:00
										 |  |  |                 Invalid = 0x0, | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |                 Size_32_32_32_32 = 0x01, | 
					
						
							|  |  |  |                 Size_32_32_32 = 0x02, | 
					
						
							|  |  |  |                 Size_16_16_16_16 = 0x03, | 
					
						
							|  |  |  |                 Size_32_32 = 0x04, | 
					
						
							|  |  |  |                 Size_16_16_16 = 0x05, | 
					
						
							|  |  |  |                 Size_8_8_8_8 = 0x0a, | 
					
						
							|  |  |  |                 Size_16_16 = 0x0f, | 
					
						
							|  |  |  |                 Size_32 = 0x12, | 
					
						
							|  |  |  |                 Size_8_8_8 = 0x13, | 
					
						
							|  |  |  |                 Size_8_8 = 0x18, | 
					
						
							|  |  |  |                 Size_16 = 0x1b, | 
					
						
							|  |  |  |                 Size_8 = 0x1d, | 
					
						
							|  |  |  |                 Size_10_10_10_2 = 0x30, | 
					
						
							|  |  |  |                 Size_11_11_10 = 0x31, | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             enum class Type : u32 { | 
					
						
							|  |  |  |                 SignedNorm = 1, | 
					
						
							|  |  |  |                 UnsignedNorm = 2, | 
					
						
							|  |  |  |                 SignedInt = 3, | 
					
						
							|  |  |  |                 UnsignedInt = 4, | 
					
						
							|  |  |  |                 UnsignedScaled = 5, | 
					
						
							|  |  |  |                 SignedScaled = 6, | 
					
						
							|  |  |  |                 Float = 7, | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             union { | 
					
						
							|  |  |  |                 BitField<0, 5, u32> buffer; | 
					
						
							|  |  |  |                 BitField<6, 1, u32> constant; | 
					
						
							|  |  |  |                 BitField<7, 14, u32> offset; | 
					
						
							|  |  |  |                 BitField<21, 6, Size> size; | 
					
						
							|  |  |  |                 BitField<27, 3, Type> type; | 
					
						
							|  |  |  |                 BitField<31, 1, u32> bgra; | 
					
						
							| 
									
										
										
										
											2018-09-05 11:36:50 +02:00
										 |  |  |                 u32 hex; | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |             }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             u32 ComponentCount() const { | 
					
						
							|  |  |  |                 switch (size) { | 
					
						
							|  |  |  |                 case Size::Size_32_32_32_32: | 
					
						
							|  |  |  |                     return 4; | 
					
						
							|  |  |  |                 case Size::Size_32_32_32: | 
					
						
							|  |  |  |                     return 3; | 
					
						
							|  |  |  |                 case Size::Size_16_16_16_16: | 
					
						
							|  |  |  |                     return 4; | 
					
						
							|  |  |  |                 case Size::Size_32_32: | 
					
						
							|  |  |  |                     return 2; | 
					
						
							|  |  |  |                 case Size::Size_16_16_16: | 
					
						
							|  |  |  |                     return 3; | 
					
						
							|  |  |  |                 case Size::Size_8_8_8_8: | 
					
						
							|  |  |  |                     return 4; | 
					
						
							|  |  |  |                 case Size::Size_16_16: | 
					
						
							|  |  |  |                     return 2; | 
					
						
							|  |  |  |                 case Size::Size_32: | 
					
						
							|  |  |  |                     return 1; | 
					
						
							|  |  |  |                 case Size::Size_8_8_8: | 
					
						
							|  |  |  |                     return 3; | 
					
						
							|  |  |  |                 case Size::Size_8_8: | 
					
						
							|  |  |  |                     return 2; | 
					
						
							|  |  |  |                 case Size::Size_16: | 
					
						
							|  |  |  |                     return 1; | 
					
						
							|  |  |  |                 case Size::Size_8: | 
					
						
							|  |  |  |                     return 1; | 
					
						
							|  |  |  |                 case Size::Size_10_10_10_2: | 
					
						
							|  |  |  |                     return 4; | 
					
						
							|  |  |  |                 case Size::Size_11_11_10: | 
					
						
							|  |  |  |                     return 3; | 
					
						
							|  |  |  |                 default: | 
					
						
							|  |  |  |                     UNREACHABLE(); | 
					
						
							| 
									
										
										
										
											2018-12-19 12:52:32 +11:00
										 |  |  |                     return 1; | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-03-22 19:47:28 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |             u32 SizeInBytes() const { | 
					
						
							|  |  |  |                 switch (size) { | 
					
						
							|  |  |  |                 case Size::Size_32_32_32_32: | 
					
						
							|  |  |  |                     return 16; | 
					
						
							|  |  |  |                 case Size::Size_32_32_32: | 
					
						
							|  |  |  |                     return 12; | 
					
						
							|  |  |  |                 case Size::Size_16_16_16_16: | 
					
						
							|  |  |  |                     return 8; | 
					
						
							|  |  |  |                 case Size::Size_32_32: | 
					
						
							|  |  |  |                     return 8; | 
					
						
							|  |  |  |                 case Size::Size_16_16_16: | 
					
						
							|  |  |  |                     return 6; | 
					
						
							|  |  |  |                 case Size::Size_8_8_8_8: | 
					
						
							|  |  |  |                     return 4; | 
					
						
							|  |  |  |                 case Size::Size_16_16: | 
					
						
							|  |  |  |                     return 4; | 
					
						
							|  |  |  |                 case Size::Size_32: | 
					
						
							|  |  |  |                     return 4; | 
					
						
							|  |  |  |                 case Size::Size_8_8_8: | 
					
						
							|  |  |  |                     return 3; | 
					
						
							|  |  |  |                 case Size::Size_8_8: | 
					
						
							|  |  |  |                     return 2; | 
					
						
							|  |  |  |                 case Size::Size_16: | 
					
						
							|  |  |  |                     return 2; | 
					
						
							|  |  |  |                 case Size::Size_8: | 
					
						
							|  |  |  |                     return 1; | 
					
						
							|  |  |  |                 case Size::Size_10_10_10_2: | 
					
						
							|  |  |  |                     return 4; | 
					
						
							|  |  |  |                 case Size::Size_11_11_10: | 
					
						
							|  |  |  |                     return 4; | 
					
						
							|  |  |  |                 default: | 
					
						
							|  |  |  |                     UNREACHABLE(); | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2018-03-22 19:47:28 -04:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |             std::string SizeString() const { | 
					
						
							|  |  |  |                 switch (size) { | 
					
						
							|  |  |  |                 case Size::Size_32_32_32_32: | 
					
						
							|  |  |  |                     return "32_32_32_32"; | 
					
						
							|  |  |  |                 case Size::Size_32_32_32: | 
					
						
							|  |  |  |                     return "32_32_32"; | 
					
						
							|  |  |  |                 case Size::Size_16_16_16_16: | 
					
						
							|  |  |  |                     return "16_16_16_16"; | 
					
						
							|  |  |  |                 case Size::Size_32_32: | 
					
						
							|  |  |  |                     return "32_32"; | 
					
						
							|  |  |  |                 case Size::Size_16_16_16: | 
					
						
							|  |  |  |                     return "16_16_16"; | 
					
						
							|  |  |  |                 case Size::Size_8_8_8_8: | 
					
						
							|  |  |  |                     return "8_8_8_8"; | 
					
						
							|  |  |  |                 case Size::Size_16_16: | 
					
						
							|  |  |  |                     return "16_16"; | 
					
						
							|  |  |  |                 case Size::Size_32: | 
					
						
							|  |  |  |                     return "32"; | 
					
						
							|  |  |  |                 case Size::Size_8_8_8: | 
					
						
							|  |  |  |                     return "8_8_8"; | 
					
						
							|  |  |  |                 case Size::Size_8_8: | 
					
						
							|  |  |  |                     return "8_8"; | 
					
						
							|  |  |  |                 case Size::Size_16: | 
					
						
							|  |  |  |                     return "16"; | 
					
						
							|  |  |  |                 case Size::Size_8: | 
					
						
							|  |  |  |                     return "8"; | 
					
						
							|  |  |  |                 case Size::Size_10_10_10_2: | 
					
						
							|  |  |  |                     return "10_10_10_2"; | 
					
						
							|  |  |  |                 case Size::Size_11_11_10: | 
					
						
							|  |  |  |                     return "11_11_10"; | 
					
						
							| 
									
										
										
										
											2019-04-03 04:33:36 -03:00
										 |  |  |                 default: | 
					
						
							|  |  |  |                     UNREACHABLE(); | 
					
						
							|  |  |  |                     return {}; | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2018-03-22 19:47:28 -04:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-24 21:04:23 -04:00
										 |  |  |             std::string TypeString() const { | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |                 switch (type) { | 
					
						
							|  |  |  |                 case Type::SignedNorm: | 
					
						
							| 
									
										
										
										
											2018-03-24 21:04:23 -04:00
										 |  |  |                     return "SNORM"; | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |                 case Type::UnsignedNorm: | 
					
						
							| 
									
										
										
										
											2018-03-24 21:04:23 -04:00
										 |  |  |                     return "UNORM"; | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |                 case Type::SignedInt: | 
					
						
							| 
									
										
										
										
											2018-03-24 21:04:23 -04:00
										 |  |  |                     return "SINT"; | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |                 case Type::UnsignedInt: | 
					
						
							| 
									
										
										
										
											2018-03-24 21:04:23 -04:00
										 |  |  |                     return "UINT"; | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |                 case Type::UnsignedScaled: | 
					
						
							| 
									
										
										
										
											2018-03-24 21:04:23 -04:00
										 |  |  |                     return "USCALED"; | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |                 case Type::SignedScaled: | 
					
						
							| 
									
										
										
										
											2018-03-24 21:04:23 -04:00
										 |  |  |                     return "SSCALED"; | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |                 case Type::Float: | 
					
						
							| 
									
										
										
										
											2018-03-24 21:04:23 -04:00
										 |  |  |                     return "FLOAT"; | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |                 } | 
					
						
							|  |  |  |                 UNREACHABLE(); | 
					
						
							|  |  |  |                 return {}; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-03-25 00:09:53 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |             bool IsNormalized() const { | 
					
						
							|  |  |  |                 return (type == Type::SignedNorm) || (type == Type::UnsignedNorm); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-08-11 20:36:40 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |             bool IsValid() const { | 
					
						
							|  |  |  |                 return size != Size::Invalid; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-09-05 11:36:50 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             bool operator<(const VertexAttribute& other) const { | 
					
						
							|  |  |  |                 return hex < other.hex; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-03-24 16:26:14 -04:00
										 |  |  |         }; | 
					
						
							| 
									
										
										
										
											2018-03-22 19:47:28 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-10 17:33:49 -04:00
										 |  |  |         enum class DepthMode : u32 { | 
					
						
							|  |  |  |             MinusOneToOne = 0, | 
					
						
							|  |  |  |             ZeroToOne = 1, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-22 19:47:28 -04:00
										 |  |  |         enum class PrimitiveTopology : u32 { | 
					
						
							|  |  |  |             Points = 0x0, | 
					
						
							|  |  |  |             Lines = 0x1, | 
					
						
							|  |  |  |             LineLoop = 0x2, | 
					
						
							|  |  |  |             LineStrip = 0x3, | 
					
						
							|  |  |  |             Triangles = 0x4, | 
					
						
							|  |  |  |             TriangleStrip = 0x5, | 
					
						
							|  |  |  |             TriangleFan = 0x6, | 
					
						
							|  |  |  |             Quads = 0x7, | 
					
						
							|  |  |  |             QuadStrip = 0x8, | 
					
						
							|  |  |  |             Polygon = 0x9, | 
					
						
							|  |  |  |             LinesAdjacency = 0xa, | 
					
						
							|  |  |  |             LineStripAdjacency = 0xb, | 
					
						
							|  |  |  |             TrianglesAdjacency = 0xc, | 
					
						
							|  |  |  |             TriangleStripAdjacency = 0xd, | 
					
						
							|  |  |  |             Patches = 0xe, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-13 14:18:37 -04:00
										 |  |  |         enum class IndexFormat : u32 { | 
					
						
							|  |  |  |             UnsignedByte = 0x0, | 
					
						
							|  |  |  |             UnsignedShort = 0x1, | 
					
						
							|  |  |  |             UnsignedInt = 0x2, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 13:31:20 -05:00
										 |  |  |         enum class ComparisonOp : u32 { | 
					
						
							| 
									
										
										
										
											2018-07-05 13:01:31 -05:00
										 |  |  |             // These values are used by Nouveau and most games, they correspond to the OpenGL token
 | 
					
						
							|  |  |  |             // values for these operations.
 | 
					
						
							|  |  |  |             Never = 0x200, | 
					
						
							|  |  |  |             Less = 0x201, | 
					
						
							|  |  |  |             Equal = 0x202, | 
					
						
							|  |  |  |             LessEqual = 0x203, | 
					
						
							|  |  |  |             Greater = 0x204, | 
					
						
							|  |  |  |             NotEqual = 0x205, | 
					
						
							|  |  |  |             GreaterEqual = 0x206, | 
					
						
							|  |  |  |             Always = 0x207, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // These values are used by some games, they seem to be NV04 values.
 | 
					
						
							|  |  |  |             NeverOld = 1, | 
					
						
							|  |  |  |             LessOld = 2, | 
					
						
							|  |  |  |             EqualOld = 3, | 
					
						
							|  |  |  |             LessEqualOld = 4, | 
					
						
							|  |  |  |             GreaterOld = 5, | 
					
						
							|  |  |  |             NotEqualOld = 6, | 
					
						
							|  |  |  |             GreaterEqualOld = 7, | 
					
						
							|  |  |  |             AlwaysOld = 8, | 
					
						
							| 
									
										
										
										
											2018-07-02 13:31:20 -05:00
										 |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-20 18:42:36 -05:00
										 |  |  |         enum class LogicOperation : u32 { | 
					
						
							|  |  |  |             Clear = 0x1500, | 
					
						
							|  |  |  |             And = 0x1501, | 
					
						
							|  |  |  |             AndReverse = 0x1502, | 
					
						
							|  |  |  |             Copy = 0x1503, | 
					
						
							|  |  |  |             AndInverted = 0x1504, | 
					
						
							|  |  |  |             NoOp = 0x1505, | 
					
						
							|  |  |  |             Xor = 0x1506, | 
					
						
							|  |  |  |             Or = 0x1507, | 
					
						
							|  |  |  |             Nor = 0x1508, | 
					
						
							|  |  |  |             Equiv = 0x1509, | 
					
						
							|  |  |  |             Invert = 0x150A, | 
					
						
							|  |  |  |             OrReverse = 0x150B, | 
					
						
							|  |  |  |             CopyInverted = 0x150C, | 
					
						
							|  |  |  |             OrInverted = 0x150D, | 
					
						
							|  |  |  |             Nand = 0x150E, | 
					
						
							|  |  |  |             Set = 0x150F, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-22 00:25:46 -04:00
										 |  |  |         enum class StencilOp : u32 { | 
					
						
							|  |  |  |             Keep = 1, | 
					
						
							|  |  |  |             Zero = 2, | 
					
						
							|  |  |  |             Replace = 3, | 
					
						
							|  |  |  |             Incr = 4, | 
					
						
							|  |  |  |             Decr = 5, | 
					
						
							|  |  |  |             Invert = 6, | 
					
						
							|  |  |  |             IncrWrap = 7, | 
					
						
							|  |  |  |             DecrWrap = 8, | 
					
						
							| 
									
										
										
										
											2018-11-07 00:27:12 -03:00
										 |  |  |             KeepOGL = 0x1E00, | 
					
						
							|  |  |  |             ZeroOGL = 0, | 
					
						
							|  |  |  |             ReplaceOGL = 0x1E01, | 
					
						
							|  |  |  |             IncrOGL = 0x1E02, | 
					
						
							|  |  |  |             DecrOGL = 0x1E03, | 
					
						
							|  |  |  |             InvertOGL = 0x150A, | 
					
						
							|  |  |  |             IncrWrapOGL = 0x8507, | 
					
						
							|  |  |  |             DecrWrapOGL = 0x8508, | 
					
						
							| 
									
										
										
										
											2018-08-22 00:25:46 -04:00
										 |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-09 22:28:19 -04:00
										 |  |  |         enum class MemoryLayout : u32 { | 
					
						
							|  |  |  |             Linear = 0, | 
					
						
							|  |  |  |             BlockLinear = 1, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         enum class InvMemoryLayout : u32 { | 
					
						
							|  |  |  |             BlockLinear = 0, | 
					
						
							|  |  |  |             Linear = 1, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-27 19:40:10 -03:00
										 |  |  |         enum class CounterReset : u32 { | 
					
						
							|  |  |  |             SampleCnt = 0x01, | 
					
						
							|  |  |  |             Unk02 = 0x02, | 
					
						
							|  |  |  |             Unk03 = 0x03, | 
					
						
							|  |  |  |             Unk04 = 0x04, | 
					
						
							|  |  |  |             EmittedPrimitives = 0x10, // Not tested
 | 
					
						
							|  |  |  |             Unk11 = 0x11, | 
					
						
							|  |  |  |             Unk12 = 0x12, | 
					
						
							|  |  |  |             Unk13 = 0x13, | 
					
						
							|  |  |  |             Unk15 = 0x15, | 
					
						
							|  |  |  |             Unk16 = 0x16, | 
					
						
							|  |  |  |             Unk17 = 0x17, | 
					
						
							|  |  |  |             Unk18 = 0x18, | 
					
						
							|  |  |  |             Unk1A = 0x1A, | 
					
						
							|  |  |  |             Unk1B = 0x1B, | 
					
						
							|  |  |  |             Unk1C = 0x1C, | 
					
						
							|  |  |  |             Unk1D = 0x1D, | 
					
						
							|  |  |  |             Unk1E = 0x1E, | 
					
						
							|  |  |  |             GeneratedPrimitives = 0x1F, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-28 21:41:41 -03:00
										 |  |  |         enum class FrontFace : u32 { | 
					
						
							|  |  |  |             ClockWise = 0x0900, | 
					
						
							|  |  |  |             CounterClockWise = 0x0901, | 
					
						
							|  |  |  |         }; | 
					
						
							| 
									
										
										
										
											2018-07-02 13:31:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-28 21:41:41 -03:00
										 |  |  |         enum class CullFace : u32 { | 
					
						
							|  |  |  |             Front = 0x0404, | 
					
						
							|  |  |  |             Back = 0x0405, | 
					
						
							|  |  |  |             FrontAndBack = 0x0408, | 
					
						
							| 
									
										
										
										
											2018-07-02 13:31:20 -05:00
										 |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-13 23:13:47 -04:00
										 |  |  |         struct Blend { | 
					
						
							|  |  |  |             enum class Equation : u32 { | 
					
						
							|  |  |  |                 Add = 1, | 
					
						
							|  |  |  |                 Subtract = 2, | 
					
						
							|  |  |  |                 ReverseSubtract = 3, | 
					
						
							|  |  |  |                 Min = 4, | 
					
						
							|  |  |  |                 Max = 5, | 
					
						
							| 
									
										
										
										
											2018-11-22 00:51:01 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 // These values are used by Nouveau and some games.
 | 
					
						
							|  |  |  |                 AddGL = 0x8006, | 
					
						
							|  |  |  |                 SubtractGL = 0x8007, | 
					
						
							|  |  |  |                 ReverseSubtractGL = 0x8008, | 
					
						
							|  |  |  |                 MinGL = 0x800a, | 
					
						
							|  |  |  |                 MaxGL = 0x800b | 
					
						
							| 
									
										
										
										
											2018-04-13 23:13:47 -04:00
										 |  |  |             }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             enum class Factor : u32 { | 
					
						
							|  |  |  |                 Zero = 0x1, | 
					
						
							|  |  |  |                 One = 0x2, | 
					
						
							|  |  |  |                 SourceColor = 0x3, | 
					
						
							|  |  |  |                 OneMinusSourceColor = 0x4, | 
					
						
							|  |  |  |                 SourceAlpha = 0x5, | 
					
						
							|  |  |  |                 OneMinusSourceAlpha = 0x6, | 
					
						
							|  |  |  |                 DestAlpha = 0x7, | 
					
						
							|  |  |  |                 OneMinusDestAlpha = 0x8, | 
					
						
							|  |  |  |                 DestColor = 0x9, | 
					
						
							|  |  |  |                 OneMinusDestColor = 0xa, | 
					
						
							|  |  |  |                 SourceAlphaSaturate = 0xb, | 
					
						
							|  |  |  |                 Source1Color = 0x10, | 
					
						
							|  |  |  |                 OneMinusSource1Color = 0x11, | 
					
						
							|  |  |  |                 Source1Alpha = 0x12, | 
					
						
							|  |  |  |                 OneMinusSource1Alpha = 0x13, | 
					
						
							|  |  |  |                 ConstantColor = 0x61, | 
					
						
							|  |  |  |                 OneMinusConstantColor = 0x62, | 
					
						
							|  |  |  |                 ConstantAlpha = 0x63, | 
					
						
							|  |  |  |                 OneMinusConstantAlpha = 0x64, | 
					
						
							| 
									
										
										
										
											2018-08-11 20:57:16 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 // These values are used by Nouveau and some games.
 | 
					
						
							|  |  |  |                 ZeroGL = 0x4000, | 
					
						
							|  |  |  |                 OneGL = 0x4001, | 
					
						
							|  |  |  |                 SourceColorGL = 0x4300, | 
					
						
							|  |  |  |                 OneMinusSourceColorGL = 0x4301, | 
					
						
							|  |  |  |                 SourceAlphaGL = 0x4302, | 
					
						
							|  |  |  |                 OneMinusSourceAlphaGL = 0x4303, | 
					
						
							|  |  |  |                 DestAlphaGL = 0x4304, | 
					
						
							|  |  |  |                 OneMinusDestAlphaGL = 0x4305, | 
					
						
							|  |  |  |                 DestColorGL = 0x4306, | 
					
						
							|  |  |  |                 OneMinusDestColorGL = 0x4307, | 
					
						
							|  |  |  |                 SourceAlphaSaturateGL = 0x4308, | 
					
						
							|  |  |  |                 ConstantColorGL = 0xc001, | 
					
						
							|  |  |  |                 OneMinusConstantColorGL = 0xc002, | 
					
						
							|  |  |  |                 ConstantAlphaGL = 0xc003, | 
					
						
							|  |  |  |                 OneMinusConstantAlphaGL = 0xc004, | 
					
						
							|  |  |  |                 Source1ColorGL = 0xc900, | 
					
						
							|  |  |  |                 OneMinusSource1ColorGL = 0xc901, | 
					
						
							|  |  |  |                 Source1AlphaGL = 0xc902, | 
					
						
							|  |  |  |                 OneMinusSource1AlphaGL = 0xc903, | 
					
						
							| 
									
										
										
										
											2018-04-13 23:13:47 -04:00
										 |  |  |             }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             u32 separate_alpha; | 
					
						
							|  |  |  |             Equation equation_rgb; | 
					
						
							|  |  |  |             Factor factor_source_rgb; | 
					
						
							|  |  |  |             Factor factor_dest_rgb; | 
					
						
							|  |  |  |             Equation equation_a; | 
					
						
							|  |  |  |             Factor factor_source_a; | 
					
						
							|  |  |  |             Factor factor_dest_a; | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |             INSERT_UNION_PADDING_WORDS(1); | 
					
						
							| 
									
										
										
										
											2018-04-13 23:13:47 -04:00
										 |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-01 00:43:59 -03:00
										 |  |  |         enum class TessellationPrimitive : u32 { | 
					
						
							|  |  |  |             Isolines = 0, | 
					
						
							|  |  |  |             Triangles = 1, | 
					
						
							|  |  |  |             Quads = 2, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         enum class TessellationSpacing : u32 { | 
					
						
							|  |  |  |             Equal = 0, | 
					
						
							|  |  |  |             FractionalOdd = 1, | 
					
						
							|  |  |  |             FractionalEven = 2, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-24 19:43:57 -03:00
										 |  |  |         enum class PolygonMode : u32 { | 
					
						
							|  |  |  |             Point = 0x1b00, | 
					
						
							|  |  |  |             Line = 0x1b01, | 
					
						
							|  |  |  |             Fill = 0x1b02, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-26 14:38:53 -04:00
										 |  |  |         struct RenderTargetConfig { | 
					
						
							|  |  |  |             u32 address_high; | 
					
						
							|  |  |  |             u32 address_low; | 
					
						
							|  |  |  |             u32 width; | 
					
						
							|  |  |  |             u32 height; | 
					
						
							|  |  |  |             Tegra::RenderTargetFormat format; | 
					
						
							| 
									
										
										
										
											2018-10-08 14:34:55 -04:00
										 |  |  |             union { | 
					
						
							|  |  |  |                 BitField<0, 3, u32> block_width; | 
					
						
							|  |  |  |                 BitField<4, 3, u32> block_height; | 
					
						
							|  |  |  |                 BitField<8, 3, u32> block_depth; | 
					
						
							| 
									
										
										
										
											2018-10-09 22:28:19 -04:00
										 |  |  |                 BitField<12, 1, InvMemoryLayout> type; | 
					
						
							|  |  |  |             } memory_layout; | 
					
						
							| 
									
										
										
										
											2018-10-15 21:04:20 -04:00
										 |  |  |             union { | 
					
						
							| 
									
										
										
										
											2020-02-16 04:12:38 -03:00
										 |  |  |                 BitField<0, 16, u32> layers; | 
					
						
							| 
									
										
										
										
											2018-10-15 21:04:20 -04:00
										 |  |  |                 BitField<16, 1, u32> volume; | 
					
						
							|  |  |  |             }; | 
					
						
							| 
									
										
										
										
											2018-06-26 14:38:53 -04:00
										 |  |  |             u32 layer_stride; | 
					
						
							|  |  |  |             u32 base_layer; | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |             INSERT_UNION_PADDING_WORDS(7); | 
					
						
							| 
									
										
										
										
											2018-06-26 14:38:53 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |             GPUVAddr Address() const { | 
					
						
							|  |  |  |                 return static_cast<GPUVAddr>((static_cast<GPUVAddr>(address_high) << 32) | | 
					
						
							|  |  |  |                                              address_low); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-04 23:46:06 -03:00
										 |  |  |         struct ColorMask { | 
					
						
							|  |  |  |             union { | 
					
						
							|  |  |  |                 u32 raw; | 
					
						
							|  |  |  |                 BitField<0, 4, u32> R; | 
					
						
							|  |  |  |                 BitField<4, 4, u32> G; | 
					
						
							|  |  |  |                 BitField<8, 4, u32> B; | 
					
						
							|  |  |  |                 BitField<12, 4, u32> A; | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-14 14:34:02 -03:00
										 |  |  |         struct ViewportTransform { | 
					
						
							|  |  |  |             f32 scale_x; | 
					
						
							|  |  |  |             f32 scale_y; | 
					
						
							|  |  |  |             f32 scale_z; | 
					
						
							|  |  |  |             f32 translate_x; | 
					
						
							|  |  |  |             f32 translate_y; | 
					
						
							|  |  |  |             f32 translate_z; | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |             INSERT_UNION_PADDING_WORDS(2); | 
					
						
							| 
									
										
										
										
											2018-11-14 14:34:02 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-26 01:50:38 -03:00
										 |  |  |             Common::Rectangle<f32> GetRect() const { | 
					
						
							| 
									
										
										
										
											2018-11-14 14:34:02 -03:00
										 |  |  |                 return { | 
					
						
							|  |  |  |                     GetX(),               // left
 | 
					
						
							|  |  |  |                     GetY() + GetHeight(), // top
 | 
					
						
							|  |  |  |                     GetX() + GetWidth(),  // right
 | 
					
						
							|  |  |  |                     GetY()                // bottom
 | 
					
						
							|  |  |  |                 }; | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-26 01:50:38 -03:00
										 |  |  |             f32 GetX() const { | 
					
						
							|  |  |  |                 return std::max(0.0f, translate_x - std::fabs(scale_x)); | 
					
						
							| 
									
										
										
										
											2018-11-14 14:34:02 -03:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-26 01:50:38 -03:00
										 |  |  |             f32 GetY() const { | 
					
						
							|  |  |  |                 return std::max(0.0f, translate_y - std::fabs(scale_y)); | 
					
						
							| 
									
										
										
										
											2018-11-14 14:34:02 -03:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-26 01:50:38 -03:00
										 |  |  |             f32 GetWidth() const { | 
					
						
							|  |  |  |                 return translate_x + std::fabs(scale_x) - GetX(); | 
					
						
							| 
									
										
										
										
											2018-11-14 14:34:02 -03:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-26 01:50:38 -03:00
										 |  |  |             f32 GetHeight() const { | 
					
						
							|  |  |  |                 return translate_y + std::fabs(scale_y) - GetY(); | 
					
						
							| 
									
										
										
										
											2018-11-14 14:34:02 -03:00
										 |  |  |             } | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         struct ScissorTest { | 
					
						
							|  |  |  |             u32 enable; | 
					
						
							|  |  |  |             union { | 
					
						
							|  |  |  |                 BitField<0, 16, u32> min_x; | 
					
						
							|  |  |  |                 BitField<16, 16, u32> max_x; | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  |             union { | 
					
						
							|  |  |  |                 BitField<0, 16, u32> min_y; | 
					
						
							|  |  |  |                 BitField<16, 16, u32> max_y; | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  |             u32 fill; | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         struct ViewPort { | 
					
						
							|  |  |  |             union { | 
					
						
							|  |  |  |                 BitField<0, 16, u32> x; | 
					
						
							|  |  |  |                 BitField<16, 16, u32> width; | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  |             union { | 
					
						
							|  |  |  |                 BitField<0, 16, u32> y; | 
					
						
							|  |  |  |                 BitField<16, 16, u32> height; | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  |             float depth_range_near; | 
					
						
							|  |  |  |             float depth_range_far; | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-11 01:08:28 -03:00
										 |  |  |         struct TransformFeedbackBinding { | 
					
						
							| 
									
										
										
										
											2020-03-02 01:54:00 -03:00
										 |  |  |             u32 buffer_enable; | 
					
						
							|  |  |  |             u32 address_high; | 
					
						
							|  |  |  |             u32 address_low; | 
					
						
							|  |  |  |             s32 buffer_size; | 
					
						
							|  |  |  |             s32 buffer_offset; | 
					
						
							| 
									
										
										
										
											2020-03-11 01:08:28 -03:00
										 |  |  |             INSERT_UNION_PADDING_WORDS(3); | 
					
						
							| 
									
										
										
										
											2020-03-02 19:31:26 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |             GPUVAddr Address() const { | 
					
						
							|  |  |  |                 return static_cast<GPUVAddr>((static_cast<GPUVAddr>(address_high) << 32) | | 
					
						
							|  |  |  |                                              address_low); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-03-02 01:54:00 -03:00
										 |  |  |         }; | 
					
						
							|  |  |  |         static_assert(sizeof(TransformFeedbackBinding) == 32); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-11 01:08:28 -03:00
										 |  |  |         struct TransformFeedbackLayout { | 
					
						
							| 
									
										
										
										
											2020-03-02 01:54:00 -03:00
										 |  |  |             u32 stream; | 
					
						
							|  |  |  |             u32 varying_count; | 
					
						
							|  |  |  |             u32 stride; | 
					
						
							| 
									
										
										
										
											2020-03-11 01:08:28 -03:00
										 |  |  |             INSERT_UNION_PADDING_WORDS(1); | 
					
						
							| 
									
										
										
										
											2020-03-02 01:54:00 -03:00
										 |  |  |         }; | 
					
						
							|  |  |  |         static_assert(sizeof(TransformFeedbackLayout) == 16); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-15 15:21:06 +02:00
										 |  |  |         bool IsShaderConfigEnabled(std::size_t index) const { | 
					
						
							| 
									
										
										
										
											2018-07-12 22:57:57 -04:00
										 |  |  |             // The VertexB is always enabled.
 | 
					
						
							| 
									
										
										
										
											2018-09-15 15:21:06 +02:00
										 |  |  |             if (index == static_cast<std::size_t>(Regs::ShaderProgram::VertexB)) { | 
					
						
							| 
									
										
										
										
											2018-07-12 22:57:57 -04:00
										 |  |  |                 return true; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             return shader_config[index].enable != 0; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-02 19:31:26 -03:00
										 |  |  |         bool IsShaderConfigEnabled(Regs::ShaderProgram type) const { | 
					
						
							|  |  |  |             return IsShaderConfigEnabled(static_cast<std::size_t>(type)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  |         union { | 
					
						
							|  |  |  |             struct { | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x45); | 
					
						
							| 
									
										
										
										
											2018-04-23 20:01:29 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							| 
									
										
										
										
											2018-10-29 23:36:03 -04:00
										 |  |  |                     u32 upload_address; | 
					
						
							| 
									
										
										
										
											2018-04-23 20:01:29 -05:00
										 |  |  |                     u32 data; | 
					
						
							|  |  |  |                     u32 entry; | 
					
						
							| 
									
										
										
										
											2018-10-29 23:36:03 -04:00
										 |  |  |                     u32 bind; | 
					
						
							| 
									
										
										
										
											2018-04-23 20:01:29 -05:00
										 |  |  |                 } macros; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x17); | 
					
						
							| 
									
										
										
										
											2019-04-22 19:27:36 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-25 12:57:10 -04:00
										 |  |  |                 Upload::Registers upload; | 
					
						
							| 
									
										
										
										
											2019-04-22 19:27:36 -04:00
										 |  |  |                 struct { | 
					
						
							|  |  |  |                     union { | 
					
						
							|  |  |  |                         BitField<0, 1, u32> linear; | 
					
						
							|  |  |  |                     }; | 
					
						
							|  |  |  |                 } exec_upload; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 u32 data_upload; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x44); | 
					
						
							| 
									
										
										
										
											2019-04-02 11:46:00 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     union { | 
					
						
							|  |  |  |                         BitField<0, 16, u32> sync_point; | 
					
						
							|  |  |  |                         BitField<16, 1, u32> unknown; | 
					
						
							|  |  |  |                         BitField<20, 1, u32> increment; | 
					
						
							|  |  |  |                     }; | 
					
						
							|  |  |  |                 } sync_info; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-01 00:43:59 -03:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x15); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 union { | 
					
						
							|  |  |  |                     BitField<0, 2, TessellationPrimitive> prim; | 
					
						
							|  |  |  |                     BitField<4, 2, TessellationSpacing> spacing; | 
					
						
							|  |  |  |                     BitField<8, 1, u32> cw; | 
					
						
							|  |  |  |                     BitField<9, 1, u32> connected; | 
					
						
							|  |  |  |                 } tess_mode; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-01 04:39:48 -03:00
										 |  |  |                 std::array<f32, 4> tess_level_outer; | 
					
						
							|  |  |  |                 std::array<f32, 2> tess_level_inner; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-18 19:26:52 -03:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x10); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 u32 rasterize_enable; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-02 01:54:00 -03:00
										 |  |  |                 std::array<TransformFeedbackBinding, NumTransformFeedbackBuffers> tfb_bindings; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 INSERT_UNION_PADDING_WORDS(0xC0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 std::array<TransformFeedbackLayout, NumTransformFeedbackBuffers> tfb_layouts; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 INSERT_UNION_PADDING_WORDS(0x1); | 
					
						
							| 
									
										
										
										
											2018-09-25 19:41:21 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 tfb_enabled; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x2E); | 
					
						
							| 
									
										
										
										
											2018-03-19 16:46:29 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-13 20:13:16 -03:00
										 |  |  |                 std::array<RenderTargetConfig, NumRenderTargets> rt; | 
					
						
							| 
									
										
										
										
											2018-03-19 16:46:29 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-13 20:13:16 -03:00
										 |  |  |                 std::array<ViewportTransform, NumViewports> viewport_transform; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 std::array<ViewPort, NumViewports> viewports; | 
					
						
							| 
									
										
										
										
											2018-03-24 01:22:19 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x1D); | 
					
						
							| 
									
										
										
										
											2018-03-20 23:28:06 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 first; | 
					
						
							|  |  |  |                     u32 count; | 
					
						
							|  |  |  |                 } vertex_buffer; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-10 17:33:49 -04:00
										 |  |  |                 DepthMode depth_mode; | 
					
						
							| 
									
										
										
										
											2018-06-06 23:53:43 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 float clear_color[4]; | 
					
						
							|  |  |  |                 float clear_depth; | 
					
						
							| 
									
										
										
										
											2018-11-26 20:31:44 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x3); | 
					
						
							| 
									
										
										
										
											2018-11-26 20:31:44 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-22 00:25:46 -04:00
										 |  |  |                 s32 clear_stencil; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-24 19:43:57 -03:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 PolygonMode polygon_mode_front; | 
					
						
							|  |  |  |                 PolygonMode polygon_mode_back; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 INSERT_UNION_PADDING_WORDS(0x3); | 
					
						
							| 
									
										
										
										
											2018-11-26 20:31:44 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 polygon_offset_point_enable; | 
					
						
							|  |  |  |                 u32 polygon_offset_line_enable; | 
					
						
							|  |  |  |                 u32 polygon_offset_fill_enable; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-01 00:36:19 -03:00
										 |  |  |                 u32 patch_vertices; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 INSERT_UNION_PADDING_WORDS(0xC); | 
					
						
							| 
									
										
										
										
											2018-10-08 20:49:36 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-13 20:13:16 -03:00
										 |  |  |                 std::array<ScissorTest, NumViewports> scissor_test; | 
					
						
							| 
									
										
										
										
											2018-10-08 20:49:36 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x15); | 
					
						
							| 
									
										
										
										
											2018-08-22 00:25:46 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 s32 stencil_back_func_ref; | 
					
						
							| 
									
										
										
										
											2019-11-13 16:33:35 -03:00
										 |  |  |                 u32 stencil_back_mask; | 
					
						
							| 
									
										
										
										
											2020-02-02 17:50:46 -03:00
										 |  |  |                 u32 stencil_back_func_mask; | 
					
						
							| 
									
										
										
										
											2018-06-06 23:53:43 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0xC); | 
					
						
							| 
									
										
										
										
											2018-11-04 23:46:06 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 color_mask_common; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-06 01:39:41 -03:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x2); | 
					
						
							| 
									
										
										
										
											2018-09-09 19:01:21 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-29 20:45:12 -03:00
										 |  |  |                 f32 depth_bounds[2]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-06 01:39:41 -03:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 u32 rt_separate_frag_data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 INSERT_UNION_PADDING_WORDS(0xC); | 
					
						
							| 
									
										
										
										
											2018-03-19 16:49:41 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 address_high; | 
					
						
							|  |  |  |                     u32 address_low; | 
					
						
							| 
									
										
										
										
											2018-07-02 12:42:04 -05:00
										 |  |  |                     Tegra::DepthFormat format; | 
					
						
							| 
									
										
										
										
											2018-10-08 14:34:55 -04:00
										 |  |  |                     union { | 
					
						
							|  |  |  |                         BitField<0, 4, u32> block_width; | 
					
						
							|  |  |  |                         BitField<4, 4, u32> block_height; | 
					
						
							|  |  |  |                         BitField<8, 4, u32> block_depth; | 
					
						
							| 
									
										
										
										
											2018-10-09 22:28:19 -04:00
										 |  |  |                         BitField<20, 1, InvMemoryLayout> type; | 
					
						
							|  |  |  |                     } memory_layout; | 
					
						
							| 
									
										
										
										
											2018-03-19 16:49:41 -05:00
										 |  |  |                     u32 layer_stride; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     GPUVAddr Address() const { | 
					
						
							|  |  |  |                         return static_cast<GPUVAddr>((static_cast<GPUVAddr>(address_high) << 32) | | 
					
						
							|  |  |  |                                                      address_low); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } zeta; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x41); | 
					
						
							| 
									
										
										
										
											2018-11-21 00:40:32 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 union { | 
					
						
							|  |  |  |                     BitField<0, 4, u32> stencil; | 
					
						
							|  |  |  |                     BitField<4, 4, u32> unknown; | 
					
						
							|  |  |  |                     BitField<8, 4, u32> scissor; | 
					
						
							|  |  |  |                     BitField<12, 4, u32> viewport; | 
					
						
							|  |  |  |                 } clear_flags; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-24 19:43:57 -03:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x10); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 u32 fill_rectangle; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 INSERT_UNION_PADDING_WORDS(0x8); | 
					
						
							| 
									
										
										
										
											2018-03-20 23:33:56 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-05 11:36:50 +02:00
										 |  |  |                 std::array<VertexAttribute, NumVertexAttributes> vertex_attrib_format; | 
					
						
							| 
									
										
										
										
											2018-03-20 23:33:56 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0xF); | 
					
						
							| 
									
										
										
										
											2018-03-19 16:46:29 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     union { | 
					
						
							|  |  |  |                         BitField<0, 4, u32> count; | 
					
						
							| 
									
										
										
										
											2018-09-09 19:01:21 -04:00
										 |  |  |                         BitField<4, 3, u32> map_0; | 
					
						
							|  |  |  |                         BitField<7, 3, u32> map_1; | 
					
						
							|  |  |  |                         BitField<10, 3, u32> map_2; | 
					
						
							|  |  |  |                         BitField<13, 3, u32> map_3; | 
					
						
							|  |  |  |                         BitField<16, 3, u32> map_4; | 
					
						
							|  |  |  |                         BitField<19, 3, u32> map_5; | 
					
						
							|  |  |  |                         BitField<22, 3, u32> map_6; | 
					
						
							|  |  |  |                         BitField<25, 3, u32> map_7; | 
					
						
							| 
									
										
										
										
											2018-03-19 16:46:29 -05:00
										 |  |  |                     }; | 
					
						
							| 
									
										
										
										
											2018-09-09 19:01:21 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-15 15:21:06 +02:00
										 |  |  |                     u32 GetMap(std::size_t index) const { | 
					
						
							| 
									
										
										
										
											2018-09-09 19:01:21 -04:00
										 |  |  |                         const std::array<u32, NumRenderTargets> maps{map_0, map_1, map_2, map_3, | 
					
						
							|  |  |  |                                                                      map_4, map_5, map_6, map_7}; | 
					
						
							|  |  |  |                         ASSERT(index < maps.size()); | 
					
						
							|  |  |  |                         return maps[index]; | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2018-03-19 16:46:29 -05:00
										 |  |  |                 } rt_control; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x2); | 
					
						
							| 
									
										
										
										
											2018-07-21 01:54:47 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 zeta_width; | 
					
						
							|  |  |  |                 u32 zeta_height; | 
					
						
							| 
									
										
										
										
											2020-02-16 04:12:38 -03:00
										 |  |  |                 union { | 
					
						
							|  |  |  |                     BitField<0, 16, u32> zeta_layers; | 
					
						
							|  |  |  |                     BitField<16, 1, u32> zeta_volume; | 
					
						
							|  |  |  |                 }; | 
					
						
							| 
									
										
										
										
											2018-07-21 01:54:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-16 04:12:38 -03:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x26); | 
					
						
							| 
									
										
										
										
											2018-07-02 13:31:20 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 depth_test_enable; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x5); | 
					
						
							| 
									
										
										
										
											2018-06-08 17:04:41 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 independent_blend_enable; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 13:31:20 -05:00
										 |  |  |                 u32 depth_write_enabled; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-25 19:41:21 -03:00
										 |  |  |                 u32 alpha_test_enabled; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x6); | 
					
						
							| 
									
										
										
										
											2018-07-04 10:26:46 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 d3d_cull_mode; | 
					
						
							| 
									
										
										
										
											2018-07-02 13:31:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-05 13:01:31 -05:00
										 |  |  |                 ComparisonOp depth_test_func; | 
					
						
							| 
									
										
										
										
											2018-10-08 23:34:11 -04:00
										 |  |  |                 float alpha_test_ref; | 
					
						
							|  |  |  |                 ComparisonOp alpha_test_func; | 
					
						
							| 
									
										
										
										
											2018-11-02 00:21:25 -03:00
										 |  |  |                 u32 draw_tfb_stride; | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     float r; | 
					
						
							|  |  |  |                     float g; | 
					
						
							|  |  |  |                     float b; | 
					
						
							|  |  |  |                     float a; | 
					
						
							|  |  |  |                 } blend_color; | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x4); | 
					
						
							| 
									
										
										
										
											2018-06-08 17:04:41 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 separate_alpha; | 
					
						
							|  |  |  |                     Blend::Equation equation_rgb; | 
					
						
							|  |  |  |                     Blend::Factor factor_source_rgb; | 
					
						
							|  |  |  |                     Blend::Factor factor_dest_rgb; | 
					
						
							|  |  |  |                     Blend::Equation equation_a; | 
					
						
							|  |  |  |                     Blend::Factor factor_source_a; | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                     INSERT_UNION_PADDING_WORDS(1); | 
					
						
							| 
									
										
										
										
											2018-06-08 17:04:41 -05:00
										 |  |  |                     Blend::Factor factor_dest_a; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     u32 enable_common; | 
					
						
							|  |  |  |                     u32 enable[NumRenderTargets]; | 
					
						
							|  |  |  |                 } blend; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-22 00:25:46 -04:00
										 |  |  |                 u32 stencil_enable; | 
					
						
							|  |  |  |                 StencilOp stencil_front_op_fail; | 
					
						
							|  |  |  |                 StencilOp stencil_front_op_zfail; | 
					
						
							|  |  |  |                 StencilOp stencil_front_op_zpass; | 
					
						
							|  |  |  |                 ComparisonOp stencil_front_func_func; | 
					
						
							|  |  |  |                 s32 stencil_front_func_ref; | 
					
						
							|  |  |  |                 u32 stencil_front_func_mask; | 
					
						
							|  |  |  |                 u32 stencil_front_mask; | 
					
						
							| 
									
										
										
										
											2018-07-17 15:00:21 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x2); | 
					
						
							| 
									
										
										
										
											2018-11-13 22:09:01 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 frag_color_clamp; | 
					
						
							| 
									
										
										
										
											2018-07-04 10:26:46 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 union { | 
					
						
							| 
									
										
										
										
											2018-11-25 04:37:29 -03:00
										 |  |  |                     BitField<0, 1, u32> y_negate; | 
					
						
							| 
									
										
										
										
											2018-07-04 10:26:46 -05:00
										 |  |  |                     BitField<4, 1, u32> triangle_rast_flip; | 
					
						
							|  |  |  |                 } screen_y_control; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x21); | 
					
						
							| 
									
										
										
										
											2018-07-02 11:21:23 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 vb_element_base; | 
					
						
							| 
									
										
										
										
											2019-09-15 11:48:54 -04:00
										 |  |  |                 u32 vb_base_instance; | 
					
						
							| 
									
										
										
										
											2018-07-02 11:21:23 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x35); | 
					
						
							| 
									
										
										
										
											2018-11-26 20:45:21 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-26 02:20:08 -03:00
										 |  |  |                 u32 clip_distance_enabled; | 
					
						
							| 
									
										
										
										
											2018-11-26 20:45:21 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-27 19:40:10 -03:00
										 |  |  |                 u32 samplecnt_enable; | 
					
						
							| 
									
										
										
										
											2018-09-28 01:31:01 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 float point_size; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-04 15:19:45 -03:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 u32 point_sprite_enable; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-27 19:40:10 -03:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x3); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 CounterReset counter_reset; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 INSERT_UNION_PADDING_WORDS(0x1); | 
					
						
							| 
									
										
										
										
											2018-07-21 01:54:47 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 zeta_enable; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-14 00:02:54 -03:00
										 |  |  |                 union { | 
					
						
							| 
									
										
										
										
											2018-11-14 17:31:47 -03:00
										 |  |  |                     BitField<0, 1, u32> alpha_to_coverage; | 
					
						
							|  |  |  |                     BitField<4, 1, u32> alpha_to_one; | 
					
						
							| 
									
										
										
										
											2018-11-14 00:02:54 -03:00
										 |  |  |                 } multisample_control; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x4); | 
					
						
							| 
									
										
										
										
											2019-06-30 22:21:28 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 address_high; | 
					
						
							|  |  |  |                     u32 address_low; | 
					
						
							|  |  |  |                     ConditionMode mode; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     GPUVAddr Address() const { | 
					
						
							|  |  |  |                         return static_cast<GPUVAddr>((static_cast<GPUVAddr>(address_high) << 32) | | 
					
						
							|  |  |  |                                                      address_low); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } condition; | 
					
						
							| 
									
										
										
										
											2018-03-19 00:36:25 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 tsc_address_high; | 
					
						
							|  |  |  |                     u32 tsc_address_low; | 
					
						
							|  |  |  |                     u32 tsc_limit; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     GPUVAddr TSCAddress() const { | 
					
						
							|  |  |  |                         return static_cast<GPUVAddr>( | 
					
						
							|  |  |  |                             (static_cast<GPUVAddr>(tsc_address_high) << 32) | tsc_address_low); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } tsc; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x1); | 
					
						
							| 
									
										
										
										
											2018-11-26 20:31:44 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 float polygon_offset_factor; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x1); | 
					
						
							| 
									
										
										
										
											2018-03-19 00:32:57 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 tic_address_high; | 
					
						
							|  |  |  |                     u32 tic_address_low; | 
					
						
							|  |  |  |                     u32 tic_limit; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     GPUVAddr TICAddress() const { | 
					
						
							|  |  |  |                         return static_cast<GPUVAddr>( | 
					
						
							|  |  |  |                             (static_cast<GPUVAddr>(tic_address_high) << 32) | tic_address_low); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } tic; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x5); | 
					
						
							| 
									
										
										
										
											2018-07-17 15:00:21 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-22 00:25:46 -04:00
										 |  |  |                 u32 stencil_two_side_enable; | 
					
						
							|  |  |  |                 StencilOp stencil_back_op_fail; | 
					
						
							|  |  |  |                 StencilOp stencil_back_op_zfail; | 
					
						
							|  |  |  |                 StencilOp stencil_back_op_zpass; | 
					
						
							|  |  |  |                 ComparisonOp stencil_back_func_func; | 
					
						
							| 
									
										
										
										
											2018-07-17 15:00:21 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x4); | 
					
						
							| 
									
										
										
										
											2018-10-24 17:09:40 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 framebuffer_srgb; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-26 20:31:44 -03:00
										 |  |  |                 float polygon_offset_units; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x11); | 
					
						
							| 
									
										
										
										
											2018-07-04 10:26:46 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 union { | 
					
						
							|  |  |  |                     BitField<2, 1, u32> coord_origin; | 
					
						
							|  |  |  |                     BitField<3, 10, u32> enable; | 
					
						
							|  |  |  |                 } point_coord_replace; | 
					
						
							| 
									
										
										
										
											2018-03-19 00:32:57 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 19:23:11 -05:00
										 |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 code_address_high; | 
					
						
							|  |  |  |                     u32 code_address_low; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     GPUVAddr CodeAddress() const { | 
					
						
							|  |  |  |                         return static_cast<GPUVAddr>( | 
					
						
							|  |  |  |                             (static_cast<GPUVAddr>(code_address_high) << 32) | code_address_low); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } code_address; | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(1); | 
					
						
							| 
									
										
										
										
											2018-03-22 19:47:28 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-04 19:13:15 -05:00
										 |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 vertex_end_gl; | 
					
						
							| 
									
										
										
										
											2018-03-20 23:28:06 -05:00
										 |  |  |                     union { | 
					
						
							|  |  |  |                         u32 vertex_begin_gl; | 
					
						
							| 
									
										
										
										
											2018-03-22 19:47:28 -04:00
										 |  |  |                         BitField<0, 16, PrimitiveTopology> topology; | 
					
						
							| 
									
										
										
										
											2018-08-11 19:21:31 -05:00
										 |  |  |                         BitField<26, 1, u32> instance_next; | 
					
						
							|  |  |  |                         BitField<27, 1, u32> instance_cont; | 
					
						
							| 
									
										
										
										
											2018-03-20 23:28:06 -05:00
										 |  |  |                     }; | 
					
						
							| 
									
										
										
										
											2018-03-04 19:13:15 -05:00
										 |  |  |                 } draw; | 
					
						
							| 
									
										
										
										
											2018-03-22 19:47:28 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0xA); | 
					
						
							| 
									
										
										
										
											2018-10-25 19:04:13 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 enabled; | 
					
						
							|  |  |  |                     u32 index; | 
					
						
							|  |  |  |                 } primitive_restart; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x5F); | 
					
						
							| 
									
										
										
										
											2018-04-13 14:18:37 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 start_addr_high; | 
					
						
							|  |  |  |                     u32 start_addr_low; | 
					
						
							|  |  |  |                     u32 end_addr_high; | 
					
						
							|  |  |  |                     u32 end_addr_low; | 
					
						
							|  |  |  |                     IndexFormat format; | 
					
						
							|  |  |  |                     u32 first; | 
					
						
							|  |  |  |                     u32 count; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     unsigned FormatSizeInBytes() const { | 
					
						
							|  |  |  |                         switch (format) { | 
					
						
							|  |  |  |                         case IndexFormat::UnsignedByte: | 
					
						
							|  |  |  |                             return 1; | 
					
						
							|  |  |  |                         case IndexFormat::UnsignedShort: | 
					
						
							|  |  |  |                             return 2; | 
					
						
							|  |  |  |                         case IndexFormat::UnsignedInt: | 
					
						
							|  |  |  |                             return 4; | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         UNREACHABLE(); | 
					
						
							| 
									
										
										
										
											2018-12-19 12:52:32 +11:00
										 |  |  |                         return 1; | 
					
						
							| 
									
										
										
										
											2018-04-13 14:18:37 -04:00
										 |  |  |                     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     GPUVAddr StartAddress() const { | 
					
						
							|  |  |  |                         return static_cast<GPUVAddr>( | 
					
						
							|  |  |  |                             (static_cast<GPUVAddr>(start_addr_high) << 32) | start_addr_low); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     GPUVAddr EndAddress() const { | 
					
						
							|  |  |  |                         return static_cast<GPUVAddr>((static_cast<GPUVAddr>(end_addr_high) << 32) | | 
					
						
							|  |  |  |                                                      end_addr_low); | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2018-10-02 14:47:26 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |                     /// Adjust the index buffer offset so it points to the first desired index.
 | 
					
						
							|  |  |  |                     GPUVAddr IndexStart() const { | 
					
						
							|  |  |  |                         return StartAddress() + static_cast<size_t>(first) * | 
					
						
							|  |  |  |                                                     static_cast<size_t>(FormatSizeInBytes()); | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2018-04-13 14:18:37 -04:00
										 |  |  |                 } index_array; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x7); | 
					
						
							| 
									
										
										
										
											2018-07-02 13:31:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x1F); | 
					
						
							| 
									
										
										
										
											2018-11-26 20:31:44 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 float polygon_offset_clamp; | 
					
						
							| 
									
										
										
										
											2018-08-18 14:42:26 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 is_instanced[NumVertexArrays]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     /// Returns whether the vertex array specified by index is supposed to be
 | 
					
						
							|  |  |  |                     /// accessed per instance or not.
 | 
					
						
							|  |  |  |                     bool IsInstancingEnabled(u32 index) const { | 
					
						
							|  |  |  |                         return is_instanced[index]; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } instanced_arrays; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-15 16:14:17 -03:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x4); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 union { | 
					
						
							|  |  |  |                     BitField<0, 1, u32> enable; | 
					
						
							|  |  |  |                     BitField<4, 8, u32> unk4; | 
					
						
							|  |  |  |                 } vp_point_size; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 INSERT_UNION_PADDING_WORDS(1); | 
					
						
							| 
									
										
										
										
											2018-07-02 13:31:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-28 21:41:41 -03:00
										 |  |  |                 u32 cull_test_enabled; | 
					
						
							|  |  |  |                 FrontFace front_face; | 
					
						
							|  |  |  |                 CullFace cull_face; | 
					
						
							| 
									
										
										
										
											2018-07-02 13:31:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-24 13:15:14 -03:00
										 |  |  |                 u32 pixel_center_integer; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x1); | 
					
						
							| 
									
										
										
										
											2018-11-24 13:15:14 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 viewport_transform_enabled; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x3); | 
					
						
							| 
									
										
										
										
											2018-11-23 12:11:21 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 union { | 
					
						
							|  |  |  |                     BitField<0, 1, u32> depth_range_0_1; | 
					
						
							|  |  |  |                     BitField<3, 1, u32> depth_clamp_near; | 
					
						
							|  |  |  |                     BitField<4, 1, u32> depth_clamp_far; | 
					
						
							|  |  |  |                 } view_volume_clip_control; | 
					
						
							| 
									
										
										
										
											2018-08-20 18:42:36 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-06 01:39:41 -03:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x1F); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 u32 depth_bounds_enable; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 INSERT_UNION_PADDING_WORDS(1); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-20 18:42:36 -05:00
										 |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 enable; | 
					
						
							|  |  |  |                     LogicOperation operation; | 
					
						
							|  |  |  |                 } logic_op; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x1); | 
					
						
							| 
									
										
										
										
											2018-06-06 23:53:43 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 union { | 
					
						
							|  |  |  |                     u32 raw; | 
					
						
							|  |  |  |                     BitField<0, 1, u32> Z; | 
					
						
							|  |  |  |                     BitField<1, 1, u32> S; | 
					
						
							|  |  |  |                     BitField<2, 1, u32> R; | 
					
						
							|  |  |  |                     BitField<3, 1, u32> G; | 
					
						
							|  |  |  |                     BitField<4, 1, u32> B; | 
					
						
							|  |  |  |                     BitField<5, 1, u32> A; | 
					
						
							|  |  |  |                     BitField<6, 4, u32> RT; | 
					
						
							|  |  |  |                     BitField<10, 11, u32> layer; | 
					
						
							|  |  |  |                 } clear_buffers; | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0xB); | 
					
						
							| 
									
										
										
										
											2018-11-04 23:46:06 -03:00
										 |  |  |                 std::array<ColorMask, NumRenderTargets> color_mask; | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x38); | 
					
						
							| 
									
										
										
										
											2018-04-13 14:18:37 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 query_address_high; | 
					
						
							|  |  |  |                     u32 query_address_low; | 
					
						
							|  |  |  |                     u32 query_sequence; | 
					
						
							|  |  |  |                     union { | 
					
						
							|  |  |  |                         u32 raw; | 
					
						
							| 
									
										
										
										
											2020-01-27 22:48:15 -04:00
										 |  |  |                         BitField<0, 2, QueryOperation> operation; | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  |                         BitField<4, 1, u32> fence; | 
					
						
							| 
									
										
										
										
											2018-04-23 17:06:57 -05:00
										 |  |  |                         BitField<12, 4, QueryUnit> unit; | 
					
						
							|  |  |  |                         BitField<16, 1, QuerySyncCondition> sync_cond; | 
					
						
							|  |  |  |                         BitField<23, 5, QuerySelect> select; | 
					
						
							|  |  |  |                         BitField<28, 1, u32> short_query; | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  |                     } query_get; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     GPUVAddr QueryAddress() const { | 
					
						
							|  |  |  |                         return static_cast<GPUVAddr>( | 
					
						
							|  |  |  |                             (static_cast<GPUVAddr>(query_address_high) << 32) | query_address_low); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } query; | 
					
						
							| 
									
										
										
										
											2018-03-16 19:23:11 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x3C); | 
					
						
							| 
									
										
										
										
											2018-03-16 22:47:45 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     union { | 
					
						
							|  |  |  |                         BitField<0, 12, u32> stride; | 
					
						
							|  |  |  |                         BitField<12, 1, u32> enable; | 
					
						
							|  |  |  |                     }; | 
					
						
							|  |  |  |                     u32 start_high; | 
					
						
							|  |  |  |                     u32 start_low; | 
					
						
							|  |  |  |                     u32 divisor; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     GPUVAddr StartAddress() const { | 
					
						
							|  |  |  |                         return static_cast<GPUVAddr>((static_cast<GPUVAddr>(start_high) << 32) | | 
					
						
							|  |  |  |                                                      start_low); | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2018-04-21 19:19:33 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                     bool IsEnabled() const { | 
					
						
							|  |  |  |                         return enable != 0 && StartAddress() != 0; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 22:47:45 -05:00
										 |  |  |                 } vertex_array[NumVertexArrays]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-08 17:04:41 -05:00
										 |  |  |                 Blend independent_blend[NumRenderTargets]; | 
					
						
							| 
									
										
										
										
											2018-03-16 22:47:45 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 limit_high; | 
					
						
							|  |  |  |                     u32 limit_low; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     GPUVAddr LimitAddress() const { | 
					
						
							|  |  |  |                         return static_cast<GPUVAddr>((static_cast<GPUVAddr>(limit_high) << 32) | | 
					
						
							|  |  |  |                                                      limit_low); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } vertex_array_limit[NumVertexArrays]; | 
					
						
							| 
									
										
										
										
											2018-03-16 19:23:11 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     union { | 
					
						
							|  |  |  |                         BitField<0, 1, u32> enable; | 
					
						
							|  |  |  |                         BitField<4, 4, ShaderProgram> program; | 
					
						
							|  |  |  |                     }; | 
					
						
							| 
									
										
										
										
											2018-04-07 23:14:41 -04:00
										 |  |  |                     u32 offset; | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                     INSERT_UNION_PADDING_WORDS(14); | 
					
						
							| 
									
										
										
										
											2018-03-16 22:06:24 -05:00
										 |  |  |                 } shader_config[MaxShaderProgram]; | 
					
						
							| 
									
										
										
										
											2018-03-16 19:23:11 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x60); | 
					
						
							| 
									
										
										
										
											2019-08-31 17:43:19 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 firmware[0x20]; | 
					
						
							| 
									
										
										
										
											2018-03-17 16:17:45 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 cb_size; | 
					
						
							|  |  |  |                     u32 cb_address_high; | 
					
						
							|  |  |  |                     u32 cb_address_low; | 
					
						
							|  |  |  |                     u32 cb_pos; | 
					
						
							|  |  |  |                     u32 cb_data[NumCBData]; | 
					
						
							| 
									
										
										
										
											2018-03-17 17:06:23 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                     GPUVAddr BufferAddress() const { | 
					
						
							|  |  |  |                         return static_cast<GPUVAddr>( | 
					
						
							|  |  |  |                             (static_cast<GPUVAddr>(cb_address_high) << 32) | cb_address_low); | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2018-03-17 16:17:45 -05:00
										 |  |  |                 } const_buffer; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x10); | 
					
						
							| 
									
										
										
										
											2018-03-17 16:17:45 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     union { | 
					
						
							| 
									
										
										
										
											2018-03-17 17:06:23 -05:00
										 |  |  |                         u32 raw_config; | 
					
						
							| 
									
										
										
										
											2018-03-17 16:17:45 -05:00
										 |  |  |                         BitField<0, 1, u32> valid; | 
					
						
							|  |  |  |                         BitField<4, 5, u32> index; | 
					
						
							|  |  |  |                     }; | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                     INSERT_UNION_PADDING_WORDS(7); | 
					
						
							| 
									
										
										
										
											2018-03-17 17:08:26 -05:00
										 |  |  |                 } cb_bind[MaxShaderStage]; | 
					
						
							| 
									
										
										
										
											2018-03-17 16:17:45 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x56); | 
					
						
							| 
									
										
										
										
											2018-03-18 03:13:22 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 u32 tex_cb_index; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-02 01:54:00 -03:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x7D); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 std::array<std::array<u8, 128>, NumTransformFeedbackBuffers> tfb_varying_locs; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 INSERT_UNION_PADDING_WORDS(0x298); | 
					
						
							| 
									
										
										
										
											2018-03-18 15:22:06 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     /// Compressed address of a buffer that holds information about bound SSBOs.
 | 
					
						
							|  |  |  |                     /// This address is usually bound to c0 in the shaders.
 | 
					
						
							|  |  |  |                     u32 buffer_address; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     GPUVAddr BufferAddress() const { | 
					
						
							|  |  |  |                         return static_cast<GPUVAddr>(buffer_address) << 8; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } ssbo_info; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0x11); | 
					
						
							| 
									
										
										
										
											2018-03-18 19:03:20 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 struct { | 
					
						
							|  |  |  |                     u32 address[MaxShaderStage]; | 
					
						
							|  |  |  |                     u32 size[MaxShaderStage]; | 
					
						
							|  |  |  |                 } tex_info_buffers; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-03 18:54:03 -05:00
										 |  |  |                 INSERT_UNION_PADDING_WORDS(0xCC); | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  |             }; | 
					
						
							|  |  |  |             std::array<u32, NUM_REGS> reg_array; | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |     } regs{}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static_assert(sizeof(Regs) == Regs::NUM_REGS * sizeof(u32), "Maxwell3D Regs has wrong size"); | 
					
						
							| 
									
										
										
										
											2019-05-14 08:41:51 -04:00
										 |  |  |     static_assert(std::is_trivially_copyable_v<Regs>, "Maxwell3D Regs must be trivially copyable"); | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 22:06:24 -05:00
										 |  |  |     struct State { | 
					
						
							| 
									
										
										
										
											2018-03-17 17:06:23 -05:00
										 |  |  |         struct ShaderStageInfo { | 
					
						
							|  |  |  |             std::array<ConstBufferInfo, Regs::MaxConstBuffers> const_buffers; | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-17 17:08:26 -05:00
										 |  |  |         std::array<ShaderStageInfo, Regs::MaxShaderStage> shader_stages; | 
					
						
							| 
									
										
										
										
											2018-08-11 19:21:31 -05:00
										 |  |  |         u32 current_instance = 0; ///< Current instance to be used to simulate instanced rendering.
 | 
					
						
							| 
									
										
										
										
											2018-03-16 22:06:24 -05:00
										 |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-17 16:17:45 -05:00
										 |  |  |     State state{}; | 
					
						
							| 
									
										
										
										
											2018-03-16 22:06:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-28 15:14:47 -05:00
										 |  |  |     /// Reads a register value located at the input method address
 | 
					
						
							|  |  |  |     u32 GetRegisterValue(u32 method) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-23 18:56:27 -05:00
										 |  |  |     /// Write the value to the register identified by method.
 | 
					
						
							| 
									
										
										
										
											2018-11-23 23:20:56 -05:00
										 |  |  |     void CallMethod(const GPU::MethodCall& method_call); | 
					
						
							| 
									
										
										
										
											2018-03-23 18:56:27 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-15 11:48:54 -04:00
										 |  |  |     /// Write the value to the register identified by method.
 | 
					
						
							|  |  |  |     void CallMethodFromMME(const GPU::MethodCall& method_call); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void FlushMMEInlineDraw(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-20 04:03:33 -03:00
										 |  |  |     /// Given a texture handle, returns the TSC and TIC entries.
 | 
					
						
							|  |  |  |     Texture::FullTextureInfo GetTextureInfo(Texture::TextureHandle tex_handle) const; | 
					
						
							| 
									
										
										
										
											2019-03-26 18:18:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-06 12:58:16 -05:00
										 |  |  |     /// Returns the texture information for a specific texture in a specific shader stage.
 | 
					
						
							| 
									
										
										
										
											2019-11-18 18:35:21 -03:00
										 |  |  |     Texture::FullTextureInfo GetStageTexture(ShaderType stage, std::size_t offset) const; | 
					
						
							| 
									
										
										
										
											2018-06-06 12:58:16 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-23 14:02:02 -04:00
										 |  |  |     u32 AccessConstBuffer32(ShaderType stage, u64 const_buffer, u64 offset) const override; | 
					
						
							| 
									
										
										
										
											2019-04-07 08:30:26 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-25 09:53:18 -04:00
										 |  |  |     SamplerDescriptor AccessBoundSampler(ShaderType stage, u64 offset) const override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     SamplerDescriptor AccessBindlessSampler(ShaderType stage, u64 const_buffer, | 
					
						
							|  |  |  |                                             u64 offset) const override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     u32 GetBoundBuffer() const override { | 
					
						
							|  |  |  |         return regs.tex_cb_index; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-03 16:16:29 -04:00
										 |  |  |     VideoCore::GuestDriverProfile& AccessGuestDriverProfile() override; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-08 10:28:29 -04:00
										 |  |  |     const VideoCore::GuestDriverProfile& AccessGuestDriverProfile() const override; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-29 23:36:03 -04:00
										 |  |  |     /// Memory for macro code - it's undetermined how big this is, however 1MB is much larger than
 | 
					
						
							|  |  |  |     /// we've seen used.
 | 
					
						
							|  |  |  |     using MacroMemory = std::array<u32, 0x40000>; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets a reference to macro memory.
 | 
					
						
							|  |  |  |     const MacroMemory& GetMacroMemory() const { | 
					
						
							|  |  |  |         return macro_memory; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-30 22:21:28 -04:00
										 |  |  |     bool ShouldExecute() const { | 
					
						
							|  |  |  |         return execute_on; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-26 22:14:10 -03:00
										 |  |  |     /// Notify a memory write has happened.
 | 
					
						
							|  |  |  |     void OnMemoryWrite() { | 
					
						
							| 
									
										
										
										
											2019-12-29 01:05:02 -03:00
										 |  |  |         dirty.flags |= dirty.on_write_stores; | 
					
						
							| 
									
										
										
										
											2019-12-26 22:14:10 -03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-22 07:23:13 -04:00
										 |  |  |     enum class MMEDrawMode : u32 { | 
					
						
							| 
									
										
										
										
											2019-09-15 11:48:54 -04:00
										 |  |  |         Undefined, | 
					
						
							|  |  |  |         Array, | 
					
						
							|  |  |  |         Indexed, | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct MMEDrawState { | 
					
						
							| 
									
										
										
										
											2019-09-22 07:23:13 -04:00
										 |  |  |         MMEDrawMode current_mode{MMEDrawMode::Undefined}; | 
					
						
							| 
									
										
										
										
											2019-09-15 14:25:07 -04:00
										 |  |  |         u32 current_count{}; | 
					
						
							|  |  |  |         u32 instance_count{}; | 
					
						
							|  |  |  |         bool instance_mode{}; | 
					
						
							|  |  |  |         bool gl_begin_consume{}; | 
					
						
							|  |  |  |         u32 gl_end_count{}; | 
					
						
							| 
									
										
										
										
											2019-09-15 11:48:54 -04:00
										 |  |  |     } mme_draw; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-21 01:19:07 -03:00
										 |  |  |     struct DirtyState { | 
					
						
							|  |  |  |         using Flags = std::bitset<std::numeric_limits<u8>::max()>; | 
					
						
							|  |  |  |         using Table = std::array<u8, Regs::NUM_REGS>; | 
					
						
							|  |  |  |         using Tables = std::array<Table, 2>; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Flags flags; | 
					
						
							|  |  |  |         Flags on_write_stores; | 
					
						
							|  |  |  |         Tables tables{}; | 
					
						
							| 
									
										
										
										
											2019-12-26 22:14:10 -03:00
										 |  |  |     } dirty; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2018-10-25 23:42:39 -04:00
										 |  |  |     void InitializeRegisterDefaults(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-15 22:05:17 -05:00
										 |  |  |     Core::System& system; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-03 12:55:58 -04:00
										 |  |  |     VideoCore::RasterizerInterface& rasterizer; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-05 18:25:20 -04:00
										 |  |  |     MemoryManager& memory_manager; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-29 23:36:03 -04:00
										 |  |  |     /// Start offsets of each macro in macro_memory
 | 
					
						
							| 
									
										
										
										
											2019-09-01 04:59:27 -03:00
										 |  |  |     std::array<u32, 0x80> macro_positions = {}; | 
					
						
							| 
									
										
										
										
											2018-10-29 23:36:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-15 11:48:54 -04:00
										 |  |  |     std::array<bool, Regs::NUM_REGS> mme_inline{}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-29 23:36:03 -04:00
										 |  |  |     /// Memory for macro code
 | 
					
						
							|  |  |  |     MacroMemory macro_memory; | 
					
						
							| 
									
										
										
										
											2018-03-18 04:17:10 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-18 03:13:22 -05:00
										 |  |  |     /// Macro method that is currently being executed / being fed parameters.
 | 
					
						
							|  |  |  |     u32 executing_macro = 0; | 
					
						
							|  |  |  |     /// Parameters that have been submitted to the macro call so far.
 | 
					
						
							|  |  |  |     std::vector<u32> macro_params; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-28 15:20:18 -05:00
										 |  |  |     /// Interpreter for the macro codes uploaded to the GPU.
 | 
					
						
							|  |  |  |     MacroInterpreter macro_interpreter; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-12 09:25:47 -04:00
										 |  |  |     static constexpr u32 null_cb_data = 0xFFFFFFFF; | 
					
						
							|  |  |  |     struct { | 
					
						
							| 
									
										
										
										
											2019-07-15 10:24:01 -04:00
										 |  |  |         std::array<std::array<u32, 0x4000>, 16> buffer; | 
					
						
							| 
									
										
										
										
											2019-07-12 09:25:47 -04:00
										 |  |  |         u32 current{null_cb_data}; | 
					
						
							|  |  |  |         u32 id{null_cb_data}; | 
					
						
							|  |  |  |         u32 start_pos{}; | 
					
						
							|  |  |  |         u32 counter{}; | 
					
						
							|  |  |  |     } cb_data_state; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-17 19:37:01 -04:00
										 |  |  |     Upload::State upload_state; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-30 22:21:28 -04:00
										 |  |  |     bool execute_on{true}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-16 04:02:30 -05:00
										 |  |  |     std::array<u8, Regs::NUM_REGS> dirty_pointers{}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-26 15:46:49 -05:00
										 |  |  |     /// Retrieves information about a specific TIC entry from the TIC buffer.
 | 
					
						
							|  |  |  |     Texture::TICEntry GetTICEntry(u32 tic_index) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Retrieves information about a specific TSC entry from the TSC buffer.
 | 
					
						
							|  |  |  |     Texture::TSCEntry GetTSCEntry(u32 tsc_index) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-18 03:13:22 -05:00
										 |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2018-03-18 04:17:10 -05:00
										 |  |  |      * Call a macro on this engine. | 
					
						
							| 
									
										
										
										
											2018-03-18 03:13:22 -05:00
										 |  |  |      * @param method Method to call | 
					
						
							| 
									
										
										
										
											2019-08-25 01:08:35 -03:00
										 |  |  |      * @param num_parameters Number of arguments | 
					
						
							| 
									
										
										
										
											2018-03-18 03:13:22 -05:00
										 |  |  |      * @param parameters Arguments to the method call | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-08-25 01:08:35 -03:00
										 |  |  |     void CallMacroMethod(u32 method, std::size_t num_parameters, const u32* parameters); | 
					
						
							| 
									
										
										
										
											2018-03-18 03:13:22 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-29 23:36:03 -04:00
										 |  |  |     /// Handles writes to the macro uploading register.
 | 
					
						
							| 
									
										
										
										
											2018-04-23 20:01:29 -05:00
										 |  |  |     void ProcessMacroUpload(u32 data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-29 23:36:03 -04:00
										 |  |  |     /// Handles writes to the macro bind register.
 | 
					
						
							|  |  |  |     void ProcessMacroBind(u32 data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-31 17:43:19 -03:00
										 |  |  |     /// Handles firmware blob 4
 | 
					
						
							|  |  |  |     void ProcessFirmwareCall4(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-06 23:53:43 -05:00
										 |  |  |     /// Handles a write to the CLEAR_BUFFERS register.
 | 
					
						
							|  |  |  |     void ProcessClearBuffers(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  |     /// Handles a write to the QUERY_GET register.
 | 
					
						
							|  |  |  |     void ProcessQueryGet(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-27 19:40:10 -03:00
										 |  |  |     /// Writes the query result accordingly.
 | 
					
						
							| 
									
										
										
										
											2020-01-27 22:48:15 -04:00
										 |  |  |     void StampQueryResult(u64 payload, bool long_query); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-27 19:40:10 -03:00
										 |  |  |     /// Handles conditional rendering.
 | 
					
						
							| 
									
										
										
										
											2019-06-30 22:21:28 -04:00
										 |  |  |     void ProcessQueryCondition(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-27 19:40:10 -03:00
										 |  |  |     /// Handles counter resets.
 | 
					
						
							|  |  |  |     void ProcessCounterReset(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-02 11:46:00 -04:00
										 |  |  |     /// Handles writes to syncing register.
 | 
					
						
							|  |  |  |     void ProcessSyncPoint(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-18 15:19:47 -05:00
										 |  |  |     /// Handles a write to the CB_DATA[i] register.
 | 
					
						
							| 
									
										
										
										
											2019-07-12 09:25:47 -04:00
										 |  |  |     void StartCBData(u32 method); | 
					
						
							| 
									
										
										
										
											2018-03-18 15:19:47 -05:00
										 |  |  |     void ProcessCBData(u32 value); | 
					
						
							| 
									
										
										
										
											2019-07-12 09:25:47 -04:00
										 |  |  |     void FinishCBData(); | 
					
						
							| 
									
										
										
										
											2018-03-18 15:19:47 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-17 17:06:23 -05:00
										 |  |  |     /// Handles a write to the CB_BIND register.
 | 
					
						
							| 
									
										
										
										
											2019-11-18 18:35:21 -03:00
										 |  |  |     void ProcessCBBind(std::size_t stage_index); | 
					
						
							| 
									
										
										
										
											2018-03-17 17:06:23 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-04 19:13:15 -05:00
										 |  |  |     /// Handles a write to the VERTEX_END_GL register, triggering a draw.
 | 
					
						
							|  |  |  |     void DrawArrays(); | 
					
						
							| 
									
										
										
										
											2019-09-22 07:23:13 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // Handles a instance drawcall from MME
 | 
					
						
							|  |  |  |     void StepInstance(MMEDrawMode expected_mode, u32 count); | 
					
						
							| 
									
										
										
										
											2019-11-26 18:52:15 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Returns a query's value or an empty object if the value will be deferred through a cache.
 | 
					
						
							|  |  |  |     std::optional<u64> GetQueryResult(); | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2018-02-11 21:34:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  | #define ASSERT_REG_POSITION(field_name, position)                                                  \
 | 
					
						
							|  |  |  |     static_assert(offsetof(Maxwell3D::Regs, field_name) == position * 4,                           \ | 
					
						
							|  |  |  |                   "Field " #field_name " has invalid position") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-23 20:01:29 -05:00
										 |  |  | ASSERT_REG_POSITION(macros, 0x45); | 
					
						
							| 
									
										
										
										
											2019-04-22 19:27:36 -04:00
										 |  |  | ASSERT_REG_POSITION(upload, 0x60); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(exec_upload, 0x6C); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(data_upload, 0x6D); | 
					
						
							| 
									
										
										
										
											2019-04-02 11:46:00 -04:00
										 |  |  | ASSERT_REG_POSITION(sync_info, 0xB2); | 
					
						
							| 
									
										
										
										
											2019-11-01 00:43:59 -03:00
										 |  |  | ASSERT_REG_POSITION(tess_mode, 0xC8); | 
					
						
							| 
									
										
										
										
											2019-11-01 04:39:48 -03:00
										 |  |  | ASSERT_REG_POSITION(tess_level_outer, 0xC9); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(tess_level_inner, 0xCD); | 
					
						
							| 
									
										
										
										
											2019-12-18 19:26:52 -03:00
										 |  |  | ASSERT_REG_POSITION(rasterize_enable, 0xDF); | 
					
						
							| 
									
										
										
										
											2020-03-02 01:54:00 -03:00
										 |  |  | ASSERT_REG_POSITION(tfb_bindings, 0xE0); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(tfb_layouts, 0x1C0); | 
					
						
							| 
									
										
										
										
											2018-09-25 19:41:21 -03:00
										 |  |  | ASSERT_REG_POSITION(tfb_enabled, 0x1D1); | 
					
						
							| 
									
										
										
										
											2018-03-19 16:46:29 -05:00
										 |  |  | ASSERT_REG_POSITION(rt, 0x200); | 
					
						
							| 
									
										
										
										
											2018-11-13 20:13:16 -03:00
										 |  |  | ASSERT_REG_POSITION(viewport_transform, 0x280); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(viewports, 0x300); | 
					
						
							| 
									
										
										
										
											2018-03-20 23:28:06 -05:00
										 |  |  | ASSERT_REG_POSITION(vertex_buffer, 0x35D); | 
					
						
							| 
									
										
										
										
											2019-12-10 17:33:49 -04:00
										 |  |  | ASSERT_REG_POSITION(depth_mode, 0x35F); | 
					
						
							| 
									
										
										
										
											2018-06-06 23:53:43 -05:00
										 |  |  | ASSERT_REG_POSITION(clear_color[0], 0x360); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(clear_depth, 0x364); | 
					
						
							| 
									
										
										
										
											2018-08-22 00:25:46 -04:00
										 |  |  | ASSERT_REG_POSITION(clear_stencil, 0x368); | 
					
						
							| 
									
										
										
										
											2020-02-24 19:43:57 -03:00
										 |  |  | ASSERT_REG_POSITION(polygon_mode_front, 0x36B); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(polygon_mode_back, 0x36C); | 
					
						
							| 
									
										
										
										
											2018-11-26 20:31:44 -03:00
										 |  |  | ASSERT_REG_POSITION(polygon_offset_point_enable, 0x370); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(polygon_offset_line_enable, 0x371); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(polygon_offset_fill_enable, 0x372); | 
					
						
							| 
									
										
										
										
											2019-11-01 00:36:19 -03:00
										 |  |  | ASSERT_REG_POSITION(patch_vertices, 0x373); | 
					
						
							| 
									
										
										
										
											2018-10-08 20:49:36 -04:00
										 |  |  | ASSERT_REG_POSITION(scissor_test, 0x380); | 
					
						
							| 
									
										
										
										
											2018-08-22 00:25:46 -04:00
										 |  |  | ASSERT_REG_POSITION(stencil_back_func_ref, 0x3D5); | 
					
						
							| 
									
										
										
										
											2020-02-02 17:50:46 -03:00
										 |  |  | ASSERT_REG_POSITION(stencil_back_mask, 0x3D6); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(stencil_back_func_mask, 0x3D7); | 
					
						
							| 
									
										
										
										
											2018-11-04 23:46:06 -03:00
										 |  |  | ASSERT_REG_POSITION(color_mask_common, 0x3E4); | 
					
						
							| 
									
										
										
										
											2018-09-09 19:01:21 -04:00
										 |  |  | ASSERT_REG_POSITION(rt_separate_frag_data, 0x3EB); | 
					
						
							| 
									
										
										
										
											2019-11-06 01:39:41 -03:00
										 |  |  | ASSERT_REG_POSITION(depth_bounds, 0x3E7); | 
					
						
							| 
									
										
										
										
											2018-03-19 16:49:41 -05:00
										 |  |  | ASSERT_REG_POSITION(zeta, 0x3F8); | 
					
						
							| 
									
										
										
										
											2018-11-21 00:40:32 -03:00
										 |  |  | ASSERT_REG_POSITION(clear_flags, 0x43E); | 
					
						
							| 
									
										
										
										
											2020-02-24 19:43:57 -03:00
										 |  |  | ASSERT_REG_POSITION(fill_rectangle, 0x44F); | 
					
						
							| 
									
										
										
										
											2018-09-05 11:36:50 +02:00
										 |  |  | ASSERT_REG_POSITION(vertex_attrib_format, 0x458); | 
					
						
							| 
									
										
										
										
											2018-03-19 16:46:29 -05:00
										 |  |  | ASSERT_REG_POSITION(rt_control, 0x487); | 
					
						
							| 
									
										
										
										
											2018-07-21 01:54:47 -04:00
										 |  |  | ASSERT_REG_POSITION(zeta_width, 0x48a); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(zeta_height, 0x48b); | 
					
						
							| 
									
										
										
										
											2020-02-16 04:12:38 -03:00
										 |  |  | ASSERT_REG_POSITION(zeta_layers, 0x48c); | 
					
						
							| 
									
										
										
										
											2018-07-02 13:31:20 -05:00
										 |  |  | ASSERT_REG_POSITION(depth_test_enable, 0x4B3); | 
					
						
							| 
									
										
										
										
											2018-06-08 17:04:41 -05:00
										 |  |  | ASSERT_REG_POSITION(independent_blend_enable, 0x4B9); | 
					
						
							| 
									
										
										
										
											2018-07-02 13:31:20 -05:00
										 |  |  | ASSERT_REG_POSITION(depth_write_enabled, 0x4BA); | 
					
						
							| 
									
										
										
										
											2018-09-25 19:41:21 -03:00
										 |  |  | ASSERT_REG_POSITION(alpha_test_enabled, 0x4BB); | 
					
						
							| 
									
										
										
										
											2018-07-04 10:26:46 -05:00
										 |  |  | ASSERT_REG_POSITION(d3d_cull_mode, 0x4C2); | 
					
						
							| 
									
										
										
										
											2018-07-02 13:31:20 -05:00
										 |  |  | ASSERT_REG_POSITION(depth_test_func, 0x4C3); | 
					
						
							| 
									
										
										
										
											2018-11-02 00:21:25 -03:00
										 |  |  | ASSERT_REG_POSITION(alpha_test_ref, 0x4C4); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(alpha_test_func, 0x4C5); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(draw_tfb_stride, 0x4C6); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(blend_color, 0x4C7); | 
					
						
							| 
									
										
										
										
											2018-06-08 17:04:41 -05:00
										 |  |  | ASSERT_REG_POSITION(blend, 0x4CF); | 
					
						
							| 
									
										
										
										
											2018-08-22 00:25:46 -04:00
										 |  |  | ASSERT_REG_POSITION(stencil_enable, 0x4E0); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(stencil_front_op_fail, 0x4E1); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(stencil_front_op_zfail, 0x4E2); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(stencil_front_op_zpass, 0x4E3); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(stencil_front_func_func, 0x4E4); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(stencil_front_func_ref, 0x4E5); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(stencil_front_func_mask, 0x4E6); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(stencil_front_mask, 0x4E7); | 
					
						
							| 
									
										
										
										
											2018-11-13 22:09:01 -03:00
										 |  |  | ASSERT_REG_POSITION(frag_color_clamp, 0x4EA); | 
					
						
							| 
									
										
										
										
											2018-07-04 10:26:46 -05:00
										 |  |  | ASSERT_REG_POSITION(screen_y_control, 0x4EB); | 
					
						
							| 
									
										
										
										
											2018-07-02 11:21:23 -05:00
										 |  |  | ASSERT_REG_POSITION(vb_element_base, 0x50D); | 
					
						
							| 
									
										
										
										
											2019-09-15 11:48:54 -04:00
										 |  |  | ASSERT_REG_POSITION(vb_base_instance, 0x50E); | 
					
						
							| 
									
										
										
										
											2018-11-26 20:45:21 -03:00
										 |  |  | ASSERT_REG_POSITION(clip_distance_enabled, 0x544); | 
					
						
							| 
									
										
										
										
											2019-07-27 19:40:10 -03:00
										 |  |  | ASSERT_REG_POSITION(samplecnt_enable, 0x545); | 
					
						
							| 
									
										
										
										
											2018-09-28 01:31:01 -03:00
										 |  |  | ASSERT_REG_POSITION(point_size, 0x546); | 
					
						
							| 
									
										
										
										
											2020-02-04 15:19:45 -03:00
										 |  |  | ASSERT_REG_POSITION(point_sprite_enable, 0x548); | 
					
						
							| 
									
										
										
										
											2019-07-27 19:40:10 -03:00
										 |  |  | ASSERT_REG_POSITION(counter_reset, 0x54C); | 
					
						
							| 
									
										
										
										
											2018-07-21 01:54:47 -04:00
										 |  |  | ASSERT_REG_POSITION(zeta_enable, 0x54E); | 
					
						
							| 
									
										
										
										
											2018-11-14 00:02:54 -03:00
										 |  |  | ASSERT_REG_POSITION(multisample_control, 0x54F); | 
					
						
							| 
									
										
										
										
											2019-06-30 22:21:28 -04:00
										 |  |  | ASSERT_REG_POSITION(condition, 0x554); | 
					
						
							| 
									
										
										
										
											2018-03-19 00:36:25 -05:00
										 |  |  | ASSERT_REG_POSITION(tsc, 0x557); | 
					
						
							| 
									
										
										
										
											2018-11-26 20:31:44 -03:00
										 |  |  | ASSERT_REG_POSITION(polygon_offset_factor, 0x55b); | 
					
						
							| 
									
										
										
										
											2018-03-19 00:32:57 -05:00
										 |  |  | ASSERT_REG_POSITION(tic, 0x55D); | 
					
						
							| 
									
										
										
										
											2018-08-22 00:25:46 -04:00
										 |  |  | ASSERT_REG_POSITION(stencil_two_side_enable, 0x565); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(stencil_back_op_fail, 0x566); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(stencil_back_op_zfail, 0x567); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(stencil_back_op_zpass, 0x568); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(stencil_back_func_func, 0x569); | 
					
						
							| 
									
										
										
										
											2018-10-24 17:09:40 -03:00
										 |  |  | ASSERT_REG_POSITION(framebuffer_srgb, 0x56E); | 
					
						
							| 
									
										
										
										
											2018-11-26 20:31:44 -03:00
										 |  |  | ASSERT_REG_POSITION(polygon_offset_units, 0x56F); | 
					
						
							| 
									
										
										
										
											2018-07-04 10:26:46 -05:00
										 |  |  | ASSERT_REG_POSITION(point_coord_replace, 0x581); | 
					
						
							| 
									
										
										
										
											2018-03-16 19:23:11 -05:00
										 |  |  | ASSERT_REG_POSITION(code_address, 0x582); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(draw, 0x585); | 
					
						
							| 
									
										
										
										
											2018-10-25 19:04:13 -04:00
										 |  |  | ASSERT_REG_POSITION(primitive_restart, 0x591); | 
					
						
							| 
									
										
										
										
											2018-04-13 14:18:37 -04:00
										 |  |  | ASSERT_REG_POSITION(index_array, 0x5F2); | 
					
						
							| 
									
										
										
										
											2018-11-26 20:31:44 -03:00
										 |  |  | ASSERT_REG_POSITION(polygon_offset_clamp, 0x61F); | 
					
						
							| 
									
										
										
										
											2018-08-18 14:42:26 -05:00
										 |  |  | ASSERT_REG_POSITION(instanced_arrays, 0x620); | 
					
						
							| 
									
										
										
										
											2020-01-15 16:14:17 -03:00
										 |  |  | ASSERT_REG_POSITION(vp_point_size, 0x644); | 
					
						
							| 
									
										
										
										
											2019-12-28 21:41:41 -03:00
										 |  |  | ASSERT_REG_POSITION(cull_test_enabled, 0x646); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(front_face, 0x647); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(cull_face, 0x648); | 
					
						
							| 
									
										
										
										
											2018-11-24 13:15:14 -03:00
										 |  |  | ASSERT_REG_POSITION(pixel_center_integer, 0x649); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(viewport_transform_enabled, 0x64B); | 
					
						
							| 
									
										
										
										
											2018-11-23 12:11:21 -03:00
										 |  |  | ASSERT_REG_POSITION(view_volume_clip_control, 0x64F); | 
					
						
							| 
									
										
										
										
											2019-11-06 01:39:41 -03:00
										 |  |  | ASSERT_REG_POSITION(depth_bounds_enable, 0x66F); | 
					
						
							| 
									
										
										
										
											2018-08-20 18:42:36 -05:00
										 |  |  | ASSERT_REG_POSITION(logic_op, 0x671); | 
					
						
							| 
									
										
										
										
											2018-06-06 23:53:43 -05:00
										 |  |  | ASSERT_REG_POSITION(clear_buffers, 0x674); | 
					
						
							| 
									
										
										
										
											2018-11-04 23:46:06 -03:00
										 |  |  | ASSERT_REG_POSITION(color_mask, 0x680); | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  | ASSERT_REG_POSITION(query, 0x6C0); | 
					
						
							| 
									
										
										
										
											2018-03-16 22:47:45 -05:00
										 |  |  | ASSERT_REG_POSITION(vertex_array[0], 0x700); | 
					
						
							| 
									
										
										
										
											2018-06-08 17:04:41 -05:00
										 |  |  | ASSERT_REG_POSITION(independent_blend, 0x780); | 
					
						
							| 
									
										
										
										
											2018-03-16 22:47:45 -05:00
										 |  |  | ASSERT_REG_POSITION(vertex_array_limit[0], 0x7C0); | 
					
						
							| 
									
										
										
										
											2018-03-16 19:23:11 -05:00
										 |  |  | ASSERT_REG_POSITION(shader_config[0], 0x800); | 
					
						
							| 
									
										
										
										
											2019-08-31 17:43:19 -03:00
										 |  |  | ASSERT_REG_POSITION(firmware, 0x8C0); | 
					
						
							| 
									
										
										
										
											2018-03-17 16:17:45 -05:00
										 |  |  | ASSERT_REG_POSITION(const_buffer, 0x8E0); | 
					
						
							| 
									
										
										
										
											2018-03-17 16:29:20 -05:00
										 |  |  | ASSERT_REG_POSITION(cb_bind[0], 0x904); | 
					
						
							| 
									
										
										
										
											2018-03-18 03:13:22 -05:00
										 |  |  | ASSERT_REG_POSITION(tex_cb_index, 0x982); | 
					
						
							| 
									
										
										
										
											2020-03-02 01:54:00 -03:00
										 |  |  | ASSERT_REG_POSITION(tfb_varying_locs, 0xA00); | 
					
						
							| 
									
										
										
										
											2018-03-18 15:22:06 -05:00
										 |  |  | ASSERT_REG_POSITION(ssbo_info, 0xD18); | 
					
						
							| 
									
										
										
										
											2018-03-18 19:03:20 -05:00
										 |  |  | ASSERT_REG_POSITION(tex_info_buffers.address[0], 0xD2A); | 
					
						
							|  |  |  | ASSERT_REG_POSITION(tex_info_buffers.size[0], 0xD2F); | 
					
						
							| 
									
										
										
										
											2018-02-12 12:34:41 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | #undef ASSERT_REG_POSITION
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-20 18:14:17 -04:00
										 |  |  | } // namespace Tegra::Engines
 |