vkFreeDescriptorSets
To free allocated descriptor sets, call:
VkResult vkFreeDescriptorSets(
VkDevice device,
VkDescriptorPool descriptorPool,
uint32_t descriptorSetCount,
const VkDescriptorSet* pDescriptorSets);
deviceis the logical device that owns the descriptor pool.descriptorPoolis the descriptor pool from which the descriptor sets were allocated.descriptorSetCountis the number of elements in thepDescriptorSetsarray.pDescriptorSetsis a pointer to an array of handles to VkDescriptorSet objects.
After calling vkFreeDescriptorSets, all descriptor sets in
pDescriptorSets are invalid.
Valid Usage
VUID-vkFreeDescriptorSets-pDescriptorSets-00309
All submitted commands that refer to any element of
pDescriptorSets must have completed execution
VUID-vkFreeDescriptorSets-pDescriptorSets-00310
pDescriptorSets must be a valid pointer to an array of
descriptorSetCount VkDescriptorSet handles, each element of
which must either be a valid handle or VK_NULL_HANDLE
VUID-vkFreeDescriptorSets-descriptorPool-00312
descriptorPool must have been created with the
VK_DESCRIPTOR_POOL_CREATE_FREE_DESCRIPTOR_SET_BIT flag
Valid Usage (Implicit)
VUID-vkFreeDescriptorSets-device-parameter
device must be a valid VkDevice handle
VUID-vkFreeDescriptorSets-descriptorPool-parameter
descriptorPool must be a valid VkDescriptorPool handle
VUID-vkFreeDescriptorSets-descriptorSetCount-arraylength
descriptorSetCount must be greater than 0
VUID-vkFreeDescriptorSets-descriptorPool-parent
descriptorPool must have been created, allocated, or retrieved from device
VUID-vkFreeDescriptorSets-pDescriptorSets-parent
Each element of pDescriptorSets that is a valid handle must have been created, allocated, or retrieved from descriptorPool
Host Synchronization
- Host access to
descriptorPoolmust be externally synchronized - Host access to each member of
pDescriptorSetsmust be externally synchronized ::