diff options
| author | 2023-07-10 18:54:19 -0700 | |
|---|---|---|
| committer | 2023-07-10 18:54:19 -0700 | |
| commit | ce7c418e0cc05d92c18ad69c7cb37fecfa71b037 (patch) | |
| tree | ea1852111c1b3c3c340608ae518fc8711a4fcfe3 /src/core/hle | |
| parent | Merge pull request #11050 from SuperSamus/sdl-button-labels (diff) | |
| parent | Fix ScratchBuffer moves (diff) | |
| download | yuzu-ce7c418e0cc05d92c18ad69c7cb37fecfa71b037.tar.gz yuzu-ce7c418e0cc05d92c18ad69c7cb37fecfa71b037.tar.xz yuzu-ce7c418e0cc05d92c18ad69c7cb37fecfa71b037.zip | |
Merge pull request #10996 from Kelebek1/readblock_optimisation
Use spans over guest memory where possible instead of copying data
Diffstat (limited to 'src/core/hle')
| -rw-r--r-- | src/core/hle/service/hle_ipc.cpp | 32 |
1 files changed, 22 insertions, 10 deletions
diff --git a/src/core/hle/service/hle_ipc.cpp b/src/core/hle/service/hle_ipc.cpp index 2290df705..f6a1e54f2 100644 --- a/src/core/hle/service/hle_ipc.cpp +++ b/src/core/hle/service/hle_ipc.cpp | |||
| @@ -329,8 +329,22 @@ std::vector<u8> HLERequestContext::ReadBufferCopy(std::size_t buffer_index) cons | |||
| 329 | } | 329 | } |
| 330 | 330 | ||
| 331 | std::span<const u8> HLERequestContext::ReadBuffer(std::size_t buffer_index) const { | 331 | std::span<const u8> HLERequestContext::ReadBuffer(std::size_t buffer_index) const { |
| 332 | static thread_local std::array<Common::ScratchBuffer<u8>, 2> read_buffer_a; | 332 | static thread_local std::array read_buffer_a{ |
| 333 | static thread_local std::array<Common::ScratchBuffer<u8>, 2> read_buffer_x; | 333 | Core::Memory::CpuGuestMemory<u8, Core::Memory::GuestMemoryFlags::SafeRead>(memory, 0, 0), |
| 334 | Core::Memory::CpuGuestMemory<u8, Core::Memory::GuestMemoryFlags::SafeRead>(memory, 0, 0), | ||
| 335 | }; | ||
| 336 | static thread_local std::array read_buffer_data_a{ | ||
| 337 | Common::ScratchBuffer<u8>(), | ||
| 338 | Common::ScratchBuffer<u8>(), | ||
| 339 | }; | ||
| 340 | static thread_local std::array read_buffer_x{ | ||
| 341 | Core::Memory::CpuGuestMemory<u8, Core::Memory::GuestMemoryFlags::SafeRead>(memory, 0, 0), | ||
| 342 | Core::Memory::CpuGuestMemory<u8, Core::Memory::GuestMemoryFlags::SafeRead>(memory, 0, 0), | ||
| 343 | }; | ||
| 344 | static thread_local std::array read_buffer_data_x{ | ||
| 345 | Common::ScratchBuffer<u8>(), | ||
| 346 | Common::ScratchBuffer<u8>(), | ||
| 347 | }; | ||
| 334 | 348 | ||
| 335 | const bool is_buffer_a{BufferDescriptorA().size() > buffer_index && | 349 | const bool is_buffer_a{BufferDescriptorA().size() > buffer_index && |
| 336 | BufferDescriptorA()[buffer_index].Size()}; | 350 | BufferDescriptorA()[buffer_index].Size()}; |
| @@ -339,19 +353,17 @@ std::span<const u8> HLERequestContext::ReadBuffer(std::size_t buffer_index) cons | |||
| 339 | BufferDescriptorA().size() > buffer_index, { return {}; }, | 353 | BufferDescriptorA().size() > buffer_index, { return {}; }, |
| 340 | "BufferDescriptorA invalid buffer_index {}", buffer_index); | 354 | "BufferDescriptorA invalid buffer_index {}", buffer_index); |
| 341 | auto& read_buffer = read_buffer_a[buffer_index]; | 355 | auto& read_buffer = read_buffer_a[buffer_index]; |
| 342 | read_buffer.resize_destructive(BufferDescriptorA()[buffer_index].Size()); | 356 | return read_buffer.Read(BufferDescriptorA()[buffer_index].Address(), |
| 343 | memory.ReadBlock(BufferDescriptorA()[buffer_index].Address(), read_buffer.data(), | 357 | BufferDescriptorA()[buffer_index].Size(), |
| 344 | read_buffer.size()); | 358 | &read_buffer_data_a[buffer_index]); |
| 345 | return read_buffer; | ||
| 346 | } else { | 359 | } else { |
| 347 | ASSERT_OR_EXECUTE_MSG( | 360 | ASSERT_OR_EXECUTE_MSG( |
| 348 | BufferDescriptorX().size() > buffer_index, { return {}; }, | 361 | BufferDescriptorX().size() > buffer_index, { return {}; }, |
| 349 | "BufferDescriptorX invalid buffer_index {}", buffer_index); | 362 | "BufferDescriptorX invalid buffer_index {}", buffer_index); |
| 350 | auto& read_buffer = read_buffer_x[buffer_index]; | 363 | auto& read_buffer = read_buffer_x[buffer_index]; |
| 351 | read_buffer.resize_destructive(BufferDescriptorX()[buffer_index].Size()); | 364 | return read_buffer.Read(BufferDescriptorX()[buffer_index].Address(), |
| 352 | memory.ReadBlock(BufferDescriptorX()[buffer_index].Address(), read_buffer.data(), | 365 | BufferDescriptorX()[buffer_index].Size(), |
| 353 | read_buffer.size()); | 366 | &read_buffer_data_x[buffer_index]); |
| 354 | return read_buffer; | ||
| 355 | } | 367 | } |
| 356 | } | 368 | } |
| 357 | 369 | ||