summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGravatar Subv2018-03-19 16:46:29 -0500
committerGravatar Subv2018-03-19 16:46:29 -0500
commit21d9519032ec787cc5fad7aa3f9e7ff2c9453f72 (patch)
treedc08e396bcdf29a20f366d91fd6a7e492c093de4 /src
parentMerge pull request #251 from Subv/tic_tsc (diff)
downloadyuzu-21d9519032ec787cc5fad7aa3f9e7ff2c9453f72.tar.gz
yuzu-21d9519032ec787cc5fad7aa3f9e7ff2c9453f72.tar.xz
yuzu-21d9519032ec787cc5fad7aa3f9e7ff2c9453f72.zip
GPU: Added the render target (RT) registers to Maxwell3D's reg structure.
Diffstat (limited to 'src')
-rw-r--r--src/video_core/engines/maxwell_3d.h33
1 files changed, 32 insertions, 1 deletions
diff --git a/src/video_core/engines/maxwell_3d.h b/src/video_core/engines/maxwell_3d.h
index 096679162..f354241e4 100644
--- a/src/video_core/engines/maxwell_3d.h
+++ b/src/video_core/engines/maxwell_3d.h
@@ -31,6 +31,7 @@ public:
31 struct Regs { 31 struct Regs {
32 static constexpr size_t NUM_REGS = 0xE36; 32 static constexpr size_t NUM_REGS = 0xE36;
33 33
34 static constexpr size_t NumRenderTargets = 8;
34 static constexpr size_t NumCBData = 16; 35 static constexpr size_t NumCBData = 16;
35 static constexpr size_t NumVertexArrays = 32; 36 static constexpr size_t NumVertexArrays = 32;
36 static constexpr size_t MaxShaderProgram = 6; 37 static constexpr size_t MaxShaderProgram = 6;
@@ -62,7 +63,35 @@ public:
62 63
63 union { 64 union {
64 struct { 65 struct {
65 INSERT_PADDING_WORDS(0x557); 66 INSERT_PADDING_WORDS(0x200);
67
68 struct {
69 u32 address_high;
70 u32 address_low;
71 u32 horiz;
72 u32 vert;
73 u32 format;
74 u32 block_dimensions;
75 u32 array_mode;
76 u32 layer_stride;
77 u32 base_layer;
78 INSERT_PADDING_WORDS(7);
79
80 GPUVAddr Address() const {
81 return static_cast<GPUVAddr>((static_cast<GPUVAddr>(address_high) << 32) |
82 address_low);
83 }
84 } rt[NumRenderTargets];
85
86 INSERT_PADDING_WORDS(0x207);
87
88 struct {
89 union {
90 BitField<0, 4, u32> count;
91 };
92 } rt_control;
93
94 INSERT_PADDING_WORDS(0xCF);
66 95
67 struct { 96 struct {
68 u32 tsc_address_high; 97 u32 tsc_address_high;
@@ -291,6 +320,8 @@ private:
291 static_assert(offsetof(Maxwell3D::Regs, field_name) == position * 4, \ 320 static_assert(offsetof(Maxwell3D::Regs, field_name) == position * 4, \
292 "Field " #field_name " has invalid position") 321 "Field " #field_name " has invalid position")
293 322
323ASSERT_REG_POSITION(rt, 0x200);
324ASSERT_REG_POSITION(rt_control, 0x487);
294ASSERT_REG_POSITION(tsc, 0x557); 325ASSERT_REG_POSITION(tsc, 0x557);
295ASSERT_REG_POSITION(tic, 0x55D); 326ASSERT_REG_POSITION(tic, 0x55D);
296ASSERT_REG_POSITION(code_address, 0x582); 327ASSERT_REG_POSITION(code_address, 0x582);