summaryrefslogtreecommitdiffstats
path: root/src/video_core/primitive_assembly.cpp
diff options
context:
space:
mode:
authorTony Wasserka <NeoBrainX@gmail.com>2014-12-07 00:26:48 +0100
committerTony Wasserka <NeoBrainX@gmail.com>2014-12-20 18:06:54 +0100
commitcd322e328ec6957b6744ee9b68d29b2c29a554df (patch)
treefec41fd5536f562e7a842d86176224dddd6e1df0 /src/video_core/primitive_assembly.cpp
parentPica/CommandProcessor: Add a safety check for invalid (?) GPU configurations. (diff)
downloadyuzu-cd322e328ec6957b6744ee9b68d29b2c29a554df.tar
yuzu-cd322e328ec6957b6744ee9b68d29b2c29a554df.tar.gz
yuzu-cd322e328ec6957b6744ee9b68d29b2c29a554df.tar.bz2
yuzu-cd322e328ec6957b6744ee9b68d29b2c29a554df.tar.lz
yuzu-cd322e328ec6957b6744ee9b68d29b2c29a554df.tar.xz
yuzu-cd322e328ec6957b6744ee9b68d29b2c29a554df.tar.zst
yuzu-cd322e328ec6957b6744ee9b68d29b2c29a554df.zip
Diffstat (limited to 'src/video_core/primitive_assembly.cpp')
-rw-r--r--src/video_core/primitive_assembly.cpp23
1 files changed, 15 insertions, 8 deletions
diff --git a/src/video_core/primitive_assembly.cpp b/src/video_core/primitive_assembly.cpp
index 102693ed9..ff46c7b52 100644
--- a/src/video_core/primitive_assembly.cpp
+++ b/src/video_core/primitive_assembly.cpp
@@ -30,20 +30,27 @@ void PrimitiveAssembler<VertexType>::SubmitVertex(VertexType& vtx, TriangleHandl
}
break;
+ case Regs::TriangleTopology::Strip:
case Regs::TriangleTopology::Fan:
- if (buffer_index == 2) {
- buffer_index = 0;
-
- triangle_handler(buffer[0], buffer[1], vtx);
+ if (strip_ready) {
+ // TODO: Should be "buffer[0], buffer[1], vtx" instead!
+ // Not quite sure why we need this order for things to show up properly.
+ // Maybe a bug in the rasterizer?
+ triangle_handler(buffer[1], buffer[0], vtx);
+ }
+ buffer[buffer_index] = vtx;
- buffer[1] = vtx;
- } else {
- buffer[buffer_index++] = vtx;
+ if (topology == Regs::TriangleTopology::Strip) {
+ strip_ready |= (buffer_index == 1);
+ buffer_index = !buffer_index;
+ } else if (topology == Regs::TriangleTopology::Fan) {
+ buffer_index = 1;
+ strip_ready = true;
}
break;
default:
- LOG_ERROR(Render_Software, "Unknown triangle topology %x:", (int)topology);
+ LOG_ERROR(HW_GPU, "Unknown triangle topology %x:", (int)topology);
break;
}
}