FFmpeg
vulkan_av1.c
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 #include "av1dec.h"
20 
21 #include "vulkan_decode.h"
22 
23 /* Maximum number of tiles specified by any defined level */
24 #define MAX_TILES 256
25 
28  .decode_extension = FF_VK_EXT_VIDEO_DECODE_AV1,
29  .queue_flags = VK_QUEUE_VIDEO_DECODE_BIT_KHR,
30  .decode_op = VK_VIDEO_CODEC_OPERATION_DECODE_AV1_BIT_KHR,
31  .ext_props = {
32  .extensionName = VK_STD_VULKAN_VIDEO_CODEC_AV1_DECODE_EXTENSION_NAME,
33  .specVersion = VK_STD_VULKAN_VIDEO_CODEC_AV1_DECODE_SPEC_VERSION,
34  },
35 };
36 
37 typedef struct AV1VulkanDecodePicture {
39 
40  /* TODO: investigate if this can be removed to make decoding completely
41  * independent. */
43 
44  uint32_t tile_sizes[MAX_TILES];
45 
46  /* Current picture */
47  StdVideoDecodeAV1ReferenceInfo std_ref;
48  VkVideoDecodeAV1DpbSlotInfoKHR vkav1_ref;
49  uint16_t width_in_sbs_minus1[64];
50  uint16_t height_in_sbs_minus1[64];
51  uint16_t mi_col_starts[64];
52  uint16_t mi_row_starts[64];
53  StdVideoAV1TileInfo tile_info;
54  StdVideoAV1Quantization quantization;
55  StdVideoAV1Segmentation segmentation;
56  StdVideoAV1LoopFilter loop_filter;
57  StdVideoAV1CDEF cdef;
58  StdVideoAV1LoopRestoration loop_restoration;
59  StdVideoAV1GlobalMotion global_motion;
60  StdVideoAV1FilmGrain film_grain;
61  StdVideoDecodeAV1PictureInfo std_pic_info;
62  VkVideoDecodeAV1PictureInfoKHR av1_pic_info;
63 
64  /* Picture refs */
66  StdVideoDecodeAV1ReferenceInfo std_refs [AV1_NUM_REF_FRAMES];
67  VkVideoDecodeAV1DpbSlotInfoKHR vkav1_refs[AV1_NUM_REF_FRAMES];
68 
69  uint8_t frame_id_set;
70  uint8_t frame_id;
73 
74 static int vk_av1_fill_pict(AVCodecContext *avctx, const AV1Frame **ref_src,
75  VkVideoReferenceSlotInfoKHR *ref_slot, /* Main structure */
76  VkVideoPictureResourceInfoKHR *ref, /* Goes in ^ */
77  StdVideoDecodeAV1ReferenceInfo *vkav1_std_ref,
78  VkVideoDecodeAV1DpbSlotInfoKHR *vkav1_ref, /* Goes in ^ */
79  const AV1Frame *pic, int is_current, int has_grain,
80  const uint8_t *saved_order_hints)
81 {
85  FFVulkanDecodePicture *vkpic = &hp->vp;
86 
87  int err = ff_vk_decode_prepare_frame(dec, pic->f, vkpic, is_current,
88  has_grain || dec->dedicated_dpb);
89  if (err < 0)
90  return err;
91 
92  *vkav1_std_ref = (StdVideoDecodeAV1ReferenceInfo) {
93  .flags = (StdVideoDecodeAV1ReferenceInfoFlags) {
94  .disable_frame_end_update_cdf = pic->raw_frame_header->disable_frame_end_update_cdf,
95  .segmentation_enabled = pic->raw_frame_header->segmentation_enabled,
96  },
97  .frame_type = pic->raw_frame_header->frame_type,
98  .OrderHint = pic->raw_frame_header->order_hint,
99  .RefFrameSignBias = hp->ref_frame_sign_bias_mask,
100  };
101 
102  if (saved_order_hints) {
103  if (dec->quirk_av1_offset)
104  for (int i = 1; i < STD_VIDEO_AV1_TOTAL_REFS_PER_FRAME; i++)
105  vkav1_std_ref->SavedOrderHints[i - 1] = saved_order_hints[i];
106  else
107  for (int i = 0; i < STD_VIDEO_AV1_TOTAL_REFS_PER_FRAME; i++)
108  vkav1_std_ref->SavedOrderHints[i] = saved_order_hints[i];
109  }
110 
111  *vkav1_ref = (VkVideoDecodeAV1DpbSlotInfoKHR) {
112  .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_AV1_DPB_SLOT_INFO_KHR,
113  .pStdReferenceInfo = vkav1_std_ref,
114  };
115 
116  vkav1_std_ref->flags.disable_frame_end_update_cdf = pic->raw_frame_header->disable_frame_end_update_cdf;
117  vkav1_std_ref->flags.segmentation_enabled = pic->raw_frame_header->segmentation_enabled;
118  vkav1_std_ref->frame_type = pic->raw_frame_header->frame_type;
119 
120  *ref = (VkVideoPictureResourceInfoKHR) {
121  .sType = VK_STRUCTURE_TYPE_VIDEO_PICTURE_RESOURCE_INFO_KHR,
122  .codedOffset = (VkOffset2D){ 0, 0 },
123  .codedExtent = (VkExtent2D){ pic->f->width, pic->f->height },
124  .baseArrayLayer = ((has_grain || dec->dedicated_dpb) && ctx->common.layered_dpb) ?
125  hp->frame_id : 0,
126  .imageViewBinding = vkpic->view.ref[0],
127  };
128 
129  *ref_slot = (VkVideoReferenceSlotInfoKHR) {
130  .sType = VK_STRUCTURE_TYPE_VIDEO_REFERENCE_SLOT_INFO_KHR,
131  .pNext = vkav1_ref,
132  .slotIndex = hp->frame_id,
133  .pPictureResource = ref,
134  };
135 
136  if (ref_src)
137  *ref_src = pic;
138 
139  return 0;
140 }
141 
143  StdVideoAV1TimingInfo *av1_timing_info,
144  StdVideoAV1ColorConfig *av1_color_config,
145  StdVideoAV1SequenceHeader *av1_sequence_header)
146 {
147  const AV1DecContext *s = avctx->priv_data;
148  const AV1RawSequenceHeader *seq = s->raw_seq;
149 
150  *av1_timing_info = (StdVideoAV1TimingInfo) {
151  .flags = (StdVideoAV1TimingInfoFlags) {
152  .equal_picture_interval = seq->timing_info.equal_picture_interval,
153  },
154  .num_units_in_display_tick = seq->timing_info.num_units_in_display_tick,
155  .time_scale = seq->timing_info.time_scale,
156  .num_ticks_per_picture_minus_1 = seq->timing_info.num_ticks_per_picture_minus_1,
157  };
158 
159  *av1_color_config = (StdVideoAV1ColorConfig) {
160  .flags = (StdVideoAV1ColorConfigFlags) {
161  .mono_chrome = seq->color_config.mono_chrome,
162  .color_range = seq->color_config.color_range,
163  .separate_uv_delta_q = seq->color_config.separate_uv_delta_q,
164  },
165  .BitDepth = seq->color_config.twelve_bit ? 12 :
166  seq->color_config.high_bitdepth ? 10 : 8,
167  .subsampling_x = seq->color_config.subsampling_x,
168  .subsampling_y = seq->color_config.subsampling_y,
169  .color_primaries = seq->color_config.color_primaries,
170  .transfer_characteristics = seq->color_config.transfer_characteristics,
171  .matrix_coefficients = seq->color_config.matrix_coefficients,
172  };
173 
174  *av1_sequence_header = (StdVideoAV1SequenceHeader) {
175  .flags = (StdVideoAV1SequenceHeaderFlags) {
176  .still_picture = seq->still_picture,
177  .reduced_still_picture_header = seq->reduced_still_picture_header,
178  .use_128x128_superblock = seq->use_128x128_superblock,
179  .enable_filter_intra = seq->enable_filter_intra,
180  .enable_intra_edge_filter = seq->enable_intra_edge_filter,
181  .enable_interintra_compound = seq->enable_interintra_compound,
182  .enable_masked_compound = seq->enable_masked_compound,
183  .enable_warped_motion = seq->enable_warped_motion,
184  .enable_dual_filter = seq->enable_dual_filter,
185  .enable_order_hint = seq->enable_order_hint,
186  .enable_jnt_comp = seq->enable_jnt_comp,
187  .enable_ref_frame_mvs = seq->enable_ref_frame_mvs,
188  .frame_id_numbers_present_flag = seq->frame_id_numbers_present_flag,
189  .enable_superres = seq->enable_superres,
190  .enable_cdef = seq->enable_cdef,
191  .enable_restoration = seq->enable_restoration,
192  .film_grain_params_present = seq->film_grain_params_present,
193  .timing_info_present_flag = seq->timing_info_present_flag,
194  .initial_display_delay_present_flag = seq->initial_display_delay_present_flag,
195  },
196  .seq_profile = seq->seq_profile,
197  .frame_width_bits_minus_1 = seq->frame_width_bits_minus_1,
198  .frame_height_bits_minus_1 = seq->frame_height_bits_minus_1,
199  .max_frame_width_minus_1 = seq->max_frame_width_minus_1,
200  .max_frame_height_minus_1 = seq->max_frame_height_minus_1,
201  .delta_frame_id_length_minus_2 = seq->delta_frame_id_length_minus_2,
202  .additional_frame_id_length_minus_1 = seq->additional_frame_id_length_minus_1,
203  .order_hint_bits_minus_1 = seq->order_hint_bits_minus_1,
204  .seq_force_integer_mv = seq->seq_force_integer_mv,
205  .seq_force_screen_content_tools = seq->seq_force_screen_content_tools,
206  .pTimingInfo = av1_timing_info,
207  .pColorConfig = av1_color_config,
208  };
209 }
210 
213 {
214  int err;
217 
218  StdVideoAV1SequenceHeader av1_sequence_header;
219  StdVideoAV1TimingInfo av1_timing_info;
220  StdVideoAV1ColorConfig av1_color_config;
221  VkVideoDecodeAV1SessionParametersCreateInfoKHR av1_params;
222  VkVideoSessionParametersCreateInfoKHR session_params_create;
223 
224  vk_av1_params_fill(avctx, &av1_timing_info, &av1_color_config,
225  &av1_sequence_header);
226 
227  av1_params = (VkVideoDecodeAV1SessionParametersCreateInfoKHR) {
228  .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_AV1_SESSION_PARAMETERS_CREATE_INFO_KHR,
229  .pStdSequenceHeader = &av1_sequence_header,
230  };
231  session_params_create = (VkVideoSessionParametersCreateInfoKHR) {
232  .sType = VK_STRUCTURE_TYPE_VIDEO_SESSION_PARAMETERS_CREATE_INFO_KHR,
233  .pNext = &av1_params,
234  .videoSession = ctx->common.session,
235  .videoSessionParametersTemplate = VK_NULL_HANDLE,
236  };
237 
238  err = ff_vk_decode_create_params(buf, avctx, ctx, &session_params_create);
239  if (err < 0)
240  return err;
241 
242  av_log(avctx, AV_LOG_DEBUG, "Created frame parameters\n");
243 
244  return 0;
245 }
246 
248  av_unused const AVBufferRef *buffer_ref,
249  av_unused const uint8_t *buffer,
250  av_unused uint32_t size)
251 {
252  int err;
253  int ref_count = 0;
254  AV1DecContext *s = avctx->priv_data;
255  const AV1Frame *pic = &s->cur_frame;
258 
260  FFVulkanDecodePicture *vp = &ap->vp;
261 
262  const AV1RawFrameHeader *frame_header = s->raw_frame_header;
263  const AV1RawFilmGrainParams *film_grain = &s->cur_frame.film_grain;
264 
265  const int apply_grain = !(avctx->export_side_data & AV_CODEC_EXPORT_DATA_FILM_GRAIN) &&
266  film_grain->apply_grain;
267  StdVideoAV1FrameRestorationType remap_lr_type[4] = { STD_VIDEO_AV1_FRAME_RESTORATION_TYPE_NONE,
268  STD_VIDEO_AV1_FRAME_RESTORATION_TYPE_SWITCHABLE,
269  STD_VIDEO_AV1_FRAME_RESTORATION_TYPE_WIENER,
270  STD_VIDEO_AV1_FRAME_RESTORATION_TYPE_SGRPROJ };
271 
272  if (!dec->session_params &&
273  !(ctx->s.extensions & FF_VK_EXT_VIDEO_MAINTENANCE_2)) {
274  err = vk_av1_create_params(avctx, &dec->session_params, ap);
275  if (err < 0)
276  return err;
277  }
278 
279  if (!ap->frame_id_set) {
280  unsigned slot_idx = 0;
281  for (unsigned i = 0; i < 32; i++) {
282  if (!(dec->frame_id_alloc_mask & (1 << i))) {
283  slot_idx = i;
284  break;
285  }
286  }
287  ap->frame_id = slot_idx;
288  ap->frame_id_set = 1;
289  dec->frame_id_alloc_mask |= (1 << slot_idx);
290  }
291 
292  ap->ref_frame_sign_bias_mask = 0x0;
293  for (int i = 0; i < STD_VIDEO_AV1_TOTAL_REFS_PER_FRAME; i++)
294  ap->ref_frame_sign_bias_mask |= pic->ref_frame_sign_bias[i] << i;
295 
296  for (int i = 0; i < STD_VIDEO_AV1_REFS_PER_FRAME; i++) {
297  const int idx = pic->raw_frame_header->ref_frame_idx[i];
298  const AV1Frame *ref_frame = &s->ref[idx];
299  AV1VulkanDecodePicture *hp = ref_frame->hwaccel_picture_private;
300  int found = 0;
301 
302  if (!ref_frame->f)
303  continue;
304 
305  for (int j = 0; j < ref_count; j++) {
306  if (vp->ref_slots[j].slotIndex == hp->frame_id) {
307  found = 1;
308  break;
309  }
310  }
311  if (found)
312  continue;
313 
314  err = vk_av1_fill_pict(avctx, &ap->ref_src[ref_count], &vp->ref_slots[ref_count],
315  &vp->refs[ref_count], &ap->std_refs[ref_count], &ap->vkav1_refs[ref_count],
316  ref_frame, 0, 0, ref_frame->order_hints);
317  if (err < 0)
318  return err;
319 
320  ref_count++;
321  }
322 
323  err = vk_av1_fill_pict(avctx, NULL, &vp->ref_slot, &vp->ref,
324  &ap->std_ref,
325  &ap->vkav1_ref,
326  pic, 1, apply_grain, NULL);
327  if (err < 0)
328  return err;
329 
330  ap->av1_pic_info = (VkVideoDecodeAV1PictureInfoKHR) {
331  .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_AV1_PICTURE_INFO_KHR,
332  .pStdPictureInfo = &ap->std_pic_info,
333  .frameHeaderOffset = 0,
334  .tileCount = 0,
335  .pTileOffsets = NULL,
336  .pTileSizes = ap->tile_sizes,
337  };
338 
339  for (int i = 0; i < STD_VIDEO_AV1_REFS_PER_FRAME; i++) {
340  const int idx = pic->raw_frame_header->ref_frame_idx[i];
341  const AV1Frame *ref_frame = &s->ref[idx];
342  AV1VulkanDecodePicture *hp = ref_frame->hwaccel_picture_private;
343 
344  if (!ref_frame->f)
345  ap->av1_pic_info.referenceNameSlotIndices[i] = AV1_REF_FRAME_NONE;
346  else
347  ap->av1_pic_info.referenceNameSlotIndices[i] = hp->frame_id;
348  }
349 
350  vp->decode_info = (VkVideoDecodeInfoKHR) {
351  .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_INFO_KHR,
352  .pNext = &ap->av1_pic_info,
353  .flags = 0x0,
354  .pSetupReferenceSlot = &vp->ref_slot,
355  .referenceSlotCount = ref_count,
356  .pReferenceSlots = vp->ref_slots,
357  .dstPictureResource = (VkVideoPictureResourceInfoKHR) {
358  .sType = VK_STRUCTURE_TYPE_VIDEO_PICTURE_RESOURCE_INFO_KHR,
359  .codedOffset = (VkOffset2D){ 0, 0 },
360  .codedExtent = (VkExtent2D){ pic->f->width, pic->f->height },
361  .baseArrayLayer = 0,
362  .imageViewBinding = vp->view.out[0],
363  },
364  };
365 
366  ap->tile_info = (StdVideoAV1TileInfo) {
367  .flags = (StdVideoAV1TileInfoFlags) {
368  .uniform_tile_spacing_flag = frame_header->uniform_tile_spacing_flag,
369  },
370  .TileCols = frame_header->tile_cols,
371  .TileRows = frame_header->tile_rows,
372  .context_update_tile_id = frame_header->context_update_tile_id,
373  .tile_size_bytes_minus_1 = frame_header->tile_size_bytes_minus1,
374  .pWidthInSbsMinus1 = ap->width_in_sbs_minus1,
375  .pHeightInSbsMinus1 = ap->height_in_sbs_minus1,
376  .pMiColStarts = ap->mi_col_starts,
377  .pMiRowStarts = ap->mi_row_starts,
378  };
379 
380  ap->quantization = (StdVideoAV1Quantization) {
381  .flags.using_qmatrix = frame_header->using_qmatrix,
382  .flags.diff_uv_delta = frame_header->diff_uv_delta,
383  .base_q_idx = frame_header->base_q_idx,
384  .DeltaQYDc = frame_header->delta_q_y_dc,
385  .DeltaQUDc = frame_header->delta_q_u_dc,
386  .DeltaQUAc = frame_header->delta_q_u_ac,
387  .DeltaQVDc = frame_header->delta_q_v_dc,
388  .DeltaQVAc = frame_header->delta_q_v_ac,
389  .qm_y = frame_header->qm_y,
390  .qm_u = frame_header->qm_u,
391  .qm_v = frame_header->qm_v,
392  };
393 
394  ap->loop_filter = (StdVideoAV1LoopFilter) {
395  .flags = (StdVideoAV1LoopFilterFlags) {
396  .loop_filter_delta_enabled = frame_header->loop_filter_delta_enabled,
397  .loop_filter_delta_update = frame_header->loop_filter_delta_update,
398  },
399  .loop_filter_sharpness = frame_header->loop_filter_sharpness,
400  };
401 
402  for (int i = 0; i < STD_VIDEO_AV1_MAX_LOOP_FILTER_STRENGTHS; i++)
403  ap->loop_filter.loop_filter_level[i] = frame_header->loop_filter_level[i];
404  for (int i = 0; i < STD_VIDEO_AV1_LOOP_FILTER_ADJUSTMENTS; i++)
405  ap->loop_filter.loop_filter_mode_deltas[i] = frame_header->loop_filter_mode_deltas[i];
406 
407  ap->cdef = (StdVideoAV1CDEF) {
408  .cdef_damping_minus_3 = frame_header->cdef_damping_minus_3,
409  .cdef_bits = frame_header->cdef_bits,
410  };
411 
412  ap->loop_restoration = (StdVideoAV1LoopRestoration) {
413  .FrameRestorationType[0] = remap_lr_type[frame_header->lr_type[0]],
414  .FrameRestorationType[1] = remap_lr_type[frame_header->lr_type[1]],
415  .FrameRestorationType[2] = remap_lr_type[frame_header->lr_type[2]],
416  .LoopRestorationSize[0] = 1 + frame_header->lr_unit_shift,
417  .LoopRestorationSize[1] = 1 + frame_header->lr_unit_shift - frame_header->lr_uv_shift,
418  .LoopRestorationSize[2] = 1 + frame_header->lr_unit_shift - frame_header->lr_uv_shift,
419  };
420 
421  ap->film_grain = (StdVideoAV1FilmGrain) {
422  .flags = (StdVideoAV1FilmGrainFlags) {
423  .chroma_scaling_from_luma = film_grain->chroma_scaling_from_luma,
424  .overlap_flag = film_grain->overlap_flag,
425  .clip_to_restricted_range = film_grain->clip_to_restricted_range,
426  },
427  .grain_scaling_minus_8 = film_grain->grain_scaling_minus_8,
428  .ar_coeff_lag = film_grain->ar_coeff_lag,
429  .ar_coeff_shift_minus_6 = film_grain->ar_coeff_shift_minus_6,
430  .grain_scale_shift = film_grain->grain_scale_shift,
431  .grain_seed = film_grain->grain_seed,
432  .film_grain_params_ref_idx = film_grain->film_grain_params_ref_idx,
433  .num_y_points = film_grain->num_y_points,
434  .num_cb_points = film_grain->num_cb_points,
435  .num_cr_points = film_grain->num_cr_points,
436  .cb_mult = film_grain->cb_mult,
437  .cb_luma_mult = film_grain->cb_luma_mult,
438  .cb_offset = film_grain->cb_offset,
439  .cr_mult = film_grain->cr_mult,
440  .cr_luma_mult = film_grain->cr_luma_mult,
441  .cr_offset = film_grain->cr_offset,
442  };
443 
444  /* Setup frame header */
445  ap->std_pic_info = (StdVideoDecodeAV1PictureInfo) {
446  .flags = (StdVideoDecodeAV1PictureInfoFlags) {
447  .error_resilient_mode = frame_header->error_resilient_mode,
448  .disable_cdf_update = frame_header->disable_cdf_update,
449  .use_superres = frame_header->use_superres,
450  .render_and_frame_size_different = frame_header->render_and_frame_size_different,
451  .allow_screen_content_tools = frame_header->allow_screen_content_tools,
452  .is_filter_switchable = frame_header->is_filter_switchable,
453  .force_integer_mv = pic->force_integer_mv,
454  .frame_size_override_flag = frame_header->frame_size_override_flag,
455  .buffer_removal_time_present_flag = frame_header->buffer_removal_time_present_flag,
456  .allow_intrabc = frame_header->allow_intrabc,
457  .frame_refs_short_signaling = frame_header->frame_refs_short_signaling,
458  .allow_high_precision_mv = frame_header->allow_high_precision_mv,
459  .is_motion_mode_switchable = frame_header->is_motion_mode_switchable,
460  .use_ref_frame_mvs = frame_header->use_ref_frame_mvs,
461  .disable_frame_end_update_cdf = frame_header->disable_frame_end_update_cdf,
462  .allow_warped_motion = frame_header->allow_warped_motion,
463  .reduced_tx_set = frame_header->reduced_tx_set,
464  .reference_select = frame_header->reference_select,
465  .skip_mode_present = frame_header->skip_mode_present,
466  .delta_q_present = frame_header->delta_q_present,
467  .delta_lf_present = frame_header->delta_lf_present,
468  .delta_lf_multi = frame_header->delta_lf_multi,
469  .segmentation_enabled = frame_header->segmentation_enabled,
470  .segmentation_update_map = frame_header->segmentation_update_map,
471  .segmentation_temporal_update = frame_header->segmentation_temporal_update,
472  .segmentation_update_data = frame_header->segmentation_update_data,
473  .UsesLr = frame_header->lr_type[0] || frame_header->lr_type[1] || frame_header->lr_type[2],
474  .apply_grain = apply_grain,
475  },
476  .frame_type = frame_header->frame_type,
477  .current_frame_id = frame_header->current_frame_id,
478  .OrderHint = frame_header->order_hint,
479  .primary_ref_frame = frame_header->primary_ref_frame,
480  .refresh_frame_flags = frame_header->refresh_frame_flags,
481  .interpolation_filter = frame_header->interpolation_filter,
482  .TxMode = frame_header->tx_mode,
483  .delta_q_res = frame_header->delta_q_res,
484  .delta_lf_res = frame_header->delta_lf_res,
485  .SkipModeFrame[0] = s->cur_frame.skip_mode_frame_idx[0],
486  .SkipModeFrame[1] = s->cur_frame.skip_mode_frame_idx[1],
487  .coded_denom = frame_header->coded_denom,
488  .pTileInfo = &ap->tile_info,
489  .pQuantization = &ap->quantization,
490  .pSegmentation = &ap->segmentation,
491  .pLoopFilter = &ap->loop_filter,
492  .pCDEF = &ap->cdef,
493  .pLoopRestoration = &ap->loop_restoration,
494  .pGlobalMotion = &ap->global_motion,
495  .pFilmGrain = apply_grain ? &ap->film_grain : NULL,
496  };
497 
498  for (int i = 0; i < 64; i++) {
499  ap->width_in_sbs_minus1[i] = frame_header->width_in_sbs_minus_1[i];
500  ap->height_in_sbs_minus1[i] = frame_header->height_in_sbs_minus_1[i];
501  ap->mi_col_starts[i] = frame_header->tile_start_col_sb[i];
502  ap->mi_row_starts[i] = frame_header->tile_start_row_sb[i];
503  }
504 
505  for (int i = 0; i < STD_VIDEO_AV1_MAX_SEGMENTS; i++) {
506  ap->segmentation.FeatureEnabled[i] = 0x0;
507  for (int j = 0; j < STD_VIDEO_AV1_SEG_LVL_MAX; j++) {
508  ap->segmentation.FeatureEnabled[i] |= (frame_header->feature_enabled[i][j] << j);
509  ap->segmentation.FeatureData[i][j] = frame_header->feature_value[i][j];
510  }
511  }
512 
513  if (dec->quirk_av1_offset)
514  for (int i = 1; i < STD_VIDEO_AV1_TOTAL_REFS_PER_FRAME; i++)
515  ap->std_pic_info.OrderHints[i - 1] = pic->order_hints[i];
516  else
517  for (int i = 0; i < STD_VIDEO_AV1_TOTAL_REFS_PER_FRAME; i++)
518  ap->std_pic_info.OrderHints[i] = pic->order_hints[i];
519 
520  for (int i = 0; i < STD_VIDEO_AV1_TOTAL_REFS_PER_FRAME; i++) {
521  ap->loop_filter.loop_filter_ref_deltas[i] = frame_header->loop_filter_ref_deltas[i];
522  ap->global_motion.GmType[i] = s->cur_frame.gm_type[i];
523  for (int j = 0; j < STD_VIDEO_AV1_GLOBAL_MOTION_PARAMS; j++) {
524  ap->global_motion.gm_params[i][j] = s->cur_frame.gm_params[i][j];
525  }
526  }
527 
528  for (int i = 0; i < STD_VIDEO_AV1_MAX_CDEF_FILTER_STRENGTHS; i++) {
529  ap->cdef.cdef_y_pri_strength[i] = frame_header->cdef_y_pri_strength[i];
530  ap->cdef.cdef_y_sec_strength[i] = frame_header->cdef_y_sec_strength[i];
531  ap->cdef.cdef_uv_pri_strength[i] = frame_header->cdef_uv_pri_strength[i];
532  ap->cdef.cdef_uv_sec_strength[i] = frame_header->cdef_uv_sec_strength[i];
533  }
534 
535  if (apply_grain) {
536  for (int i = 0; i < STD_VIDEO_AV1_MAX_NUM_Y_POINTS; i++) {
537  ap->film_grain.point_y_value[i] = film_grain->point_y_value[i];
538  ap->film_grain.point_y_scaling[i] = film_grain->point_y_scaling[i];
539  }
540 
541  for (int i = 0; i < STD_VIDEO_AV1_MAX_NUM_CB_POINTS; i++) {
542  ap->film_grain.point_cb_value[i] = film_grain->point_cb_value[i];
543  ap->film_grain.point_cb_scaling[i] = film_grain->point_cb_scaling[i];
544  ap->film_grain.point_cr_value[i] = film_grain->point_cr_value[i];
545  ap->film_grain.point_cr_scaling[i] = film_grain->point_cr_scaling[i];
546  }
547 
548  for (int i = 0; i < STD_VIDEO_AV1_MAX_NUM_POS_LUMA; i++)
549  ap->film_grain.ar_coeffs_y_plus_128[i] = film_grain->ar_coeffs_y_plus_128[i];
550 
551  for (int i = 0; i < STD_VIDEO_AV1_MAX_NUM_POS_CHROMA; i++) {
552  ap->film_grain.ar_coeffs_cb_plus_128[i] = film_grain->ar_coeffs_cb_plus_128[i];
553  ap->film_grain.ar_coeffs_cr_plus_128[i] = film_grain->ar_coeffs_cr_plus_128[i];
554  }
555  }
556 
557  ap->dec = dec;
558 
559  return 0;
560 }
561 
563  const uint8_t *data,
564  uint32_t size)
565 {
566  int err;
567  const AV1DecContext *s = avctx->priv_data;
568  AV1VulkanDecodePicture *ap = s->cur_frame.hwaccel_picture_private;
569  FFVulkanDecodePicture *vp = &ap->vp;
570 
571  /* Too many tiles, exceeding all defined levels in the AV1 spec */
572  if (ap->av1_pic_info.tileCount > MAX_TILES)
573  return AVERROR(ENOSYS);
574 
575  for (int i = s->tg_start; i <= s->tg_end; i++) {
576  ap->tile_sizes[ap->av1_pic_info.tileCount] = s->tile_group_info[i].tile_size;
577 
578  err = ff_vk_decode_add_slice(avctx, vp,
579  data + s->tile_group_info[i].tile_offset,
580  s->tile_group_info[i].tile_size, 0,
581  &ap->av1_pic_info.tileCount,
582  &ap->av1_pic_info.pTileOffsets);
583  if (err < 0)
584  return err;
585  }
586 
587  return 0;
588 }
589 
591 {
592  const AV1DecContext *s = avctx->priv_data;
595 
596  const AV1Frame *pic = &s->cur_frame;
598  FFVulkanDecodePicture *vp = &ap->vp;
600  AVFrame *rav[AV1_NUM_REF_FRAMES] = { 0 };
601 
602 #ifdef VK_KHR_video_maintenance2
603  StdVideoAV1SequenceHeader av1_sequence_header;
604  StdVideoAV1TimingInfo av1_timing_info;
605  StdVideoAV1ColorConfig av1_color_config;
606  VkVideoDecodeAV1InlineSessionParametersInfoKHR av1_params;
607 
608  if (ctx->s.extensions & FF_VK_EXT_VIDEO_MAINTENANCE_2) {
609  vk_av1_params_fill(avctx, &av1_timing_info, &av1_color_config,
610  &av1_sequence_header);
611  av1_params = (VkVideoDecodeAV1InlineSessionParametersInfoKHR) {
612  .sType = VK_STRUCTURE_TYPE_VIDEO_DECODE_AV1_INLINE_SESSION_PARAMETERS_INFO_KHR,
613  .pStdSequenceHeader = &av1_sequence_header,
614  };
615  ap->av1_pic_info.pNext = &av1_params;
616  }
617 #endif
618 
619  if (!ap->av1_pic_info.tileCount)
620  return 0;
621 
622  if (!dec->session_params &&
623  !(ctx->s.extensions & FF_VK_EXT_VIDEO_MAINTENANCE_2)) {
624  int err = vk_av1_create_params(avctx, &dec->session_params, ap);
625  if (err < 0)
626  return err;
627  }
628 
629  for (int i = 0; i < vp->decode_info.referenceSlotCount; i++) {
630  const AV1Frame *rp = ap->ref_src[i];
632 
633  rvp[i] = &rhp->vp;
634  rav[i] = ap->ref_src[i]->f;
635  }
636 
637  av_log(avctx, AV_LOG_VERBOSE, "Decoding frame, %"SIZE_SPECIFIER" bytes, %i tiles\n",
638  vp->slices_size, ap->av1_pic_info.tileCount);
639 
640  return ff_vk_decode_frame(avctx, pic->f, vp, rav, rvp);
641 }
642 
644 {
645  AVHWDeviceContext *hwctx = _hwctx.nc;
647 
648  /* Workaround for a spec issue. */
649  if (ap->frame_id_set)
650  ap->dec->frame_id_alloc_mask &= ~(1 << ap->frame_id);
651 
652  /* Free frame resources, this also destroys the session parameters. */
653  ff_vk_decode_free_frame(hwctx, &ap->vp);
654 }
655 
657  .p.name = "av1_vulkan",
658  .p.type = AVMEDIA_TYPE_VIDEO,
659  .p.id = AV_CODEC_ID_AV1,
660  .p.pix_fmt = AV_PIX_FMT_VULKAN,
661  .start_frame = &vk_av1_start_frame,
662  .decode_slice = &vk_av1_decode_slice,
663  .end_frame = &vk_av1_end_frame,
664  .free_frame_priv = &vk_av1_free_frame_priv,
665  .frame_priv_data_size = sizeof(AV1VulkanDecodePicture),
668  .decode_params = &ff_vk_params_invalidate,
671  .frame_params = &ff_vk_frame_params,
672  .priv_data_size = sizeof(FFVulkanDecodeContext),
673 
674  /* NOTE: Threading is intentionally disabled here. Due to the design of Vulkan,
675  * where frames are opaque to users, and mostly opaque for driver developers,
676  * there's an issue with current hardware accelerator implementations of AV1,
677  * where they require an internal index. With regular hwaccel APIs, this index
678  * is given to users as an opaque handle directly. With Vulkan, due to increased
679  * flexibility, this index cannot be present anywhere.
680  * The current implementation tracks the index for the driver and submits it
681  * as necessary information. Due to needing to modify the decoding context,
682  * which is not thread-safe, on frame free, threading is disabled. */
683  .caps_internal = HWACCEL_CAP_ASYNC_SAFE,
684 };
ff_av1_vulkan_hwaccel
const FFHWAccel ff_av1_vulkan_hwaccel
Definition: vulkan_av1.c:656
AV1RawTimingInfo::num_units_in_display_tick
uint32_t num_units_in_display_tick
Definition: cbs_av1.h:68
AV1RawTimingInfo::time_scale
uint32_t time_scale
Definition: cbs_av1.h:69
AV1RawSequenceHeader::seq_force_integer_mv
uint8_t seq_force_integer_mv
Definition: cbs_av1.h:129
FFVulkanDecodePicture::slices_size
size_t slices_size
Definition: vulkan_decode.h:112
AV1RawColorConfig::color_primaries
uint8_t color_primaries
Definition: cbs_av1.h:56
AVERROR
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 sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
AV1RawSequenceHeader::timing_info_present_flag
uint8_t timing_info_present_flag
Definition: cbs_av1.h:87
AV1RawSequenceHeader
Definition: cbs_av1.h:82
AV1RawColorConfig::color_range
uint8_t color_range
Definition: cbs_av1.h:60
FFVulkanDecodeContext::shared_ctx
FFVulkanDecodeShared * shared_ctx
Definition: vulkan_decode.h:66
AVRefStructOpaque
RefStruct is an API for creating reference-counted objects with minimal overhead.
Definition: refstruct.h:58
MAX_TILES
#define MAX_TILES
Definition: vulkan_av1.c:24
AV1RawFilmGrainParams::apply_grain
uint8_t apply_grain
Definition: cbs_av1.h:143
AV1VulkanDecodePicture::cdef
StdVideoAV1CDEF cdef
Definition: vulkan_av1.c:57
FF_VK_EXT_VIDEO_MAINTENANCE_2
#define FF_VK_EXT_VIDEO_MAINTENANCE_2
Definition: vulkan_functions.h:54
AVRefStructOpaque::nc
void * nc
Definition: refstruct.h:59
av_unused
#define av_unused
Definition: attributes.h:131
FFHWAccel::p
AVHWAccel p
The public AVHWAccel.
Definition: hwaccel_internal.h:38
AV1VulkanDecodePicture::height_in_sbs_minus1
uint16_t height_in_sbs_minus1[64]
Definition: vulkan_av1.c:50
AV1VulkanDecodePicture::loop_filter
StdVideoAV1LoopFilter loop_filter
Definition: vulkan_av1.c:56
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:410
AVFrame::width
int width
Definition: frame.h:482
ff_vk_dec_av1_desc
const FFVulkanDecodeDescriptor ff_vk_dec_av1_desc
Definition: vulkan_av1.c:26
AV1Frame::raw_frame_header
AV1RawFrameHeader * raw_frame_header
Definition: av1dec.h:48
data
const char data[16]
Definition: mxf.c:149
AV1RawFrameHeader::disable_frame_end_update_cdf
uint8_t disable_frame_end_update_cdf
Definition: cbs_av1.h:222
FFVulkanDecodeDescriptor::codec_id
enum AVCodecID codec_id
Definition: vulkan_decode.h:30
AV1RawSequenceHeader::timing_info
AV1RawTimingInfo timing_info
Definition: cbs_av1.h:92
FFVulkanDecodeContext::frame_id_alloc_mask
uint32_t frame_id_alloc_mask
Definition: vulkan_decode.h:71
AV_LOG_VERBOSE
#define AV_LOG_VERBOSE
Detailed information.
Definition: log.h:225
AV1RawSequenceHeader::frame_id_numbers_present_flag
uint8_t frame_id_numbers_present_flag
Definition: cbs_av1.h:110
AV1VulkanDecodePicture::tile_info
StdVideoAV1TileInfo tile_info
Definition: vulkan_av1.c:53
FFVulkanDecodeContext
Definition: vulkan_decode.h:65
AV_PIX_FMT_VULKAN
@ AV_PIX_FMT_VULKAN
Vulkan hardware images.
Definition: pixfmt.h:379
ff_vk_decode_prepare_frame
int ff_vk_decode_prepare_frame(FFVulkanDecodeContext *dec, AVFrame *pic, FFVulkanDecodePicture *vkpic, int is_current, int alloc_dpb)
Prepare a frame, creates the image view, and sets up the dpb fields.
Definition: vulkan_decode.c:147
AV1RawSequenceHeader::seq_profile
uint8_t seq_profile
Definition: cbs_av1.h:83
AV1RawColorConfig::subsampling_y
uint8_t subsampling_y
Definition: cbs_av1.h:62
AV1RawColorConfig::separate_uv_delta_q
uint8_t separate_uv_delta_q
Definition: cbs_av1.h:64
FFVulkanDecodeContext::session_params
AVBufferRef * session_params
Definition: vulkan_decode.h:67
vk_av1_params_fill
static void vk_av1_params_fill(AVCodecContext *avctx, StdVideoAV1TimingInfo *av1_timing_info, StdVideoAV1ColorConfig *av1_color_config, StdVideoAV1SequenceHeader *av1_sequence_header)
Definition: vulkan_av1.c:142
AV1RawSequenceHeader::film_grain_params_present
uint8_t film_grain_params_present
Definition: cbs_av1.h:139
FFHWAccel
Definition: hwaccel_internal.h:34
AV1RawSequenceHeader::enable_ref_frame_mvs
uint8_t enable_ref_frame_mvs
Definition: cbs_av1.h:124
AV1RawSequenceHeader::enable_filter_intra
uint8_t enable_filter_intra
Definition: cbs_av1.h:115
AV1VulkanDecodePicture::quantization
StdVideoAV1Quantization quantization
Definition: vulkan_av1.c:54
vk_av1_end_frame
static int vk_av1_end_frame(AVCodecContext *avctx)
Definition: vulkan_av1.c:590
AV1RawSequenceHeader::delta_frame_id_length_minus_2
uint8_t delta_frame_id_length_minus_2
Definition: cbs_av1.h:111
FFVulkanDecodePicture::view
struct FFVulkanDecodePicture::@298 view
ff_vk_decode_frame
int ff_vk_decode_frame(AVCodecContext *avctx, AVFrame *pic, FFVulkanDecodePicture *vp, AVFrame *rpic[], FFVulkanDecodePicture *rvkp[])
Decode a frame.
Definition: vulkan_decode.c:368
FFVulkanDecodeShared
Definition: vulkan_decode.h:47
AVHWDeviceContext
This struct aggregates all the (hardware/vendor-specific) "high-level" state, i.e.
Definition: hwcontext.h:61
AV1Frame
Definition: av1dec.h:37
AV1RawSequenceHeader::enable_masked_compound
uint8_t enable_masked_compound
Definition: cbs_av1.h:118
AV1VulkanDecodePicture::std_pic_info
StdVideoDecodeAV1PictureInfo std_pic_info
Definition: vulkan_av1.c:61
s
#define s(width, name)
Definition: cbs_vp9.c:198
FFVulkanDecodePicture
Definition: vulkan_decode.h:85
ff_vk_decode_create_params
int ff_vk_decode_create_params(AVBufferRef **par_ref, void *logctx, FFVulkanDecodeShared *ctx, const VkVideoSessionParametersCreateInfoKHR *session_params_create)
Create VkVideoSessionParametersKHR wrapped in an AVBufferRef.
Definition: vulkan_decode.c:1104
AV_LOG_DEBUG
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
Definition: log.h:230
ctx
AVFormatContext * ctx
Definition: movenc.c:49
AV1VulkanDecodePicture::std_ref
StdVideoDecodeAV1ReferenceInfo std_ref
Definition: vulkan_av1.c:47
AV1RawColorConfig::transfer_characteristics
uint8_t transfer_characteristics
Definition: cbs_av1.h:57
AV1RawFrameHeader::segmentation_enabled
uint8_t segmentation_enabled
Definition: cbs_av1.h:251
av1dec.h
AV1Frame::f
struct AVFrame * f
Definition: av1dec.h:40
HWACCEL_CAP_ASYNC_SAFE
#define HWACCEL_CAP_ASYNC_SAFE
Header providing the internals of AVHWAccel.
Definition: hwaccel_internal.h:31
AV1_NUM_REF_FRAMES
@ AV1_NUM_REF_FRAMES
Definition: av1.h:84
NULL
#define NULL
Definition: coverity.c:32
AV_CODEC_ID_AV1
@ AV_CODEC_ID_AV1
Definition: codec_id.h:284
AV1RawFrameHeader
Definition: cbs_av1.h:174
ff_vk_decode_free_frame
void ff_vk_decode_free_frame(AVHWDeviceContext *dev_ctx, FFVulkanDecodePicture *vp)
Free a frame and its state.
Definition: vulkan_decode.c:574
AV1_REF_FRAME_NONE
@ AV1_REF_FRAME_NONE
Definition: av1.h:61
AVCodecContext::internal
struct AVCodecInternal * internal
Private context used for internal data.
Definition: avcodec.h:466
ff_vk_decode_uninit
int ff_vk_decode_uninit(AVCodecContext *avctx)
Free decoder.
Definition: vulkan_decode.c:1133
flush
void(* flush)(AVBSFContext *ctx)
Definition: dts2pts.c:370
AV1RawSequenceHeader::enable_jnt_comp
uint8_t enable_jnt_comp
Definition: cbs_av1.h:123
ff_vk_frame_params
int ff_vk_frame_params(AVCodecContext *avctx, AVBufferRef *hw_frames_ctx)
Initialize hw_frames_ctx with the parameters needed to decode the stream using the parameters from av...
Definition: vulkan_decode.c:1016
AV1RawSequenceHeader::seq_force_screen_content_tools
uint8_t seq_force_screen_content_tools
Definition: cbs_av1.h:127
AV1VulkanDecodePicture::ref_frame_sign_bias_mask
uint8_t ref_frame_sign_bias_mask
Definition: vulkan_av1.c:71
AV1RawSequenceHeader::max_frame_height_minus_1
uint16_t max_frame_height_minus_1
Definition: cbs_av1.h:108
init
int(* init)(AVBSFContext *ctx)
Definition: dts2pts.c:368
AV1VulkanDecodePicture::loop_restoration
StdVideoAV1LoopRestoration loop_restoration
Definition: vulkan_av1.c:58
AV1RawTimingInfo::num_ticks_per_picture_minus_1
uint32_t num_ticks_per_picture_minus_1
Definition: cbs_av1.h:72
AVCodecInternal::hwaccel_priv_data
void * hwaccel_priv_data
hwaccel-specific private data
Definition: internal.h:130
for
for(k=2;k<=8;++k)
Definition: h264pred_template.c:424
FFVulkanDecodePicture::ref
VkImageView ref[AV_NUM_DATA_POINTERS]
Definition: vulkan_decode.h:89
AV1VulkanDecodePicture::mi_col_starts
uint16_t mi_col_starts[64]
Definition: vulkan_av1.c:51
size
int size
Definition: twinvq_data.h:10344
AV1DecContext
Definition: av1dec.h:85
AV1RawSequenceHeader::use_128x128_superblock
uint8_t use_128x128_superblock
Definition: cbs_av1.h:114
AV1RawSequenceHeader::frame_height_bits_minus_1
uint8_t frame_height_bits_minus_1
Definition: cbs_av1.h:106
ref_frame
static int ref_frame(VVCFrame *dst, const VVCFrame *src)
Definition: dec.c:593
AV1RawSequenceHeader::still_picture
uint8_t still_picture
Definition: cbs_av1.h:84
AV1RawSequenceHeader::initial_display_delay_present_flag
uint8_t initial_display_delay_present_flag
Definition: cbs_av1.h:89
AV1RawSequenceHeader::enable_interintra_compound
uint8_t enable_interintra_compound
Definition: cbs_av1.h:117
AV1RawFrameHeader::order_hint
uint8_t order_hint
Definition: cbs_av1.h:191
AVHWAccel::name
const char * name
Name of the hardware accelerated codec.
Definition: avcodec.h:1948
uninit
static void uninit(AVBSFContext *ctx)
Definition: pcm_rechunk.c:68
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:256
AV1RawSequenceHeader::enable_dual_filter
uint8_t enable_dual_filter
Definition: cbs_av1.h:120
AV1VulkanDecodePicture::vkav1_refs
VkVideoDecodeAV1DpbSlotInfoKHR vkav1_refs[AV1_NUM_REF_FRAMES]
Definition: vulkan_av1.c:67
AV1RawSequenceHeader::enable_superres
uint8_t enable_superres
Definition: cbs_av1.h:133
AV1Frame::hwaccel_picture_private
void * hwaccel_picture_private
RefStruct reference.
Definition: av1dec.h:45
vk_av1_start_frame
static int vk_av1_start_frame(AVCodecContext *avctx, av_unused const AVBufferRef *buffer_ref, av_unused const uint8_t *buffer, av_unused uint32_t size)
Definition: vulkan_av1.c:247
AV1RawTimingInfo::equal_picture_interval
uint8_t equal_picture_interval
Definition: cbs_av1.h:71
AV1RawSequenceHeader::enable_intra_edge_filter
uint8_t enable_intra_edge_filter
Definition: cbs_av1.h:116
AV1RawSequenceHeader::max_frame_width_minus_1
uint16_t max_frame_width_minus_1
Definition: cbs_av1.h:107
AV1VulkanDecodePicture::av1_pic_info
VkVideoDecodeAV1PictureInfoKHR av1_pic_info
Definition: vulkan_av1.c:62
AV1RawSequenceHeader::color_config
AV1RawColorConfig color_config
Definition: cbs_av1.h:137
AV1VulkanDecodePicture::tile_sizes
uint32_t tile_sizes[MAX_TILES]
Definition: vulkan_av1.c:44
AV1VulkanDecodePicture::segmentation
StdVideoAV1Segmentation segmentation
Definition: vulkan_av1.c:55
AV1RawSequenceHeader::enable_order_hint
uint8_t enable_order_hint
Definition: cbs_av1.h:122
AV1VulkanDecodePicture::width_in_sbs_minus1
uint16_t width_in_sbs_minus1[64]
Definition: vulkan_av1.c:49
ff_vk_decode_flush
void ff_vk_decode_flush(AVCodecContext *avctx)
Flush decoder.
Definition: vulkan_decode.c:332
AV1RawColorConfig::subsampling_x
uint8_t subsampling_x
Definition: cbs_av1.h:61
AV1VulkanDecodePicture::global_motion
StdVideoAV1GlobalMotion global_motion
Definition: vulkan_av1.c:59
AV1VulkanDecodePicture::film_grain
StdVideoAV1FilmGrain film_grain
Definition: vulkan_av1.c:60
ff_vk_decode_add_slice
int ff_vk_decode_add_slice(AVCodecContext *avctx, FFVulkanDecodePicture *vp, const uint8_t *data, size_t size, int add_startcode, uint32_t *nb_slices, const uint32_t **offsets)
Add slice data to frame.
Definition: vulkan_decode.c:251
AV1RawColorConfig::high_bitdepth
uint8_t high_bitdepth
Definition: cbs_av1.h:51
AV1VulkanDecodePicture::ref_src
const AV1Frame * ref_src[AV1_NUM_REF_FRAMES]
Definition: vulkan_av1.c:65
SIZE_SPECIFIER
#define SIZE_SPECIFIER
Definition: internal.h:129
AV1VulkanDecodePicture::mi_row_starts
uint16_t mi_row_starts[64]
Definition: vulkan_av1.c:52
AV1RawSequenceHeader::frame_width_bits_minus_1
uint8_t frame_width_bits_minus_1
Definition: cbs_av1.h:105
AV1RawSequenceHeader::enable_warped_motion
uint8_t enable_warped_motion
Definition: cbs_av1.h:119
AVCodecContext
main external API structure.
Definition: avcodec.h:431
AVFrame::height
int height
Definition: frame.h:482
FFVulkanDecodeContext::dedicated_dpb
int dedicated_dpb
Definition: vulkan_decode.h:69
frame_header
Definition: truemotion1.c:88
buffer
the frame and frame reference mechanism is intended to as much as expensive copies of that data while still allowing the filters to produce correct results The data is stored in buffers represented by AVFrame structures Several references can point to the same frame buffer
Definition: filter_design.txt:49
AV1RawColorConfig::mono_chrome
uint8_t mono_chrome
Definition: cbs_av1.h:53
update_thread_context
the pkt_dts and pkt_pts fields in AVFrame will work as usual Restrictions on codec whose streams don t reset across will not work because their bitstreams cannot be decoded in parallel *The contents of buffers must not be read before as well as code calling up to before the decode process starts Call have update_thread_context() run it in the next thread. Add AV_CODEC_CAP_FRAME_THREADS to the codec capabilities. There will be very little speed gain at this point but it should work. Use ff_thread_get_buffer()(or ff_progress_frame_get_buffer() in case you have inter-frame dependencies and use the ProgressFrame API) to allocate frame buffers. Call ff_progress_frame_report() after some part of the current picture has decoded. A good place to put this is where draw_horiz_band() is called - add this if it isn 't called anywhere
FFVulkanDecodeDescriptor
Definition: vulkan_decode.h:29
ref
static int ref[MAX_W *MAX_W]
Definition: jpeg2000dwt.c:117
AVCodecContext::export_side_data
int export_side_data
Bit set of AV_CODEC_EXPORT_DATA_* flags, which affects the kind of metadata exported in frame,...
Definition: avcodec.h:1780
ff_vk_params_invalidate
int ff_vk_params_invalidate(AVCodecContext *avctx, int t, const uint8_t *b, uint32_t s)
Removes current session parameters to recreate them.
Definition: vulkan_decode.c:110
vk_av1_free_frame_priv
static void vk_av1_free_frame_priv(AVRefStructOpaque _hwctx, void *data)
Definition: vulkan_av1.c:643
AV1VulkanDecodePicture::vkav1_ref
VkVideoDecodeAV1DpbSlotInfoKHR vkav1_ref
Definition: vulkan_av1.c:48
ff_vk_update_thread_context
int ff_vk_update_thread_context(AVCodecContext *dst, const AVCodecContext *src)
Synchronize the contexts between 2 threads.
Definition: vulkan_decode.c:91
FF_VK_EXT_VIDEO_DECODE_AV1
#define FF_VK_EXT_VIDEO_DECODE_AV1
Definition: vulkan_functions.h:59
AV1RawSequenceHeader::order_hint_bits_minus_1
uint8_t order_hint_bits_minus_1
Definition: cbs_av1.h:131
AV1RawColorConfig::matrix_coefficients
uint8_t matrix_coefficients
Definition: cbs_av1.h:58
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
AVBufferRef
A reference to a data buffer.
Definition: buffer.h:82
frame_header::flags
uint8_t flags
Definition: truemotion1.c:98
vk_av1_create_params
static int vk_av1_create_params(AVCodecContext *avctx, AVBufferRef **buf, AV1VulkanDecodePicture *ap)
Definition: vulkan_av1.c:211
AV1RawSequenceHeader::enable_restoration
uint8_t enable_restoration
Definition: cbs_av1.h:135
vulkan_decode.h
AV1RawColorConfig::twelve_bit
uint8_t twelve_bit
Definition: cbs_av1.h:52
AV1VulkanDecodePicture::vp
FFVulkanDecodePicture vp
Definition: vulkan_av1.c:38
AVCodecContext::priv_data
void * priv_data
Definition: avcodec.h:458
AV1RawSequenceHeader::additional_frame_id_length_minus_1
uint8_t additional_frame_id_length_minus_1
Definition: cbs_av1.h:112
AV1RawSequenceHeader::enable_cdef
uint8_t enable_cdef
Definition: cbs_av1.h:134
AV1RawSequenceHeader::reduced_still_picture_header
uint8_t reduced_still_picture_header
Definition: cbs_av1.h:85
AV1RawFilmGrainParams
Definition: cbs_av1.h:142
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:27
AV1VulkanDecodePicture::std_refs
StdVideoDecodeAV1ReferenceInfo std_refs[AV1_NUM_REF_FRAMES]
Definition: vulkan_av1.c:66
ff_vk_decode_init
int ff_vk_decode_init(AVCodecContext *avctx)
Initialize decoder.
Definition: vulkan_decode.c:1182
FFVulkanDecodePicture::decode_info
VkVideoDecodeInfoKHR decode_info
Definition: vulkan_decode.h:108
AV1VulkanDecodePicture
Definition: vulkan_av1.c:37
AV1VulkanDecodePicture::frame_id
uint8_t frame_id
Definition: vulkan_av1.c:70
vk_av1_fill_pict
static int vk_av1_fill_pict(AVCodecContext *avctx, const AV1Frame **ref_src, VkVideoReferenceSlotInfoKHR *ref_slot, VkVideoPictureResourceInfoKHR *ref, StdVideoDecodeAV1ReferenceInfo *vkav1_std_ref, VkVideoDecodeAV1DpbSlotInfoKHR *vkav1_ref, const AV1Frame *pic, int is_current, int has_grain, const uint8_t *saved_order_hints)
Definition: vulkan_av1.c:74
AV1VulkanDecodePicture::dec
FFVulkanDecodeContext * dec
Definition: vulkan_av1.c:42
AV1VulkanDecodePicture::frame_id_set
uint8_t frame_id_set
Definition: vulkan_av1.c:69
vk_av1_decode_slice
static int vk_av1_decode_slice(AVCodecContext *avctx, const uint8_t *data, uint32_t size)
Definition: vulkan_av1.c:562
FFVulkanDecodeContext::quirk_av1_offset
int quirk_av1_offset
Definition: vulkan_decode.h:75
AV_CODEC_EXPORT_DATA_FILM_GRAIN
#define AV_CODEC_EXPORT_DATA_FILM_GRAIN
Decoding only.
Definition: avcodec.h:400
AV1RawFrameHeader::frame_type
uint8_t frame_type
Definition: cbs_av1.h:180