FFmpeg
vulkan.h
Go to the documentation of this file.
1 /*
2  * This file is part of FFmpeg.
3  *
4  * FFmpeg is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2.1 of the License, or (at your option) any later version.
8  *
9  * FFmpeg is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public
15  * License along with FFmpeg; if not, write to the Free Software
16  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17  */
18 
19 #ifndef AVUTIL_VULKAN_H
20 #define AVUTIL_VULKAN_H
21 
22 #define VK_NO_PROTOTYPES
23 
24 #include <stdatomic.h>
25 
26 #include "pixdesc.h"
27 #include "bprint.h"
28 #include "hwcontext.h"
29 #include "vulkan_functions.h"
30 #include "hwcontext_vulkan.h"
31 #include "avassert.h"
32 #include "intreadwrite.h"
33 
34 /* GLSL management macros */
35 #define INDENT(N) INDENT_##N
36 #define INDENT_0
37 #define INDENT_1 INDENT_0 " "
38 #define INDENT_2 INDENT_1 INDENT_1
39 #define INDENT_3 INDENT_2 INDENT_1
40 #define INDENT_4 INDENT_3 INDENT_1
41 #define INDENT_5 INDENT_4 INDENT_1
42 #define INDENT_6 INDENT_5 INDENT_1
43 #define C(N, S) INDENT(N) #S "\n"
44 
45 #define GLSLC(N, S) \
46  do { \
47  av_bprintf(&shd->src, C(N, S)); \
48  } while (0)
49 
50 #define GLSLA(...) \
51  do { \
52  av_bprintf(&shd->src, __VA_ARGS__); \
53  } while (0)
54 
55 #define GLSLF(N, S, ...) \
56  do { \
57  av_bprintf(&shd->src, C(N, S), __VA_ARGS__); \
58  } while (0)
59 
60 #define GLSLD(D) \
61  do { \
62  av_bprintf(&shd->src, "\n"); \
63  av_bprint_append_data(&shd->src, D, strlen(D)); \
64  av_bprintf(&shd->src, "\n"); \
65  } while (0)
66 
67 /* Helper, pretty much every Vulkan return value needs to be checked */
68 #define RET(x) \
69  do { \
70  if ((err = (x)) < 0) \
71  goto fail; \
72  } while (0)
73 
74 /* Convenience macros for specialization lists */
75 #define SPEC_LIST_MAX 256
76 #define SPEC_LIST_CREATE(name, max_length, max_size) \
77  av_assert1((max_length) < (SPEC_LIST_MAX - 3)); \
78  uint8_t name##_data[(max_size) + 3*sizeof(uint32_t)]; \
79  VkSpecializationMapEntry name##_entries[(max_length) + 3]; \
80  VkSpecializationInfo name##_info = { \
81  .pMapEntries = name##_entries, \
82  .pData = name##_data, \
83  }; \
84  VkSpecializationInfo *name = &name##_info;
85 
86 #define SPEC_LIST_ADD(name, idx, val_bits, val) \
87 do { \
88  unsigned int name##_cnt = name->mapEntryCount; \
89  size_t name##_off = name->dataSize; \
90  uint8_t *name##_dp = (uint8_t *)name->pData; \
91  void *name##_ep = (void *)&name->pMapEntries[name##_cnt]; \
92  AV_WN(val_bits, name##_dp + name##_off, (val)); \
93  VkSpecializationMapEntry name##_new_entry = { \
94  .constantID = (idx), \
95  .offset = name##_off, \
96  .size = val_bits >> 3, \
97  }; \
98  memcpy(name##_ep, &name##_new_entry, \
99  sizeof(VkSpecializationMapEntry)); \
100  name->dataSize = name##_off + (val_bits >> 3); \
101  name->mapEntryCount = name##_cnt + 1; \
102 } while (0)
103 
104 #define DUP_SAMPLER(x) { x, x, x, x }
105 
106 #define FF_VK_MAX_DESCRIPTOR_SETS 4
107 #define FF_VK_MAX_DESCRIPTOR_BINDINGS 16
108 #define FF_VK_MAX_DESCRIPTOR_TYPES 16
109 #define FF_VK_MAX_PUSH_CONSTS 4
110 #define FF_VK_MAX_SHADERS 16
111 
113  const char *name;
114  VkDescriptorType type;
115  const char *mem_layout; /* Storage images (rgba8, etc.) and buffers (std430, etc.) */
116  const char *mem_quali; /* readonly, writeonly, etc. */
117  const char *buf_content; /* For buffers */
118  uint32_t dimensions; /* Needed for e.g. sampler%iD */
119  uint32_t elems; /* 0 - scalar, 1 or more - vector */
120  VkShaderStageFlags stages;
121  uint32_t buf_elems; /* Appends [buf_elems] to the contents. Avoids manually printing to a string. */
122  VkSampler samplers[4]; /* Sampler to use for all elems */
124 
125 typedef struct FFVkBuffer {
126  VkBuffer buf;
127  VkDeviceMemory mem;
128  VkMemoryPropertyFlagBits flags;
129  size_t size;
130  VkDeviceAddress address;
131 
132  /* Only valid when allocated via ff_vk_get_pooled_buffer with HOST_VISIBLE or
133  * via ff_vk_host_map_buffer */
134  uint8_t *mapped_mem;
135 
136  /* Set by ff_vk_host_map_buffer. This is the offset at which the buffer data
137  * actually begins at.
138  * The address and mapped_mem fields will be offset by this amount. */
140 
141  /* If host mapping, reference to the backing host memory buffer */
143 } FFVkBuffer;
144 
145 typedef struct FFVkExecContext {
146  uint32_t idx;
147  const struct FFVkExecPool *parent;
149 
150  /* Queue for the execution context */
151  VkQueue queue;
152  int qf;
153  int qi;
154 
155  /* Command buffer for the context */
156  VkCommandBuffer buf;
157 
158  /* Fence for the command buffer */
159  VkFence fence;
160 
161  /* Opaque data, untouched, free to use by users */
162  void *opaque;
163 
164  void *query_data;
166 
167  /* Buffer dependencies */
170  unsigned int buf_deps_alloc_size;
171 
172  /* Frame dependencies */
174  unsigned int frame_deps_alloc_size;
176 
177  /* Software frame dependencies */
181 
182  VkSemaphoreSubmitInfo *sem_wait;
183  unsigned int sem_wait_alloc;
185 
186  VkSemaphoreSubmitInfo *sem_sig;
187  unsigned int sem_sig_alloc;
189 
190  uint64_t **sem_sig_val_dst;
191  unsigned int sem_sig_val_dst_alloc;
193 
194  uint8_t *frame_locked;
196 
197  VkAccessFlagBits *access_dst;
198  unsigned int access_dst_alloc;
199 
200  VkImageLayout *layout_dst;
201  unsigned int layout_dst_alloc;
202 
203  uint32_t *queue_family_dst;
205 
206  uint8_t *frame_update;
209 
210 typedef struct FFVulkanDescriptorSet {
211  /* Descriptor buffer */
212  VkDeviceSize layout_size;
213  VkDeviceSize aligned_size; /* descriptorBufferOffsetAlignment */
214  VkBufferUsageFlags usage;
215 
216  VkDescriptorSetLayoutBinding binding[FF_VK_MAX_DESCRIPTOR_BINDINGS];
218 
220 
221  /* Descriptor set is shared between all submissions */
222  int singular;
224 
225 typedef struct FFVulkanShader {
226  /* Name for id/debugging purposes */
227  const char *name;
228 
229  /* Whether shader is precompiled or not */
231  VkSpecializationInfo *specialization_info;
232 
233  /* Shader text */
234  AVBPrint src;
235 
236  /* Compute shader local group sizes */
237  uint32_t lg_size[3];
238 
239  /* Shader bind point/type */
240  VkPipelineStageFlags stage;
241  VkPipelineBindPoint bind_point;
242 
243  /* Creation info */
244  VkPipelineShaderStageRequiredSubgroupSizeCreateInfo subgroup_info;
245 
246  /* Base shader object */
247  VkShaderEXT object;
248  VkPipeline pipeline;
249 
250  /* Pipeline layout */
251  VkPipelineLayout pipeline_layout;
252 
253  /* Push consts */
254  VkPushConstantRange push_consts[FF_VK_MAX_PUSH_CONSTS];
256 
257  /* Descriptor sets */
260 
261  /* Descriptors */
262  VkDescriptorSetLayout desc_layout[FF_VK_MAX_DESCRIPTOR_SETS];
263 
264  /* Descriptor pool */
265  int use_push;
269 
271  /* Descriptor buffer */
273  uint8_t *desc_mem;
275 
276 typedef struct FFVulkanShaderData {
277  /* Shader to which this data belongs to */
280 
281  /* Descriptor buffer */
283  VkDescriptorBufferBindingInfoEXT desc_bind[FF_VK_MAX_DESCRIPTOR_SETS];
284 
285  /* Descriptor pools */
286  VkDescriptorSet *desc_sets;
287  VkDescriptorPool desc_pool;
289 
290 typedef struct FFVkExecPool {
293 
294  VkCommandPool *cmd_buf_pools;
295  VkCommandBuffer *cmd_bufs;
297 
298  VkQueryPool query_pool;
299  void *query_data;
305  size_t qd_size;
306 
307  /* Registered shaders' data */
310 } FFVkExecPool;
311 
312 typedef struct FFVulkanContext {
313  const AVClass *class;
314  void *log_parent;
315 
318  VkPhysicalDeviceProperties2 props;
319  VkPhysicalDeviceVulkan11Properties props_11;
320  VkPhysicalDeviceDriverProperties driver_props;
321  VkPhysicalDeviceMemoryProperties mprops;
322  VkPhysicalDeviceExternalMemoryHostPropertiesEXT hprops;
323  VkPhysicalDeviceDescriptorBufferPropertiesEXT desc_buf_props;
324  VkPhysicalDeviceSubgroupSizeControlProperties subgroup_props;
325  VkPhysicalDeviceCooperativeMatrixPropertiesKHR coop_matrix_props;
326  VkPhysicalDevicePushDescriptorPropertiesKHR push_desc_props;
327  VkPhysicalDeviceOpticalFlowPropertiesNV optical_flow_props;
328 #ifdef VK_EXT_shader_long_vector
329  VkPhysicalDeviceShaderLongVectorPropertiesEXT long_vector_props;
330 #endif
331  VkQueueFamilyQueryResultStatusPropertiesKHR *query_props;
332  VkQueueFamilyVideoPropertiesKHR *video_props;
333  VkQueueFamilyProperties2 *qf_props;
335  VkPhysicalDeviceHostImageCopyPropertiesEXT host_image_props;
336  VkImageLayout *host_image_copy_layouts;
337 
338  VkCooperativeMatrixPropertiesKHR *coop_mat_props;
340 
341  VkPhysicalDeviceShaderAtomicFloatFeaturesEXT atomic_float_feats;
342  VkPhysicalDeviceVulkan12Features feats_12;
343  VkPhysicalDeviceFeatures2 feats;
344 
345  VkMemoryPropertyFlagBits host_cached_flag;
346 
350 
355 
356  uint32_t qfs[64];
357  int nb_qfs;
358 
359  /* Properties */
365 
366 static inline int ff_vk_count_images(AVVkFrame *f)
367 {
368  int cnt = 0;
369  while (cnt < FF_ARRAY_ELEMS(f->img) && f->img[cnt])
370  cnt++;
371 
372  return cnt;
373 }
374 
375 static inline const void *ff_vk_find_struct(const void *chain, VkStructureType stype)
376 {
377  const VkBaseInStructure *in = chain;
378  while (in) {
379  if (in->sType == stype)
380  return in;
381 
382  in = in->pNext;
383  }
384 
385  return NULL;
386 }
387 
388 static inline void ff_vk_link_struct(void *chain, const void *in)
389 {
390  VkBaseOutStructure *out = chain;
391  while (out->pNext)
392  out = out->pNext;
393 
394  out->pNext = (void *)in;
395 }
396 
397 #define FF_VK_STRUCT_EXT(CTX, BASE, STRUCT_P, EXT_FLAG, TYPE) \
398  do { \
399  if ((EXT_FLAG == FF_VK_EXT_NO_FLAG) || \
400  ((CTX)->extensions & EXT_FLAG)) { \
401  (STRUCT_P)->sType = TYPE; \
402  ff_vk_link_struct(BASE, STRUCT_P); \
403  } \
404  } while (0)
405 
406 /* Identity mapping - r = r, b = b, g = g, a = a */
407 extern const VkComponentMapping ff_comp_identity_map;
408 
409 /**
410  * Initializes the AVClass, in case this context is not used
411  * as the main user's context.
412  * May use either a frames context reference, or a device context reference.
413  */
414 int ff_vk_init(FFVulkanContext *s, void *log_parent,
415  AVBufferRef *device_ref, AVBufferRef *frames_ref);
416 
417 /**
418  * Converts Vulkan return values to strings
419  */
420 const char *ff_vk_ret2str(VkResult res);
421 
422 /**
423  * Map between usage and features.
424  */
425 VkImageUsageFlags ff_vk_map_feats_to_usage(VkFormatFeatureFlagBits2 feats);
426 VkFormatFeatureFlagBits2 ff_vk_map_usage_to_feats(VkImageUsageFlags usage);
427 
428 /**
429  * Returns 1 if pixfmt is a usable RGB format.
430  */
432 
433 /**
434  * Since storage images may not be swizzled, we have to do this in the
435  * shader itself. This fills in a lookup table to do it.
436  */
437 void ff_vk_set_perm(enum AVPixelFormat pix_fmt, int lut[4], int inv);
438 
439 /**
440  * Get the aspect flag for a plane from an image.
441  */
442 VkImageAspectFlags ff_vk_aspect_flag(AVFrame *f, int p);
443 
444 /**
445  * Returns the format to use for images in shaders.
446  */
448  /* Native format with no conversion. May require casting. */
450  /* Float conversion of the native format. */
452  /* Signed integer version of the native format */
454  /* Unsigned integer version of the native format */
456 };
458  enum FFVkShaderRepFormat rep_fmt);
459 
460 /**
461  * Loads props/mprops/driver_props
462  */
464 
465 /**
466  * Chooses an appropriate QF.
467  */
469  VkQueueFlagBits dev_family,
470  VkVideoCodecOperationFlagBitsKHR vid_ops);
471 
472 /**
473  * Allocates/frees an execution pool.
474  * If used in a multi-threaded context, there must be at least as many contexts
475  * as there are threads.
476  * ff_vk_exec_pool_init_desc() MUST be called if ff_vk_exec_descriptor_set_add()
477  * has been called.
478  */
480  FFVkExecPool *pool, int nb_contexts,
481  int nb_queries, VkQueryType query_type, int query_64bit,
482  const void *query_create_pnext);
484 
485 /**
486  * Retrieve an execution pool. Threadsafe.
487  */
489 
490 /**
491  * Performs nb_queries queries and returns their results and statuses.
492  * 64_BIT and WITH_STATUS flags are ignored as 64_BIT must be specified via
493  * query_64bit in ff_vk_exec_pool_init() and WITH_STATUS is always enabled.
494  */
496  void **data, VkQueryResultFlagBits flags);
497 
498 /**
499  * Start/submit/wait an execution.
500  * ff_vk_exec_start() always waits on a submission, so using ff_vk_exec_wait()
501  * is not necessary (unless using it is just better).
502  */
506 
507 /**
508  * Execution dependency management.
509  * Can attach buffers to executions that will only be unref'd once the
510  * buffer has finished executing.
511  * Adding a frame dep will *lock the frame*, until either the dependencies
512  * are discarded, the execution is submitted, or a failure happens.
513  * update_frame will update the frame's properties before it is unlocked,
514  * only if submission was successful.
515  */
517  AVBufferRef **deps, int nb_deps, int ref);
519  VkSemaphore sem, uint64_t val,
520  VkPipelineStageFlagBits2 stage);
522  VkSemaphore *sem, int nb,
523  VkPipelineStageFlagBits2 stage,
524  int wait); /* Ownership transferred if !wait */
526  VkPipelineStageFlagBits2 wait_stage,
527  VkPipelineStageFlagBits2 signal_stage);
529  AVFrame *f);
531  VkImageMemoryBarrier2 *bar, uint32_t *nb_img_bar);
533  VkSemaphore *dst, uint64_t *dst_val,
534  AVFrame *f);
536 
537 /**
538  * Create a single imageview for a given plane.
539  */
541  VkImageView *img_view, VkImageAspectFlags *aspect,
542  AVFrame *f, int plane, enum FFVkShaderRepFormat rep_fmt);
543 
544 /**
545  * Create an imageview and add it as a dependency to an execution.
546  */
548  VkImageView views[AV_NUM_DATA_POINTERS],
549  AVFrame *f, enum FFVkShaderRepFormat rep_fmt);
550 
551 #define ff_vk_buf_barrier(dst, vkb, s_stage, s_access, s_access2, \
552  d_stage, d_access, d_access2, offs, bsz) \
553  do { \
554  dst = (VkBufferMemoryBarrier2) { \
555  .sType = VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER_2, \
556  .srcStageMask = VK_PIPELINE_STAGE_2_ ##s_stage, \
557  .srcAccessMask = VK_ACCESS_2_ ##s_access | \
558  VK_ACCESS_2_ ##s_access2, \
559  .dstStageMask = VK_PIPELINE_STAGE_2_ ##d_stage, \
560  .dstAccessMask = VK_ACCESS_2_ ##d_access | \
561  VK_ACCESS_2_ ##d_access2, \
562  .srcQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED, \
563  .dstQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED, \
564  .buffer = vkb->buf, \
565  .offset = offs, \
566  .size = bsz \
567  }; \
568  } while(0)
569 
571  AVFrame *pic, VkImageMemoryBarrier2 *bar, int *nb_bar,
572  VkPipelineStageFlags2 src_stage,
573  VkPipelineStageFlags2 dst_stage,
574  VkAccessFlagBits2 new_access,
575  VkImageLayout new_layout,
576  uint32_t new_qf);
577 
578 /**
579  * Memory/buffer/image allocation helpers.
580  */
581 int ff_vk_alloc_mem(FFVulkanContext *s, VkMemoryRequirements *req,
582  VkMemoryPropertyFlagBits req_flags, void *alloc_extension,
583  VkMemoryPropertyFlagBits *mem_flags, VkDeviceMemory *mem);
585  void *pNext, void *alloc_pNext,
586  VkBufferUsageFlags usage, VkMemoryPropertyFlagBits flags);
587 
588 /**
589  * Flush or invalidate a single buffer, with a given size and offset.
590  */
592  VkDeviceSize offset, VkDeviceSize mem_size,
593  int flush);
594 
595 /**
596  * Buffer management code.
597  */
598 int ff_vk_map_buffers(FFVulkanContext *s, FFVkBuffer **buf, uint8_t *mem[],
599  int nb_buffers, int invalidate);
600 int ff_vk_unmap_buffers(FFVulkanContext *s, FFVkBuffer **buf, int nb_buffers,
601  int flush);
602 
603 static inline int ff_vk_map_buffer(FFVulkanContext *s, FFVkBuffer *buf, uint8_t **mem,
604  int invalidate)
605 {
606  return ff_vk_map_buffers(s, (FFVkBuffer *[]){ buf }, mem,
607  1, invalidate);
608 }
609 
610 static inline int ff_vk_unmap_buffer(FFVulkanContext *s, FFVkBuffer *buf, int flush)
611 {
612  return ff_vk_unmap_buffers(s, (FFVkBuffer *[]){ buf }, 1, flush);
613 }
614 
616 
617 /** Initialize a pool and create AVBufferRefs containing FFVkBuffer.
618  * Threadsafe to use. Buffers are automatically mapped on creation if
619  * VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT is set in mem_props. Users should
620  * synchronize access themselvesd. Mainly meant for device-local buffers. */
622  AVBufferRef **buf, VkBufferUsageFlags usage,
623  void *create_pNext, size_t size,
624  VkMemoryPropertyFlagBits mem_props);
625 
626 /** Maps a system RAM buffer into a Vulkan buffer.
627  * References the source buffer.
628  */
630  uint8_t *src_data, const AVBufferRef *src_buf,
631  VkBufferUsageFlags usage);
632 
633 /**
634  * Create a sampler.
635  */
636 int ff_vk_init_sampler(FFVulkanContext *s, VkSampler *sampler,
637  int unnorm_coords, VkFilter filt);
638 
639 /**
640  * Initialize a shader object, with a specific set of extensions, type+bind,
641  * local group size, and subgroup requirements.
642  */
643 int ff_vk_shader_init(FFVulkanContext *s, FFVulkanShader *shd, const char *name,
644  VkPipelineStageFlags stage,
645  const char *extensions[], int nb_extensions,
646  int lg_x, int lg_y, int lg_z,
647  uint32_t required_subgroup_size);
648 
649 /**
650  * Initialize a shader object.
651  * If spec is non-null, it must have been created with SPEC_LIST_CREATE().
652  * The IDs for the workgroup size must be 253, 254, 255.
653  */
655  VkPipelineStageFlags stage, VkSpecializationInfo *spec,
656  uint32_t wg_size[3], uint32_t required_subgroup_size);
657 
658 /**
659  * Output the shader code as logging data, with a specific
660  * priority.
661  */
662 void ff_vk_shader_print(void *ctx, FFVulkanShader *shd, int prio);
663 
664 /**
665  * Link a shader into an executable.
666  */
668  const char *spirv, size_t spirv_len,
669  const char *entrypoint);
670 
671 /**
672  * Add/update push constants for execution.
673  */
675  VkShaderStageFlagBits stage);
676 
677 /**
678  * Add descriptor to a shader. Must be called before shader init.
679  */
681  const FFVulkanDescriptorSetBinding *desc, int nb,
682  int singular, int print_to_shader_only);
683 
684 /**
685  * Register a shader with an exec pool.
686  * Pool may be NULL if all descriptor sets are read-only.
687  */
689  FFVulkanShader *shd);
690 
691 /**
692  * Bind a shader.
693  */
695  FFVulkanShader *shd);
696 
697 /**
698  * Update push constant in a shader.
699  * Must be called before binding the shader.
700  */
702  FFVulkanShader *shd,
703  VkShaderStageFlagBits stage,
704  int offset, size_t size, void *src);
705 
706 /**
707  * Update a descriptor in a buffer with a buffer.
708  * Must be called before binding the shader.
709  */
711  FFVulkanShader *shd,
712  int set, int bind, int elem,
713  FFVkBuffer *buf, VkDeviceSize offset, VkDeviceSize len,
714  VkFormat fmt);
715 
716 /**
717  * Sets an image descriptor for specified shader and binding.
718  */
720  FFVulkanShader *shd, int set, int bind, int offs,
721  VkImageView view, VkImageLayout layout,
722  VkSampler sampler);
723 
724 /**
725  * Update a descriptor in a buffer with an image array..
726  * Must be called before binding the shader.
727  */
729  FFVulkanShader *shd, AVFrame *f,
730  VkImageView *views, int set, int binding,
731  VkImageLayout layout, VkSampler sampler);
732 
733 /**
734  * Free a shader.
735  */
737 
738 /**
739  * Frees main context.
740  */
742 
743 #endif /* AVUTIL_VULKAN_H */
FFVulkanShader::bind_point
VkPipelineBindPoint bind_point
Definition: vulkan.h:241
flags
const SwsFlags flags[]
Definition: swscale.c:61
ff_vk_ret2str
const char * ff_vk_ret2str(VkResult res)
Converts Vulkan return values to strings.
Definition: vulkan.c:40
ff_vk_exec_add_dep_bool_sem
int ff_vk_exec_add_dep_bool_sem(FFVulkanContext *s, FFVkExecContext *e, VkSemaphore *sem, int nb, VkPipelineStageFlagBits2 stage, int wait)
Definition: vulkan.c:712
ff_vk_map_buffers
int ff_vk_map_buffers(FFVulkanContext *s, FFVkBuffer **buf, uint8_t *mem[], int nb_buffers, int invalidate)
Buffer management code.
Definition: vulkan.c:1112
ff_vk_unmap_buffers
int ff_vk_unmap_buffers(FFVulkanContext *s, FFVkBuffer **buf, int nb_buffers, int flush)
Definition: vulkan.c:1192
AVPixelFormat
AVPixelFormat
Pixel format.
Definition: pixfmt.h:71
name
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf default minimum maximum flags name is the option name
Definition: writing_filters.txt:88
ff_vk_exec_discard_deps
void ff_vk_exec_discard_deps(FFVulkanContext *s, FFVkExecContext *e)
Definition: vulkan.c:590
ff_vk_map_usage_to_feats
VkFormatFeatureFlagBits2 ff_vk_map_usage_to_feats(VkImageUsageFlags usage)
FFVulkanContext::hwfc
AVVulkanFramesContext * hwfc
Definition: vulkan.h:354
ff_vk_uninit
void ff_vk_uninit(FFVulkanContext *s)
Frees main context.
Definition: vulkan.c:2815
ff_vk_exec_add_dep_frame
int ff_vk_exec_add_dep_frame(FFVulkanContext *s, FFVkExecContext *e, AVFrame *f, VkPipelineStageFlagBits2 wait_stage, VkPipelineStageFlagBits2 signal_stage)
Definition: vulkan.c:778
FFVulkanContext::output_height
int output_height
Definition: vulkan.h:361
FFVulkanContext::props_11
VkPhysicalDeviceVulkan11Properties props_11
Definition: vulkan.h:319
FFVkExecContext::frame_deps_alloc_size
unsigned int frame_deps_alloc_size
Definition: vulkan.h:174
out
static FILE * out
Definition: movenc.c:55
FFVulkanExtensions
uint64_t FFVulkanExtensions
Definition: vulkan_functions.h:29
AVBufferPool
The buffer pool.
Definition: buffer_internal.h:88
ff_vk_load_props
int ff_vk_load_props(FFVulkanContext *s)
Loads props/mprops/driver_props.
Definition: vulkan.c:147
ff_vk_exec_pool_init
int ff_vk_exec_pool_init(FFVulkanContext *s, AVVulkanDeviceQueueFamily *qf, FFVkExecPool *pool, int nb_contexts, int nb_queries, VkQueryType query_type, int query_64bit, const void *query_create_pnext)
Allocates/frees an execution pool.
Definition: vulkan.c:355
ff_vk_exec_add_dep_sw_frame
int ff_vk_exec_add_dep_sw_frame(FFVulkanContext *s, FFVkExecContext *e, AVFrame *f)
Definition: vulkan.c:645
FFVulkanContext::device_ref
AVBufferRef * device_ref
Definition: vulkan.h:347
FFVkExecPool::contexts
FFVkExecContext * contexts
Definition: vulkan.h:291
FFVkExecPool::idx
atomic_uint_least64_t idx
Definition: vulkan.h:292
FFVulkanDescriptorSetData
Definition: vulkan.h:270
FFVulkanShader::nb_desc_pool_size
int nb_desc_pool_size
Definition: vulkan.h:267
FFVulkanShaderData
Definition: vulkan.h:276
FFVkExecContext::qf
int qf
Definition: vulkan.h:152
FFVulkanDescriptorSet::aligned_size
VkDeviceSize aligned_size
Definition: vulkan.h:213
FFVulkanShaderData::shd
FFVulkanShader * shd
Definition: vulkan.h:278
ff_vk_init
int ff_vk_init(FFVulkanContext *s, void *log_parent, AVBufferRef *device_ref, AVBufferRef *frames_ref)
Initializes the AVClass, in case this context is not used as the main user's context.
Definition: vulkan.c:2827
FFVulkanShader::desc_pool_size
VkDescriptorPoolSize desc_pool_size[FF_VK_MAX_DESCRIPTOR_TYPES]
Definition: vulkan.h:266
FFVkBuffer::host_ref
AVBufferRef * host_ref
Definition: vulkan.h:142
FFVulkanShaderData::desc_set_buf
FFVulkanDescriptorSetData desc_set_buf[FF_VK_MAX_DESCRIPTOR_SETS]
Definition: vulkan.h:282
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:427
pixdesc.h
FFVulkanDescriptorSetBinding::stages
VkShaderStageFlags stages
Definition: vulkan.h:120
ff_vk_map_buffer
static int ff_vk_map_buffer(FFVulkanContext *s, FFVkBuffer *buf, uint8_t **mem, int invalidate)
Definition: vulkan.h:603
FFVulkanShader::subgroup_info
VkPipelineShaderStageRequiredSubgroupSizeCreateInfo subgroup_info
Definition: vulkan.h:244
ff_vk_find_struct
static const void * ff_vk_find_struct(const void *chain, VkStructureType stype)
Definition: vulkan.h:375
FFVulkanShader::pipeline
VkPipeline pipeline
Definition: vulkan.h:248
FFVkExecContext::sem_sig_alloc
unsigned int sem_sig_alloc
Definition: vulkan.h:187
FF_VK_MAX_SHADERS
#define FF_VK_MAX_SHADERS
Definition: vulkan.h:110
FFVulkanShader::src
AVBPrint src
Definition: vulkan.h:234
FFVulkanShader::use_push
int use_push
Definition: vulkan.h:265
ff_vk_exec_add_dep_wait_sem
int ff_vk_exec_add_dep_wait_sem(FFVulkanContext *s, FFVkExecContext *e, VkSemaphore sem, uint64_t val, VkPipelineStageFlagBits2 stage)
Definition: vulkan.c:695
data
const char data[16]
Definition: mxf.c:149
FFVkBuffer::address
VkDeviceAddress address
Definition: vulkan.h:130
FFVkExecContext::sem_wait
VkSemaphoreSubmitInfo * sem_wait
Definition: vulkan.h:182
FF_VK_REP_NATIVE
@ FF_VK_REP_NATIVE
Definition: vulkan.h:449
FF_VK_REP_INT
@ FF_VK_REP_INT
Definition: vulkan.h:453
FFVulkanDescriptorSetBinding::buf_content
const char * buf_content
Definition: vulkan.h:117
ff_vk_shader_print
void ff_vk_shader_print(void *ctx, FFVulkanShader *shd, int prio)
Output the shader code as logging data, with a specific priority.
Definition: vulkan.c:2165
FFVkExecPool::query_pool
VkQueryPool query_pool
Definition: vulkan.h:298
FFVkExecPool::nb_reg_shd
int nb_reg_shd
Definition: vulkan.h:309
FFVulkanDescriptorSetData::desc_mem
uint8_t * desc_mem
Definition: vulkan.h:273
FFVkExecContext::nb_sw_frame_deps
int nb_sw_frame_deps
Definition: vulkan.h:180
FFVulkanShaderData::desc_sets
VkDescriptorSet * desc_sets
Definition: vulkan.h:286
FFVulkanContext::tot_nb_qfs
int tot_nb_qfs
Definition: vulkan.h:334
FFVkShaderRepFormat
FFVkShaderRepFormat
Returns the format to use for images in shaders.
Definition: vulkan.h:447
FFVkBuffer::buf
VkBuffer buf
Definition: vulkan.h:126
ff_vk_shader_free
void ff_vk_shader_free(FFVulkanContext *s, FFVulkanShader *shd)
Free a shader.
Definition: vulkan.c:2789
FFVkExecContext::frame_update_alloc_size
unsigned int frame_update_alloc_size
Definition: vulkan.h:207
ff_vk_shader_register_exec
int ff_vk_shader_register_exec(FFVulkanContext *s, FFVkExecPool *pool, FFVulkanShader *shd)
Register a shader with an exec pool.
Definition: vulkan.c:2582
ff_vk_shader_rep_fmt
const char * ff_vk_shader_rep_fmt(enum AVPixelFormat pix_fmt, enum FFVkShaderRepFormat rep_fmt)
Definition: vulkan.c:1605
ff_vk_flush_buffer
int ff_vk_flush_buffer(FFVulkanContext *s, FFVkBuffer *buf, VkDeviceSize offset, VkDeviceSize mem_size, int flush)
Flush or invalidate a single buffer, with a given size and offset.
Definition: vulkan.c:1161
FFVulkanDescriptorSet::nb_bindings
int nb_bindings
Definition: vulkan.h:219
FFVulkanContext::feats
VkPhysicalDeviceFeatures2 feats
Definition: vulkan.h:343
ff_vk_exec_mirror_sem_value
int ff_vk_exec_mirror_sem_value(FFVulkanContext *s, FFVkExecContext *e, VkSemaphore *dst, uint64_t *dst_val, AVFrame *f)
Definition: vulkan.c:877
FFVulkanDescriptorSet::layout_size
VkDeviceSize layout_size
Definition: vulkan.h:212
AVVulkanFramesContext
Allocated as AVHWFramesContext.hwctx, used to set pool-specific options.
Definition: hwcontext_vulkan.h:212
FFVkExecPool::query_64bit
int query_64bit
Definition: vulkan.h:302
FFVulkanContext::subgroup_props
VkPhysicalDeviceSubgroupSizeControlProperties subgroup_props
Definition: vulkan.h:324
val
static double val(void *priv, double ch)
Definition: aeval.c:77
FFVulkanContext::frames_ref
AVBufferRef * frames_ref
Definition: vulkan.h:352
FFVulkanContext::atomic_float_feats
VkPhysicalDeviceShaderAtomicFloatFeaturesEXT atomic_float_feats
Definition: vulkan.h:341
ff_vk_shader_link
int ff_vk_shader_link(FFVulkanContext *s, FFVulkanShader *shd, const char *spirv, size_t spirv_len, const char *entrypoint)
Link a shader into an executable.
Definition: vulkan.c:2355
FFVkExecPool::query_statuses
int query_statuses
Definition: vulkan.h:301
AVHWDeviceContext
This struct aggregates all the (hardware/vendor-specific) "high-level" state, i.e.
Definition: hwcontext.h:63
FFVulkanDescriptorSetBinding::type
VkDescriptorType type
Definition: vulkan.h:114
ff_vk_exec_get_query
VkResult ff_vk_exec_get_query(FFVulkanContext *s, FFVkExecContext *e, void **data, VkQueryResultFlagBits flags)
Performs nb_queries queries and returns their results and statuses.
Definition: vulkan.c:518
FFVulkanShader::specialization_info
VkSpecializationInfo * specialization_info
Definition: vulkan.h:231
avassert.h
FFVulkanDescriptorSetData::buf
FFVkBuffer buf
Definition: vulkan.h:272
FFVulkanShaderData::desc_bind
VkDescriptorBufferBindingInfoEXT desc_bind[FF_VK_MAX_DESCRIPTOR_SETS]
Definition: vulkan.h:283
FF_ARRAY_ELEMS
#define FF_ARRAY_ELEMS(a)
Definition: sinewin_tablegen.c:29
FFVulkanDescriptorSetBinding::samplers
VkSampler samplers[4]
Definition: vulkan.h:122
FFVkExecContext::frame_deps
AVFrame ** frame_deps
Definition: vulkan.h:173
ff_vk_link_struct
static void ff_vk_link_struct(void *chain, const void *in)
Definition: vulkan.h:388
set
static void set(uint8_t *a[], int ch, int index, int ch_count, enum AVSampleFormat f, double v)
Definition: swresample.c:57
ff_vk_host_map_buffer
int ff_vk_host_map_buffer(FFVulkanContext *s, AVBufferRef **dst, uint8_t *src_data, const AVBufferRef *src_buf, VkBufferUsageFlags usage)
Maps a system RAM buffer into a Vulkan buffer.
Definition: vulkan.c:1381
FFVkExecContext::queue_family_dst
uint32_t * queue_family_dst
Definition: vulkan.h:203
FFVulkanDescriptorSetBinding::elems
uint32_t elems
Definition: vulkan.h:119
ff_vk_shader_add_descriptor_set
int ff_vk_shader_add_descriptor_set(FFVulkanContext *s, FFVulkanShader *shd, const FFVulkanDescriptorSetBinding *desc, int nb, int singular, int print_to_shader_only)
Add descriptor to a shader.
Definition: vulkan.c:2482
FFVulkanContext::output_width
int output_width
Definition: vulkan.h:360
ff_vk_shader_update_desc_buffer
int ff_vk_shader_update_desc_buffer(FFVulkanContext *s, FFVkExecContext *e, FFVulkanShader *shd, int set, int bind, int elem, FFVkBuffer *buf, VkDeviceSize offset, VkDeviceSize len, VkFormat fmt)
Update a descriptor in a buffer with a buffer.
Definition: vulkan.c:2730
intreadwrite.h
s
#define s(width, name)
Definition: cbs_vp9.c:198
FFVulkanContext::log_parent
void * log_parent
Definition: vulkan.h:314
FFVulkanContext::driver_props
VkPhysicalDeviceDriverProperties driver_props
Definition: vulkan.h:320
pix_fmt
static enum AVPixelFormat pix_fmt
Definition: demux_decode.c:41
FFVkExecContext::fence
VkFence fence
Definition: vulkan.h:159
FFVulkanShader::desc_set
FFVulkanDescriptorSet desc_set[FF_VK_MAX_DESCRIPTOR_SETS]
Definition: vulkan.h:258
ff_vk_free_buf
void ff_vk_free_buf(FFVulkanContext *s, FFVkBuffer *buf)
Definition: vulkan.c:1234
FFVulkanContext::host_cached_flag
VkMemoryPropertyFlagBits host_cached_flag
Definition: vulkan.h:345
FF_VK_REP_FLOAT
@ FF_VK_REP_FLOAT
Definition: vulkan.h:451
FFVkExecContext::nb_buf_deps
int nb_buf_deps
Definition: vulkan.h:169
FFVulkanShader::stage
VkPipelineStageFlags stage
Definition: vulkan.h:240
ctx
static AVFormatContext * ctx
Definition: movenc.c:49
ff_vk_create_buf
int ff_vk_create_buf(FFVulkanContext *s, FFVkBuffer *buf, size_t size, void *pNext, void *alloc_pNext, VkBufferUsageFlags usage, VkMemoryPropertyFlagBits flags)
Definition: vulkan.c:1020
FF_VK_MAX_DESCRIPTOR_BINDINGS
#define FF_VK_MAX_DESCRIPTOR_BINDINGS
Definition: vulkan.h:107
FFVulkanDescriptorSetBinding::mem_layout
const char * mem_layout
Definition: vulkan.h:115
FFVkExecContext::frame_update
uint8_t * frame_update
Definition: vulkan.h:206
FFVkExecContext::query_idx
int query_idx
Definition: vulkan.h:165
FFVkExecPool::query_status_stride
int query_status_stride
Definition: vulkan.h:303
FFVkExecContext::parent
const struct FFVkExecPool * parent
Definition: vulkan.h:147
ff_vk_shader_update_push_const
void ff_vk_shader_update_push_const(FFVulkanContext *s, FFVkExecContext *e, FFVulkanShader *shd, VkShaderStageFlagBits stage, int offset, size_t size, void *src)
Update push constant in a shader.
Definition: vulkan.c:2756
AVVulkanDeviceContext
Main Vulkan context, allocated as AVHWDeviceContext.hwctx.
Definition: hwcontext_vulkan.h:59
FFVulkanDescriptorSet::binding_offset
VkDeviceSize binding_offset[FF_VK_MAX_DESCRIPTOR_BINDINGS]
Definition: vulkan.h:217
AVClass
Describe the class of an AVClass context structure.
Definition: log.h:76
FFVkExecContext::sw_frame_deps_alloc_size
unsigned int sw_frame_deps_alloc_size
Definition: vulkan.h:179
FFVkExecContext::sem_sig_val_dst_alloc
unsigned int sem_sig_val_dst_alloc
Definition: vulkan.h:191
NULL
#define NULL
Definition: coverity.c:32
FFVulkanDescriptorSetBinding::buf_elems
uint32_t buf_elems
Definition: vulkan.h:121
ff_vk_create_imageviews
int ff_vk_create_imageviews(FFVulkanContext *s, FFVkExecContext *e, VkImageView views[AV_NUM_DATA_POINTERS], AVFrame *f, enum FFVkShaderRepFormat rep_fmt)
Create an imageview and add it as a dependency to an execution.
Definition: vulkan.c:1946
ff_vk_frame_barrier
void ff_vk_frame_barrier(FFVulkanContext *s, FFVkExecContext *e, AVFrame *pic, VkImageMemoryBarrier2 *bar, int *nb_bar, VkPipelineStageFlags2 src_stage, VkPipelineStageFlags2 dst_stage, VkAccessFlagBits2 new_access, VkImageLayout new_layout, uint32_t new_qf)
Definition: vulkan.c:2029
FFVkExecContext::access_dst_alloc
unsigned int access_dst_alloc
Definition: vulkan.h:198
FFVulkanDescriptorSet::singular
int singular
Definition: vulkan.h:222
FFVkExecContext::sem_sig_cnt
int sem_sig_cnt
Definition: vulkan.h:188
FFVulkanDescriptorSetBinding::dimensions
uint32_t dimensions
Definition: vulkan.h:118
FFVulkanContext::coop_matrix_props
VkPhysicalDeviceCooperativeMatrixPropertiesKHR coop_matrix_props
Definition: vulkan.h:325
FFVulkanContext::qf_props
VkQueueFamilyProperties2 * qf_props
Definition: vulkan.h:333
hwcontext_vulkan.h
flush
void(* flush)(AVBSFContext *ctx)
Definition: dts2pts.c:552
FFVkExecContext::qi
int qi
Definition: vulkan.h:153
FFVkExecContext::had_submission
int had_submission
Definition: vulkan.h:148
FFVkBuffer::size
size_t size
Definition: vulkan.h:129
FFVkExecPool::nb_queries
int nb_queries
Definition: vulkan.h:304
FFVkBuffer::mapped_mem
uint8_t * mapped_mem
Definition: vulkan.h:134
FFVulkanContext
Definition: vulkan.h:312
FFVulkanShader::nb_descriptor_sets
int nb_descriptor_sets
Definition: vulkan.h:259
ff_vk_init_sampler
int ff_vk_init_sampler(FFVulkanContext *s, VkSampler *sampler, int unnorm_coords, VkFilter filt)
Create a sampler.
Definition: vulkan.c:1490
FFVkExecContext::query_data
void * query_data
Definition: vulkan.h:164
ff_vk_shader_add_push_const
int ff_vk_shader_add_push_const(FFVulkanShader *shd, int offset, int size, VkShaderStageFlagBits stage)
Add/update push constants for execution.
Definition: vulkan.c:1479
ff_vk_exec_wait
void ff_vk_exec_wait(FFVulkanContext *s, FFVkExecContext *e)
Definition: vulkan.c:551
FFVulkanContext::device
AVHWDeviceContext * device
Definition: vulkan.h:348
usage
const char * usage
Definition: floatimg_cmp.c:62
f
f
Definition: af_crystalizer.c:122
FFVkExecContext::layout_dst
VkImageLayout * layout_dst
Definition: vulkan.h:200
ff_vk_get_pooled_buffer
int ff_vk_get_pooled_buffer(FFVulkanContext *ctx, AVBufferPool **buf_pool, AVBufferRef **buf, VkBufferUsageFlags usage, void *create_pNext, size_t size, VkMemoryPropertyFlagBits mem_props)
Initialize a pool and create AVBufferRefs containing FFVkBuffer.
Definition: vulkan.c:1276
FFVkExecContext::queue_family_dst_alloc
unsigned int queue_family_dst_alloc
Definition: vulkan.h:204
FFVulkanDescriptorSetBinding
Definition: vulkan.h:112
ff_vk_exec_start
int ff_vk_exec_start(FFVulkanContext *s, FFVkExecContext *e)
Start/submit/wait an execution.
Definition: vulkan.c:558
FFVulkanShaderData::nb_descriptor_sets
int nb_descriptor_sets
Definition: vulkan.h:279
dst
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
Definition: dsp.h:87
AVVkFrame
Definition: hwcontext_vulkan.h:302
FFVulkanContext::host_image_props
VkPhysicalDeviceHostImageCopyPropertiesEXT host_image_props
Definition: vulkan.h:335
size
int size
Definition: twinvq_data.h:10344
AV_NUM_DATA_POINTERS
#define AV_NUM_DATA_POINTERS
Definition: frame.h:428
FFVkExecContext::nb_frame_deps
int nb_frame_deps
Definition: vulkan.h:175
FFVulkanShader
Definition: vulkan.h:225
ff_vk_create_imageview
int ff_vk_create_imageview(FFVulkanContext *s, VkImageView *img_view, VkImageAspectFlags *aspect, AVFrame *f, int plane, enum FFVkShaderRepFormat rep_fmt)
Create a single imageview for a given plane.
Definition: vulkan.c:1895
FFVulkanShader::pipeline_layout
VkPipelineLayout pipeline_layout
Definition: vulkan.h:251
FFVkExecContext::sem_sig_val_dst_cnt
int sem_sig_val_dst_cnt
Definition: vulkan.h:192
FFVulkanContext::output_format
enum AVPixelFormat output_format
Definition: vulkan.h:362
FFVulkanShader::desc_layout
VkDescriptorSetLayout desc_layout[FF_VK_MAX_DESCRIPTOR_SETS]
Definition: vulkan.h:262
FFVkBuffer::flags
VkMemoryPropertyFlagBits flags
Definition: vulkan.h:128
ff_vk_aspect_flag
VkImageAspectFlags ff_vk_aspect_flag(AVFrame *f, int p)
Get the aspect flag for a plane from an image.
Definition: vulkan.c:1522
offset
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf offset
Definition: writing_filters.txt:86
FFVkExecContext
Definition: vulkan.h:145
FFVulkanDescriptorSetBinding::name
const char * name
Definition: vulkan.h:113
FFVulkanDescriptorSet::binding
VkDescriptorSetLayoutBinding binding[FF_VK_MAX_DESCRIPTOR_BINDINGS]
Definition: vulkan.h:216
ff_vk_shader_load
int ff_vk_shader_load(FFVulkanShader *shd, VkPipelineStageFlags stage, VkSpecializationInfo *spec, uint32_t wg_size[3], uint32_t required_subgroup_size)
Initialize a shader object.
Definition: vulkan.c:2072
ff_vk_exec_add_dep_buf
int ff_vk_exec_add_dep_buf(FFVulkanContext *s, FFVkExecContext *e, AVBufferRef **deps, int nb_deps, int ref)
Execution dependency management.
Definition: vulkan.c:618
ff_vk_exec_bind_shader
void ff_vk_exec_bind_shader(FFVulkanContext *s, FFVkExecContext *e, FFVulkanShader *shd)
Bind a shader.
Definition: vulkan.c:2766
FFVulkanContext::input_frames_ref
AVBufferRef * input_frames_ref
Definition: vulkan.h:351
FFVkExecContext::sem_wait_cnt
int sem_wait_cnt
Definition: vulkan.h:184
layout
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel layout
Definition: filter_design.txt:18
FFVkExecContext::queue
VkQueue queue
Definition: vulkan.h:151
FFVulkanContext::qfs
uint32_t qfs[64]
Definition: vulkan.h:356
ff_vk_shader_update_img
int ff_vk_shader_update_img(FFVulkanContext *s, FFVkExecContext *e, FFVulkanShader *shd, int set, int bind, int offs, VkImageView view, VkImageLayout layout, VkSampler sampler)
Sets an image descriptor for specified shader and binding.
Definition: vulkan.c:2692
ff_vk_exec_submit
int ff_vk_exec_submit(FFVulkanContext *s, FFVkExecContext *e)
Definition: vulkan.c:903
bprint.h
FFVkExecPool::cmd_buf_pools
VkCommandPool * cmd_buf_pools
Definition: vulkan.h:294
FF_VK_REP_UINT
@ FF_VK_REP_UINT
Definition: vulkan.h:455
FFVulkanShaderData::desc_pool
VkDescriptorPool desc_pool
Definition: vulkan.h:287
VkFormat
enum VkFormat VkFormat
Definition: hwcontext_stub.c:25
FFVulkanShader::push_consts_num
int push_consts_num
Definition: vulkan.h:255
FFVkExecContext::layout_dst_alloc
unsigned int layout_dst_alloc
Definition: vulkan.h:201
ff_vk_exec_get
FFVkExecContext * ff_vk_exec_get(FFVulkanContext *s, FFVkExecPool *pool)
Retrieve an execution pool.
Definition: vulkan.c:546
ff_vk_mt_is_np_rgb
int ff_vk_mt_is_np_rgb(enum AVPixelFormat pix_fmt)
Returns 1 if pixfmt is a usable RGB format.
Definition: vulkan.c:1539
ff_vk_unmap_buffer
static int ff_vk_unmap_buffer(FFVulkanContext *s, FFVkBuffer *buf, int flush)
Definition: vulkan.h:610
FFVkBuffer::mem
VkDeviceMemory mem
Definition: vulkan.h:127
ff_vk_shader_init
int ff_vk_shader_init(FFVulkanContext *s, FFVulkanShader *shd, const char *name, VkPipelineStageFlags stage, const char *extensions[], int nb_extensions, int lg_x, int lg_y, int lg_z, uint32_t required_subgroup_size)
Initialize a shader object, with a specific set of extensions, type+bind, local group size,...
Definition: vulkan.c:2101
ff_vk_qf_find
AVVulkanDeviceQueueFamily * ff_vk_qf_find(FFVulkanContext *s, VkQueueFlagBits dev_family, VkVideoCodecOperationFlagBitsKHR vid_ops)
Chooses an appropriate QF.
Definition: vulkan.c:286
FFVulkanContext::hprops
VkPhysicalDeviceExternalMemoryHostPropertiesEXT hprops
Definition: vulkan.h:322
FFVulkanContext::props
VkPhysicalDeviceProperties2 props
Definition: vulkan.h:318
FFVkExecContext::frame_locked_alloc_size
unsigned int frame_locked_alloc_size
Definition: vulkan.h:195
len
int len
Definition: vorbis_enc_data.h:426
filt
static const int8_t filt[NUMTAPS *2]
Definition: af_earwax.c:40
FFVulkanContext::extensions
FFVulkanExtensions extensions
Definition: vulkan.h:317
FFVulkanContext::nb_qfs
int nb_qfs
Definition: vulkan.h:357
FFVulkanContext::mprops
VkPhysicalDeviceMemoryProperties mprops
Definition: vulkan.h:321
FFVkExecContext::sem_wait_alloc
unsigned int sem_wait_alloc
Definition: vulkan.h:183
AVHWFramesContext
This struct describes a set or pool of "hardware" frames (i.e.
Definition: hwcontext.h:118
ff_vk_shader_update_img_array
void ff_vk_shader_update_img_array(FFVulkanContext *s, FFVkExecContext *e, FFVulkanShader *shd, AVFrame *f, VkImageView *views, int set, int binding, VkImageLayout layout, VkSampler sampler)
Update a descriptor in a buffer with an image array.
Definition: vulkan.c:2717
FFVulkanContext::desc_buf_props
VkPhysicalDeviceDescriptorBufferPropertiesEXT desc_buf_props
Definition: vulkan.h:323
ff_comp_identity_map
const VkComponentMapping ff_comp_identity_map
Definition: vulkan.c:32
FFVulkanShader::name
const char * name
Definition: vulkan.h:227
FFVulkanContext::vkfn
FFVulkanFunctions vkfn
Definition: vulkan.h:316
FF_VK_MAX_DESCRIPTOR_TYPES
#define FF_VK_MAX_DESCRIPTOR_TYPES
Definition: vulkan.h:108
FFVkExecContext::opaque
void * opaque
Definition: vulkan.h:162
FFVkExecPool
Definition: vulkan.h:290
FFVkExecContext::frame_locked
uint8_t * frame_locked
Definition: vulkan.h:194
FFVkExecPool::query_data
void * query_data
Definition: vulkan.h:299
FFVkExecContext::sem_sig
VkSemaphoreSubmitInfo * sem_sig
Definition: vulkan.h:186
FFVkExecContext::buf
VkCommandBuffer buf
Definition: vulkan.h:156
ff_vk_alloc_mem
int ff_vk_alloc_mem(FFVulkanContext *s, VkMemoryRequirements *req, VkMemoryPropertyFlagBits req_flags, void *alloc_extension, VkMemoryPropertyFlagBits *mem_flags, VkDeviceMemory *mem)
Memory/buffer/image allocation helpers.
Definition: vulkan.c:969
FFVulkanContext::input_format
enum AVPixelFormat input_format
Definition: vulkan.h:363
FFVulkanContext::coop_mat_props_nb
uint32_t coop_mat_props_nb
Definition: vulkan.h:339
vulkan_functions.h
FFVulkanShader::precompiled
int precompiled
Definition: vulkan.h:230
ff_vk_exec_update_frame
void ff_vk_exec_update_frame(FFVulkanContext *s, FFVkExecContext *e, AVFrame *f, VkImageMemoryBarrier2 *bar, uint32_t *nb_img_bar)
Definition: vulkan.c:858
FFVulkanContext::video_props
VkQueueFamilyVideoPropertiesKHR * video_props
Definition: vulkan.h:332
FFVulkanShader::object
VkShaderEXT object
Definition: vulkan.h:247
ref
static int ref[MAX_W *MAX_W]
Definition: jpeg2000dwt.c:117
FFVulkanShader::lg_size
uint32_t lg_size[3]
Definition: vulkan.h:237
ff_vk_map_feats_to_usage
VkImageUsageFlags ff_vk_map_feats_to_usage(VkFormatFeatureFlagBits2 feats)
Map between usage and features.
Windows::Graphics::DirectX::Direct3D11::p
IDirect3DDxgiInterfaceAccess _COM_Outptr_ void ** p
Definition: vsrc_gfxcapture_winrt.hpp:53
FFVulkanDescriptorSet::usage
VkBufferUsageFlags usage
Definition: vulkan.h:214
ff_vk_exec_pool_free
void ff_vk_exec_pool_free(FFVulkanContext *s, FFVkExecPool *pool)
Definition: vulkan.c:299
desc
const char * desc
Definition: libsvtav1.c:78
FFVulkanContext::hwctx
AVVulkanDeviceContext * hwctx
Definition: vulkan.h:349
AVBufferRef
A reference to a data buffer.
Definition: buffer.h:82
FFVulkanShader::push_consts
VkPushConstantRange push_consts[FF_VK_MAX_PUSH_CONSTS]
Definition: vulkan.h:254
FFVkExecPool::cmd_bufs
VkCommandBuffer * cmd_bufs
Definition: vulkan.h:295
FFVulkanContext::push_desc_props
VkPhysicalDevicePushDescriptorPropertiesKHR push_desc_props
Definition: vulkan.h:326
FFVulkanContext::feats_12
VkPhysicalDeviceVulkan12Features feats_12
Definition: vulkan.h:342
FFVkExecContext::sw_frame_deps
AVFrame ** sw_frame_deps
Definition: vulkan.h:178
ff_vk_count_images
static int ff_vk_count_images(AVVkFrame *f)
Definition: vulkan.h:366
FFVkBuffer::virtual_offset
size_t virtual_offset
Definition: vulkan.h:139
FFVkExecContext::buf_deps_alloc_size
unsigned int buf_deps_alloc_size
Definition: vulkan.h:170
FFVkExecContext::buf_deps
AVBufferRef ** buf_deps
Definition: vulkan.h:168
FFVkBuffer
Definition: vulkan.h:125
hwcontext.h
AVVulkanDeviceQueueFamily
Definition: hwcontext_vulkan.h:33
FFVkExecPool::qd_size
size_t qd_size
Definition: vulkan.h:305
FFVulkanContext::frames
AVHWFramesContext * frames
Definition: vulkan.h:353
FFVulkanDescriptorSet
Definition: vulkan.h:210
FFVulkanContext::optical_flow_props
VkPhysicalDeviceOpticalFlowPropertiesNV optical_flow_props
Definition: vulkan.h:327
ff_vk_set_perm
void ff_vk_set_perm(enum AVPixelFormat pix_fmt, int lut[4], int inv)
Since storage images may not be swizzled, we have to do this in the shader itself.
Definition: vulkan.c:1561
FFVkExecPool::query_results
int query_results
Definition: vulkan.h:300
FFVkExecContext::sem_sig_val_dst
uint64_t ** sem_sig_val_dst
Definition: vulkan.h:190
FFVkExecPool::reg_shd
FFVulkanShaderData reg_shd[FF_VK_MAX_SHADERS]
Definition: vulkan.h:308
FFVulkanContext::query_props
VkQueueFamilyQueryResultStatusPropertiesKHR * query_props
Definition: vulkan.h:331
FFVulkanContext::host_image_copy_layouts
VkImageLayout * host_image_copy_layouts
Definition: vulkan.h:336
FFVulkanDescriptorSetBinding::mem_quali
const char * mem_quali
Definition: vulkan.h:116
FFVulkanFunctions
Definition: vulkan_functions.h:274
FFVkExecPool::pool_size
int pool_size
Definition: vulkan.h:296
FFVulkanContext::coop_mat_props
VkCooperativeMatrixPropertiesKHR * coop_mat_props
Definition: vulkan.h:338
FFVkExecContext::idx
uint32_t idx
Definition: vulkan.h:146
src
#define src
Definition: vp8dsp.c:248
atomic_uint_least64_t
intptr_t atomic_uint_least64_t
Definition: stdatomic.h:69
FF_VK_MAX_PUSH_CONSTS
#define FF_VK_MAX_PUSH_CONSTS
Definition: vulkan.h:109
FFVkExecContext::access_dst
VkAccessFlagBits * access_dst
Definition: vulkan.h:197
FF_VK_MAX_DESCRIPTOR_SETS
#define FF_VK_MAX_DESCRIPTOR_SETS
Definition: vulkan.h:106