diff options
| author | bunnei <bunneidev@gmail.com> | 2014-12-03 01:04:22 -0500 | 
|---|---|---|
| committer | bunnei <bunneidev@gmail.com> | 2014-12-09 19:07:14 -0500 | 
| commit | f94d8f960361e36c5436717924bda5a3a6c6d47a (patch) | |
| tree | ecad0fa27f48e672af06218ef850c9ae673147a3 /src/video_core | |
| parent | e90b37b9358e9dcc8279b0071fd53968c1f441e8 (diff) | |
GSP: Trigger GPU interrupts at more accurate locations.
Diffstat (limited to 'src/video_core')
| -rw-r--r-- | src/video_core/command_processor.cpp | 6 | ||||
| -rw-r--r-- | src/video_core/pica.h | 10 | 
2 files changed, 15 insertions, 1 deletions
| diff --git a/src/video_core/command_processor.cpp b/src/video_core/command_processor.cpp index 585323a81..431139cc2 100644 --- a/src/video_core/command_processor.cpp +++ b/src/video_core/command_processor.cpp @@ -8,6 +8,7 @@  #include "pica.h"  #include "primitive_assembly.h"  #include "vertex_shader.h" +#include "core/hle/service/gsp_gpu.h"  #include "debug_utils/debug_utils.h" @@ -40,6 +41,11 @@ static inline void WritePicaReg(u32 id, u32 value, u32 mask) {      DebugUtils::OnPicaRegWrite(id, registers[id]);      switch(id) { +        // Trigger IRQ +        case PICA_REG_INDEX(trigger_irq): +            GSP_GPU::SignalInterrupt(GSP_GPU::InterruptId::P3D); +            return; +          // It seems like these trigger vertex rendering          case PICA_REG_INDEX(trigger_draw):          case PICA_REG_INDEX(trigger_draw_indexed): diff --git a/src/video_core/pica.h b/src/video_core/pica.h index e7ca38978..8bac178ca 100644 --- a/src/video_core/pica.h +++ b/src/video_core/pica.h @@ -45,10 +45,16 @@ struct Regs {  #define INSERT_PADDING_WORDS_HELPER2(x, y) INSERT_PADDING_WORDS_HELPER1(x, y)  #define INSERT_PADDING_WORDS(num_words) u32 INSERT_PADDING_WORDS_HELPER2(pad, __LINE__)[(num_words)]; -    INSERT_PADDING_WORDS(0x41); +    INSERT_PADDING_WORDS(0x10); + +    u32 trigger_irq; + +    INSERT_PADDING_WORDS(0x30);      BitField<0, 24, u32> viewport_size_x; +      INSERT_PADDING_WORDS(0x1); +      BitField<0, 24, u32> viewport_size_y;      INSERT_PADDING_WORDS(0x9); @@ -544,6 +550,7 @@ struct Regs {                      map.insert({i, #name + std::string("+") + std::to_string(i-PICA_REG_INDEX(name))});       \              } while(false) +        ADD_FIELD(trigger_irq);          ADD_FIELD(viewport_size_x);          ADD_FIELD(viewport_size_y);          ADD_FIELD(viewport_depth_range); @@ -607,6 +614,7 @@ private:  #ifndef _MSC_VER  #define ASSERT_REG_POSITION(field_name, position) static_assert(offsetof(Regs, field_name) == position * 4, "Field "#field_name" has invalid position") +ASSERT_REG_POSITION(trigger_irq, 0x10);  ASSERT_REG_POSITION(viewport_size_x, 0x41);  ASSERT_REG_POSITION(viewport_size_y, 0x43);  ASSERT_REG_POSITION(viewport_depth_range, 0x4d); | 
