mirror of
https://github.com/doitsujin/dxvk.git
synced 2025-01-19 05:52:11 +01:00
[dxvk] Zero-initialize newly allocated buffer slices on creation
Fixes random flicker in God of War. Since patch 1.0.9, the game's lighting system relies on MAP_DISCARD returning a zero-initialized memory slices for its constant buffers, or some lights would get skipped in various compute passes. Changing the memset to e.g. write 0xFF instead of 0 shows this issue.
This commit is contained in:
parent
e440fa26ab
commit
6b8e8afd5b
@ -29,8 +29,10 @@ namespace dxvk {
|
||||
? MaxBufferSize / m_physSliceStride
|
||||
: 1;
|
||||
|
||||
// Allocate the initial set of buffer slices
|
||||
m_buffer = allocBuffer(m_physSliceCount);
|
||||
// Allocate the initial set of buffer slices. Only clear
|
||||
// buffer memory if there is more than one slice, since
|
||||
// we expect the client api to initialize the first slice.
|
||||
m_buffer = allocBuffer(m_physSliceCount, m_physSliceCount > 1);
|
||||
|
||||
DxvkBufferSliceHandle slice;
|
||||
slice.handle = m_buffer.buffer;
|
||||
@ -52,7 +54,7 @@ namespace dxvk {
|
||||
}
|
||||
|
||||
|
||||
DxvkBufferHandle DxvkBuffer::allocBuffer(VkDeviceSize sliceCount) const {
|
||||
DxvkBufferHandle DxvkBuffer::allocBuffer(VkDeviceSize sliceCount, bool clear) const {
|
||||
auto vkd = m_device->vkd();
|
||||
|
||||
VkBufferCreateInfo info;
|
||||
@ -124,6 +126,9 @@ namespace dxvk {
|
||||
handle.memory.memory(), handle.memory.offset()) != VK_SUCCESS)
|
||||
throw DxvkError("DxvkBuffer: Failed to bind device memory");
|
||||
|
||||
if (clear && (m_memFlags & VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT))
|
||||
std::memset(handle.memory.mapPtr(0), 0, info.size);
|
||||
|
||||
return handle;
|
||||
}
|
||||
|
||||
|
@ -245,7 +245,7 @@ namespace dxvk {
|
||||
// backing buffer and add all slices to the free list.
|
||||
if (unlikely(m_freeSlices.empty())) {
|
||||
if (likely(!m_lazyAlloc)) {
|
||||
DxvkBufferHandle handle = allocBuffer(m_physSliceCount);
|
||||
DxvkBufferHandle handle = allocBuffer(m_physSliceCount, true);
|
||||
|
||||
for (uint32_t i = 0; i < m_physSliceCount; i++)
|
||||
pushSlice(handle, i);
|
||||
@ -317,7 +317,8 @@ namespace dxvk {
|
||||
}
|
||||
|
||||
DxvkBufferHandle allocBuffer(
|
||||
VkDeviceSize sliceCount) const;
|
||||
VkDeviceSize sliceCount,
|
||||
bool clear) const;
|
||||
|
||||
VkDeviceSize computeSliceAlignment() const;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user