mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-13 21:28:01 +02:00
hwcontext_vulkan: do not chain structs of unsupported extensions in vkCreateDevice
Fixes: vkCreateDevice(): pCreateInfo->pNext<VkPhysicalDeviceOpticalFlowFeaturesNV> includes a pointer to a VkPhysicalDeviceOpticalFlowFeaturesNV, but when creating VkDevice, the parent extension (VK_NV_optical_flow) was not included in ppEnabledExtensionNames. The Vulkan spec states: Each pNext member of any structure (including this one) in the pNext chain must be either NULL or a pointer to a valid struct for extending VkDeviceCreateInfo.
This commit is contained in:
parent
12080ff040
commit
ef11a6456d
@ -1369,17 +1369,27 @@ static int vulkan_device_create_internal(AVHWDeviceContext *ctx,
|
|||||||
p->device_features_1_2.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VULKAN_1_2_FEATURES;
|
p->device_features_1_2.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VULKAN_1_2_FEATURES;
|
||||||
p->device_features_1_2.pNext = &p->device_features_1_3;
|
p->device_features_1_2.pNext = &p->device_features_1_3;
|
||||||
p->device_features_1_3.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VULKAN_1_3_FEATURES;
|
p->device_features_1_3.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VULKAN_1_3_FEATURES;
|
||||||
p->device_features_1_3.pNext = &p->desc_buf_features;
|
p->device_features_1_3.pNext = NULL;
|
||||||
p->desc_buf_features.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_BUFFER_FEATURES_EXT;
|
|
||||||
p->desc_buf_features.pNext = &p->atomic_float_features;
|
#define OPT_CHAIN(EXT_FLAG, STRUCT_P, TYPE) \
|
||||||
p->atomic_float_features.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_ATOMIC_FLOAT_FEATURES_EXT;
|
do { \
|
||||||
p->atomic_float_features.pNext = &p->coop_matrix_features;
|
if (p->vkctx.extensions & EXT_FLAG) { \
|
||||||
p->coop_matrix_features.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_COOPERATIVE_MATRIX_FEATURES_KHR;
|
(STRUCT_P)->sType = TYPE; \
|
||||||
p->coop_matrix_features.pNext = &p->optical_flow_features;
|
ff_vk_link_struct(hwctx->device_features.pNext, STRUCT_P); \
|
||||||
p->optical_flow_features.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_OPTICAL_FLOW_FEATURES_NV;
|
} \
|
||||||
p->optical_flow_features.pNext = &p->shader_object_features;
|
} while (0)
|
||||||
p->shader_object_features.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_OBJECT_FEATURES_EXT;
|
|
||||||
p->shader_object_features.pNext = NULL;
|
OPT_CHAIN(FF_VK_EXT_DESCRIPTOR_BUFFER, &p->desc_buf_features,
|
||||||
|
VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_BUFFER_FEATURES_EXT);
|
||||||
|
OPT_CHAIN(FF_VK_EXT_ATOMIC_FLOAT, &p->atomic_float_features,
|
||||||
|
VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_ATOMIC_FLOAT_FEATURES_EXT);
|
||||||
|
OPT_CHAIN(FF_VK_EXT_COOP_MATRIX, &p->coop_matrix_features,
|
||||||
|
VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_COOPERATIVE_MATRIX_FEATURES_KHR);
|
||||||
|
OPT_CHAIN(FF_VK_EXT_SHADER_OBJECT, &p->shader_object_features,
|
||||||
|
VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_OBJECT_FEATURES_EXT);
|
||||||
|
OPT_CHAIN(FF_VK_EXT_OPTICAL_FLOW, &p->optical_flow_features,
|
||||||
|
VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_OPTICAL_FLOW_FEATURES_NV);
|
||||||
|
#undef OPT_CHAIN
|
||||||
|
|
||||||
ctx->free = vulkan_device_free;
|
ctx->free = vulkan_device_free;
|
||||||
|
|
||||||
|
@ -291,6 +291,15 @@ static inline const void *ff_vk_find_struct(const void *chain, VkStructureType s
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void ff_vk_link_struct(void *chain, const void *in)
|
||||||
|
{
|
||||||
|
VkBaseOutStructure *out = chain;
|
||||||
|
while (out->pNext)
|
||||||
|
out = out->pNext;
|
||||||
|
|
||||||
|
out->pNext = (void *)in;
|
||||||
|
}
|
||||||
|
|
||||||
/* Identity mapping - r = r, b = b, g = g, a = a */
|
/* Identity mapping - r = r, b = b, g = g, a = a */
|
||||||
extern const VkComponentMapping ff_comp_identity_map;
|
extern const VkComponentMapping ff_comp_identity_map;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user