diff --git a/src/dxvk/dxvk_buffer.cpp b/src/dxvk/dxvk_buffer.cpp index 33d53e9c9..0c3f291c6 100644 --- a/src/dxvk/dxvk_buffer.cpp +++ b/src/dxvk/dxvk_buffer.cpp @@ -48,9 +48,8 @@ namespace dxvk { bool DxvkBuffer::canRelocate() const { - return !m_storage->flags().test(DxvkAllocationFlag::Imported) - && !m_bufferInfo.mapPtr - && !(m_info.usage & VK_BUFFER_USAGE_SHADER_DEVICE_ADDRESS_BIT) + return !m_bufferInfo.mapPtr && !m_stableAddress + && !m_storage->flags().test(DxvkAllocationFlag::Imported) && !(m_info.flags & VK_BUFFER_CREATE_SPARSE_BINDING_BIT); } diff --git a/src/dxvk/dxvk_buffer.h b/src/dxvk/dxvk_buffer.h index 46fa83903..7ca44b446 100644 --- a/src/dxvk/dxvk_buffer.h +++ b/src/dxvk/dxvk_buffer.h @@ -210,6 +210,16 @@ namespace dxvk { : nullptr; } + /** + * \brief GPU address + * + * May be 0 if the device address usage flag is not + * enabled for this buffer. + */ + VkDeviceAddress gpuAddress() const { + return m_bufferInfo.gpuAddress; + } + /** * \brief Queries shader stages that can access this buffer * @@ -350,6 +360,16 @@ namespace dxvk { */ bool canRelocate() const; + /** + * \brief Enables stable GPU address + * + * Subsequent calls to \c canRelocate will be \c false, preventing + * the buffer from being relocated or invalidated by the backend. + */ + void enableStableAddress() { + m_stableAddress = true; + } + /** * \brief Creates or retrieves a buffer view * @@ -377,6 +397,8 @@ namespace dxvk { uint32_t m_xfbStride = 0u; uint32_t m_version = 0u; + bool m_stableAddress = false; + DxvkResourceBufferInfo m_bufferInfo = { }; Rc m_storage; diff --git a/src/dxvk/dxvk_context.cpp b/src/dxvk/dxvk_context.cpp index ac54e5b8d..a1950c387 100644 --- a/src/dxvk/dxvk_context.cpp +++ b/src/dxvk/dxvk_context.cpp @@ -1894,6 +1894,13 @@ namespace dxvk { } + void DxvkContext::ensureBufferAddress( + const Rc& buffer) { + // Really nothing else to do here but set the flag + buffer->enableStableAddress(); + } + + void DxvkContext::invalidateImage( const Rc& image, Rc&& slice) { diff --git a/src/dxvk/dxvk_context.h b/src/dxvk/dxvk_context.h index 8475a85cd..cbba27de0 100644 --- a/src/dxvk/dxvk_context.h +++ b/src/dxvk/dxvk_context.h @@ -962,6 +962,18 @@ namespace dxvk { const Rc& buffer, Rc&& slice); + /** + * \brief Ensures that buffer will not be relocated + * + * This guarantees that the buffer's GPU address remains the same + * throughout its lifetime. Only prevents implicit invalidation or + * relocation by the backend, client APIs must take care to respect + * this too. + * \param [in] buffer Buffer to lock in place + */ + void ensureBufferAddress( + const Rc& buffer); + /** * \brief Invalidates image content *