summaryrefslogtreecommitdiffstats
path: root/src/video_core/renderer_vulkan/vk_descriptor_pool.cpp
diff options
context:
space:
mode:
authorFernando Sahmkow <fsahmkow27@gmail.com>2021-08-29 22:45:17 +0200
committerFernando Sahmkow <fsahmkow27@gmail.com>2021-09-13 23:09:18 +0200
commite7ca37b1e5d6dd62870c7b7c953598ad7785c9f9 (patch)
tree8b3b8634c7b6910acdd2bc1363b4770dba2f1397 /src/video_core/renderer_vulkan/vk_descriptor_pool.cpp
parentMerge pull request #6929 from yuzu-emu/revert-6870-trace-back-stack-back-stack-back (diff)
downloadyuzu-e7ca37b1e5d6dd62870c7b7c953598ad7785c9f9.tar
yuzu-e7ca37b1e5d6dd62870c7b7c953598ad7785c9f9.tar.gz
yuzu-e7ca37b1e5d6dd62870c7b7c953598ad7785c9f9.tar.bz2
yuzu-e7ca37b1e5d6dd62870c7b7c953598ad7785c9f9.tar.lz
yuzu-e7ca37b1e5d6dd62870c7b7c953598ad7785c9f9.tar.xz
yuzu-e7ca37b1e5d6dd62870c7b7c953598ad7785c9f9.tar.zst
yuzu-e7ca37b1e5d6dd62870c7b7c953598ad7785c9f9.zip
Diffstat (limited to 'src/video_core/renderer_vulkan/vk_descriptor_pool.cpp')
-rw-r--r--src/video_core/renderer_vulkan/vk_descriptor_pool.cpp6
1 files changed, 3 insertions, 3 deletions
diff --git a/src/video_core/renderer_vulkan/vk_descriptor_pool.cpp b/src/video_core/renderer_vulkan/vk_descriptor_pool.cpp
index 8e77e4796..60e45f1b9 100644
--- a/src/video_core/renderer_vulkan/vk_descriptor_pool.cpp
+++ b/src/video_core/renderer_vulkan/vk_descriptor_pool.cpp
@@ -18,7 +18,6 @@ namespace Vulkan {
// Prefer small grow rates to avoid saturating the descriptor pool with barely used pipelines
constexpr size_t SETS_GROW_RATE = 16;
constexpr s32 SCORE_THRESHOLD = 3;
-constexpr u32 SETS_PER_POOL = 64;
struct DescriptorBank {
DescriptorBankInfo info;
@@ -58,11 +57,12 @@ static DescriptorBankInfo MakeBankInfo(std::span<const Shader::Info> infos) {
static void AllocatePool(const Device& device, DescriptorBank& bank) {
std::array<VkDescriptorPoolSize, 6> pool_sizes;
size_t pool_cursor{};
+ const u32 sets_per_pool = device.GetSetsPerPool();
const auto add = [&](VkDescriptorType type, u32 count) {
if (count > 0) {
pool_sizes[pool_cursor++] = {
.type = type,
- .descriptorCount = count * SETS_PER_POOL,
+ .descriptorCount = count * sets_per_pool,
};
}
};
@@ -77,7 +77,7 @@ static void AllocatePool(const Device& device, DescriptorBank& bank) {
.sType = VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO,
.pNext = nullptr,
.flags = VK_DESCRIPTOR_POOL_CREATE_FREE_DESCRIPTOR_SET_BIT,
- .maxSets = SETS_PER_POOL,
+ .maxSets = sets_per_pool,
.poolSizeCount = static_cast<u32>(pool_cursor),
.pPoolSizes = std::data(pool_sizes),
}));