summaryrefslogtreecommitdiff
path: root/src/core/hle
diff options
context:
space:
mode:
Diffstat (limited to 'src/core/hle')
-rw-r--r--src/core/hle/service/hle_ipc.cpp32
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
331std::span<const u8> HLERequestContext::ReadBuffer(std::size_t buffer_index) const { 331std::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