1
0
mirror of https://github.com/doitsujin/dxvk.git synced 2025-01-19 05:52:11 +01:00

[dxvk] Try harder to allocate memory from a given memory type

Before failing, see if we can't allocate a smaller chunk size.
This commit is contained in:
Philip Rebohle 2019-07-16 09:44:45 +02:00
parent 18aada29ef
commit 6936da17d9
No known key found for this signature in database
GPG Key ID: C8CC613427A31C99

View File

@ -295,18 +295,19 @@ namespace dxvk {
memory = type->chunks[i]->alloc(flags, size, align, priority); memory = type->chunks[i]->alloc(flags, size, align, priority);
if (!memory) { if (!memory) {
DxvkDeviceMemory devMem = tryAllocDeviceMemory( DxvkDeviceMemory devMem;
type, flags, type->heap->chunkSize, priority, nullptr);
if (devMem.memHandle == VK_NULL_HANDLE) for (uint32_t i = 0; i < 6 && (type->heap->chunkSize >> i) >= size && !devMem.memHandle; i++)
return DxvkMemory(); devMem = tryAllocDeviceMemory(type, flags, type->heap->chunkSize >> i, priority, nullptr);
if (devMem.memHandle) {
Rc<DxvkMemoryChunk> chunk = new DxvkMemoryChunk(this, type, devMem); Rc<DxvkMemoryChunk> chunk = new DxvkMemoryChunk(this, type, devMem);
memory = chunk->alloc(flags, size, align, priority); memory = chunk->alloc(flags, size, align, priority);
type->chunks.push_back(std::move(chunk)); type->chunks.push_back(std::move(chunk));
} }
} }
}
if (memory) if (memory)
type->heap->stats.memoryUsed += memory.m_length; type->heap->stats.memoryUsed += memory.m_length;