summaryrefslogtreecommitdiffstats
path: root/src/video_core/engines/maxwell_3d.h
diff options
context:
space:
mode:
authorSubv <subv2112@gmail.com>2018-03-17 02:32:44 +0100
committerSubv <subv2112@gmail.com>2018-03-17 02:32:44 +0100
commit29feece4b849bd40cc6dcef6c60f4bc58707557a (patch)
treea9e78b0689325e2f3b330785c767e5b3ff2f738e /src/video_core/engines/maxwell_3d.h
parentMerge pull request #236 from bunnei/refactor-process-creation (diff)
downloadyuzu-29feece4b849bd40cc6dcef6c60f4bc58707557a.tar
yuzu-29feece4b849bd40cc6dcef6c60f4bc58707557a.tar.gz
yuzu-29feece4b849bd40cc6dcef6c60f4bc58707557a.tar.bz2
yuzu-29feece4b849bd40cc6dcef6c60f4bc58707557a.tar.lz
yuzu-29feece4b849bd40cc6dcef6c60f4bc58707557a.tar.xz
yuzu-29feece4b849bd40cc6dcef6c60f4bc58707557a.tar.zst
yuzu-29feece4b849bd40cc6dcef6c60f4bc58707557a.zip
Diffstat (limited to 'src/video_core/engines/maxwell_3d.h')
-rw-r--r--src/video_core/engines/maxwell_3d.h22
1 files changed, 21 insertions, 1 deletions
diff --git a/src/video_core/engines/maxwell_3d.h b/src/video_core/engines/maxwell_3d.h
index 93f7698a0..954369cf5 100644
--- a/src/video_core/engines/maxwell_3d.h
+++ b/src/video_core/engines/maxwell_3d.h
@@ -4,6 +4,8 @@
#pragma once
+#include <unordered_map>
+#include <vector>
#include "common/bit_field.h"
#include "common/common_funcs.h"
#include "common/common_types.h"
@@ -20,6 +22,13 @@ public:
/// Write the value to the register identified by method.
void WriteReg(u32 method, u32 value);
+ /**
+ * Handles a method call to this engine.
+ * @param method Method to call
+ * @param parameters Arguments to the method call
+ */
+ void CallMethod(u32 method, const std::vector<u32>& parameters);
+
/// Register structure of the Maxwell3D engine.
/// TODO(Subv): This structure will need to be made bigger as more registers are discovered.
struct Regs {
@@ -63,13 +72,24 @@ public:
static_assert(sizeof(Regs) == Regs::NUM_REGS * sizeof(u32), "Maxwell3D Regs has wrong size");
private:
+ MemoryManager& memory_manager;
+
/// Handles a write to the QUERY_GET register.
void ProcessQueryGet();
/// Handles a write to the VERTEX_END_GL register, triggering a draw.
void DrawArrays();
- MemoryManager& memory_manager;
+ /// Method call handlers
+ void PrepareShader(const std::vector<u32>& parameters);
+
+ struct MethodInfo {
+ const char* name;
+ u32 arguments;
+ void (Maxwell3D::*handler)(const std::vector<u32>& parameters);
+ };
+
+ static const std::unordered_map<u32, MethodInfo> method_handlers;
};
#define ASSERT_REG_POSITION(field_name, position) \