FFmpeg
d3d12va_encode_h264.c
Go to the documentation of this file.
1 /*
2  * Direct3D 12 HW acceleration video encoder
3  *
4  * This file is part of FFmpeg.
5  *
6  * FFmpeg is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * FFmpeg is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with FFmpeg; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19  */
20 #include "libavutil/opt.h"
21 #include "libavutil/common.h"
22 #include "libavutil/mem.h"
23 #include "libavutil/pixdesc.h"
25 
26 #include "avcodec.h"
27 #include "cbs.h"
28 #include "cbs_h264.h"
29 #include "hw_base_encode_h264.h"
30 #include "h2645data.h"
31 #include "h264_levels.h"
32 #include "codec_internal.h"
33 #include "d3d12va_encode.h"
34 
35 typedef struct D3D12VAEncodeH264Picture {
39 
40 typedef struct D3D12VAEncodeH264Context {
42 
43  // User options.
44  int qp;
45  int profile;
46  int level;
47  int deblock;
49 
50  // Writer structures.
53 
57 
58 typedef struct D3D12VAEncodeH264Level {
59  int level;
60  D3D12_VIDEO_ENCODER_LEVELS_H264 d3d12_level;
62 
64  { 10, D3D12_VIDEO_ENCODER_LEVELS_H264_1 },
65  { 11, D3D12_VIDEO_ENCODER_LEVELS_H264_11 },
66  { 12, D3D12_VIDEO_ENCODER_LEVELS_H264_12 },
67  { 13, D3D12_VIDEO_ENCODER_LEVELS_H264_13 },
68  { 20, D3D12_VIDEO_ENCODER_LEVELS_H264_2 },
69  { 21, D3D12_VIDEO_ENCODER_LEVELS_H264_21 },
70  { 22, D3D12_VIDEO_ENCODER_LEVELS_H264_22 },
71  { 30, D3D12_VIDEO_ENCODER_LEVELS_H264_3 },
72  { 31, D3D12_VIDEO_ENCODER_LEVELS_H264_31 },
73  { 32, D3D12_VIDEO_ENCODER_LEVELS_H264_32 },
74  { 40, D3D12_VIDEO_ENCODER_LEVELS_H264_4 },
75  { 41, D3D12_VIDEO_ENCODER_LEVELS_H264_41 },
76  { 42, D3D12_VIDEO_ENCODER_LEVELS_H264_42 },
77  { 50, D3D12_VIDEO_ENCODER_LEVELS_H264_5 },
78  { 51, D3D12_VIDEO_ENCODER_LEVELS_H264_51 },
79  { 52, D3D12_VIDEO_ENCODER_LEVELS_H264_52 },
80  { 60, D3D12_VIDEO_ENCODER_LEVELS_H264_6 },
81  { 61, D3D12_VIDEO_ENCODER_LEVELS_H264_61 },
82  { 62, D3D12_VIDEO_ENCODER_LEVELS_H264_62 },
83 };
84 
85 static const D3D12_VIDEO_ENCODER_PROFILE_H264 profile_main = D3D12_VIDEO_ENCODER_PROFILE_H264_MAIN;
86 static const D3D12_VIDEO_ENCODER_PROFILE_H264 profile_high = D3D12_VIDEO_ENCODER_PROFILE_H264_HIGH;
87 static const D3D12_VIDEO_ENCODER_PROFILE_H264 profile_high_10 = D3D12_VIDEO_ENCODER_PROFILE_H264_HIGH_10;
88 
89 #define D3D_PROFILE_DESC(name) \
90  { sizeof(D3D12_VIDEO_ENCODER_PROFILE_H264), { .pH264Profile = (D3D12_VIDEO_ENCODER_PROFILE_H264 *)&profile_ ## name } }
92  { AV_PROFILE_H264_MAIN, 8, 3, 1, 1, D3D_PROFILE_DESC(main) },
93  { AV_PROFILE_H264_HIGH, 8, 3, 1, 1, D3D_PROFILE_DESC(high) },
94  { AV_PROFILE_H264_HIGH_10, 10, 3, 1, 1, D3D_PROFILE_DESC(high_10) },
96 };
97 
99  char *data, size_t *data_len,
101 {
102  D3D12VAEncodeH264Context *priv = avctx->priv_data;
103  int err;
104 
105  err = ff_cbs_write_fragment_data(priv->cbc, au);
106  if (err < 0) {
107  av_log(avctx, AV_LOG_ERROR, "Failed to write packed header.\n");
108  return err;
109  }
110 
111  if (*data_len < 8 * au->data_size - au->data_bit_padding) {
112  av_log(avctx, AV_LOG_ERROR, "Access unit too large: "
113  "%zu < %zu.\n", *data_len,
114  8 * au->data_size - au->data_bit_padding);
115  return AVERROR(ENOSPC);
116  }
117 
118  memcpy(data, au->data, au->data_size);
119  *data_len = 8 * au->data_size - au->data_bit_padding;
120 
121  return 0;
122 }
123 
126  void *nal_unit)
127 {
128  H264RawNALUnitHeader *header = nal_unit;
129  int err;
130 
131  err = ff_cbs_insert_unit_content(au, -1,
132  header->nal_unit_type, nal_unit, NULL);
133  if (err < 0) {
134  av_log(avctx, AV_LOG_ERROR, "Failed to add NAL unit: "
135  "type = %d.\n", header->nal_unit_type);
136  return err;
137  }
138 
139  return 0;
140 }
141 
143  char *data, size_t *data_len)
144 {
145  D3D12VAEncodeH264Context *priv = avctx->priv_data;
147  int err;
148 
149  err = d3d12va_encode_h264_add_nal(avctx, au, &priv->units.raw_sps);
150  if (err < 0)
151  goto fail;
152 
153  err = d3d12va_encode_h264_add_nal(avctx, au, &priv->units.raw_pps);
154  if (err < 0)
155  goto fail;
156 
157  err = d3d12va_encode_h264_write_access_unit(avctx, data, data_len, au);
158 fail:
159  ff_cbs_fragment_reset(au);
160  return err;
161 }
162 
164 {
165  FFHWBaseEncodeContext *base_ctx = avctx->priv_data;
167  D3D12VAEncodeH264Context *priv = avctx->priv_data;
168  AVD3D12VAFramesContext *hwctx = base_ctx->input_frames->hwctx;
169  H264RawSPS *sps = &priv->units.raw_sps;
170  H264RawPPS *pps = &priv->units.raw_pps;
171  D3D12_VIDEO_ENCODER_PROFILE_H264 profile = D3D12_VIDEO_ENCODER_PROFILE_H264_MAIN;
172  D3D12_VIDEO_ENCODER_LEVELS_H264 level = { 0 };
173  const AVPixFmtDescriptor *desc;
174  HRESULT hr;
175  int err;
176 
177  D3D12_FEATURE_DATA_VIDEO_ENCODER_SUPPORT support = {
178  .NodeIndex = 0,
179  .Codec = D3D12_VIDEO_ENCODER_CODEC_H264,
180  .InputFormat = hwctx->format,
181  .RateControl = ctx->rc,
182  .IntraRefresh = ctx->intra_refresh.Mode,
183  .SubregionFrameEncoding = D3D12_VIDEO_ENCODER_FRAME_SUBREGION_LAYOUT_MODE_FULL_FRAME,
184  .ResolutionsListCount = 1,
185  .pResolutionList = &ctx->resolution,
186  .CodecGopSequence = ctx->gop,
187  .MaxReferenceFramesInDPB = MAX_DPB_SIZE - 1,
188  .CodecConfiguration = ctx->codec_conf,
189  .SuggestedProfile.DataSize = sizeof(D3D12_VIDEO_ENCODER_PROFILE_H264),
190  .SuggestedProfile.pH264Profile = &profile,
191  .SuggestedLevel.DataSize = sizeof(D3D12_VIDEO_ENCODER_LEVELS_H264),
192  .SuggestedLevel.pH264LevelSetting = &level,
193  .pResolutionDependentSupport = &ctx->res_limits,
194  };
195 
196  hr = ID3D12VideoDevice3_CheckFeatureSupport(ctx->video_device3, D3D12_FEATURE_VIDEO_ENCODER_SUPPORT,
197  &support, sizeof(support));
198 
199  if (FAILED(hr)) {
200  av_log(avctx, AV_LOG_ERROR, "Failed to check encoder support(%lx).\n", (long)hr);
201  return AVERROR(EINVAL);
202  }
203 
204  if (!(support.SupportFlags & D3D12_VIDEO_ENCODER_SUPPORT_FLAG_GENERAL_SUPPORT_OK)) {
205  av_log(avctx, AV_LOG_ERROR, "Driver does not support some request features. %#x\n",
206  support.ValidationFlags);
207  return AVERROR(EINVAL);
208  }
209 
210  if (support.SupportFlags & D3D12_VIDEO_ENCODER_SUPPORT_FLAG_RECONSTRUCTED_FRAMES_REQUIRE_TEXTURE_ARRAYS) {
211  ctx->is_texture_array = 1;
212  av_log(avctx, AV_LOG_DEBUG, "D3D12 video encode on this device uses texture array mode.\n");
213  }
214 
215  // Check if the configuration with DELTA_QP is supported
216  if (support.SupportFlags & D3D12_VIDEO_ENCODER_SUPPORT_FLAG_RATE_CONTROL_DELTA_QP_AVAILABLE) {
217  base_ctx->roi_allowed = 1;
218  // Store the QP map region size from resolution limits
219  ctx->qp_map_region_size = ctx->res_limits.QPMapRegionPixelsSize;
220  av_log(avctx, AV_LOG_DEBUG, "ROI encoding is supported via delta QP "
221  "(QP map region size: %d pixels).\n", ctx->qp_map_region_size);
222  } else {
223  base_ctx->roi_allowed = 0;
224  av_log(avctx, AV_LOG_DEBUG, "ROI encoding not supported by hardware for current rate control mode \n");
225  }
226 
227  // Check motion estimation precision mode support
228  if (ctx->me_precision != D3D12_VIDEO_ENCODER_MOTION_ESTIMATION_PRECISION_MODE_MAXIMUM) {
229  if (!(support.SupportFlags & D3D12_VIDEO_ENCODER_SUPPORT_FLAG_MOTION_ESTIMATION_PRECISION_MODE_LIMIT_AVAILABLE)) {
230  av_log(avctx, AV_LOG_ERROR, "Hardware does not support motion estimation "
231  "precision mode limits.\n");
232  return AVERROR(ENOTSUP);
233  }
234  av_log(avctx, AV_LOG_VERBOSE, "Hardware supports motion estimation "
235  "precision mode limits.\n");
236  }
237 
239  av_assert0(desc);
240 
241  sps->pic_width_in_mbs_minus1 = ((base_ctx->surface_width + 0x0F) >> 4) - 1;
242  sps->pic_height_in_map_units_minus1 = ((base_ctx->surface_height + 0x0F) >> 4) - 1;
243 
244  priv->unit_opts.mb_width = sps->pic_width_in_mbs_minus1 + 1;
245  priv->unit_opts.mb_height = sps->pic_height_in_map_units_minus1 +1;
246 
247  err = ff_hw_base_encode_init_params_h264(base_ctx, avctx,
248  &priv->units, &priv->unit_opts);
249  if (err < 0)
250  return err;
251 
252  avctx->level = priv->units.raw_sps.level_idc;
253 
254  ctx->gop.pH264GroupOfPictures->pic_order_cnt_type = sps->pic_order_cnt_type;
255 
256  // override the default value according to the gop size
257  sps->log2_max_frame_num_minus4 = FFMAX(av_ceil_log2(base_ctx->gop_size) - 4, 0);
258  ctx->gop.pH264GroupOfPictures->log2_max_frame_num_minus4 = sps->log2_max_frame_num_minus4;
259  pps->deblocking_filter_control_present_flag = 1;
260 
261  return 0;
262 }
263 
265 {
266  HRESULT hr;
267  FFHWBaseEncodeContext *base_ctx = avctx->priv_data;
269  D3D12VAEncodeH264Context *priv = avctx->priv_data;
270 
271  D3D12_VIDEO_ENCODER_CODEC_CONFIGURATION_H264 *config;
272  D3D12_VIDEO_ENCODER_CODEC_CONFIGURATION_SUPPORT_H264 h264_caps;
273 
274  D3D12_FEATURE_DATA_VIDEO_ENCODER_CODEC_CONFIGURATION_SUPPORT codec_caps = {
275  .NodeIndex = 0,
276  .Codec = D3D12_VIDEO_ENCODER_CODEC_H264,
277  .Profile = ctx->profile->d3d12_profile,
278  .CodecSupportLimits.DataSize = sizeof(D3D12_VIDEO_ENCODER_CODEC_CONFIGURATION_SUPPORT_H264),
279  };
280 
281  codec_caps.CodecSupportLimits.pH264Support = &h264_caps;
282  hr = ID3D12VideoDevice3_CheckFeatureSupport(ctx->video_device3, D3D12_FEATURE_VIDEO_ENCODER_CODEC_CONFIGURATION_SUPPORT,
283  &codec_caps, sizeof(codec_caps));
284  if (!(SUCCEEDED(hr) && codec_caps.IsSupported))
285  return AVERROR(EINVAL);
286 
287  ctx->codec_conf.DataSize = sizeof(D3D12_VIDEO_ENCODER_CODEC_CONFIGURATION_H264);
288  ctx->codec_conf.pH264Config = av_mallocz(ctx->codec_conf.DataSize);
289  if (!ctx->codec_conf.pH264Config)
290  return AVERROR(ENOMEM);
291 
292  config = ctx->codec_conf.pH264Config;
293 
294  config->ConfigurationFlags = D3D12_VIDEO_ENCODER_CODEC_CONFIGURATION_H264_FLAG_NONE;
295 
296  if (h264_caps.SupportFlags & D3D12_VIDEO_ENCODER_CODEC_CONFIGURATION_SUPPORT_H264_FLAG_CABAC_ENCODING_SUPPORT) {
297  config->ConfigurationFlags |= D3D12_VIDEO_ENCODER_CODEC_CONFIGURATION_H264_FLAG_ENABLE_CABAC_ENCODING;
298  priv->unit_opts.cabac = 1;
299  }
300 
301  // Deblocking filter configuration
302  if (priv->deblock == 1) {
303  if (h264_caps.DisableDeblockingFilterSupportedModes & D3D12_VIDEO_ENCODER_CODEC_CONFIGURATION_H264_SLICES_DEBLOCKING_MODE_FLAG_0_ALL_LUMA_CHROMA_SLICE_BLOCK_EDGES_ALWAYS_FILTERED) {
304  config->DisableDeblockingFilterConfig = D3D12_VIDEO_ENCODER_CODEC_CONFIGURATION_H264_SLICES_DEBLOCKING_MODE_0_ALL_LUMA_CHROMA_SLICE_BLOCK_EDGES_ALWAYS_FILTERED;
305  } else {
306  av_log(avctx, AV_LOG_ERROR, "Requested deblocking filter enable mode not supported by driver.\n");
307  return AVERROR(ENOTSUP);
308  }
309  } else if (priv->deblock == 0) {
310  if (h264_caps.DisableDeblockingFilterSupportedModes & D3D12_VIDEO_ENCODER_CODEC_CONFIGURATION_H264_SLICES_DEBLOCKING_MODE_FLAG_1_DISABLE_ALL_SLICE_BLOCK_EDGES) {
311  config->DisableDeblockingFilterConfig = D3D12_VIDEO_ENCODER_CODEC_CONFIGURATION_H264_SLICES_DEBLOCKING_MODE_1_DISABLE_ALL_SLICE_BLOCK_EDGES;
312  } else {
313  av_log(avctx, AV_LOG_ERROR, "Requested deblocking filter disable mode not supported by driver.\n");
314  return AVERROR(ENOTSUP);
315  }
316  }
317 
318  base_ctx->surface_width = FFALIGN(avctx->width, 16);
319  base_ctx->surface_height = FFALIGN(avctx->height, 16);
320 
321  return 0;
322 }
323 
325 {
326  FFHWBaseEncodeContext *base_ctx = avctx->priv_data;
328  D3D12VAEncodeH264Context *priv = avctx->priv_data;
329  int fixed_qp_idr, fixed_qp_p, fixed_qp_b;
330  int err;
331 
332  err = ff_cbs_init(&priv->cbc, AV_CODEC_ID_H264, avctx);
333  if (err < 0)
334  return err;
335 
336  // Rate control
337  if (ctx->rc.Mode == D3D12_VIDEO_ENCODER_RATE_CONTROL_MODE_CQP) {
338  D3D12_VIDEO_ENCODER_RATE_CONTROL_CQP *cqp_ctl;
339  fixed_qp_p = av_clip(ctx->rc_quality, 1, 51);
340  if (avctx->i_quant_factor > 0.0)
341  fixed_qp_idr = av_clip((avctx->i_quant_factor * fixed_qp_p +
342  avctx->i_quant_offset) + 0.5, 1, 51);
343  else
344  fixed_qp_idr = fixed_qp_p;
345  if (avctx->b_quant_factor > 0.0)
346  fixed_qp_b = av_clip((avctx->b_quant_factor * fixed_qp_p +
347  avctx->b_quant_offset) + 0.5, 1, 51);
348  else
349  fixed_qp_b = fixed_qp_p;
350 
351  av_log(avctx, AV_LOG_DEBUG, "Using fixed QP = "
352  "%d / %d / %d for IDR- / P- / B-frames.\n",
353  fixed_qp_idr, fixed_qp_p, fixed_qp_b);
354 
355  ctx->rc.ConfigParams.DataSize = sizeof(D3D12_VIDEO_ENCODER_RATE_CONTROL_CQP);
356  cqp_ctl = av_mallocz(ctx->rc.ConfigParams.DataSize);
357  if (!cqp_ctl)
358  return AVERROR(ENOMEM);
359 
360  cqp_ctl->ConstantQP_FullIntracodedFrame = fixed_qp_idr;
361  cqp_ctl->ConstantQP_InterPredictedFrame_PrevRefOnly = fixed_qp_p;
362  cqp_ctl->ConstantQP_InterPredictedFrame_BiDirectionalRef = fixed_qp_b;
363 
364  ctx->rc.ConfigParams.pConfiguration_CQP = cqp_ctl;
365  }
366  priv->unit_opts.fixed_qp_idr = 26;
367 
368  // GOP
369  ctx->gop.DataSize = sizeof(D3D12_VIDEO_ENCODER_SEQUENCE_GOP_STRUCTURE_H264);
370  ctx->gop.pH264GroupOfPictures = av_mallocz(ctx->gop.DataSize);
371  if (!ctx->gop.pH264GroupOfPictures)
372  return AVERROR(ENOMEM);
373 
374  ctx->gop.pH264GroupOfPictures->GOPLength = base_ctx->gop_size;
375  ctx->gop.pH264GroupOfPictures->PPicturePeriod = base_ctx->b_per_p + 1;
376  ctx->gop.pH264GroupOfPictures->log2_max_frame_num_minus4 = FFMAX(av_ceil_log2(base_ctx->gop_size) - 4, 0);
377 
378  return 0;
379 }
380 
382 {
384  int i;
385 
386  ctx->level.DataSize = sizeof(D3D12_VIDEO_ENCODER_LEVELS_H264);
387  ctx->level.pH264LevelSetting = av_mallocz(ctx->level.DataSize);
388  if (!ctx->level.pH264LevelSetting)
389  return AVERROR(ENOMEM);
390 
391  for (i = 0; i < FF_ARRAY_ELEMS(h264_levels); i++) {
392  if (avctx->level == h264_levels[i].level) {
393  *ctx->level.pH264LevelSetting = h264_levels[i].d3d12_level;
394  break;
395  }
396  }
397 
398  if (i == FF_ARRAY_ELEMS(h264_levels)) {
399  av_log(avctx, AV_LOG_ERROR, "Invalid level %d.\n", avctx->level);
400  return AVERROR(EINVAL);
401  }
402 
403  return 0;
404 }
405 
407 {
408  if (!pic->pic_ctl.pH264PicData)
409  return;
410 
411  av_freep(&pic->pic_ctl.pH264PicData->pList0ReferenceFrames);
412  av_freep(&pic->pic_ctl.pH264PicData->pList1ReferenceFrames);
413  av_freep(&pic->pic_ctl.pH264PicData->pReferenceFramesReconPictureDescriptors);
414  av_freep(&pic->pic_ctl.pH264PicData);
415 }
416 
418  FFHWBaseEncodePicture *base_pic)
419 {
420  FFHWBaseEncodeContext *base_ctx = avctx->priv_data;
422  D3D12VAEncodePicture *pic = base_pic->priv;
423  D3D12VAEncodeH264Picture *hpic = base_pic->codec_priv;
424  FFHWBaseEncodePicture *prev = base_pic->prev;
425  D3D12VAEncodeH264Picture *hprev = prev ? prev->codec_priv : NULL;
426  D3D12_VIDEO_ENCODER_REFERENCE_PICTURE_DESCRIPTOR_H264 *pd = NULL;
427  UINT *ref_list0 = NULL, *ref_list1 = NULL;
428  int i, idx = 0;
429 
430  pic->pic_ctl.DataSize = sizeof(D3D12_VIDEO_ENCODER_PICTURE_CONTROL_CODEC_DATA_H264);
431  pic->pic_ctl.pH264PicData = av_mallocz(pic->pic_ctl.DataSize);
432  if (!pic->pic_ctl.pH264PicData)
433  return AVERROR(ENOMEM);
434 
435  if (base_pic->type == FF_HW_PICTURE_TYPE_IDR) {
436  av_assert0(base_pic->display_order == base_pic->encode_order);
437  hpic->last_idr_frame = base_pic->display_order;
438  ctx->idr_pic_id++;
439  } else {
440  av_assert0(prev);
441  hpic->last_idr_frame = hprev->last_idr_frame;
442  }
443  hpic->pic_order_cnt = base_pic->display_order - hpic->last_idr_frame;
444 
445  switch(base_pic->type) {
447  pic->pic_ctl.pH264PicData->FrameType = D3D12_VIDEO_ENCODER_FRAME_TYPE_H264_IDR_FRAME;
448  pic->pic_ctl.pH264PicData->idr_pic_id = ctx->idr_pic_id;
449  break;
451  pic->pic_ctl.pH264PicData->FrameType = D3D12_VIDEO_ENCODER_FRAME_TYPE_H264_I_FRAME;
452  break;
454  pic->pic_ctl.pH264PicData->FrameType = D3D12_VIDEO_ENCODER_FRAME_TYPE_H264_P_FRAME;
455  break;
457  pic->pic_ctl.pH264PicData->FrameType = D3D12_VIDEO_ENCODER_FRAME_TYPE_H264_B_FRAME;
458  break;
459  default:
460  av_assert0(0 && "invalid picture type");
461  }
462 
463  pic->pic_ctl.pH264PicData->PictureOrderCountNumber = hpic->pic_order_cnt;
464  pic->pic_ctl.pH264PicData->FrameDecodingOrderNumber = hpic->pic_order_cnt;
465 
466  if (base_pic->type == FF_HW_PICTURE_TYPE_P || base_pic->type == FF_HW_PICTURE_TYPE_B) {
467  pd = av_calloc(MAX_PICTURE_REFERENCES, sizeof(*pd));
468  if (!pd)
469  return AVERROR(ENOMEM);
470 
471  ref_list0 = av_calloc(MAX_PICTURE_REFERENCES, sizeof(*ref_list0));
472  if (!ref_list0)
473  return AVERROR(ENOMEM);
474 
475  pic->pic_ctl.pH264PicData->List0ReferenceFramesCount = base_pic->nb_refs[0];
476  for (i = 0; i < base_pic->nb_refs[0]; i++) {
477  FFHWBaseEncodePicture *ref = base_pic->refs[0][i];
479 
480  av_assert0(ref && ref->encode_order < base_pic->encode_order);
481  href = ref->codec_priv;
482 
483  ref_list0[i] = idx;
484  pd[idx].ReconstructedPictureResourceIndex = idx;
485  pd[idx].PictureOrderCountNumber = href->pic_order_cnt;
486  idx++;
487  }
488  }
489 
490  if (base_pic->type == FF_HW_PICTURE_TYPE_B) {
491  ref_list1 = av_calloc(MAX_PICTURE_REFERENCES, sizeof(*ref_list1));
492  if (!ref_list1)
493  return AVERROR(ENOMEM);
494 
495  pic->pic_ctl.pH264PicData->List1ReferenceFramesCount = base_pic->nb_refs[1];
496  for (i = 0; i < base_pic->nb_refs[1]; i++) {
497  FFHWBaseEncodePicture *ref = base_pic->refs[1][i];
499 
500  av_assert0(ref && ref->encode_order < base_pic->encode_order);
501  href = ref->codec_priv;
502 
503  ref_list1[i] = idx;
504  pd[idx].ReconstructedPictureResourceIndex = idx;
505  pd[idx].PictureOrderCountNumber = href->pic_order_cnt;
506  idx++;
507  }
508  }
509 
510  pic->pic_ctl.pH264PicData->pList0ReferenceFrames = ref_list0;
511  pic->pic_ctl.pH264PicData->pList1ReferenceFrames = ref_list1;
512  pic->pic_ctl.pH264PicData->ReferenceFramesReconPictureDescriptorsCount = idx;
513  pic->pic_ctl.pH264PicData->pReferenceFramesReconPictureDescriptors = pd;
514 
515  // Process ROI side data if present and supported
516  if (base_ctx->roi_allowed && pic->qp_map && pic->qp_map_size > 0) {
517  pic->pic_ctl.pH264PicData->QPMapValuesCount = pic->qp_map_size;
518  pic->pic_ctl.pH264PicData->pRateControlQPMap = (INT8 *)pic->qp_map;
519  }
520 
521  return 0;
522 }
523 
526 
527  .d3d12_codec = D3D12_VIDEO_ENCODER_CODEC_H264,
528 
529  .flags = FF_HW_FLAG_B_PICTURES |
532 
533  .default_quality = 25,
534 
535  .get_encoder_caps = &d3d12va_encode_h264_get_encoder_caps,
536 
537  .configure = &d3d12va_encode_h264_configure,
538 
539  .set_level = &d3d12va_encode_h264_set_level,
540 
541  .picture_priv_data_size = sizeof(D3D12VAEncodeH264Picture),
542 
543  .init_sequence_params = &d3d12va_encode_h264_init_sequence_params,
544 
545  .init_picture_params = &d3d12va_encode_h264_init_picture_params,
546 
547  .free_picture_params = &d3d12va_encode_h264_free_picture_params,
548 
550 };
551 
553 {
555  D3D12VAEncodeH264Context *priv = avctx->priv_data;
556 
557  ctx->codec = &d3d12va_encode_type_h264;
558 
559  if (avctx->profile == AV_PROFILE_UNKNOWN)
560  avctx->profile = priv->profile;
561  if (avctx->level == AV_LEVEL_UNKNOWN)
562  avctx->level = priv->level;
563 
564  if (avctx->level != AV_LEVEL_UNKNOWN && avctx->level & ~0xff) {
565  av_log(avctx, AV_LOG_ERROR, "Invalid level %d: must fit "
566  "in 8-bit unsigned integer.\n", avctx->level);
567  return AVERROR(EINVAL);
568  }
569 
570  if (priv->qp > 0)
571  ctx->explicit_qp = priv->qp;
572 
573  return ff_d3d12va_encode_init(avctx);
574 }
575 
577 {
578  D3D12VAEncodeH264Context *priv = avctx->priv_data;
579 
580  ff_cbs_fragment_free(&priv->current_access_unit);
581  ff_cbs_close(&priv->cbc);
582 
583  av_freep(&priv->common.codec_conf.pH264Config);
584  av_freep(&priv->common.gop.pH264GroupOfPictures);
585  av_freep(&priv->common.level.pH264LevelSetting);
586 
587  if (priv->common.rc.ConfigParams.pConfiguration_CQP != NULL) {
588  av_freep(&priv->common.rc.ConfigParams.pConfiguration_CQP);
589  }
590 
591  return ff_d3d12va_encode_close(avctx);
592 }
593 
594 #define OFFSET(x) offsetof(D3D12VAEncodeH264Context, x)
595 #define FLAGS (AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM)
600 
601  { "qp", "Constant QP (for P-frames; scaled by qfactor/qoffset for I/B)",
602  OFFSET(qp), AV_OPT_TYPE_INT, { .i64 = 0 }, 0, 52, FLAGS },
603 
604  { "profile", "Set profile (general_profile_idc)",
606  { .i64 = AV_PROFILE_UNKNOWN }, AV_PROFILE_UNKNOWN, 0xff, FLAGS, "profile" },
607 
608 #define PROFILE(name, value) name, NULL, 0, AV_OPT_TYPE_CONST, \
609  { .i64 = value }, 0, 0, FLAGS, "profile"
610  { PROFILE("main", AV_PROFILE_H264_MAIN) },
611  { PROFILE("high", AV_PROFILE_H264_HIGH) },
612  { PROFILE("high10", AV_PROFILE_H264_HIGH_10) },
613 #undef PROFILE
614 
615  { "level", "Set level (general_level_idc)",
617  { .i64 = AV_LEVEL_UNKNOWN }, AV_LEVEL_UNKNOWN, 0xff, FLAGS, "level" },
618 
619 #define LEVEL(name, value) name, NULL, 0, AV_OPT_TYPE_CONST, \
620  { .i64 = value }, 0, 0, FLAGS, "level"
621  { LEVEL("1", 10) },
622  { LEVEL("1.1", 11) },
623  { LEVEL("1.2", 12) },
624  { LEVEL("1.3", 13) },
625  { LEVEL("2", 20) },
626  { LEVEL("2.1", 21) },
627  { LEVEL("2.2", 22) },
628  { LEVEL("3", 30) },
629  { LEVEL("3.1", 31) },
630  { LEVEL("3.2", 32) },
631  { LEVEL("4", 40) },
632  { LEVEL("4.1", 41) },
633  { LEVEL("4.2", 42) },
634  { LEVEL("5", 50) },
635  { LEVEL("5.1", 51) },
636  { LEVEL("5.2", 52) },
637  { LEVEL("6", 60) },
638  { LEVEL("6.1", 61) },
639  { LEVEL("6.2", 62) },
640 #undef LEVEL
641 
642  { "deblock", "Deblocking filter mode",
643  OFFSET(deblock), AV_OPT_TYPE_BOOL, { .i64 = -1 }, -1, 1, FLAGS },
644 
645  { NULL },
646 };
647 
649  { "b", "0" },
650  { "bf", "2" },
651  { "g", "120" },
652  { "qmin", "-1" },
653  { "qmax", "-1" },
654  { NULL },
655 };
656 
658  .class_name = "h264_d3d12va",
659  .item_name = av_default_item_name,
660  .option = d3d12va_encode_h264_options,
661  .version = LIBAVUTIL_VERSION_INT,
662 };
663 
665  .p.name = "h264_d3d12va",
666  CODEC_LONG_NAME("D3D12VA h264 encoder"),
667  .p.type = AVMEDIA_TYPE_VIDEO,
668  .p.id = AV_CODEC_ID_H264,
669  .priv_data_size = sizeof(D3D12VAEncodeH264Context),
672  .close = &d3d12va_encode_h264_close,
673  .p.priv_class = &d3d12va_encode_h264_class,
674  .p.capabilities = AV_CODEC_CAP_DELAY | AV_CODEC_CAP_HARDWARE |
676  .caps_internal = FF_CODEC_CAP_NOT_INIT_THREADSAFE |
678  .defaults = d3d12va_encode_h264_defaults,
680  .hw_configs = ff_d3d12va_encode_hw_configs,
681  .p.wrapper_name = "d3d12va",
682 };
cbs.h
D3D12VAEncodeH264Context::units
FFHWBaseEncodeH264 units
Definition: d3d12va_encode_h264.c:51
CODEC_PIXFMTS
#define CODEC_PIXFMTS(...)
Definition: codec_internal.h:392
FF_HW_PICTURE_TYPE_I
@ FF_HW_PICTURE_TYPE_I
Definition: hw_base_encode.h:40
level
uint8_t level
Definition: svq3.c:208
av_clip
#define av_clip
Definition: common.h:100
FF_CODEC_CAP_INIT_CLEANUP
#define FF_CODEC_CAP_INIT_CLEANUP
The codec allows calling the close function for deallocation even if the init function returned a fai...
Definition: codec_internal.h:42
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
opt.h
FFHWBaseEncodeH264Opts
Definition: hw_base_encode_h264.h:34
d3d12va_encode_h264_free_picture_params
static void d3d12va_encode_h264_free_picture_params(D3D12VAEncodePicture *pic)
Definition: d3d12va_encode_h264.c:406
FF_HW_FLAG_NON_IDR_KEY_PICTURES
@ FF_HW_FLAG_NON_IDR_KEY_PICTURES
Definition: hw_base_encode.h:58
OFFSET
#define OFFSET(x)
Definition: d3d12va_encode_h264.c:594
FFHWBaseEncodePicture::priv
void * priv
Definition: hw_base_encode.h:63
profile_high
static const D3D12_VIDEO_ENCODER_PROFILE_H264 profile_high
Definition: d3d12va_encode_h264.c:86
deblock
static void deblock(const RV60Context *s, AVFrame *frame, int xpos, int ypos, int size, int dpos)
Definition: rv60dec.c:2154
FFHWBaseEncodePicture::codec_priv
void * codec_priv
Definition: hw_base_encode.h:65
h264_levels.h
D3D12VAEncodeH264Context::idr_pic_id
int idr_pic_id
Definition: d3d12va_encode_h264.c:48
av_pix_fmt_desc_get
const AVPixFmtDescriptor * av_pix_fmt_desc_get(enum AVPixelFormat pix_fmt)
Definition: pixdesc.c:3456
AV_CODEC_CAP_HARDWARE
#define AV_CODEC_CAP_HARDWARE
Codec is backed by a hardware implementation.
Definition: codec.h:130
AV_PROFILE_H264_MAIN
#define AV_PROFILE_H264_MAIN
Definition: defs.h:112
cbs_h264.h
int64_t
long long int64_t
Definition: coverity.c:34
pixdesc.h
CodedBitstreamContext
Context structure for coded bitstream operations.
Definition: cbs.h:226
AVOption
AVOption.
Definition: opt.h:429
d3d12va_encode.h
d3d12va_encode_h264_write_access_unit
static int d3d12va_encode_h264_write_access_unit(AVCodecContext *avctx, char *data, size_t *data_len, CodedBitstreamFragment *au)
Definition: d3d12va_encode_h264.c:98
data
const char data[16]
Definition: mxf.c:149
high
int high
Definition: dovi_rpuenc.c:39
AVCodecContext::b_quant_offset
float b_quant_offset
qscale offset between IP and B-frames
Definition: avcodec.h:793
FF_CODEC_CAP_NOT_INIT_THREADSAFE
#define FF_CODEC_CAP_NOT_INIT_THREADSAFE
The codec is not known to be init-threadsafe (i.e.
Definition: codec_internal.h:34
FFCodec
Definition: codec_internal.h:127
AV_LOG_VERBOSE
#define AV_LOG_VERBOSE
Detailed information.
Definition: log.h:226
ff_hw_base_encode_init_params_h264
int ff_hw_base_encode_init_params_h264(FFHWBaseEncodeContext *base_ctx, AVCodecContext *avctx, FFHWBaseEncodeH264 *common, FFHWBaseEncodeH264Opts *opts)
Definition: hw_base_encode_h264.c:26
D3D12VAEncodePicture::qp_map_size
int qp_map_size
Definition: d3d12va_encode.h:63
D3D12VAEncodeH264Context
Definition: d3d12va_encode_h264.c:40
D3D12VAEncodeH264Context::level
int level
Definition: d3d12va_encode_h264.c:46
FFMAX
#define FFMAX(a, b)
Definition: macros.h:47
tf_sess_config.config
config
Definition: tf_sess_config.py:33
d3d12va_encode_h264_profiles
static const D3D12VAEncodeProfile d3d12va_encode_h264_profiles[]
Definition: d3d12va_encode_h264.c:91
FFHWBaseEncodeContext
Definition: hw_base_encode.h:122
ff_d3d12va_encode_hw_configs
const AVCodecHWConfigInternal *const ff_d3d12va_encode_hw_configs[]
Definition: d3d12va_encode.c:37
AVCodecContext::i_quant_factor
float i_quant_factor
qscale factor between P- and I-frames If > 0 then the last P-frame quantizer will be used (q = lastp_...
Definition: avcodec.h:802
FFCodecDefault
Definition: codec_internal.h:96
FFCodec::p
AVCodec p
The public AVCodec.
Definition: codec_internal.h:131
FFHWBaseEncodePicture::type
int type
Definition: hw_base_encode.h:78
av_ceil_log2
#define av_ceil_log2
Definition: common.h:97
fail
#define fail()
Definition: checkasm.h:217
FFHWBaseEncodeH264
Definition: hw_base_encode_h264.h:25
D3D12VAEncodeH264Context::cbc
CodedBitstreamContext * cbc
Definition: d3d12va_encode_h264.c:54
D3D12VA_ENCODE_RC_OPTIONS
#define D3D12VA_ENCODE_RC_OPTIONS
Definition: d3d12va_encode.h:430
FFHWBaseEncodePicture::prev
struct FFHWBaseEncodePicture * prev
Definition: hw_base_encode.h:101
D3D12VAEncodeH264Picture
Definition: d3d12va_encode_h264.c:35
FFHWBaseEncodeH264Opts::cabac
int cabac
Definition: hw_base_encode_h264.h:41
AV_LOG_ERROR
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:210
FF_ARRAY_ELEMS
#define FF_ARRAY_ELEMS(a)
Definition: sinewin_tablegen.c:29
main
int main
Definition: dovi_rpuenc.c:38
AV_PROFILE_UNKNOWN
#define AV_PROFILE_UNKNOWN
Definition: defs.h:65
D3D12VA_ENCODE_COMMON_OPTIONS
#define D3D12VA_ENCODE_COMMON_OPTIONS
Definition: d3d12va_encode.h:396
CodedBitstreamFragment
Coded bitstream fragment structure, combining one or more units.
Definition: cbs.h:129
d3d12va_encode_h264_add_nal
static int d3d12va_encode_h264_add_nal(AVCodecContext *avctx, CodedBitstreamFragment *au, void *nal_unit)
Definition: d3d12va_encode_h264.c:124
FFHWBaseEncodeH264Opts::fixed_qp_idr
int fixed_qp_idr
Definition: hw_base_encode_h264.h:42
D3D12VAEncodeH264Level::level
int level
Definition: d3d12va_encode_h264.c:59
CodedBitstreamFragment::data_size
size_t data_size
The number of bytes in the bitstream.
Definition: cbs.h:142
D3D12VAEncodeH264Picture::last_idr_frame
int64_t last_idr_frame
Definition: d3d12va_encode_h264.c:37
AV_PROFILE_H264_HIGH_10
#define AV_PROFILE_H264_HIGH_10
Definition: defs.h:115
AV_CODEC_CAP_ENCODER_REORDERED_OPAQUE
#define AV_CODEC_CAP_ENCODER_REORDERED_OPAQUE
This encoder can reorder user opaque values from input AVFrames and return them with corresponding ou...
Definition: codec.h:144
av_assert0
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Definition: avassert.h:41
AV_LOG_DEBUG
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
Definition: log.h:231
LEVEL
#define LEVEL(name, value)
ctx
AVFormatContext * ctx
Definition: movenc.c:49
D3D12VAEncodeH264Context::common
D3D12VAEncodeContext common
Definition: d3d12va_encode_h264.c:41
D3D12VAEncodePicture::pic_ctl
D3D12_VIDEO_ENCODER_PICTURE_CONTROL_CODEC_DATA pic_ctl
Definition: d3d12va_encode.h:57
CodedBitstreamFragment::data_bit_padding
size_t data_bit_padding
The number of bits which should be ignored in the final byte.
Definition: cbs.h:146
av_mallocz
#define av_mallocz(s)
Definition: tableprint_vlc.h:31
h2645data.h
AV_CODEC_ID_H264
@ AV_CODEC_ID_H264
Definition: codec_id.h:79
CODEC_LONG_NAME
#define CODEC_LONG_NAME(str)
Definition: codec_internal.h:332
FFHWBaseEncodeH264::raw_sps
H264RawSPS raw_sps
Definition: hw_base_encode_h264.h:26
FFHWBaseEncodeContext::b_per_p
int b_per_p
Definition: hw_base_encode.h:189
FLAGS
#define FLAGS
Definition: d3d12va_encode_h264.c:595
LIBAVUTIL_VERSION_INT
#define LIBAVUTIL_VERSION_INT
Definition: version.h:85
AVClass
Describe the class of an AVClass context structure.
Definition: log.h:76
NULL
#define NULL
Definition: coverity.c:32
AVHWFramesContext::sw_format
enum AVPixelFormat sw_format
The pixel format identifying the actual data layout of the hardware frames.
Definition: hwcontext.h:213
hw_base_encode_h264.h
d3d12va_encode_h264_init_picture_params
static int d3d12va_encode_h264_init_picture_params(AVCodecContext *avctx, FFHWBaseEncodePicture *base_pic)
Definition: d3d12va_encode_h264.c:417
AV_LEVEL_UNKNOWN
#define AV_LEVEL_UNKNOWN
Definition: defs.h:209
d3d12va_encode_h264_get_encoder_caps
static int d3d12va_encode_h264_get_encoder_caps(AVCodecContext *avctx)
Definition: d3d12va_encode_h264.c:264
d3d12va_encode_h264_defaults
static const FFCodecDefault d3d12va_encode_h264_defaults[]
Definition: d3d12va_encode_h264.c:648
FF_CODEC_RECEIVE_PACKET_CB
#define FF_CODEC_RECEIVE_PACKET_CB(func)
Definition: codec_internal.h:367
D3D12VAEncodeH264Context::deblock
int deblock
Definition: d3d12va_encode_h264.c:47
H264RawNALUnitHeader
Definition: cbs_h264.h:31
av_default_item_name
const char * av_default_item_name(void *ptr)
Return the context name.
Definition: log.c:242
PROFILE
#define PROFILE(name, value)
D3D12VAEncodeH264Picture::pic_order_cnt
int pic_order_cnt
Definition: d3d12va_encode_h264.c:36
AVD3D12VAFramesContext
This struct is allocated as AVHWFramesContext.hwctx.
Definition: hwcontext_d3d12va.h:172
AV_PIX_FMT_D3D12
@ AV_PIX_FMT_D3D12
Hardware surfaces for Direct3D 12.
Definition: pixfmt.h:440
AVCodecContext::level
int level
Encoding level descriptor.
Definition: avcodec.h:1636
D3D12VAEncodeH264Context::qp
int qp
Definition: d3d12va_encode_h264.c:44
D3D12VAEncodeContext::rc
D3D12_VIDEO_ENCODER_RATE_CONTROL rc
Definition: d3d12va_encode.h:266
D3D12VAEncodeContext::codec_conf
D3D12_VIDEO_ENCODER_CODEC_CONFIGURATION codec_conf
Definition: d3d12va_encode.h:264
init
int(* init)(AVBSFContext *ctx)
Definition: dts2pts.c:550
AV_CODEC_CAP_DR1
#define AV_CODEC_CAP_DR1
Codec uses get_buffer() or get_encode_buffer() for allocating buffers and supports custom allocators.
Definition: codec.h:52
codec_internal.h
ff_d3d12va_encode_init
int ff_d3d12va_encode_init(AVCodecContext *avctx)
Definition: d3d12va_encode.c:1703
FFHWBaseEncodePicture::nb_refs
int nb_refs[MAX_REFERENCE_LIST_NUM]
Definition: hw_base_encode.h:97
profile_main
static const D3D12_VIDEO_ENCODER_PROFILE_H264 profile_main
Definition: d3d12va_encode_h264.c:85
MAX_DPB_SIZE
#define MAX_DPB_SIZE
Definition: hw_base_encode.h:26
D3D12VAEncodeProfile
Definition: d3d12va_encode.h:66
CodedBitstreamFragment::data
uint8_t * data
Pointer to the bitstream form of this fragment.
Definition: cbs.h:135
d3d12va_encode_h264_write_sequence_header
static int d3d12va_encode_h264_write_sequence_header(AVCodecContext *avctx, char *data, size_t *data_len)
Definition: d3d12va_encode_h264.c:142
ff_h264_d3d12va_encoder
const FFCodec ff_h264_d3d12va_encoder
Definition: d3d12va_encode_h264.c:664
FFHWBaseEncodeH264::raw_pps
H264RawPPS raw_pps
Definition: hw_base_encode_h264.h:27
d3d12va_encode_type_h264
static const D3D12VAEncodeType d3d12va_encode_type_h264
Definition: d3d12va_encode_h264.c:524
header
static const uint8_t header[24]
Definition: sdr2.c:68
FFHWBaseEncodePicture::encode_order
int64_t encode_order
Definition: hw_base_encode.h:70
d3d12va_encode_h264_close
static int d3d12va_encode_h264_close(AVCodecContext *avctx)
Definition: d3d12va_encode_h264.c:576
FFHWBaseEncodeContext::roi_allowed
int roi_allowed
Definition: hw_base_encode.h:201
d3d12va_encode_h264_init_sequence_params
static int d3d12va_encode_h264_init_sequence_params(AVCodecContext *avctx)
Definition: d3d12va_encode_h264.c:163
D3D12VAEncodePicture
Definition: d3d12va_encode.h:42
AVCodecContext::b_quant_factor
float b_quant_factor
qscale factor between IP and B-frames If > 0 then the last P-frame quantizer will be used (q= lastp_q...
Definition: avcodec.h:786
FFHWBaseEncodeH264Opts::mb_height
int mb_height
Definition: hw_base_encode_h264.h:39
FF_HW_PICTURE_TYPE_B
@ FF_HW_PICTURE_TYPE_B
Definition: hw_base_encode.h:42
D3D12VAEncodeContext::level
D3D12_VIDEO_ENCODER_LEVEL_SETTING level
Definition: d3d12va_encode.h:270
D3D_PROFILE_DESC
#define D3D_PROFILE_DESC(name)
Definition: d3d12va_encode_h264.c:89
D3D12VAEncodePicture::qp_map
void * qp_map
Definition: d3d12va_encode.h:62
d3d12va_encode_h264_init
static int d3d12va_encode_h264_init(AVCodecContext *avctx)
Definition: d3d12va_encode_h264.c:552
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:256
common.h
FFHWBaseEncodePicture::refs
struct FFHWBaseEncodePicture * refs[MAX_REFERENCE_LIST_NUM][MAX_PICTURE_REFERENCES]
Definition: hw_base_encode.h:98
AVCodec::name
const char * name
Name of the codec implementation.
Definition: codec.h:179
D3D12VAEncodeH264Context::current_access_unit
CodedBitstreamFragment current_access_unit
Definition: d3d12va_encode_h264.c:55
profile
int profile
Definition: mxfenc.c:2297
AVCodecContext::height
int height
Definition: avcodec.h:600
av_calloc
void * av_calloc(size_t nmemb, size_t size)
Definition: mem.c:264
avcodec.h
AVD3D12VAFramesContext::format
DXGI_FORMAT format
DXGI_FORMAT format.
Definition: hwcontext_d3d12va.h:177
FFHWBaseEncodeContext::gop_size
int gop_size
Definition: hw_base_encode.h:184
FFHWBaseEncodePicture
Definition: hw_base_encode.h:61
AVClass::class_name
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
Definition: log.h:81
AVHWFramesContext::hwctx
void * hwctx
The format-specific data, allocated and freed automatically along with this context.
Definition: hwcontext.h:153
sps
static int FUNC() sps(CodedBitstreamContext *ctx, RWContext *rw, H264RawSPS *current)
Definition: cbs_h264_syntax_template.c:260
D3D12VAEncodeContext
Definition: d3d12va_encode.h:150
d3d12va_encode_h264_options
static const AVOption d3d12va_encode_h264_options[]
Definition: d3d12va_encode_h264.c:596
FFHWBaseEncodeContext::surface_height
int surface_height
Definition: hw_base_encode.h:141
AVCodecContext
main external API structure.
Definition: avcodec.h:439
AV_PROFILE_H264_HIGH
#define AV_PROFILE_H264_HIGH
Definition: defs.h:114
write_sequence_header
static int write_sequence_header(AVCodecContext *avctx, FFHWBaseEncodePicture *base_pic, uint8_t *data, size_t *data_len)
Definition: vulkan_encode_av1.c:1095
H264RawSPS::level_idc
uint8_t level_idc
Definition: cbs_h264.h:113
d3d12va_encode_h264_class
static const AVClass d3d12va_encode_h264_class
Definition: d3d12va_encode_h264.c:657
AV_OPT_TYPE_INT
@ AV_OPT_TYPE_INT
Underlying C type is int.
Definition: opt.h:259
AVCodecContext::profile
int profile
profile
Definition: avcodec.h:1626
h264_levels
static const D3D12VAEncodeH264Level h264_levels[]
Definition: d3d12va_encode_h264.c:63
AVCodecContext::i_quant_offset
float i_quant_offset
qscale offset between P and I-frames
Definition: avcodec.h:809
ref
static int ref[MAX_W *MAX_W]
Definition: jpeg2000dwt.c:117
pps
uint64_t pps
Definition: dovi_rpuenc.c:36
FFHWBaseEncodeContext::input_frames
AVHWFramesContext * input_frames
Definition: hw_base_encode.h:153
AV_CODEC_CAP_DELAY
#define AV_CODEC_CAP_DELAY
Encoder or decoder requires flushing with NULL input at the end in order to give the complete and cor...
Definition: codec.h:76
FFHWBaseEncodeH264Opts::mb_width
int mb_width
Definition: hw_base_encode_h264.h:38
D3D12VAEncodeH264Level::d3d12_level
D3D12_VIDEO_ENCODER_LEVELS_H264 d3d12_level
Definition: d3d12va_encode_h264.c:60
FFHWBaseEncodeContext::surface_width
int surface_width
Definition: hw_base_encode.h:140
D3D12VAEncodeContext::gop
D3D12_VIDEO_ENCODER_SEQUENCE_GOP_STRUCTURE gop
Definition: d3d12va_encode.h:268
desc
const char * desc
Definition: libsvtav1.c:78
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:200
mem.h
D3D12VAEncodeH264Context::unit_opts
FFHWBaseEncodeH264Opts unit_opts
Definition: d3d12va_encode_h264.c:52
FF_HW_FLAG_B_PICTURES
@ FF_HW_FLAG_B_PICTURES
Definition: hw_base_encode.h:53
AVPixFmtDescriptor
Descriptor that unambiguously describes how the bits of a pixel are stored in the up to 4 data planes...
Definition: pixdesc.h:69
ff_d3d12va_encode_close
int ff_d3d12va_encode_close(AVCodecContext *avctx)
Definition: d3d12va_encode.c:1842
FFALIGN
#define FFALIGN(x, a)
Definition: macros.h:78
ff_d3d12va_encode_receive_packet
int ff_d3d12va_encode_receive_packet(AVCodecContext *avctx, AVPacket *pkt)
Definition: d3d12va_encode.c:1698
AVCodecContext::priv_data
void * priv_data
Definition: avcodec.h:466
AV_OPT_TYPE_BOOL
@ AV_OPT_TYPE_BOOL
Underlying C type is int.
Definition: opt.h:327
av_freep
#define av_freep(p)
Definition: tableprint_vlc.h:35
D3D12VAEncodeType::profiles
const D3D12VAEncodeProfile * profiles
List of supported profiles.
Definition: d3d12va_encode.h:299
AVCodecContext::width
int width
picture width / height.
Definition: avcodec.h:600
FF_HW_PICTURE_TYPE_IDR
@ FF_HW_PICTURE_TYPE_IDR
Definition: hw_base_encode.h:39
d3d12va_encode_h264_set_level
static int d3d12va_encode_h264_set_level(AVCodecContext *avctx)
Definition: d3d12va_encode_h264.c:381
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:27
D3D12VAEncodeH264Level
Definition: d3d12va_encode_h264.c:58
profile_high_10
static const D3D12_VIDEO_ENCODER_PROFILE_H264 profile_high_10
Definition: d3d12va_encode_h264.c:87
HW_BASE_ENCODE_COMMON_OPTIONS
#define HW_BASE_ENCODE_COMMON_OPTIONS
Definition: hw_base_encode.h:243
d3d12va_encode_h264_configure
static int d3d12va_encode_h264_configure(AVCodecContext *avctx)
Definition: d3d12va_encode_h264.c:324
D3D12VAEncodeType
Definition: d3d12va_encode.h:295
hwcontext_d3d12va_internal.h
FFHWBaseEncodePicture::display_order
int64_t display_order
Definition: hw_base_encode.h:69
FF_HW_FLAG_B_PICTURE_REFERENCES
@ FF_HW_FLAG_B_PICTURE_REFERENCES
Definition: hw_base_encode.h:55
D3D12VAEncodeH264Context::profile
int profile
Definition: d3d12va_encode_h264.c:45
FF_HW_PICTURE_TYPE_P
@ FF_HW_PICTURE_TYPE_P
Definition: hw_base_encode.h:41
MAX_PICTURE_REFERENCES
#define MAX_PICTURE_REFERENCES
Definition: hw_base_encode.h:27
H264RawSPS
Definition: cbs_h264.h:102
H264RawPPS
Definition: cbs_h264.h:171