diff --git a/Source/Core/VideoBackends/D3D/D3DBoundingBox.cpp b/Source/Core/VideoBackends/D3D/D3DBoundingBox.cpp index 7a6fe64d80..8cab19ac95 100644 --- a/Source/Core/VideoBackends/D3D/D3DBoundingBox.cpp +++ b/Source/Core/VideoBackends/D3D/D3DBoundingBox.cpp @@ -88,12 +88,12 @@ std::vector D3DBoundingBox::Read(u32 index, u32 length) return values; } -void D3DBoundingBox::Write(u32 index, const std::vector& values) +void D3DBoundingBox::Write(u32 index, std::span values) { D3D11_BOX box{index * sizeof(BBoxType), 0, 0, - static_cast(index + values.size()) * sizeof(BBoxType), + static_cast((index + values.size()) * sizeof(BBoxType)), 1, 1}; D3D::context->UpdateSubresource(m_buffer.Get(), 0, &box, values.data(), 0, 0); diff --git a/Source/Core/VideoBackends/D3D/D3DBoundingBox.h b/Source/Core/VideoBackends/D3D/D3DBoundingBox.h index 4a9cc98785..6c6f14e024 100644 --- a/Source/Core/VideoBackends/D3D/D3DBoundingBox.h +++ b/Source/Core/VideoBackends/D3D/D3DBoundingBox.h @@ -19,7 +19,7 @@ public: protected: std::vector Read(u32 index, u32 length) override; - void Write(u32 index, const std::vector& values) override; + void Write(u32 index, std::span values) override; private: ComPtr m_buffer; diff --git a/Source/Core/VideoBackends/D3D12/D3D12BoundingBox.cpp b/Source/Core/VideoBackends/D3D12/D3D12BoundingBox.cpp index 1627e39343..a26c4e8160 100644 --- a/Source/Core/VideoBackends/D3D12/D3D12BoundingBox.cpp +++ b/Source/Core/VideoBackends/D3D12/D3D12BoundingBox.cpp @@ -56,9 +56,9 @@ std::vector D3D12BoundingBox::Read(u32 index, u32 length) return values; } -void D3D12BoundingBox::Write(u32 index, const std::vector& values) +void D3D12BoundingBox::Write(u32 index, std::span values) { - const u32 copy_size = static_cast(values.size()) * sizeof(BBoxType); + const u32 copy_size = static_cast(values.size() * sizeof(BBoxType)); if (!m_upload_buffer.ReserveMemory(copy_size, sizeof(BBoxType))) { WARN_LOG_FMT(VIDEO, "Executing command list while waiting for space in bbox stream buffer"); diff --git a/Source/Core/VideoBackends/D3D12/D3D12BoundingBox.h b/Source/Core/VideoBackends/D3D12/D3D12BoundingBox.h index d2d95c5c83..1fb188f873 100644 --- a/Source/Core/VideoBackends/D3D12/D3D12BoundingBox.h +++ b/Source/Core/VideoBackends/D3D12/D3D12BoundingBox.h @@ -21,7 +21,7 @@ public: protected: std::vector Read(u32 index, u32 length) override; - void Write(u32 index, const std::vector& values) override; + void Write(u32 index, std::span values) override; private: static constexpr u32 BUFFER_SIZE = sizeof(BBoxType) * NUM_BBOX_VALUES; diff --git a/Source/Core/VideoBackends/Metal/MTLBoundingBox.h b/Source/Core/VideoBackends/Metal/MTLBoundingBox.h index d4a67389a2..f73d0a4a76 100644 --- a/Source/Core/VideoBackends/Metal/MTLBoundingBox.h +++ b/Source/Core/VideoBackends/Metal/MTLBoundingBox.h @@ -18,7 +18,7 @@ public: protected: std::vector Read(u32 index, u32 length) override; - void Write(u32 index, const std::vector& values) override; + void Write(u32 index, std::span values) override; private: BBoxType* m_cpu_buffer_ptr; diff --git a/Source/Core/VideoBackends/Metal/MTLBoundingBox.mm b/Source/Core/VideoBackends/Metal/MTLBoundingBox.mm index 0bdcc9ef62..da36e6a0b2 100644 --- a/Source/Core/VideoBackends/Metal/MTLBoundingBox.mm +++ b/Source/Core/VideoBackends/Metal/MTLBoundingBox.mm @@ -42,7 +42,7 @@ std::vector Metal::BoundingBox::Read(u32 index, u32 length) } } -void Metal::BoundingBox::Write(u32 index, const std::vector& values) +void Metal::BoundingBox::Write(u32 index, std::span values) { const u32 size = values.size() * sizeof(BBoxType); if (!g_state_tracker->HasUnflushedData() && !g_state_tracker->GPUBusy()) diff --git a/Source/Core/VideoBackends/Null/NullBoundingBox.h b/Source/Core/VideoBackends/Null/NullBoundingBox.h index 74cf04e06d..f33ca2f67b 100644 --- a/Source/Core/VideoBackends/Null/NullBoundingBox.h +++ b/Source/Core/VideoBackends/Null/NullBoundingBox.h @@ -19,7 +19,7 @@ protected: { return std::vector(length); } - void Write(u32 index, const std::vector& values) override {} + void Write(u32 index, std::span values) override {} }; } // namespace Null diff --git a/Source/Core/VideoBackends/OGL/OGLBoundingBox.cpp b/Source/Core/VideoBackends/OGL/OGLBoundingBox.cpp index d21326c1f5..6936163f3e 100644 --- a/Source/Core/VideoBackends/OGL/OGLBoundingBox.cpp +++ b/Source/Core/VideoBackends/OGL/OGLBoundingBox.cpp @@ -66,7 +66,7 @@ std::vector OGLBoundingBox::Read(u32 index, u32 length) return values; } -void OGLBoundingBox::Write(u32 index, const std::vector& values) +void OGLBoundingBox::Write(u32 index, std::span values) { glBindBuffer(GL_SHADER_STORAGE_BUFFER, m_buffer_id); glBufferSubData(GL_SHADER_STORAGE_BUFFER, sizeof(BBoxType) * index, diff --git a/Source/Core/VideoBackends/OGL/OGLBoundingBox.h b/Source/Core/VideoBackends/OGL/OGLBoundingBox.h index 50d063d7b7..70de8197d9 100644 --- a/Source/Core/VideoBackends/OGL/OGLBoundingBox.h +++ b/Source/Core/VideoBackends/OGL/OGLBoundingBox.h @@ -19,7 +19,7 @@ public: protected: std::vector Read(u32 index, u32 length) override; - void Write(u32 index, const std::vector& values) override; + void Write(u32 index, std::span values) override; private: GLuint m_buffer_id = 0; diff --git a/Source/Core/VideoBackends/Software/SWBoundingBox.cpp b/Source/Core/VideoBackends/Software/SWBoundingBox.cpp index 96d38517b8..b9b3d21ca8 100644 --- a/Source/Core/VideoBackends/Software/SWBoundingBox.cpp +++ b/Source/Core/VideoBackends/Software/SWBoundingBox.cpp @@ -55,7 +55,7 @@ std::vector SWBoundingBox::Read(u32 index, u32 length) return values; } -void SWBoundingBox::Write(u32 index, const std::vector& values) +void SWBoundingBox::Write(u32 index, std::span values) { for (size_t i = 0; i < values.size(); i++) { diff --git a/Source/Core/VideoBackends/Software/SWBoundingBox.h b/Source/Core/VideoBackends/Software/SWBoundingBox.h index 116d85bdf1..e84f74f526 100644 --- a/Source/Core/VideoBackends/Software/SWBoundingBox.h +++ b/Source/Core/VideoBackends/Software/SWBoundingBox.h @@ -37,7 +37,7 @@ public: protected: std::vector Read(u32 index, u32 length) override; - void Write(u32 index, const std::vector& values) override; + void Write(u32 index, std::span values) override; }; } // namespace SW diff --git a/Source/Core/VideoBackends/Vulkan/VKBoundingBox.cpp b/Source/Core/VideoBackends/Vulkan/VKBoundingBox.cpp index 7765e97a25..af51293500 100644 --- a/Source/Core/VideoBackends/Vulkan/VKBoundingBox.cpp +++ b/Source/Core/VideoBackends/Vulkan/VKBoundingBox.cpp @@ -77,7 +77,7 @@ std::vector VKBoundingBox::Read(u32 index, u32 length) return values; } -void VKBoundingBox::Write(u32 index, const std::vector& values) +void VKBoundingBox::Write(u32 index, std::span values) { // We can't issue vkCmdUpdateBuffer within a render pass. // However, the writes must be serialized, so we can't put it in the init buffer. @@ -91,8 +91,7 @@ void VKBoundingBox::Write(u32 index, const std::vector& values) // Write the values to the GPU buffer vkCmdUpdateBuffer(g_command_buffer_mgr->GetCurrentCommandBuffer(), m_gpu_buffer, - index * sizeof(BBoxType), values.size() * sizeof(BBoxType), - reinterpret_cast(values.data())); + index * sizeof(BBoxType), values.size() * sizeof(BBoxType), values.data()); // Restore fragment shader access to the buffer. StagingBuffer::BufferMemoryBarrier( diff --git a/Source/Core/VideoBackends/Vulkan/VKBoundingBox.h b/Source/Core/VideoBackends/Vulkan/VKBoundingBox.h index 107abc7551..3520b8892c 100644 --- a/Source/Core/VideoBackends/Vulkan/VKBoundingBox.h +++ b/Source/Core/VideoBackends/Vulkan/VKBoundingBox.h @@ -26,7 +26,7 @@ public: protected: std::vector Read(u32 index, u32 length) override; - void Write(u32 index, const std::vector& values) override; + void Write(u32 index, std::span values) override; private: bool CreateGPUBuffer(); diff --git a/Source/Core/VideoCommon/BoundingBox.cpp b/Source/Core/VideoCommon/BoundingBox.cpp index ffc85d824c..33174012d7 100644 --- a/Source/Core/VideoCommon/BoundingBox.cpp +++ b/Source/Core/VideoCommon/BoundingBox.cpp @@ -51,7 +51,7 @@ void BoundingBox::Flush() for (u32 i = start; i < end; ++i) m_dirty[i] = false; - Write(start, std::vector(m_values.begin() + start, m_values.begin() + end)); + Write(start, std::span(m_values.begin() + start, m_values.begin() + end)); } } diff --git a/Source/Core/VideoCommon/BoundingBox.h b/Source/Core/VideoCommon/BoundingBox.h index ed4861d6ad..4c3064ce53 100644 --- a/Source/Core/VideoCommon/BoundingBox.h +++ b/Source/Core/VideoCommon/BoundingBox.h @@ -5,6 +5,7 @@ #include #include +#include #include #include "Common/CommonTypes.h" @@ -38,8 +39,7 @@ public: protected: virtual std::vector Read(u32 index, u32 length) = 0; - // TODO: This can likely use std::span once we're on C++20 - virtual void Write(u32 index, const std::vector& values) = 0; + virtual void Write(u32 index, std::span values) = 0; private: void Readback();