Index: source/renderer/backend/vulkan/Device.cpp =================================================================== --- source/renderer/backend/vulkan/Device.cpp +++ source/renderer/backend/vulkan/Device.cpp @@ -543,6 +543,12 @@ vulkanFunctions.vkCreateImage = vkCreateImage; vulkanFunctions.vkDestroyImage = vkDestroyImage; vulkanFunctions.vkCmdCopyBuffer = vkCmdCopyBuffer; + // Functions promoted to Vulkan 1.1. + vulkanFunctions.vkGetBufferMemoryRequirements2KHR = vkGetBufferMemoryRequirements2; + vulkanFunctions.vkGetImageMemoryRequirements2KHR = vkGetImageMemoryRequirements2; + vulkanFunctions.vkBindBufferMemory2KHR = vkBindBufferMemory2; + vulkanFunctions.vkBindImageMemory2KHR = vkBindImageMemory2; + vulkanFunctions.vkGetPhysicalDeviceMemoryProperties2KHR = vkGetPhysicalDeviceMemoryProperties2; VmaAllocatorCreateInfo allocatorCreateInfo{}; allocatorCreateInfo.instance = device->m_Instance; Index: source/renderer/backend/vulkan/VMA.h =================================================================== --- source/renderer/backend/vulkan/VMA.h +++ source/renderer/backend/vulkan/VMA.h @@ -25,7 +25,7 @@ #include #include -#define VMA_VULKAN_VERSION 1000000 +#define VMA_VULKAN_VERSION 1001000 #define VMA_ASSERT(EXPR) ASSERT(EXPR) #define VMA_HEAVY_ASSERT(EXPR) ENSURE(EXPR) #define VMA_DYNAMIC_VULKAN_FUNCTIONS 0 @@ -33,7 +33,7 @@ #define VMA_BUFFER_DEVICE_ADDRESS 0 #ifndef NDEBUG -#define VMA_DEBUG_LOG(...) debug_printf(__VA_ARGS__) +#define VMA_DEBUG_LOG(...) do { debug_printf(__VA_ARGS__); debug_printf("\n"); } while (0) #define VMA_STATS_STRING_ENABLED 1 #else #define VMA_DEBUG_LOG(...) @@ -68,6 +68,46 @@ #pragma warning(disable: 4703) // Potentially uninitialized local pointer variable used. #endif +// VMA always uses extension variants and glad doesn't provide extension +// defines and types that were promoted to the core version. So we need to +// define them manually. +#define PFN_vkBindBufferMemory2KHR PFN_vkBindBufferMemory2 +#define PFN_vkBindImageMemory2KHR PFN_vkBindImageMemory2 +#define PFN_vkGetBufferMemoryRequirements2KHR PFN_vkGetBufferMemoryRequirements2 +#define PFN_vkGetImageMemoryRequirements2KHR PFN_vkGetImageMemoryRequirements2 +#define PFN_vkGetPhysicalDeviceMemoryProperties2KHR PFN_vkGetPhysicalDeviceMemoryProperties2 + +#define vkBindBufferMemory2KHR vkBindBufferMemory2 +#define vkBindImageMemory2KHR vkBindImageMemory2 +#define vkGetBufferMemoryRequirements2KHR vkGetBufferMemoryRequirements2 +#define vkGetImageMemoryRequirements2KHR vkGetImageMemoryRequirements2 +#define vkGetPhysicalDeviceMemoryProperties2KHR vkGetPhysicalDeviceMemoryProperties2 + +#define VkBindBufferMemoryInfoKHR VkBindBufferMemoryInfo +#define VkBindImageMemoryInfoKHR VkBindImageMemoryInfo +#define VkBufferMemoryRequirementsInfo2KHR VkBufferMemoryRequirementsInfo2 +#define VkImageMemoryRequirementsInfo2KHR VkImageMemoryRequirementsInfo2 +#define VkMemoryDedicatedAllocateInfoKHR VkMemoryDedicatedAllocateInfo +#define VkMemoryDedicatedRequirementsKHR VkMemoryDedicatedRequirements +#define VkMemoryRequirements2KHR VkMemoryRequirements2 +#define VkPhysicalDeviceMemoryProperties2KHR VkPhysicalDeviceMemoryProperties2 + +#define VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO_KHR VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO +#define VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO_KHR VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO +#define VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2_KHR VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2 +#define VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2_KHR VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2 +#define VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO_KHR VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO +#define VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS_KHR VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS +#define VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2_KHR VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2 +#define VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2_KHR VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2 + +// Those extensions should be enabled automatically by picking Vulkan 1.1. +#define VK_KHR_bind_memory2 0 +#define VK_KHR_get_memory_requirements2 0 +#define VK_KHR_external_memory 0 +#define VK_EXT_memory_budget 0 +#define VK_EXT_memory_priority 0 + #include "third_party/vma/vk_mem_alloc.h" #if GCC_VERSION Index: source/third_party/vma/vk_mem_alloc.h =================================================================== --- source/third_party/vma/vk_mem_alloc.h +++ source/third_party/vma/vk_mem_alloc.h @@ -14257,7 +14257,8 @@ VMA_COPY_IF_NOT_NULL(vkBindImageMemory2KHR); #endif -#if VMA_MEMORY_BUDGET + // TODO: remove after merging https://github.com/GPUOpen-LibrariesAndSDKs/VulkanMemoryAllocator/pull/322 +#if VMA_MEMORY_BUDGET || VMA_VULKAN_VERSION >= 1001000 VMA_COPY_IF_NOT_NULL(vkGetPhysicalDeviceMemoryProperties2KHR); #endif