diff options
author | bunnei <bunneidev@gmail.com> | 2015-08-30 23:12:33 +0200 |
---|---|---|
committer | bunnei <bunneidev@gmail.com> | 2015-08-30 23:12:33 +0200 |
commit | e77dc4e9d2d43ec739c95dd4b92d6a404277b241 (patch) | |
tree | 2aad23d2573e24d8c290383cc116535716ef1632 /src/video_core | |
parent | Merge pull request #1085 from Subv/fs_stat (diff) | |
parent | GPU: Implemented register 0x22A. (diff) | |
download | yuzu-e77dc4e9d2d43ec739c95dd4b92d6a404277b241.tar yuzu-e77dc4e9d2d43ec739c95dd4b92d6a404277b241.tar.gz yuzu-e77dc4e9d2d43ec739c95dd4b92d6a404277b241.tar.bz2 yuzu-e77dc4e9d2d43ec739c95dd4b92d6a404277b241.tar.lz yuzu-e77dc4e9d2d43ec739c95dd4b92d6a404277b241.tar.xz yuzu-e77dc4e9d2d43ec739c95dd4b92d6a404277b241.tar.zst yuzu-e77dc4e9d2d43ec739c95dd4b92d6a404277b241.zip |
Diffstat (limited to 'src/video_core')
-rw-r--r-- | src/video_core/command_processor.cpp | 3 | ||||
-rw-r--r-- | src/video_core/pica.h | 7 |
2 files changed, 8 insertions, 2 deletions
diff --git a/src/video_core/command_processor.cpp b/src/video_core/command_processor.cpp index a78985510..682be89ec 100644 --- a/src/video_core/command_processor.cpp +++ b/src/video_core/command_processor.cpp @@ -235,7 +235,8 @@ static void WritePicaReg(u32 id, u32 value, u32 mask) { for (unsigned int index = 0; index < regs.num_vertices; ++index) { - unsigned int vertex = is_indexed ? (index_u16 ? index_address_16[index] : index_address_8[index]) : index; + // Indexed rendering doesn't use the start offset + unsigned int vertex = is_indexed ? (index_u16 ? index_address_16[index] : index_address_8[index]) : (index + regs.vertex_offset); // -1 is a common special value used for primitive restart. Since it's unknown if // the PICA supports it, and it would mess up the caching, guard against it here. diff --git a/src/video_core/pica.h b/src/video_core/pica.h index f40684d83..5811eb9bc 100644 --- a/src/video_core/pica.h +++ b/src/video_core/pica.h @@ -769,7 +769,12 @@ struct Regs { // Number of vertices to render u32 num_vertices; - INSERT_PADDING_WORDS(0x5); + INSERT_PADDING_WORDS(0x1); + + // The index of the first vertex to render + u32 vertex_offset; + + INSERT_PADDING_WORDS(0x3); // These two trigger rendering of triangles u32 trigger_draw; |