diff options
| author | 2015-07-26 15:56:56 +0200 | |
|---|---|---|
| committer | 2015-07-26 15:56:56 +0200 | |
| commit | 72237a930509d353f9029d7245855780071dd663 (patch) | |
| tree | f6c8bba22c20ce64df59132f51f8305f5a5059bf | |
| parent | Merge pull request #995 from linkmauve/remove-dead-option (diff) | |
| parent | Videocore: Don't reinitialize register name map on every query (diff) | |
| download | yuzu-72237a930509d353f9029d7245855780071dd663.tar.gz yuzu-72237a930509d353f9029d7245855780071dd663.tar.xz yuzu-72237a930509d353f9029d7245855780071dd663.zip | |
Merge pull request #987 from yuriks/regnames
Videocore: Don't reinitialize register name map on every query.
Diffstat (limited to '')
| -rw-r--r-- | src/video_core/pica.cpp | 72 | ||||
| -rw-r--r-- | src/video_core/pica.h | 65 |
2 files changed, 72 insertions, 65 deletions
diff --git a/src/video_core/pica.cpp b/src/video_core/pica.cpp index 543d9c443..17cb66780 100644 --- a/src/video_core/pica.cpp +++ b/src/video_core/pica.cpp | |||
| @@ -2,7 +2,8 @@ | |||
| 2 | // Licensed under GPLv2 or any later version | 2 | // Licensed under GPLv2 or any later version |
| 3 | // Refer to the license.txt file included. | 3 | // Refer to the license.txt file included. |
| 4 | 4 | ||
| 5 | #include <string.h> | 5 | #include <cstring> |
| 6 | #include <unordered_map> | ||
| 6 | 7 | ||
| 7 | #include "pica.h" | 8 | #include "pica.h" |
| 8 | 9 | ||
| @@ -10,6 +11,75 @@ namespace Pica { | |||
| 10 | 11 | ||
| 11 | State g_state; | 12 | State g_state; |
| 12 | 13 | ||
| 14 | std::string Regs::GetCommandName(int index) { | ||
| 15 | static std::unordered_map<u32, std::string> map; | ||
| 16 | |||
| 17 | if (map.empty()) { | ||
| 18 | #define ADD_FIELD(name) \ | ||
| 19 | map.insert({static_cast<u32>(PICA_REG_INDEX(name)), #name}); \ | ||
| 20 | /* TODO: change to Regs::name when VS2015 and other compilers support it */ \ | ||
| 21 | for (u32 i = PICA_REG_INDEX(name) + 1; i < PICA_REG_INDEX(name) + sizeof(Regs().name) / 4; ++i) \ | ||
| 22 | map.insert({i, #name + std::string("+") + std::to_string(i-PICA_REG_INDEX(name))}); \ | ||
| 23 | |||
| 24 | ADD_FIELD(trigger_irq); | ||
| 25 | ADD_FIELD(cull_mode); | ||
| 26 | ADD_FIELD(viewport_size_x); | ||
| 27 | ADD_FIELD(viewport_size_y); | ||
| 28 | ADD_FIELD(viewport_depth_range); | ||
| 29 | ADD_FIELD(viewport_depth_far_plane); | ||
| 30 | ADD_FIELD(viewport_corner); | ||
| 31 | ADD_FIELD(texture0_enable); | ||
| 32 | ADD_FIELD(texture0); | ||
| 33 | ADD_FIELD(texture0_format); | ||
| 34 | ADD_FIELD(texture1); | ||
| 35 | ADD_FIELD(texture1_format); | ||
| 36 | ADD_FIELD(texture2); | ||
| 37 | ADD_FIELD(texture2_format); | ||
| 38 | ADD_FIELD(tev_stage0); | ||
| 39 | ADD_FIELD(tev_stage1); | ||
| 40 | ADD_FIELD(tev_stage2); | ||
| 41 | ADD_FIELD(tev_stage3); | ||
| 42 | ADD_FIELD(tev_combiner_buffer_input); | ||
| 43 | ADD_FIELD(tev_stage4); | ||
| 44 | ADD_FIELD(tev_stage5); | ||
| 45 | ADD_FIELD(tev_combiner_buffer_color); | ||
| 46 | ADD_FIELD(output_merger); | ||
| 47 | ADD_FIELD(framebuffer); | ||
| 48 | ADD_FIELD(vertex_attributes); | ||
| 49 | ADD_FIELD(index_array); | ||
| 50 | ADD_FIELD(num_vertices); | ||
| 51 | ADD_FIELD(trigger_draw); | ||
| 52 | ADD_FIELD(trigger_draw_indexed); | ||
| 53 | ADD_FIELD(vs_default_attributes_setup); | ||
| 54 | ADD_FIELD(command_buffer); | ||
| 55 | ADD_FIELD(triangle_topology); | ||
| 56 | ADD_FIELD(gs.bool_uniforms); | ||
| 57 | ADD_FIELD(gs.int_uniforms); | ||
| 58 | ADD_FIELD(gs.main_offset); | ||
| 59 | ADD_FIELD(gs.input_register_map); | ||
| 60 | ADD_FIELD(gs.uniform_setup); | ||
| 61 | ADD_FIELD(gs.program); | ||
| 62 | ADD_FIELD(gs.swizzle_patterns); | ||
| 63 | ADD_FIELD(vs.bool_uniforms); | ||
| 64 | ADD_FIELD(vs.int_uniforms); | ||
| 65 | ADD_FIELD(vs.main_offset); | ||
| 66 | ADD_FIELD(vs.input_register_map); | ||
| 67 | ADD_FIELD(vs.uniform_setup); | ||
| 68 | ADD_FIELD(vs.program); | ||
| 69 | ADD_FIELD(vs.swizzle_patterns); | ||
| 70 | |||
| 71 | #undef ADD_FIELD | ||
| 72 | } | ||
| 73 | |||
| 74 | // Return empty string if no match is found | ||
| 75 | auto it = map.find(index); | ||
| 76 | if (it != map.end()) { | ||
| 77 | return it->second; | ||
| 78 | } else { | ||
| 79 | return std::string(); | ||
| 80 | } | ||
| 81 | } | ||
| 82 | |||
| 13 | void Init() { | 83 | void Init() { |
| 14 | } | 84 | } |
| 15 | 85 | ||
diff --git a/src/video_core/pica.h b/src/video_core/pica.h index 38599a7a3..34b02b2f8 100644 --- a/src/video_core/pica.h +++ b/src/video_core/pica.h | |||
| @@ -7,7 +7,6 @@ | |||
| 7 | #include <array> | 7 | #include <array> |
| 8 | #include <cmath> | 8 | #include <cmath> |
| 9 | #include <cstddef> | 9 | #include <cstddef> |
| 10 | #include <map> | ||
| 11 | #include <string> | 10 | #include <string> |
| 12 | 11 | ||
| 13 | #include "common/assert.h" | 12 | #include "common/assert.h" |
| @@ -908,69 +907,7 @@ struct Regs { | |||
| 908 | 907 | ||
| 909 | // Map register indices to names readable by humans | 908 | // Map register indices to names readable by humans |
| 910 | // Used for debugging purposes, so performance is not an issue here | 909 | // Used for debugging purposes, so performance is not an issue here |
| 911 | static std::string GetCommandName(int index) { | 910 | static std::string GetCommandName(int index); |
| 912 | std::map<u32, std::string> map; | ||
| 913 | |||
| 914 | #define ADD_FIELD(name) \ | ||
| 915 | do { \ | ||
| 916 | map.insert({static_cast<u32>(PICA_REG_INDEX(name)), #name}); \ | ||
| 917 | /* TODO: change to Regs::name when VS2015 and other compilers support it */ \ | ||
| 918 | for (u32 i = PICA_REG_INDEX(name) + 1; i < PICA_REG_INDEX(name) + sizeof(Regs().name) / 4; ++i) \ | ||
| 919 | map.insert({i, #name + std::string("+") + std::to_string(i-PICA_REG_INDEX(name))}); \ | ||
| 920 | } while(false) | ||
| 921 | |||
| 922 | ADD_FIELD(trigger_irq); | ||
| 923 | ADD_FIELD(cull_mode); | ||
| 924 | ADD_FIELD(viewport_size_x); | ||
| 925 | ADD_FIELD(viewport_size_y); | ||
| 926 | ADD_FIELD(viewport_depth_range); | ||
| 927 | ADD_FIELD(viewport_depth_far_plane); | ||
| 928 | ADD_FIELD(viewport_corner); | ||
| 929 | ADD_FIELD(texture0_enable); | ||
| 930 | ADD_FIELD(texture0); | ||
| 931 | ADD_FIELD(texture0_format); | ||
| 932 | ADD_FIELD(texture1); | ||
| 933 | ADD_FIELD(texture1_format); | ||
| 934 | ADD_FIELD(texture2); | ||
| 935 | ADD_FIELD(texture2_format); | ||
| 936 | ADD_FIELD(tev_stage0); | ||
| 937 | ADD_FIELD(tev_stage1); | ||
| 938 | ADD_FIELD(tev_stage2); | ||
| 939 | ADD_FIELD(tev_stage3); | ||
| 940 | ADD_FIELD(tev_combiner_buffer_input); | ||
| 941 | ADD_FIELD(tev_stage4); | ||
| 942 | ADD_FIELD(tev_stage5); | ||
| 943 | ADD_FIELD(tev_combiner_buffer_color); | ||
| 944 | ADD_FIELD(output_merger); | ||
| 945 | ADD_FIELD(framebuffer); | ||
| 946 | ADD_FIELD(vertex_attributes); | ||
| 947 | ADD_FIELD(index_array); | ||
| 948 | ADD_FIELD(num_vertices); | ||
| 949 | ADD_FIELD(trigger_draw); | ||
| 950 | ADD_FIELD(trigger_draw_indexed); | ||
| 951 | ADD_FIELD(vs_default_attributes_setup); | ||
| 952 | ADD_FIELD(command_buffer); | ||
| 953 | ADD_FIELD(triangle_topology); | ||
| 954 | ADD_FIELD(gs.bool_uniforms); | ||
| 955 | ADD_FIELD(gs.int_uniforms); | ||
| 956 | ADD_FIELD(gs.main_offset); | ||
| 957 | ADD_FIELD(gs.input_register_map); | ||
| 958 | ADD_FIELD(gs.uniform_setup); | ||
| 959 | ADD_FIELD(gs.program); | ||
| 960 | ADD_FIELD(gs.swizzle_patterns); | ||
| 961 | ADD_FIELD(vs.bool_uniforms); | ||
| 962 | ADD_FIELD(vs.int_uniforms); | ||
| 963 | ADD_FIELD(vs.main_offset); | ||
| 964 | ADD_FIELD(vs.input_register_map); | ||
| 965 | ADD_FIELD(vs.uniform_setup); | ||
| 966 | ADD_FIELD(vs.program); | ||
| 967 | ADD_FIELD(vs.swizzle_patterns); | ||
| 968 | |||
| 969 | #undef ADD_FIELD | ||
| 970 | |||
| 971 | // Return empty string if no match is found | ||
| 972 | return map[index]; | ||
| 973 | } | ||
| 974 | 911 | ||
| 975 | static inline size_t NumIds() { | 912 | static inline size_t NumIds() { |
| 976 | return sizeof(Regs) / sizeof(u32); | 913 | return sizeof(Regs) / sizeof(u32); |