diff options
| author | 2016-04-29 09:42:47 -0400 | |
|---|---|---|
| committer | 2016-04-29 09:42:47 -0400 | |
| commit | 90243c56fb90d7d74cbef40da3eec97d967c10a2 (patch) | |
| tree | 94d223001196ca9b774a8d018535ba2be8de1b01 /src/video_core/debug_utils | |
| parent | Common: Remove section measurement from profiler (#1731) (diff) | |
| parent | Move and rename the MemoryAccesses class to MemoryAccessTracker. (diff) | |
| download | yuzu-90243c56fb90d7d74cbef40da3eec97d967c10a2.tar.gz yuzu-90243c56fb90d7d74cbef40da3eec97d967c10a2.tar.xz yuzu-90243c56fb90d7d74cbef40da3eec97d967c10a2.zip | |
Merge pull request #1730 from hrydgard/vertex-loader
* Remove late accesses to attribute_config
* Refactor: Extract VertexLoader from command_processor.cpp.
Preparation for a similar concept to Dolphin or PPSSPP. These can be JIT-ed and cached.
* Move "&" to their proper place, add missing includes and make some properly relative.
* Don't keep base_address in the loader, it doesn't belong there (with it, the loader can't be cached).
* Optimize the vertex loader, nearly doubling its speed.
* Debugger fix
* Move and rename the MemoryAccesses class to MemoryAccessTracker.
Diffstat (limited to 'src/video_core/debug_utils')
| -rw-r--r-- | src/video_core/debug_utils/debug_utils.h | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/src/video_core/debug_utils/debug_utils.h b/src/video_core/debug_utils/debug_utils.h index 56f9bd958..dd0828cee 100644 --- a/src/video_core/debug_utils/debug_utils.h +++ b/src/video_core/debug_utils/debug_utils.h | |||
| @@ -216,6 +216,36 @@ void DumpTexture(const Pica::Regs::TextureConfig& texture_config, u8* data); | |||
| 216 | 216 | ||
| 217 | void DumpTevStageConfig(const std::array<Pica::Regs::TevStageConfig,6>& stages); | 217 | void DumpTevStageConfig(const std::array<Pica::Regs::TevStageConfig,6>& stages); |
| 218 | 218 | ||
| 219 | /** | ||
| 220 | * Used in the vertex loader to merge access records. TODO: Investigate if actually useful. | ||
| 221 | */ | ||
| 222 | class MemoryAccessTracker { | ||
| 223 | /// Combine overlapping and close ranges | ||
| 224 | void SimplifyRanges() { | ||
| 225 | for (auto it = ranges.begin(); it != ranges.end(); ++it) { | ||
| 226 | // NOTE: We add 32 to the range end address to make sure "close" ranges are combined, too | ||
| 227 | auto it2 = std::next(it); | ||
| 228 | while (it2 != ranges.end() && it->first + it->second + 32 >= it2->first) { | ||
| 229 | it->second = std::max(it->second, it2->first + it2->second - it->first); | ||
| 230 | it2 = ranges.erase(it2); | ||
| 231 | } | ||
| 232 | } | ||
| 233 | } | ||
| 234 | |||
| 235 | public: | ||
| 236 | /// Record a particular memory access in the list | ||
| 237 | void AddAccess(u32 paddr, u32 size) { | ||
| 238 | // Create new range or extend existing one | ||
| 239 | ranges[paddr] = std::max(ranges[paddr], size); | ||
| 240 | |||
| 241 | // Simplify ranges... | ||
| 242 | SimplifyRanges(); | ||
| 243 | } | ||
| 244 | |||
| 245 | /// Map of accessed ranges (mapping start address to range size) | ||
| 246 | std::map<u32, u32> ranges; | ||
| 247 | }; | ||
| 248 | |||
| 219 | } // namespace | 249 | } // namespace |
| 220 | 250 | ||
| 221 | } // namespace | 251 | } // namespace |