summaryrefslogtreecommitdiffstats
path: root/src/video_core/vertex_loader.h
diff options
context:
space:
mode:
authorHenrik Rydgard <hrydgard@gmail.com>2016-04-28 19:01:47 +0200
committerHenrik Rydgard <hrydgard@gmail.com>2016-04-28 19:05:55 +0200
commit47ff00881703eeab03d32e60289ac34b7f4a7994 (patch)
treeb3260ea48aba0cf7feee3cd338c6676dd4a3d604 /src/video_core/vertex_loader.h
parentRemove late accesses to attribute_config (diff)
downloadyuzu-47ff00881703eeab03d32e60289ac34b7f4a7994.tar
yuzu-47ff00881703eeab03d32e60289ac34b7f4a7994.tar.gz
yuzu-47ff00881703eeab03d32e60289ac34b7f4a7994.tar.bz2
yuzu-47ff00881703eeab03d32e60289ac34b7f4a7994.tar.lz
yuzu-47ff00881703eeab03d32e60289ac34b7f4a7994.tar.xz
yuzu-47ff00881703eeab03d32e60289ac34b7f4a7994.tar.zst
yuzu-47ff00881703eeab03d32e60289ac34b7f4a7994.zip
Diffstat (limited to 'src/video_core/vertex_loader.h')
-rw-r--r--src/video_core/vertex_loader.h53
1 files changed, 53 insertions, 0 deletions
diff --git a/src/video_core/vertex_loader.h b/src/video_core/vertex_loader.h
new file mode 100644
index 000000000..4ff62d97b
--- /dev/null
+++ b/src/video_core/vertex_loader.h
@@ -0,0 +1,53 @@
+#pragma once
+
+#include "video_core/pica.h"
+#include "video_core/shader/shader.h"
+
+namespace Pica {
+
+class MemoryAccesses {
+ /// Combine overlapping and close ranges
+ void SimplifyRanges() {
+ for (auto it = ranges.begin(); it != ranges.end(); ++it) {
+ // NOTE: We add 32 to the range end address to make sure "close" ranges are combined, too
+ auto it2 = std::next(it);
+ while (it2 != ranges.end() && it->first + it->second + 32 >= it2->first) {
+ it->second = std::max(it->second, it2->first + it2->second - it->first);
+ it2 = ranges.erase(it2);
+ }
+ }
+ }
+
+public:
+ /// Record a particular memory access in the list
+ void AddAccess(u32 paddr, u32 size) {
+ // Create new range or extend existing one
+ ranges[paddr] = std::max(ranges[paddr], size);
+
+ // Simplify ranges...
+ SimplifyRanges();
+ }
+
+ /// Map of accessed ranges (mapping start address to range size)
+ std::map<u32, u32> ranges;
+};
+
+class VertexLoader {
+public:
+ void Setup(const Pica::Regs &regs);
+ void LoadVertex(int index, int vertex, Shader::InputVertex &input, MemoryAccesses &memory_accesses);
+
+ u32 GetPhysicalBaseAddress() const { return base_address; }
+ int GetNumTotalAttributes() const { return num_total_attributes; }
+private:
+ u32 vertex_attribute_sources[16];
+ u32 vertex_attribute_strides[16] = {};
+ Regs::VertexAttributeFormat vertex_attribute_formats[16] = {};
+ u32 vertex_attribute_elements[16] = {};
+ u32 vertex_attribute_element_size[16] = {};
+ bool vertex_attribute_is_default[16];
+ u32 base_address;
+ int num_total_attributes;
+};
+
+} // namespace Pica