FFmpeg
libvpxenc.c
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2010, Google, Inc.
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 
21 /**
22  * @file
23  * VP8/9 encoder support via libvpx
24  */
25 
26 #include "config_components.h"
27 
28 #define VPX_DISABLE_CTRL_TYPECHECKS 1
29 #define VPX_CODEC_DISABLE_COMPAT 1
30 #include <vpx/vpx_encoder.h>
31 #include <vpx/vp8cx.h>
32 
33 #include "avcodec.h"
34 #include "codec_internal.h"
35 #include "encode.h"
36 #include "libavutil/avassert.h"
37 #include "libavutil/mem.h"
38 #include "libvpx.h"
39 #include "profiles.h"
40 #include "libavutil/avstring.h"
41 #include "libavutil/base64.h"
42 #include "libavutil/common.h"
43 #include "libavutil/cpu.h"
44 #include "libavutil/fifo.h"
45 #include "libavutil/internal.h"
46 #include "libavutil/intreadwrite.h"
47 #include "libavutil/mathematics.h"
48 #include "libavutil/opt.h"
49 #include "libavutil/pixdesc.h"
50 
51 #define IS_VP9(avctx) (CONFIG_LIBVPX_VP9_ENCODER && avctx->codec_id == AV_CODEC_ID_VP9)
52 #define IS_VP8(avctx) (CONFIG_LIBVPX_VP8_ENCODER && avctx->codec_id == AV_CODEC_ID_VP8)
53 
54 /**
55  * Portion of struct vpx_codec_cx_pkt from vpx_encoder.h.
56  * One encoded frame returned from the library.
57  */
58 struct FrameListData {
59  void *buf; /**< compressed data buffer */
60  size_t sz; /**< length of compressed data */
61  int64_t pts; /**< time stamp to show frame
62  (in timebase units) */
63  uint32_t flags; /**< flags for this frame */
64  uint64_t sse[4];
65  int have_sse; /**< true if we have pending sse[] */
66  struct FrameListData *next;
67 };
68 
69 typedef struct FrameData {
70  int64_t pts;
72 
73  void *frame_opaque;
75 
77 } FrameData;
78 
79 typedef struct VPxEncoderContext {
80  AVClass *class;
81  struct vpx_codec_ctx encoder;
82  struct vpx_image rawimg;
83  struct vpx_codec_ctx encoder_alpha;
84  struct vpx_image rawimg_alpha;
85  uint8_t is_alpha;
86  struct vpx_fixed_buf twopass_stats;
88  int deadline; //i.e., RT/GOOD/BEST
89  uint64_t sse[4];
90  int have_sse; /**< true if we have pending sse[] */
93 
94  int cpu_used;
95  int sharpness;
96  /**
97  * VP8 specific flags, see VP8F_* below.
98  */
99  int flags;
100 #define VP8F_ERROR_RESILIENT 0x00000001 ///< Enable measures appropriate for streaming over lossy links
101 #define VP8F_AUTO_ALT_REF 0x00000002 ///< Enable automatic alternate reference frame generation
102 
104 
108 
109  int tune;
110 
113  int crf;
118 
122 
123  // VP8-only
125 
126  // VP9-only
127  int lossless;
131  int aq_mode;
134  int vpx_cs;
135  float level;
136  int row_mt;
141 
142  // This FIFO is used to propagate various properties from frames to packets.
144  /**
145  * If the driver does not support ROI then warn the first time we
146  * encounter a frame with ROI side data.
147  */
149 #if CONFIG_LIBVPX_VP9_ENCODER && defined(VPX_CTRL_VP9E_SET_MAX_INTER_BITRATE_PCT)
150  vpx_svc_ref_frame_config_t ref_frame_config;
151 #endif
152 } VPxContext;
153 
154 /** String mappings for enum vp8e_enc_control_id */
155 static const char *const ctlidstr[] = {
156  [VP8E_SET_CPUUSED] = "VP8E_SET_CPUUSED",
157  [VP8E_SET_ENABLEAUTOALTREF] = "VP8E_SET_ENABLEAUTOALTREF",
158  [VP8E_SET_NOISE_SENSITIVITY] = "VP8E_SET_NOISE_SENSITIVITY",
159  [VP8E_SET_STATIC_THRESHOLD] = "VP8E_SET_STATIC_THRESHOLD",
160  [VP8E_SET_TOKEN_PARTITIONS] = "VP8E_SET_TOKEN_PARTITIONS",
161  [VP8E_SET_ARNR_MAXFRAMES] = "VP8E_SET_ARNR_MAXFRAMES",
162  [VP8E_SET_ARNR_STRENGTH] = "VP8E_SET_ARNR_STRENGTH",
163  [VP8E_SET_ARNR_TYPE] = "VP8E_SET_ARNR_TYPE",
164  [VP8E_SET_TUNING] = "VP8E_SET_TUNING",
165  [VP8E_SET_CQ_LEVEL] = "VP8E_SET_CQ_LEVEL",
166  [VP8E_SET_MAX_INTRA_BITRATE_PCT] = "VP8E_SET_MAX_INTRA_BITRATE_PCT",
167  [VP8E_SET_SHARPNESS] = "VP8E_SET_SHARPNESS",
168  [VP8E_SET_TEMPORAL_LAYER_ID] = "VP8E_SET_TEMPORAL_LAYER_ID",
169  [VP8E_SET_SCREEN_CONTENT_MODE] = "VP8E_SET_SCREEN_CONTENT_MODE",
170 #if CONFIG_LIBVPX_VP9_ENCODER
171  [VP9E_SET_LOSSLESS] = "VP9E_SET_LOSSLESS",
172  [VP9E_SET_TILE_COLUMNS] = "VP9E_SET_TILE_COLUMNS",
173  [VP9E_SET_TILE_ROWS] = "VP9E_SET_TILE_ROWS",
174  [VP9E_SET_FRAME_PARALLEL_DECODING] = "VP9E_SET_FRAME_PARALLEL_DECODING",
175  [VP9E_SET_AQ_MODE] = "VP9E_SET_AQ_MODE",
176  [VP9E_SET_COLOR_SPACE] = "VP9E_SET_COLOR_SPACE",
177  [VP9E_SET_SVC_LAYER_ID] = "VP9E_SET_SVC_LAYER_ID",
178 #if VPX_ENCODER_ABI_VERSION >= 12
179  [VP9E_SET_SVC_PARAMETERS] = "VP9E_SET_SVC_PARAMETERS",
180  [VP9E_SET_SVC_REF_FRAME_CONFIG] = "VP9E_SET_SVC_REF_FRAME_CONFIG",
181 #endif
182  [VP9E_SET_SVC] = "VP9E_SET_SVC",
183 #if VPX_ENCODER_ABI_VERSION >= 11
184  [VP9E_SET_COLOR_RANGE] = "VP9E_SET_COLOR_RANGE",
185 #endif
186 #if VPX_ENCODER_ABI_VERSION >= 12
187  [VP9E_SET_TARGET_LEVEL] = "VP9E_SET_TARGET_LEVEL",
188  [VP9E_GET_LEVEL] = "VP9E_GET_LEVEL",
189 #endif
190 #ifdef VPX_CTRL_VP9E_SET_ROW_MT
191  [VP9E_SET_ROW_MT] = "VP9E_SET_ROW_MT",
192 #endif
193 #ifdef VPX_CTRL_VP9E_SET_TUNE_CONTENT
194  [VP9E_SET_TUNE_CONTENT] = "VP9E_SET_TUNE_CONTENT",
195 #endif
196 #ifdef VPX_CTRL_VP9E_SET_TPL
197  [VP9E_SET_TPL] = "VP9E_SET_TPL",
198 #endif
199 #ifdef VPX_CTRL_VP9E_SET_MIN_GF_INTERVAL
200  [VP9E_SET_MIN_GF_INTERVAL] = "VP9E_SET_MIN_GF_INTERVAL",
201 #endif
202 #endif
203 };
204 
205 static av_cold void log_encoder_error(void *logctx, struct vpx_codec_ctx *encoder, const char *desc)
206 {
207  const char *error = vpx_codec_error(encoder);
208  const char *detail = vpx_codec_error_detail(encoder);
209 
210  av_log(logctx, AV_LOG_ERROR, "%s: %s\n", desc, error);
211  if (detail)
212  av_log(logctx, AV_LOG_ERROR, " Additional information: %s\n", detail);
213 }
214 
216  const struct vpx_codec_enc_cfg *cfg,
217  int level)
218 {
219  int width = -30;
220  int i;
221 
222  av_log(avctx, level, "vpx_codec_enc_cfg\n");
223  av_log(avctx, level, "generic settings\n"
224  " %*s%u\n %*s%u\n %*s%u\n %*s%u\n %*s%u\n"
225 #if CONFIG_LIBVPX_VP9_ENCODER
226  " %*s%u\n %*s%u\n"
227 #endif
228  " %*s{%u/%u}\n %*s%u\n %*s%d\n %*s%u\n",
229  width, "g_usage:", cfg->g_usage,
230  width, "g_threads:", cfg->g_threads,
231  width, "g_profile:", cfg->g_profile,
232  width, "g_w:", cfg->g_w,
233  width, "g_h:", cfg->g_h,
234 #if CONFIG_LIBVPX_VP9_ENCODER
235  width, "g_bit_depth:", cfg->g_bit_depth,
236  width, "g_input_bit_depth:", cfg->g_input_bit_depth,
237 #endif
238  width, "g_timebase:", cfg->g_timebase.num, cfg->g_timebase.den,
239  width, "g_error_resilient:", cfg->g_error_resilient,
240  width, "g_pass:", cfg->g_pass,
241  width, "g_lag_in_frames:", cfg->g_lag_in_frames);
242  av_log(avctx, level, "rate control settings\n"
243  " %*s%u\n %*s%u\n %*s%u\n %*s%u\n"
244  " %*s%d\n %*s%p(%zu)\n %*s%u\n",
245  width, "rc_dropframe_thresh:", cfg->rc_dropframe_thresh,
246  width, "rc_resize_allowed:", cfg->rc_resize_allowed,
247  width, "rc_resize_up_thresh:", cfg->rc_resize_up_thresh,
248  width, "rc_resize_down_thresh:", cfg->rc_resize_down_thresh,
249  width, "rc_end_usage:", cfg->rc_end_usage,
250  width, "rc_twopass_stats_in:", cfg->rc_twopass_stats_in.buf, cfg->rc_twopass_stats_in.sz,
251  width, "rc_target_bitrate:", cfg->rc_target_bitrate);
252  av_log(avctx, level, "quantizer settings\n"
253  " %*s%u\n %*s%u\n",
254  width, "rc_min_quantizer:", cfg->rc_min_quantizer,
255  width, "rc_max_quantizer:", cfg->rc_max_quantizer);
256  av_log(avctx, level, "bitrate tolerance\n"
257  " %*s%u\n %*s%u\n",
258  width, "rc_undershoot_pct:", cfg->rc_undershoot_pct,
259  width, "rc_overshoot_pct:", cfg->rc_overshoot_pct);
260  av_log(avctx, level, "temporal layering settings\n"
261  " %*s%u\n", width, "ts_number_layers:", cfg->ts_number_layers);
262  if (avctx->codec_id == AV_CODEC_ID_VP8) {
263  av_log(avctx, level,
264  "\n %*s", width, "ts_target_bitrate:");
265  for (i = 0; i < VPX_TS_MAX_LAYERS; i++)
266  av_log(avctx, level,
267  "%u ", cfg->ts_target_bitrate[i]);
268  }
269 #if (VPX_ENCODER_ABI_VERSION >= 12) && CONFIG_LIBVPX_VP9_ENCODER
270  if (avctx->codec_id == AV_CODEC_ID_VP9) {
271  av_log(avctx, level,
272  "\n %*s", width, "layer_target_bitrate:");
273  for (i = 0; i < VPX_TS_MAX_LAYERS; i++)
274  av_log(avctx, level,
275  "%u ", cfg->layer_target_bitrate[i]);
276  }
277 #endif
278  av_log(avctx, level, "\n");
279  av_log(avctx, level,
280  "\n %*s", width, "ts_rate_decimator:");
281  for (i = 0; i < VPX_TS_MAX_LAYERS; i++)
282  av_log(avctx, level, "%u ", cfg->ts_rate_decimator[i]);
283  av_log(avctx, level, "\n");
284  av_log(avctx, level,
285  "\n %*s%u\n", width, "ts_periodicity:", cfg->ts_periodicity);
286  av_log(avctx, level,
287  "\n %*s", width, "ts_layer_id:");
288  for (i = 0; i < VPX_TS_MAX_PERIODICITY; i++)
289  av_log(avctx, level, "%u ", cfg->ts_layer_id[i]);
290  av_log(avctx, level, "\n");
291  av_log(avctx, level, "decoder buffer model\n"
292  " %*s%u\n %*s%u\n %*s%u\n",
293  width, "rc_buf_sz:", cfg->rc_buf_sz,
294  width, "rc_buf_initial_sz:", cfg->rc_buf_initial_sz,
295  width, "rc_buf_optimal_sz:", cfg->rc_buf_optimal_sz);
296  av_log(avctx, level, "2 pass rate control settings\n"
297  " %*s%u\n %*s%u\n %*s%u\n",
298  width, "rc_2pass_vbr_bias_pct:", cfg->rc_2pass_vbr_bias_pct,
299  width, "rc_2pass_vbr_minsection_pct:", cfg->rc_2pass_vbr_minsection_pct,
300  width, "rc_2pass_vbr_maxsection_pct:", cfg->rc_2pass_vbr_maxsection_pct);
301 #if VPX_ENCODER_ABI_VERSION >= 14
302  av_log(avctx, level, " %*s%u\n",
303  width, "rc_2pass_vbr_corpus_complexity:", cfg->rc_2pass_vbr_corpus_complexity);
304 #endif
305  av_log(avctx, level, "keyframing settings\n"
306  " %*s%d\n %*s%u\n %*s%u\n",
307  width, "kf_mode:", cfg->kf_mode,
308  width, "kf_min_dist:", cfg->kf_min_dist,
309  width, "kf_max_dist:", cfg->kf_max_dist);
310  av_log(avctx, level, "\n");
311 }
312 
313 static void coded_frame_add(void *list, struct FrameListData *cx_frame)
314 {
315  struct FrameListData **p = list;
316 
317  while (*p)
318  p = &(*p)->next;
319  *p = cx_frame;
320  cx_frame->next = NULL;
321 }
322 
323 static av_cold void free_coded_frame(struct FrameListData *cx_frame)
324 {
325  av_freep(&cx_frame->buf);
326  av_freep(&cx_frame);
327 }
328 
330 {
331  struct FrameListData *p = list;
332 
333  while (p) {
334  list = list->next;
336  p = list;
337  }
338 }
339 
340 static void frame_data_uninit(FrameData *fd)
341 {
344 }
345 
346 static av_cold void fifo_free(AVFifo **fifo)
347 {
348  FrameData fd;
349  while (av_fifo_read(*fifo, &fd, 1) >= 0)
350  frame_data_uninit(&fd);
351  av_fifo_freep2(fifo);
352 }
353 
355 {
356  VPxContext *ctx = avctx->priv_data;
357 
358  return (ctx->drop_threshold > 0) || (ctx->screen_content_mode == 2);
359 }
360 
361 static int frame_data_submit(AVCodecContext *avctx, AVFifo *fifo,
362  const AVFrame *frame)
363 {
364  VPxContext *ctx = avctx->priv_data;
365  const struct vpx_codec_enc_cfg *enccfg = ctx->encoder.config.enc;
366 
367  FrameData fd = { .pts = frame->pts };
368  int ret;
369 
370  if (IS_VP9(avctx) &&
371  // Keep HDR10+ if it has bit depth higher than 8 and
372  // it has PQ trc (SMPTE2084).
373  enccfg->g_bit_depth > 8 && avctx->color_trc == AVCOL_TRC_SMPTE2084) {
375 
376  if (sd) {
377  fd.hdr10_plus = av_buffer_ref(sd->buf);
378  if (!fd.hdr10_plus)
379  return AVERROR(ENOMEM);
380  }
381  }
382 
383  fd.duration = frame->duration;
384  fd.frame_opaque = frame->opaque;
385  if (avctx->flags & AV_CODEC_FLAG_COPY_OPAQUE && frame->opaque_ref) {
386  ret = av_buffer_replace(&fd.frame_opaque_ref, frame->opaque_ref);
387  if (ret < 0)
388  goto fail;
389  }
390 
391  ret = av_fifo_write(fifo, &fd, 1);
392  if (ret == AVERROR(ENOSPC)) {
393  FrameData fd2;
394 
395  av_log(avctx, AV_LOG_WARNING, "FIFO full, will drop a front element\n");
396 
397  ret = av_fifo_read(fifo, &fd2, 1);
398  if (ret >= 0) {
399  frame_data_uninit(&fd2);
400  ret = av_fifo_write(fifo, &fd, 1);
401  }
402  }
403 
404  if (ret < 0)
405  goto fail;
406 
407  return 0;
408 fail:
409  frame_data_uninit(&fd);
410  return ret;
411 }
412 
413 static int frame_data_apply(AVCodecContext *avctx, AVFifo *fifo, AVPacket *pkt)
414 {
415  FrameData fd;
416  uint8_t *data;
417  int ret = 0;
418 
419  while (1) {
420  if (av_fifo_peek(fifo, &fd, 1, 0) < 0)
421  return 0;
422 
423  if (fd.pts == pkt->pts) {
424  break;
425  }
426 
427  if (!encoder_can_drop_frames(avctx)) {
428  av_log(avctx, AV_LOG_WARNING,
429  "Mismatching timestamps: libvpx %"PRId64" queued %"PRId64"; "
430  "this is a bug, please report it\n", pkt->pts, fd.pts);
431  goto skip;
432  }
433 
434  av_log(avctx, AV_LOG_DEBUG, "Dropped frame with pts %"PRId64"\n",
435  fd.pts);
436  av_fifo_drain2(fifo, 1);
437  frame_data_uninit(&fd);
438  }
439 
440  pkt->duration = fd.duration;
441  if (avctx->flags & AV_CODEC_FLAG_COPY_OPAQUE) {
442  pkt->opaque = fd.frame_opaque;
444  fd.frame_opaque_ref = NULL;
445  }
446 
447  if (fd.hdr10_plus) {
449  if (!data) {
450  ret = AVERROR(ENOMEM);
451  goto skip;
452  }
453 
454  memcpy(data, fd.hdr10_plus->data, fd.hdr10_plus->size);
455  }
456 
457 skip:
458  av_fifo_drain2(fifo, 1);
459  frame_data_uninit(&fd);
460 
461  return ret;
462 }
463 
465  enum vp8e_enc_control_id id, int val)
466 {
467  VPxContext *ctx = avctx->priv_data;
468  char buf[80];
469  int width = -30;
470  int res;
471 
472  snprintf(buf, sizeof(buf), "%s:", ctlidstr[id]);
473  av_log(avctx, AV_LOG_DEBUG, " %*s%d\n", width, buf, val);
474 
475  res = vpx_codec_control(&ctx->encoder, id, val);
476  if (res != VPX_CODEC_OK) {
477  snprintf(buf, sizeof(buf), "Failed to set %s codec control",
478  ctlidstr[id]);
479  log_encoder_error(avctx, &ctx->encoder, buf);
480  return AVERROR(EINVAL);
481  }
482 
483  if (ctx->is_alpha && id != VP9E_SET_COLOR_SPACE) {
484  int res_alpha = vpx_codec_control(&ctx->encoder_alpha, id, val);
485  if (res_alpha != VPX_CODEC_OK) {
486  snprintf(buf, sizeof(buf), "Failed to set %s alpha codec control",
487  ctlidstr[id]);
488  log_encoder_error(avctx, &ctx->encoder_alpha, buf);
489  return AVERROR(EINVAL);
490  }
491  }
492 
493  return 0;
494 }
495 
496 #if VPX_ENCODER_ABI_VERSION >= 12
497 static av_cold int codecctl_intp(AVCodecContext *avctx,
498  enum vp8e_enc_control_id id, int *val)
499 {
500  VPxContext *ctx = avctx->priv_data;
501  char buf[80];
502  int width = -30;
503  int res;
504 
505  snprintf(buf, sizeof(buf), "%s:", ctlidstr[id]);
506  av_log(avctx, AV_LOG_DEBUG, " %*s%d\n", width, buf, *val);
507 
508  res = vpx_codec_control(&ctx->encoder, id, val);
509  if (res != VPX_CODEC_OK) {
510  snprintf(buf, sizeof(buf), "Failed to set %s codec control",
511  ctlidstr[id]);
512  log_encoder_error(avctx, &ctx->encoder, buf);
513  return AVERROR(EINVAL);
514  }
515 
516  if (ctx->is_alpha) {
517  int res_alpha = vpx_codec_control(&ctx->encoder_alpha, id, val);
518  if (res_alpha != VPX_CODEC_OK) {
519  snprintf(buf, sizeof(buf), "Failed to set %s alpha codec control",
520  ctlidstr[id]);
521  log_encoder_error(avctx, &ctx->encoder_alpha, buf);
522  return AVERROR(EINVAL);
523  }
524  }
525 
526  return 0;
527 }
528 #endif
529 
530 static av_cold int vpx_free(AVCodecContext *avctx)
531 {
532  VPxContext *ctx = avctx->priv_data;
533 
534 #if VPX_ENCODER_ABI_VERSION >= 12
535  if (avctx->codec_id == AV_CODEC_ID_VP9 && ctx->level >= 0 &&
536  !(avctx->flags & AV_CODEC_FLAG_PASS1)) {
537  int level_out = 0;
538  if (!codecctl_intp(avctx, VP9E_GET_LEVEL, &level_out))
539  av_log(avctx, AV_LOG_INFO, "Encoded level %.1f\n", level_out * 0.1);
540  }
541 #endif
542 
543  av_freep(&ctx->ts_layer_flags);
544 
545  vpx_codec_destroy(&ctx->encoder);
546  if (ctx->is_alpha) {
547  vpx_codec_destroy(&ctx->encoder_alpha);
548  av_freep(&ctx->rawimg_alpha.planes[VPX_PLANE_U]);
549  av_freep(&ctx->rawimg_alpha.planes[VPX_PLANE_V]);
550  }
551  av_freep(&ctx->twopass_stats.buf);
552  av_freep(&avctx->stats_out);
553  free_frame_list(ctx->coded_frame_list);
554  free_frame_list(ctx->alpha_coded_frame_list);
555  if (ctx->fifo)
556  fifo_free(&ctx->fifo);
557  return 0;
558 }
559 
560 static void vp8_ts_parse_int_array(int *dest, char *value, size_t value_len, int max_entries)
561 {
562  int dest_idx = 0;
563  char *saveptr = NULL;
564  char *token = av_strtok(value, ",", &saveptr);
565 
566  while (token && dest_idx < max_entries) {
567  dest[dest_idx++] = strtoul(token, NULL, 10);
568  token = av_strtok(NULL, ",", &saveptr);
569  }
570 }
571 
572 #if CONFIG_LIBVPX_VP9_ENCODER && defined(VPX_CTRL_VP9E_SET_MAX_INTER_BITRATE_PCT)
573 static void vp8_ts_parse_int64_array(int64_t *dest, char *value, size_t value_len, int max_entries)
574 {
575  int dest_idx = 0;
576  char *saveptr = NULL;
577  char *token = av_strtok(value, ",", &saveptr);
578 
579  while (token && dest_idx < max_entries) {
580  dest[dest_idx++] = strtoull(token, NULL, 10);
581  token = av_strtok(NULL, ",", &saveptr);
582  }
583 }
584 #endif
585 
586 static void set_temporal_layer_pattern(int layering_mode, vpx_codec_enc_cfg_t *cfg,
587  int *layer_flags, int *flag_periodicity)
588 {
589  switch (layering_mode) {
590  case 2: {
591  /**
592  * 2-layers, 2-frame period.
593  */
594  static const int ids[2] = { 0, 1 };
595  cfg->ts_periodicity = 2;
596  *flag_periodicity = 2;
597  cfg->ts_number_layers = 2;
598  cfg->ts_rate_decimator[0] = 2;
599  cfg->ts_rate_decimator[1] = 1;
600  memcpy(cfg->ts_layer_id, ids, sizeof(ids));
601 
602  layer_flags[0] =
603  VP8_EFLAG_NO_REF_GF | VP8_EFLAG_NO_REF_ARF |
604  VP8_EFLAG_NO_UPD_GF | VP8_EFLAG_NO_UPD_ARF;
605  layer_flags[1] =
606  VP8_EFLAG_NO_UPD_ARF | VP8_EFLAG_NO_UPD_GF |
607  VP8_EFLAG_NO_UPD_LAST |
608  VP8_EFLAG_NO_REF_ARF | VP8_EFLAG_NO_REF_GF;
609  break;
610  }
611  case 3: {
612  /**
613  * 3-layers structure with one reference frame.
614  * This works same as temporal_layering_mode 3.
615  *
616  * 3-layers, 4-frame period.
617  */
618  static const int ids[4] = { 0, 2, 1, 2 };
619  cfg->ts_periodicity = 4;
620  *flag_periodicity = 4;
621  cfg->ts_number_layers = 3;
622  cfg->ts_rate_decimator[0] = 4;
623  cfg->ts_rate_decimator[1] = 2;
624  cfg->ts_rate_decimator[2] = 1;
625  memcpy(cfg->ts_layer_id, ids, sizeof(ids));
626 
627  /**
628  * 0=L, 1=GF, 2=ARF,
629  * Intra-layer prediction disabled.
630  */
631  layer_flags[0] =
632  VP8_EFLAG_NO_REF_GF | VP8_EFLAG_NO_REF_ARF |
633  VP8_EFLAG_NO_UPD_GF | VP8_EFLAG_NO_UPD_ARF;
634  layer_flags[1] =
635  VP8_EFLAG_NO_REF_GF | VP8_EFLAG_NO_REF_ARF |
636  VP8_EFLAG_NO_UPD_LAST | VP8_EFLAG_NO_UPD_GF |
637  VP8_EFLAG_NO_UPD_ARF;
638  layer_flags[2] =
639  VP8_EFLAG_NO_REF_GF | VP8_EFLAG_NO_REF_ARF |
640  VP8_EFLAG_NO_UPD_ARF | VP8_EFLAG_NO_UPD_LAST;
641  layer_flags[3] =
642  VP8_EFLAG_NO_REF_LAST | VP8_EFLAG_NO_REF_ARF |
643  VP8_EFLAG_NO_UPD_LAST | VP8_EFLAG_NO_UPD_GF |
644  VP8_EFLAG_NO_UPD_ARF;
645  break;
646  }
647  case 4: {
648  /**
649  * 3-layers structure.
650  * added dependency between the two TL2 frames (on top of case 3).
651  * 3-layers, 4-frame period.
652  */
653  static const int ids[4] = { 0, 2, 1, 2 };
654  cfg->ts_periodicity = 4;
655  *flag_periodicity = 4;
656  cfg->ts_number_layers = 3;
657  cfg->ts_rate_decimator[0] = 4;
658  cfg->ts_rate_decimator[1] = 2;
659  cfg->ts_rate_decimator[2] = 1;
660  memcpy(cfg->ts_layer_id, ids, sizeof(ids));
661 
662  /**
663  * 0=L, 1=GF, 2=ARF, Intra-layer prediction disabled.
664  */
665  layer_flags[0] =
666  VP8_EFLAG_NO_REF_GF | VP8_EFLAG_NO_REF_ARF |
667  VP8_EFLAG_NO_UPD_GF | VP8_EFLAG_NO_UPD_ARF;
668  layer_flags[1] =
669  VP8_EFLAG_NO_REF_GF | VP8_EFLAG_NO_REF_ARF |
670  VP8_EFLAG_NO_UPD_LAST | VP8_EFLAG_NO_UPD_GF;
671  layer_flags[2] =
672  VP8_EFLAG_NO_REF_GF | VP8_EFLAG_NO_REF_ARF |
673  VP8_EFLAG_NO_UPD_ARF | VP8_EFLAG_NO_UPD_LAST;
674  layer_flags[3] =
675  VP8_EFLAG_NO_REF_LAST |
676  VP8_EFLAG_NO_UPD_LAST | VP8_EFLAG_NO_UPD_GF |
677  VP8_EFLAG_NO_UPD_ARF;
678  break;
679  }
680  default:
681  /**
682  * do not change the layer_flags or the flag_periodicity in this case;
683  * it might be that the code is using external flags to be used.
684  */
685  break;
686 
687  }
688 }
689 
690 static int vpx_ts_param_parse(VPxContext *ctx, struct vpx_codec_enc_cfg *enccfg,
691  char *key, char *value, enum AVCodecID codec_id)
692 {
693  size_t value_len = strlen(value);
694  int ts_layering_mode = 0;
695 
696  if (!value_len)
697  return -1;
698 
699  if (!strcmp(key, "ts_number_layers"))
700  enccfg->ts_number_layers = strtoul(value, &value, 10);
701  else if (!strcmp(key, "ts_target_bitrate")) {
702  if (codec_id == AV_CODEC_ID_VP8)
703  vp8_ts_parse_int_array(enccfg->ts_target_bitrate, value, value_len, VPX_TS_MAX_LAYERS);
704 #if (VPX_ENCODER_ABI_VERSION >= 12) && CONFIG_LIBVPX_VP9_ENCODER
705  if (codec_id == AV_CODEC_ID_VP9)
706  vp8_ts_parse_int_array(enccfg->layer_target_bitrate, value, value_len, VPX_TS_MAX_LAYERS);
707 #endif
708  } else if (!strcmp(key, "ts_rate_decimator")) {
709  vp8_ts_parse_int_array(enccfg->ts_rate_decimator, value, value_len, VPX_TS_MAX_LAYERS);
710  } else if (!strcmp(key, "ts_periodicity")) {
711  enccfg->ts_periodicity = strtoul(value, &value, 10);
712  } else if (!strcmp(key, "ts_layer_id")) {
713  vp8_ts_parse_int_array(enccfg->ts_layer_id, value, value_len, VPX_TS_MAX_PERIODICITY);
714  } else if (!strcmp(key, "ts_layering_mode")) {
715  /* option for pre-defined temporal structures in function set_temporal_layer_pattern. */
716  ts_layering_mode = strtoul(value, &value, 10);
717  }
718 
719 #if (VPX_ENCODER_ABI_VERSION >= 12) && CONFIG_LIBVPX_VP9_ENCODER
720  enccfg->temporal_layering_mode = VP9E_TEMPORAL_LAYERING_MODE_BYPASS; // only bypass mode is supported for now.
721  enccfg->ss_number_layers = 1; // TODO: add spatial scalability support.
722 #endif
723  if (ts_layering_mode) {
724  // make sure the ts_layering_mode comes at the end of the ts_parameter string to ensure that
725  // correct configuration is done.
726  ctx->ts_layer_flags = av_malloc_array(VPX_TS_MAX_PERIODICITY, sizeof(*ctx->ts_layer_flags));
727  set_temporal_layer_pattern(ts_layering_mode, enccfg, ctx->ts_layer_flags, &enccfg->ts_periodicity);
728  }
729 
730  return 0;
731 }
732 
733 #if CONFIG_LIBVPX_VP9_ENCODER && defined(VPX_CTRL_VP9E_SET_MAX_INTER_BITRATE_PCT)
734 static int vpx_ref_frame_config_set_value(vpx_svc_ref_frame_config_t *ref_frame_config,
735  int ss_number_layers, char *key, char *value)
736 {
737  size_t value_len = strlen(value);
738 
739  if (!value_len)
740  return AVERROR(EINVAL);
741 
742  if (!strcmp(key, "rfc_update_buffer_slot")) {
743  vp8_ts_parse_int_array(ref_frame_config->update_buffer_slot, value, value_len, ss_number_layers);
744  } else if (!strcmp(key, "rfc_update_last")) {
745  vp8_ts_parse_int_array(ref_frame_config->update_last, value, value_len, ss_number_layers);
746  } else if (!strcmp(key, "rfc_update_golden")) {
747  vp8_ts_parse_int_array(ref_frame_config->update_golden, value, value_len, ss_number_layers);
748  } else if (!strcmp(key, "rfc_update_alt_ref")) {
749  vp8_ts_parse_int_array(ref_frame_config->update_alt_ref, value, value_len, ss_number_layers);
750  } else if (!strcmp(key, "rfc_lst_fb_idx")) {
751  vp8_ts_parse_int_array(ref_frame_config->lst_fb_idx, value, value_len, ss_number_layers);
752  } else if (!strcmp(key, "rfc_gld_fb_idx")) {
753  vp8_ts_parse_int_array(ref_frame_config->gld_fb_idx, value, value_len, ss_number_layers);
754  } else if (!strcmp(key, "rfc_alt_fb_idx")) {
755  vp8_ts_parse_int_array(ref_frame_config->alt_fb_idx, value, value_len, ss_number_layers);
756  } else if (!strcmp(key, "rfc_reference_last")) {
757  vp8_ts_parse_int_array(ref_frame_config->reference_last, value, value_len, ss_number_layers);
758  } else if (!strcmp(key, "rfc_reference_golden")) {
759  vp8_ts_parse_int_array(ref_frame_config->reference_golden, value, value_len, ss_number_layers);
760  } else if (!strcmp(key, "rfc_reference_alt_ref")) {
761  vp8_ts_parse_int_array(ref_frame_config->reference_alt_ref, value, value_len, ss_number_layers);
762  } else if (!strcmp(key, "rfc_reference_duration")) {
763  vp8_ts_parse_int64_array(ref_frame_config->duration, value, value_len, ss_number_layers);
764  }
765 
766  return 0;
767 }
768 
769 static int vpx_parse_ref_frame_config_element(vpx_svc_ref_frame_config_t *ref_frame_config,
770  int ss_number_layers, const char **buf)
771 {
772  const char key_val_sep[] = "=";
773  const char pairs_sep[] = ":";
774  char *key = av_get_token(buf, key_val_sep);
775  char *val = NULL;
776  int ret;
777 
778  if (key && *key && strspn(*buf, key_val_sep)) {
779  (*buf)++;
780  val = av_get_token(buf, pairs_sep);
781  }
782 
783  if (key && *key && val && *val)
784  ret = vpx_ref_frame_config_set_value(ref_frame_config, ss_number_layers, key, val);
785  else
786  ret = AVERROR(EINVAL);
787 
788  av_freep(&key);
789  av_freep(&val);
790 
791  return ret;
792 }
793 
794 static int vpx_parse_ref_frame_config(vpx_svc_ref_frame_config_t *ref_frame_config,
795  int ss_number_layers, const char *str)
796 {
797  int ret = 0;
798 
799  while (*str) {
800  ret =
801  vpx_parse_ref_frame_config_element(ref_frame_config, ss_number_layers, &str);
802  if (ret < 0)
803  return ret;
804 
805  if (*str)
806  str++;
807  }
808 
809  return ret;
810 }
811 #endif
812 
813 #if CONFIG_LIBVPX_VP9_ENCODER
814 static int set_pix_fmt(AVCodecContext *avctx, vpx_codec_caps_t codec_caps,
815  struct vpx_codec_enc_cfg *enccfg, vpx_codec_flags_t *flags,
816  vpx_img_fmt_t *img_fmt)
817 {
818  VPxContext *ctx = avctx->priv_data;
820  enccfg->g_bit_depth = enccfg->g_input_bit_depth = desc->comp[0].depth;
821  switch (avctx->pix_fmt) {
822  case AV_PIX_FMT_YUV420P:
823  case AV_PIX_FMT_YUVA420P:
824  enccfg->g_profile = 0;
825  *img_fmt = VPX_IMG_FMT_I420;
826  return 0;
827  case AV_PIX_FMT_YUV422P:
828  case AV_PIX_FMT_YUVA422P:
829  enccfg->g_profile = 1;
830  *img_fmt = VPX_IMG_FMT_I422;
831  return 0;
832  case AV_PIX_FMT_YUV440P:
833  enccfg->g_profile = 1;
834  *img_fmt = VPX_IMG_FMT_I440;
835  return 0;
836  case AV_PIX_FMT_GBRP:
837  case AV_PIX_FMT_GBRAP:
838  ctx->vpx_cs = VPX_CS_SRGB;
839  case AV_PIX_FMT_YUV444P:
840  case AV_PIX_FMT_YUVA444P:
841  if (avctx->colorspace == AVCOL_SPC_RGB)
842  ctx->vpx_cs = VPX_CS_SRGB;
843  enccfg->g_profile = 1;
844  *img_fmt = VPX_IMG_FMT_I444;
845  return 0;
849  if (codec_caps & VPX_CODEC_CAP_HIGHBITDEPTH) {
850  enccfg->g_profile = 2;
851  *img_fmt = VPX_IMG_FMT_I42016;
852  *flags |= VPX_CODEC_USE_HIGHBITDEPTH;
853  return 0;
854  }
855  break;
859  if (codec_caps & VPX_CODEC_CAP_HIGHBITDEPTH) {
860  enccfg->g_profile = 3;
861  *img_fmt = VPX_IMG_FMT_I42216;
862  *flags |= VPX_CODEC_USE_HIGHBITDEPTH;
863  return 0;
864  }
865  break;
868  if (codec_caps & VPX_CODEC_CAP_HIGHBITDEPTH) {
869  enccfg->g_profile = 3;
870  *img_fmt = VPX_IMG_FMT_I44016;
871  *flags |= VPX_CODEC_USE_HIGHBITDEPTH;
872  return 0;
873  }
874  break;
875  case AV_PIX_FMT_GBRP10:
876  case AV_PIX_FMT_GBRAP10:
877  case AV_PIX_FMT_GBRP12:
878  case AV_PIX_FMT_GBRAP12:
879  ctx->vpx_cs = VPX_CS_SRGB;
884  if (avctx->colorspace == AVCOL_SPC_RGB)
885  ctx->vpx_cs = VPX_CS_SRGB;
886  if (codec_caps & VPX_CODEC_CAP_HIGHBITDEPTH) {
887  enccfg->g_profile = 3;
888  *img_fmt = VPX_IMG_FMT_I44416;
889  *flags |= VPX_CODEC_USE_HIGHBITDEPTH;
890  return 0;
891  }
892  break;
893  default:
894  break;
895  }
896  av_log(avctx, AV_LOG_ERROR, "Unsupported pixel format.\n");
897  return AVERROR_INVALIDDATA;
898 }
899 
900 static int set_colorspace(AVCodecContext *avctx)
901 {
902  enum vpx_color_space vpx_cs;
903  VPxContext *ctx = avctx->priv_data;
904 
905  if (ctx->vpx_cs) {
906  vpx_cs = ctx->vpx_cs;
907  } else {
908  switch (avctx->colorspace) {
909  case AVCOL_SPC_RGB:
910  av_log(avctx, AV_LOG_ERROR,
911  "RGB colorspace is not compatible with pixel format %s.\n",
912  av_get_pix_fmt_name(avctx->pix_fmt));
913  return AVERROR(EINVAL);
914  case AVCOL_SPC_BT709: vpx_cs = VPX_CS_BT_709; break;
915  case AVCOL_SPC_UNSPECIFIED: vpx_cs = VPX_CS_UNKNOWN; break;
916  case AVCOL_SPC_RESERVED: vpx_cs = VPX_CS_RESERVED; break;
917  case AVCOL_SPC_BT470BG: vpx_cs = VPX_CS_BT_601; break;
918  case AVCOL_SPC_SMPTE170M: vpx_cs = VPX_CS_SMPTE_170; break;
919  case AVCOL_SPC_SMPTE240M: vpx_cs = VPX_CS_SMPTE_240; break;
920  case AVCOL_SPC_BT2020_NCL: vpx_cs = VPX_CS_BT_2020; break;
921  default:
922  av_log(avctx, AV_LOG_WARNING, "Unsupported colorspace (%d)\n",
923  avctx->colorspace);
924  return 0;
925  }
926  }
927  codecctl_int(avctx, VP9E_SET_COLOR_SPACE, vpx_cs);
928  return 0;
929 }
930 
931 #if VPX_ENCODER_ABI_VERSION >= 11
932 static void set_color_range(AVCodecContext *avctx)
933 {
934  enum vpx_color_range vpx_cr;
935  switch (avctx->color_range) {
937  case AVCOL_RANGE_MPEG: vpx_cr = VPX_CR_STUDIO_RANGE; break;
938  case AVCOL_RANGE_JPEG: vpx_cr = VPX_CR_FULL_RANGE; break;
939  default:
940  av_log(avctx, AV_LOG_WARNING, "Unsupported color range (%d)\n",
941  avctx->color_range);
942  return;
943  }
944 
945  codecctl_int(avctx, VP9E_SET_COLOR_RANGE, vpx_cr);
946 }
947 #endif
948 #endif
949 
950 /**
951  * Set the target bitrate to VPX library default. Also set CRF to 32 if needed.
952  */
953 static void set_vp8_defaults(AVCodecContext *avctx,
954  struct vpx_codec_enc_cfg *enccfg)
955 {
956  VPxContext *ctx = avctx->priv_data;
957  av_assert0(!avctx->bit_rate);
958  avctx->bit_rate = enccfg->rc_target_bitrate * 1000;
959  if (enccfg->rc_end_usage == VPX_CQ) {
960  av_log(avctx, AV_LOG_WARNING,
961  "Bitrate not specified for constrained quality mode, using default of %dkbit/sec\n",
962  enccfg->rc_target_bitrate);
963  } else {
964  enccfg->rc_end_usage = VPX_CQ;
965  ctx->crf = 32;
966  av_log(avctx, AV_LOG_WARNING,
967  "Neither bitrate nor constrained quality specified, using default CRF of %d and bitrate of %dkbit/sec\n",
968  ctx->crf, enccfg->rc_target_bitrate);
969  }
970 }
971 
972 
973 #if CONFIG_LIBVPX_VP9_ENCODER
974 /**
975  * Keep the target bitrate at 0 to engage constant quality mode. If CRF is not
976  * set, use 32.
977  */
978 static void set_vp9_defaults(AVCodecContext *avctx,
979  struct vpx_codec_enc_cfg *enccfg)
980 {
981  VPxContext *ctx = avctx->priv_data;
982  av_assert0(!avctx->bit_rate);
983  if (enccfg->rc_end_usage != VPX_Q && ctx->lossless < 0) {
984  enccfg->rc_end_usage = VPX_Q;
985  ctx->crf = 32;
986  av_log(avctx, AV_LOG_WARNING,
987  "Neither bitrate nor constrained quality specified, using default CRF of %d\n",
988  ctx->crf);
989  }
990 }
991 #endif
992 
993 /**
994  * Called when the bitrate is not set. It sets appropriate default values for
995  * bitrate and CRF.
996  */
997 static void set_vpx_defaults(AVCodecContext *avctx,
998  struct vpx_codec_enc_cfg *enccfg)
999 {
1000  av_assert0(!avctx->bit_rate);
1001 #if CONFIG_LIBVPX_VP9_ENCODER
1002  if (avctx->codec_id == AV_CODEC_ID_VP9) {
1003  set_vp9_defaults(avctx, enccfg);
1004  return;
1005  }
1006 #endif
1007  set_vp8_defaults(avctx, enccfg);
1008 }
1009 
1010 static av_cold int vpx_init(AVCodecContext *avctx,
1011  const struct vpx_codec_iface *iface)
1012 {
1013  VPxContext *ctx = avctx->priv_data;
1014  struct vpx_codec_enc_cfg enccfg = { 0 };
1015  struct vpx_codec_enc_cfg enccfg_alpha;
1016  vpx_codec_flags_t flags = (avctx->flags & AV_CODEC_FLAG_PSNR) ? VPX_CODEC_USE_PSNR : 0;
1017  AVCPBProperties *cpb_props;
1018  int res;
1019  vpx_img_fmt_t img_fmt = VPX_IMG_FMT_I420;
1020 #if CONFIG_LIBVPX_VP9_ENCODER
1021  vpx_codec_caps_t codec_caps = vpx_codec_get_caps(iface);
1022  vpx_svc_extra_cfg_t svc_params;
1023 #endif
1024  const AVDictionaryEntry* en = NULL;
1026 
1027  av_log(avctx, AV_LOG_INFO, "%s\n", vpx_codec_version_str());
1028  av_log(avctx, AV_LOG_VERBOSE, "%s\n", vpx_codec_build_config());
1029 
1030  if (desc && (desc->flags & AV_PIX_FMT_FLAG_ALPHA)) {
1031  ctx->is_alpha = 1;
1033  av_log(avctx, AV_LOG_ERROR,
1034  "Pixel format '%s' is not widely supported. "
1035  "Use -strict experimental to use it anyway, or use 'yuva420p' pixel format instead.\n",
1036  av_get_pix_fmt_name(avctx->pix_fmt));
1037  return AVERROR(EINVAL);
1038  }
1039  }
1040 
1041  if ((res = vpx_codec_enc_config_default(iface, &enccfg, 0)) != VPX_CODEC_OK) {
1042  av_log(avctx, AV_LOG_ERROR, "Failed to get config: %s\n",
1043  vpx_codec_err_to_string(res));
1044  return AVERROR(EINVAL);
1045  }
1046 
1047  ctx->fifo = av_fifo_alloc2(1, sizeof(FrameData), AV_FIFO_FLAG_AUTO_GROW);
1048  if (!ctx->fifo)
1049  return AVERROR(ENOMEM);
1050 
1051 #if CONFIG_LIBVPX_VP9_ENCODER
1052  if (avctx->codec_id == AV_CODEC_ID_VP9) {
1053  if (set_pix_fmt(avctx, codec_caps, &enccfg, &flags, &img_fmt))
1054  return AVERROR(EINVAL);
1055  }
1056 #endif
1057 
1058  if(!avctx->bit_rate)
1059  if(avctx->rc_max_rate || avctx->rc_buffer_size || avctx->rc_initial_buffer_occupancy) {
1060  av_log( avctx, AV_LOG_ERROR, "Rate control parameters set without a bitrate\n");
1061  return AVERROR(EINVAL);
1062  }
1063 
1064  dump_enc_cfg(avctx, &enccfg, AV_LOG_DEBUG);
1065 
1066  enccfg.g_w = avctx->width;
1067  enccfg.g_h = avctx->height;
1068  enccfg.g_timebase.num = avctx->time_base.num;
1069  enccfg.g_timebase.den = avctx->time_base.den;
1070  enccfg.g_threads =
1072  enccfg.g_lag_in_frames= ctx->lag_in_frames;
1073 
1074  if (avctx->flags & AV_CODEC_FLAG_PASS1)
1075  enccfg.g_pass = VPX_RC_FIRST_PASS;
1076  else if (avctx->flags & AV_CODEC_FLAG_PASS2)
1077  enccfg.g_pass = VPX_RC_LAST_PASS;
1078  else
1079  enccfg.g_pass = VPX_RC_ONE_PASS;
1080 
1081  if (avctx->rc_min_rate == avctx->rc_max_rate &&
1082  avctx->rc_min_rate == avctx->bit_rate && avctx->bit_rate) {
1083  enccfg.rc_end_usage = VPX_CBR;
1084  } else if (ctx->crf >= 0) {
1085  enccfg.rc_end_usage = VPX_CQ;
1086 #if CONFIG_LIBVPX_VP9_ENCODER
1087  if (!avctx->bit_rate && avctx->codec_id == AV_CODEC_ID_VP9)
1088  enccfg.rc_end_usage = VPX_Q;
1089 #endif
1090  }
1091 
1092  if (avctx->bit_rate) {
1093  enccfg.rc_target_bitrate = av_rescale_rnd(avctx->bit_rate, 1, 1000,
1095 #if CONFIG_LIBVPX_VP9_ENCODER
1096  enccfg.ss_target_bitrate[0] = enccfg.rc_target_bitrate;
1097 #endif
1098  } else {
1099  // Set bitrate to default value. Also sets CRF to default if needed.
1100  set_vpx_defaults(avctx, &enccfg);
1101  }
1102 
1103  if (avctx->codec_id == AV_CODEC_ID_VP9 && ctx->lossless == 1) {
1104  enccfg.rc_min_quantizer =
1105  enccfg.rc_max_quantizer = 0;
1106  } else {
1107  if (avctx->qmin >= 0)
1108  enccfg.rc_min_quantizer = avctx->qmin;
1109  if (avctx->qmax >= 0)
1110  enccfg.rc_max_quantizer = avctx->qmax;
1111  }
1112 
1113  if (enccfg.rc_end_usage == VPX_CQ
1114 #if CONFIG_LIBVPX_VP9_ENCODER
1115  || enccfg.rc_end_usage == VPX_Q
1116 #endif
1117  ) {
1118  if (ctx->crf < enccfg.rc_min_quantizer || ctx->crf > enccfg.rc_max_quantizer) {
1119  av_log(avctx, AV_LOG_ERROR,
1120  "CQ level %d must be between minimum and maximum quantizer value (%d-%d)\n",
1121  ctx->crf, enccfg.rc_min_quantizer, enccfg.rc_max_quantizer);
1122  return AVERROR(EINVAL);
1123  }
1124  }
1125 
1126  enccfg.rc_dropframe_thresh = ctx->drop_threshold;
1127 
1128  //0-100 (0 => CBR, 100 => VBR)
1129  enccfg.rc_2pass_vbr_bias_pct = lrint(avctx->qcompress * 100);
1130  if (avctx->bit_rate)
1131  enccfg.rc_2pass_vbr_minsection_pct =
1132  avctx->rc_min_rate * 100LL / avctx->bit_rate;
1133  if (avctx->rc_max_rate)
1134  enccfg.rc_2pass_vbr_maxsection_pct =
1135  avctx->rc_max_rate * 100LL / avctx->bit_rate;
1136 #if CONFIG_LIBVPX_VP9_ENCODER
1137  if (avctx->codec_id == AV_CODEC_ID_VP9) {
1138 #if VPX_ENCODER_ABI_VERSION >= 14
1139  if (ctx->corpus_complexity >= 0)
1140  enccfg.rc_2pass_vbr_corpus_complexity = ctx->corpus_complexity;
1141 #endif
1142  }
1143 #endif
1144 
1145  if (avctx->rc_buffer_size)
1146  enccfg.rc_buf_sz =
1147  avctx->rc_buffer_size * 1000LL / avctx->bit_rate;
1148  if (avctx->rc_initial_buffer_occupancy)
1149  enccfg.rc_buf_initial_sz =
1150  avctx->rc_initial_buffer_occupancy * 1000LL / avctx->bit_rate;
1151  enccfg.rc_buf_optimal_sz = enccfg.rc_buf_sz * 5 / 6;
1152  if (ctx->rc_undershoot_pct >= 0)
1153  enccfg.rc_undershoot_pct = ctx->rc_undershoot_pct;
1154  if (ctx->rc_overshoot_pct >= 0)
1155  enccfg.rc_overshoot_pct = ctx->rc_overshoot_pct;
1156 
1157  //_enc_init() will balk if kf_min_dist differs from max w/VPX_KF_AUTO
1158  if (avctx->keyint_min >= 0 && avctx->keyint_min == avctx->gop_size)
1159  enccfg.kf_min_dist = avctx->keyint_min;
1160  if (avctx->gop_size >= 0)
1161  enccfg.kf_max_dist = avctx->gop_size;
1162 
1163  if (enccfg.g_pass == VPX_RC_FIRST_PASS)
1164  enccfg.g_lag_in_frames = 0;
1165  else if (enccfg.g_pass == VPX_RC_LAST_PASS) {
1166  int decode_size, ret;
1167 
1168  if (!avctx->stats_in) {
1169  av_log(avctx, AV_LOG_ERROR, "No stats file for second pass\n");
1170  return AVERROR_INVALIDDATA;
1171  }
1172 
1173  ctx->twopass_stats.sz = strlen(avctx->stats_in) * 3 / 4;
1174  ret = av_reallocp(&ctx->twopass_stats.buf, ctx->twopass_stats.sz);
1175  if (ret < 0) {
1176  av_log(avctx, AV_LOG_ERROR,
1177  "Stat buffer alloc (%zu bytes) failed\n",
1178  ctx->twopass_stats.sz);
1179  ctx->twopass_stats.sz = 0;
1180  return ret;
1181  }
1182  decode_size = av_base64_decode(ctx->twopass_stats.buf, avctx->stats_in,
1183  ctx->twopass_stats.sz);
1184  if (decode_size < 0) {
1185  av_log(avctx, AV_LOG_ERROR, "Stat buffer decode failed\n");
1186  return AVERROR_INVALIDDATA;
1187  }
1188 
1189  ctx->twopass_stats.sz = decode_size;
1190  enccfg.rc_twopass_stats_in = ctx->twopass_stats;
1191  }
1192 
1193  /* 0-3: For non-zero values the encoder increasingly optimizes for reduced
1194  complexity playback on low powered devices at the expense of encode
1195  quality. */
1196  if (avctx->profile != AV_PROFILE_UNKNOWN)
1197  enccfg.g_profile = avctx->profile;
1198 
1199  enccfg.g_error_resilient = ctx->error_resilient || ctx->flags & VP8F_ERROR_RESILIENT;
1200 
1201  while ((en = av_dict_iterate(ctx->vpx_ts_parameters, en))) {
1202  if (vpx_ts_param_parse(ctx, &enccfg, en->key, en->value, avctx->codec_id) < 0)
1203  av_log(avctx, AV_LOG_WARNING,
1204  "Error parsing option '%s = %s'.\n",
1205  en->key, en->value);
1206  }
1207 
1208  /* Construct Encoder Context */
1209  res = vpx_codec_enc_init(&ctx->encoder, iface, &enccfg, flags);
1210  if (res != VPX_CODEC_OK) {
1211  dump_enc_cfg(avctx, &enccfg, AV_LOG_WARNING);
1212  log_encoder_error(avctx, &ctx->encoder, "Failed to initialize encoder");
1213  return AVERROR(EINVAL);
1214  }
1215  dump_enc_cfg(avctx, &enccfg, AV_LOG_DEBUG);
1216 
1217 #if CONFIG_LIBVPX_VP9_ENCODER
1218  if (avctx->codec_id == AV_CODEC_ID_VP9 && enccfg.ts_number_layers > 1) {
1219  memset(&svc_params, 0, sizeof(svc_params));
1220  for (int i = 0; i < enccfg.ts_number_layers; ++i) {
1221  svc_params.max_quantizers[i] = enccfg.rc_max_quantizer;
1222  svc_params.min_quantizers[i] = enccfg.rc_min_quantizer;
1223  }
1224  svc_params.scaling_factor_num[0] = enccfg.g_h;
1225  svc_params.scaling_factor_den[0] = enccfg.g_h;
1226 #if VPX_ENCODER_ABI_VERSION >= 12
1227  codecctl_int(avctx, VP9E_SET_SVC, 1);
1228  codecctl_intp(avctx, VP9E_SET_SVC_PARAMETERS, (int *)&svc_params);
1229 #endif
1230  }
1231 #endif
1232  if (ctx->is_alpha) {
1233  enccfg_alpha = enccfg;
1234  enccfg_alpha.g_profile = (flags & VPX_CODEC_USE_HIGHBITDEPTH) ? 2 : 0;
1235  res = vpx_codec_enc_init(&ctx->encoder_alpha, iface, &enccfg_alpha, flags);
1236  if (res != VPX_CODEC_OK) {
1237  log_encoder_error(avctx, &ctx->encoder_alpha, "Failed to initialize alpha encoder");
1238  return AVERROR(EINVAL);
1239  }
1240  }
1241 
1242  //codec control failures are currently treated only as warnings
1243  av_log(avctx, AV_LOG_DEBUG, "vpx_codec_control\n");
1244  codecctl_int(avctx, VP8E_SET_CPUUSED, ctx->cpu_used);
1245  if (ctx->flags & VP8F_AUTO_ALT_REF)
1246  ctx->auto_alt_ref = 1;
1247  if (ctx->auto_alt_ref >= 0)
1248  codecctl_int(avctx, VP8E_SET_ENABLEAUTOALTREF,
1249  avctx->codec_id == AV_CODEC_ID_VP8 ? !!ctx->auto_alt_ref : ctx->auto_alt_ref);
1250  if (ctx->arnr_max_frames >= 0)
1251  codecctl_int(avctx, VP8E_SET_ARNR_MAXFRAMES, ctx->arnr_max_frames);
1252  if (ctx->arnr_strength >= 0)
1253  codecctl_int(avctx, VP8E_SET_ARNR_STRENGTH, ctx->arnr_strength);
1254  if (ctx->arnr_type >= 0)
1255  codecctl_int(avctx, VP8E_SET_ARNR_TYPE, ctx->arnr_type);
1256  if (ctx->tune >= 0)
1257  codecctl_int(avctx, VP8E_SET_TUNING, ctx->tune);
1258 
1259  if (ctx->auto_alt_ref && ctx->is_alpha && avctx->codec_id == AV_CODEC_ID_VP8) {
1260  av_log(avctx, AV_LOG_ERROR, "Transparency encoding with auto_alt_ref does not work\n");
1261  return AVERROR(EINVAL);
1262  }
1263 
1264  if (ctx->sharpness >= 0)
1265  codecctl_int(avctx, VP8E_SET_SHARPNESS, ctx->sharpness);
1266 
1267  if (CONFIG_LIBVPX_VP8_ENCODER && avctx->codec_id == AV_CODEC_ID_VP8) {
1268  codecctl_int(avctx, VP8E_SET_NOISE_SENSITIVITY, ctx->noise_sensitivity);
1269  codecctl_int(avctx, VP8E_SET_TOKEN_PARTITIONS, av_log2(avctx->slices));
1270  }
1271  codecctl_int(avctx, VP8E_SET_STATIC_THRESHOLD, ctx->static_thresh);
1272  if (ctx->crf >= 0)
1273  codecctl_int(avctx, VP8E_SET_CQ_LEVEL, ctx->crf);
1274  if (ctx->max_intra_rate >= 0)
1275  codecctl_int(avctx, VP8E_SET_MAX_INTRA_BITRATE_PCT, ctx->max_intra_rate);
1276 
1277 #if CONFIG_LIBVPX_VP9_ENCODER
1278  if (avctx->codec_id == AV_CODEC_ID_VP9) {
1279  if (ctx->lossless >= 0)
1280  codecctl_int(avctx, VP9E_SET_LOSSLESS, ctx->lossless);
1281  if (ctx->tile_columns >= 0)
1282  codecctl_int(avctx, VP9E_SET_TILE_COLUMNS, ctx->tile_columns);
1283  if (ctx->tile_rows >= 0)
1284  codecctl_int(avctx, VP9E_SET_TILE_ROWS, ctx->tile_rows);
1285  if (ctx->frame_parallel >= 0)
1286  codecctl_int(avctx, VP9E_SET_FRAME_PARALLEL_DECODING, ctx->frame_parallel);
1287  if (ctx->aq_mode >= 0)
1288  codecctl_int(avctx, VP9E_SET_AQ_MODE, ctx->aq_mode);
1289  res = set_colorspace(avctx);
1290  if (res < 0)
1291  return res;
1292 #if VPX_ENCODER_ABI_VERSION >= 11
1293  set_color_range(avctx);
1294 #endif
1295 #if VPX_ENCODER_ABI_VERSION >= 12
1296  codecctl_int(avctx, VP9E_SET_TARGET_LEVEL, ctx->level < 0 ? 255 : lrint(ctx->level * 10));
1297 #endif
1298 #ifdef VPX_CTRL_VP9E_SET_ROW_MT
1299  if (ctx->row_mt >= 0)
1300  codecctl_int(avctx, VP9E_SET_ROW_MT, ctx->row_mt);
1301 #endif
1302 #ifdef VPX_CTRL_VP9E_SET_TUNE_CONTENT
1303  if (ctx->tune_content >= 0)
1304  codecctl_int(avctx, VP9E_SET_TUNE_CONTENT, ctx->tune_content);
1305 #endif
1306 #ifdef VPX_CTRL_VP9E_SET_TPL
1307  if (ctx->tpl_model >= 0)
1308  codecctl_int(avctx, VP9E_SET_TPL, ctx->tpl_model);
1309 #endif
1310 #ifdef VPX_CTRL_VP9E_SET_MIN_GF_INTERVAL
1311  if (ctx->min_gf_interval >= 0)
1312  codecctl_int(avctx, VP9E_SET_MIN_GF_INTERVAL, ctx->min_gf_interval);
1313 #endif
1314  }
1315 #endif
1316  if (avctx->codec_id == AV_CODEC_ID_VP8 && ctx->screen_content_mode >= 0) {
1317  if (ctx->screen_content_mode == 2 && ctx->is_alpha) {
1318  av_log(avctx, AV_LOG_ERROR,
1319  "Transparency encoding with screen mode with aggressive rate control not supported\n");
1320  return AVERROR(EINVAL);
1321  }
1322  codecctl_int(avctx, VP8E_SET_SCREEN_CONTENT_MODE, ctx->screen_content_mode);
1323  }
1324 
1325  av_log(avctx, AV_LOG_DEBUG, "Using deadline: %d\n", ctx->deadline);
1326 
1327  //provide dummy value to initialize wrapper, values will be updated each _encode()
1328  vpx_img_wrap(&ctx->rawimg, img_fmt, avctx->width, avctx->height, 1,
1329  (unsigned char*)1);
1330 #if CONFIG_LIBVPX_VP9_ENCODER
1331  if (avctx->codec_id == AV_CODEC_ID_VP9 && (codec_caps & VPX_CODEC_CAP_HIGHBITDEPTH))
1332  ctx->rawimg.bit_depth = enccfg.g_bit_depth;
1333 #endif
1334 
1335  cpb_props = ff_encode_add_cpb_side_data(avctx);
1336  if (!cpb_props)
1337  return AVERROR(ENOMEM);
1338 
1339  if (enccfg.rc_end_usage == VPX_CBR ||
1340  enccfg.g_pass != VPX_RC_ONE_PASS) {
1341  cpb_props->max_bitrate = avctx->rc_max_rate;
1342  cpb_props->min_bitrate = avctx->rc_min_rate;
1343  cpb_props->avg_bitrate = avctx->bit_rate;
1344  }
1345  cpb_props->buffer_size = avctx->rc_buffer_size;
1346 
1347  return 0;
1348 }
1349 
1350 static inline void cx_pktcpy(struct FrameListData *dst,
1351  const struct vpx_codec_cx_pkt *src,
1352  VPxContext *ctx)
1353 {
1354  dst->pts = src->data.frame.pts;
1355  dst->flags = src->data.frame.flags;
1356  dst->sz = src->data.frame.sz;
1357  dst->buf = src->data.frame.buf;
1358  dst->have_sse = 0;
1359  /* For alt-ref frame, don't store PSNR */
1360  if (!(dst->flags & VPX_FRAME_IS_INVISIBLE)) {
1361  dst->have_sse = ctx->have_sse;
1362  if (ctx->have_sse) {
1363  /* associate last-seen SSE to the frame. */
1364  /* Transfers ownership from ctx to dst. */
1365  /* WARNING! This makes the assumption that PSNR_PKT comes
1366  just before the frame it refers to! */
1367  memcpy(dst->sse, ctx->sse, sizeof(dst->sse));
1368  ctx->have_sse = 0;
1369  }
1370  }
1371 }
1372 
1373 /**
1374  * Store coded frame information in format suitable for return from encode2().
1375  *
1376  * Write information from @a cx_frame to @a pkt
1377  * @return packet data size on success
1378  * @return a negative AVERROR on error
1379  */
1380 static int storeframe(AVCodecContext *avctx, struct FrameListData *cx_frame,
1381  struct FrameListData *alpha_cx_frame, AVPacket *pkt)
1382 {
1383  VPxContext *ctx = avctx->priv_data;
1384  int ret = ff_get_encode_buffer(avctx, pkt, cx_frame->sz, 0);
1385  uint8_t *side_data;
1386  enum AVPictureType pict_type;
1387  int quality;
1388 
1389  if (ret < 0)
1390  return ret;
1391 
1392  memcpy(pkt->data, cx_frame->buf, pkt->size);
1393  pkt->pts = pkt->dts = cx_frame->pts;
1394 
1395  if (!!(cx_frame->flags & VPX_FRAME_IS_KEY)) {
1396  pict_type = AV_PICTURE_TYPE_I;
1398  } else {
1399  pict_type = AV_PICTURE_TYPE_P;
1400  }
1401 
1402  ret = vpx_codec_control(&ctx->encoder, VP8E_GET_LAST_QUANTIZER_64, &quality);
1403  if (ret != VPX_CODEC_OK)
1404  quality = 0;
1406  cx_frame->have_sse ? 3 : 0, pict_type);
1407 
1408  if (cx_frame->have_sse) {
1409  /* Beware of the Y/U/V/all order! */
1410  for (int i = 0; i < 3; ++i)
1411  avctx->error[i] += cx_frame->sse[i + 1];
1412  cx_frame->have_sse = 0;
1413  }
1414  if (alpha_cx_frame) {
1415  side_data = av_packet_new_side_data(pkt,
1417  alpha_cx_frame->sz + 8);
1418  if (!side_data) {
1420  return AVERROR(ENOMEM);
1421  }
1422  AV_WB64(side_data, 1);
1423  memcpy(side_data + 8, alpha_cx_frame->buf, alpha_cx_frame->sz);
1424  }
1425  ret = frame_data_apply(avctx, ctx->fifo, pkt);
1426  if (ret < 0)
1427  return ret;
1428 
1429  return pkt->size;
1430 }
1431 
1432 /**
1433  * Queue multiple output frames from the encoder, returning the front-most.
1434  * In cases where vpx_codec_get_cx_data() returns more than 1 frame append
1435  * the frame queue. Return the head frame if available.
1436  * @return Stored frame size
1437  * @return AVERROR(EINVAL) on output size error
1438  * @return AVERROR(ENOMEM) on coded frame queue data allocation error
1439  */
1440 static int queue_frames(AVCodecContext *avctx, struct vpx_codec_ctx *encoder,
1441  struct FrameListData **frame_list, AVPacket *pkt_out)
1442 {
1443  VPxContext *ctx = avctx->priv_data;
1444  const struct vpx_codec_cx_pkt *pkt;
1445  const void *iter = NULL;
1446  int size = 0;
1447 
1448  if (!ctx->is_alpha && *frame_list) {
1449  struct FrameListData *cx_frame = *frame_list;
1450  /* return the leading frame if we've already begun queueing */
1451  size = storeframe(avctx, cx_frame, NULL, pkt_out);
1452  if (size < 0)
1453  return size;
1454  *frame_list = cx_frame->next;
1455  free_coded_frame(cx_frame);
1456  }
1457 
1458  /* consume all available output from the encoder before returning. buffers
1459  are only good through the next vpx_codec call */
1460  while (pkt = vpx_codec_get_cx_data(encoder, &iter)) {
1461  switch (pkt->kind) {
1462  case VPX_CODEC_CX_FRAME_PKT:
1463  if (!ctx->is_alpha && !size) {
1464  struct FrameListData cx_frame;
1465 
1466  /* avoid storing the frame when the list is empty and we haven't yet
1467  provided a frame for output */
1468  av_assert0(!ctx->coded_frame_list);
1469  cx_pktcpy(&cx_frame, pkt, ctx);
1470  size = storeframe(avctx, &cx_frame, NULL, pkt_out);
1471  if (size < 0)
1472  return size;
1473  } else {
1474  struct FrameListData *cx_frame = av_malloc(sizeof(*cx_frame));
1475 
1476  if (!cx_frame) {
1477  av_log(avctx, AV_LOG_ERROR,
1478  "Frame queue element alloc failed\n");
1479  return AVERROR(ENOMEM);
1480  }
1481  cx_pktcpy(cx_frame, pkt, ctx);
1482  cx_frame->buf = av_malloc(cx_frame->sz);
1483 
1484  if (!cx_frame->buf) {
1485  av_log(avctx, AV_LOG_ERROR,
1486  "Data buffer alloc (%zu bytes) failed\n",
1487  cx_frame->sz);
1488  av_freep(&cx_frame);
1489  return AVERROR(ENOMEM);
1490  }
1491  memcpy(cx_frame->buf, pkt->data.frame.buf, pkt->data.frame.sz);
1492  coded_frame_add(frame_list, cx_frame);
1493  }
1494  break;
1495  case VPX_CODEC_STATS_PKT: {
1496  struct vpx_fixed_buf *stats = &ctx->twopass_stats;
1497  uint8_t *tmp;
1498  if (!pkt_out)
1499  break;
1500  tmp = av_fast_realloc(stats->buf,
1501  &ctx->twopass_stats_size,
1502  stats->sz +
1503  pkt->data.twopass_stats.sz);
1504  if (!tmp) {
1505  av_freep(&stats->buf);
1506  stats->sz = 0;
1507  av_log(avctx, AV_LOG_ERROR, "Stat buffer realloc failed\n");
1508  return AVERROR(ENOMEM);
1509  }
1510  stats->buf = tmp;
1511  memcpy((uint8_t*)stats->buf + stats->sz,
1512  pkt->data.twopass_stats.buf, pkt->data.twopass_stats.sz);
1513  stats->sz += pkt->data.twopass_stats.sz;
1514  break;
1515  }
1516  case VPX_CODEC_PSNR_PKT:
1517  if (!pkt_out)
1518  break;
1519  av_assert0(!ctx->have_sse);
1520  ctx->sse[0] = pkt->data.psnr.sse[0];
1521  ctx->sse[1] = pkt->data.psnr.sse[1];
1522  ctx->sse[2] = pkt->data.psnr.sse[2];
1523  ctx->sse[3] = pkt->data.psnr.sse[3];
1524  ctx->have_sse = 1;
1525  break;
1526  case VPX_CODEC_CUSTOM_PKT:
1527  //ignore unsupported/unrecognized packet types
1528  break;
1529  }
1530  }
1531 
1532  return size;
1533 }
1534 
1535 static int set_roi_map(AVCodecContext *avctx, const AVFrameSideData *sd, int frame_width, int frame_height,
1536  vpx_roi_map_t *roi_map, int block_size, int segment_cnt)
1537 {
1538  /**
1539  * range of vpx_roi_map_t.delta_q[i] is [-63, 63]
1540  */
1541 #define MAX_DELTA_Q 63
1542 
1543  const AVRegionOfInterest *roi = NULL;
1544  int nb_rois;
1545  uint32_t self_size;
1546  int segment_id;
1547 
1548  /* record the mapping from delta_q to "segment id + 1" in segment_mapping[].
1549  * the range of delta_q is [-MAX_DELTA_Q, MAX_DELTA_Q],
1550  * and its corresponding array index is [0, 2 * MAX_DELTA_Q],
1551  * and so the length of the mapping array is 2 * MAX_DELTA_Q + 1.
1552  * "segment id + 1", so we can say there's no mapping if the value of array element is zero.
1553  */
1554  int segment_mapping[2 * MAX_DELTA_Q + 1] = { 0 };
1555 
1556  memset(roi_map, 0, sizeof(*roi_map));
1557 
1558  /* segment id 0 in roi_map is reserved for the areas not covered by AVRegionOfInterest.
1559  * segment id 0 in roi_map is also for the areas with AVRegionOfInterest.qoffset near 0.
1560  * (delta_q of segment id 0 is 0).
1561  */
1562  segment_mapping[MAX_DELTA_Q] = 1;
1563  segment_id = 1;
1564 
1565  roi = (const AVRegionOfInterest*)sd->data;
1566  self_size = roi->self_size;
1567  if (!self_size || sd->size % self_size) {
1568  av_log(avctx, AV_LOG_ERROR, "Invalid AVRegionOfInterest.self_size.\n");
1569  return AVERROR(EINVAL);
1570  }
1571  nb_rois = sd->size / self_size;
1572 
1573  /* This list must be iterated from zero because regions are
1574  * defined in order of decreasing importance. So discard less
1575  * important areas if they exceed the segment count.
1576  */
1577  for (int i = 0; i < nb_rois; i++) {
1578  int delta_q;
1579  int mapping_index;
1580 
1581  roi = (const AVRegionOfInterest*)(sd->data + self_size * i);
1582  if (!roi->qoffset.den) {
1583  av_log(avctx, AV_LOG_ERROR, "AVRegionOfInterest.qoffset.den must not be zero.\n");
1584  return AVERROR(EINVAL);
1585  }
1586 
1587  delta_q = (int)(roi->qoffset.num * 1.0f / roi->qoffset.den * MAX_DELTA_Q);
1589 
1590  mapping_index = delta_q + MAX_DELTA_Q;
1591  if (!segment_mapping[mapping_index]) {
1592  if (segment_id == segment_cnt) {
1593  av_log(avctx, AV_LOG_WARNING,
1594  "ROI only supports %d segments (and segment 0 is reserved for non-ROIs), skipping the left ones.\n",
1595  segment_cnt);
1596  break;
1597  }
1598 
1599  segment_mapping[mapping_index] = segment_id + 1;
1600  roi_map->delta_q[segment_id] = delta_q;
1601  segment_id++;
1602  }
1603  }
1604 
1605  roi_map->rows = (frame_height + block_size - 1) / block_size;
1606  roi_map->cols = (frame_width + block_size - 1) / block_size;
1607  roi_map->roi_map = av_calloc(roi_map->rows * roi_map->cols, sizeof(*roi_map->roi_map));
1608  if (!roi_map->roi_map) {
1609  av_log(avctx, AV_LOG_ERROR, "roi_map alloc failed.\n");
1610  return AVERROR(ENOMEM);
1611  }
1612 
1613  /* This list must be iterated in reverse, so for the case that
1614  * two regions are overlapping, the more important area takes effect.
1615  */
1616  for (int i = nb_rois - 1; i >= 0; i--) {
1617  int delta_q;
1618  int mapping_value;
1619  int starty, endy, startx, endx;
1620 
1621  roi = (const AVRegionOfInterest*)(sd->data + self_size * i);
1622 
1623  starty = av_clip(roi->top / block_size, 0, roi_map->rows);
1624  endy = av_clip((roi->bottom + block_size - 1) / block_size, 0, roi_map->rows);
1625  startx = av_clip(roi->left / block_size, 0, roi_map->cols);
1626  endx = av_clip((roi->right + block_size - 1) / block_size, 0, roi_map->cols);
1627 
1628  delta_q = (int)(roi->qoffset.num * 1.0f / roi->qoffset.den * MAX_DELTA_Q);
1630 
1631  mapping_value = segment_mapping[delta_q + MAX_DELTA_Q];
1632  if (mapping_value) {
1633  for (int y = starty; y < endy; y++)
1634  for (int x = startx; x < endx; x++)
1635  roi_map->roi_map[x + y * roi_map->cols] = mapping_value - 1;
1636  }
1637  }
1638 
1639  return 0;
1640 }
1641 
1642 static int vp9_encode_set_roi(AVCodecContext *avctx, int frame_width, int frame_height, const AVFrameSideData *sd)
1643 {
1644  VPxContext *ctx = avctx->priv_data;
1645 
1646 #ifdef VPX_CTRL_VP9E_SET_ROI_MAP
1647  int version = vpx_codec_version();
1648  int major = VPX_VERSION_MAJOR(version);
1649  int minor = VPX_VERSION_MINOR(version);
1650  int patch = VPX_VERSION_PATCH(version);
1651 
1652  if (major > 1 || (major == 1 && minor > 8) || (major == 1 && minor == 8 && patch >= 1)) {
1653  vpx_roi_map_t roi_map;
1654  const int segment_cnt = 8;
1655  const int block_size = 8;
1656  int ret;
1657 
1658  if (ctx->aq_mode > 0 || ctx->cpu_used < 5 || ctx->deadline != VPX_DL_REALTIME) {
1659  if (!ctx->roi_warned) {
1660  ctx->roi_warned = 1;
1661  av_log(avctx, AV_LOG_WARNING, "ROI is only enabled when aq_mode is 0, cpu_used >= 5 "
1662  "and deadline is REALTIME, so skipping ROI.\n");
1663  return AVERROR(EINVAL);
1664  }
1665  }
1666 
1667  ret = set_roi_map(avctx, sd, frame_width, frame_height, &roi_map, block_size, segment_cnt);
1668  if (ret) {
1669  log_encoder_error(avctx, &ctx->encoder, "Failed to set_roi_map.\n");
1670  return ret;
1671  }
1672 
1673  memset(roi_map.ref_frame, -1, sizeof(roi_map.ref_frame));
1674 
1675  if (vpx_codec_control(&ctx->encoder, VP9E_SET_ROI_MAP, &roi_map)) {
1676  log_encoder_error(avctx, &ctx->encoder, "Failed to set VP9E_SET_ROI_MAP codec control.\n");
1678  }
1679  av_freep(&roi_map.roi_map);
1680  return ret;
1681  }
1682 #endif
1683 
1684  if (!ctx->roi_warned) {
1685  ctx->roi_warned = 1;
1686  av_log(avctx, AV_LOG_WARNING, "ROI is not supported, please upgrade libvpx to version >= 1.8.1. "
1687  "You may need to rebuild ffmpeg.\n");
1688  }
1689  return 0;
1690 }
1691 
1692 static int vp8_encode_set_roi(AVCodecContext *avctx, int frame_width, int frame_height, const AVFrameSideData *sd)
1693 {
1694  vpx_roi_map_t roi_map;
1695  const int segment_cnt = 4;
1696  const int block_size = 16;
1697  VPxContext *ctx = avctx->priv_data;
1698 
1699  int ret = set_roi_map(avctx, sd, frame_width, frame_height, &roi_map, block_size, segment_cnt);
1700  if (ret) {
1701  log_encoder_error(avctx, &ctx->encoder, "Failed to set_roi_map.\n");
1702  return ret;
1703  }
1704 
1705  if (vpx_codec_control(&ctx->encoder, VP8E_SET_ROI_MAP, &roi_map)) {
1706  log_encoder_error(avctx, &ctx->encoder, "Failed to set VP8E_SET_ROI_MAP codec control.\n");
1708  }
1709 
1710  av_freep(&roi_map.roi_map);
1711  return ret;
1712 }
1713 
1714 static int realloc_alpha_uv(AVCodecContext *avctx, int width, int height)
1715 {
1716  VPxContext *ctx = avctx->priv_data;
1717  struct vpx_image *rawimg_alpha = &ctx->rawimg_alpha;
1718  unsigned char **planes = rawimg_alpha->planes;
1719  int *stride = rawimg_alpha->stride;
1720 
1721  if (!planes[VPX_PLANE_U] ||
1722  !planes[VPX_PLANE_V] ||
1723  width != (int)rawimg_alpha->d_w ||
1724  height != (int)rawimg_alpha->d_h) {
1725  vpx_img_fmt_t alpha_fmt = ctx->rawimg.bit_depth > 8 ?
1726  VPX_IMG_FMT_I42016 : VPX_IMG_FMT_I420;
1727  av_freep(&planes[VPX_PLANE_U]);
1728  av_freep(&planes[VPX_PLANE_V]);
1729 
1730  vpx_img_wrap(rawimg_alpha, alpha_fmt, width, height, 1,
1731  (unsigned char*)1);
1732  planes[VPX_PLANE_U] = av_malloc_array(stride[VPX_PLANE_U], height);
1733  planes[VPX_PLANE_V] = av_malloc_array(stride[VPX_PLANE_V], height);
1734  if (!planes[VPX_PLANE_U] || !planes[VPX_PLANE_V])
1735  return AVERROR(ENOMEM);
1736 
1737  if (ctx->rawimg.bit_depth > 8) {
1738  int val = 0x80 << (ctx->rawimg.bit_depth - 8);
1739  AV_WN16(planes[VPX_PLANE_U], val);
1740  AV_WN16(planes[VPX_PLANE_V], val);
1741  av_memcpy_backptr(planes[VPX_PLANE_U] + 2, 2, stride[VPX_PLANE_U] * height - 2);
1742  av_memcpy_backptr(planes[VPX_PLANE_V] + 2, 2, stride[VPX_PLANE_V] * height - 2);
1743  } else {
1744  memset(planes[VPX_PLANE_U], 0x80, stride[VPX_PLANE_U] * height);
1745  memset(planes[VPX_PLANE_V], 0x80, stride[VPX_PLANE_V] * height);
1746  }
1747  }
1748 
1749  return 0;
1750 }
1751 
1753  const AVFrame *frame, int *got_packet)
1754 {
1755  VPxContext *ctx = avctx->priv_data;
1756  struct vpx_image *rawimg = NULL;
1757  struct vpx_image *rawimg_alpha = NULL;
1758  int64_t timestamp = 0;
1759  int res, coded_size;
1760  vpx_enc_frame_flags_t flags = 0;
1761  const struct vpx_codec_enc_cfg *enccfg = ctx->encoder.config.enc;
1762  vpx_svc_layer_id_t layer_id;
1763  int layer_id_valid = 0;
1764  unsigned long duration = 0;
1765 
1766  if (avctx->qmax >= 0 && enccfg->rc_max_quantizer != avctx->qmax) {
1767  struct vpx_codec_enc_cfg cfg = *enccfg;
1768  cfg.rc_max_quantizer = avctx->qmax;
1769  res = vpx_codec_enc_config_set(&ctx->encoder, &cfg);
1770  if (res != VPX_CODEC_OK) {
1771  log_encoder_error(avctx, &ctx->encoder, "Error reconfiguring encoder");
1772  return AVERROR_INVALIDDATA;
1773  }
1774  }
1775 
1776  if (frame) {
1778  rawimg = &ctx->rawimg;
1779  rawimg->planes[VPX_PLANE_Y] = frame->data[0];
1780  rawimg->planes[VPX_PLANE_U] = frame->data[1];
1781  rawimg->planes[VPX_PLANE_V] = frame->data[2];
1782  rawimg->stride[VPX_PLANE_Y] = frame->linesize[0];
1783  rawimg->stride[VPX_PLANE_U] = frame->linesize[1];
1784  rawimg->stride[VPX_PLANE_V] = frame->linesize[2];
1785  if (ctx->is_alpha) {
1786  rawimg_alpha = &ctx->rawimg_alpha;
1787  res = realloc_alpha_uv(avctx, frame->width, frame->height);
1788  if (res < 0)
1789  return res;
1790  rawimg_alpha->planes[VPX_PLANE_Y] = frame->data[3];
1791  rawimg_alpha->stride[VPX_PLANE_Y] = frame->linesize[3];
1792  }
1793  timestamp = frame->pts;
1794 #if VPX_IMAGE_ABI_VERSION >= 4
1795  switch (frame->color_range) {
1796  case AVCOL_RANGE_MPEG:
1797  rawimg->range = VPX_CR_STUDIO_RANGE;
1798  break;
1799  case AVCOL_RANGE_JPEG:
1800  rawimg->range = VPX_CR_FULL_RANGE;
1801  break;
1802  }
1803 #endif
1804  if (frame->pict_type == AV_PICTURE_TYPE_I)
1805  flags |= VPX_EFLAG_FORCE_KF;
1806  if (frame->metadata) {
1807  AVDictionaryEntry* en = av_dict_get(frame->metadata, "vp8-flags", NULL, 0);
1808  if (en) {
1809  flags |= strtoul(en->value, NULL, 10);
1810  }
1811 
1812  memset(&layer_id, 0, sizeof(layer_id));
1813 
1814  en = av_dict_get(frame->metadata, "temporal_id", NULL, 0);
1815  if (en) {
1816  layer_id.temporal_layer_id = strtoul(en->value, NULL, 10);
1817 #ifdef VPX_CTRL_VP9E_SET_MAX_INTER_BITRATE_PCT
1818  layer_id.temporal_layer_id_per_spatial[0] = layer_id.temporal_layer_id;
1819 #endif
1820  layer_id_valid = 1;
1821  }
1822 #if CONFIG_LIBVPX_VP9_ENCODER && defined(VPX_CTRL_VP9E_SET_MAX_INTER_BITRATE_PCT)
1823  en = av_dict_get(frame->metadata, "ref-frame-config", NULL, 0);
1824 
1825  if (en) {
1826  if (avctx->codec_id == AV_CODEC_ID_VP9) {
1827  int ret = vpx_parse_ref_frame_config(&ctx->ref_frame_config,
1828  enccfg->ss_number_layers, en->value);
1829  if (ret < 0) {
1830  av_log(avctx, AV_LOG_WARNING,
1831  "Error parsing ref_frame_config option %s.\n", en->value);
1832  return ret;
1833  }
1834 
1835  codecctl_intp(avctx, VP9E_SET_SVC_REF_FRAME_CONFIG, (int *)&ctx->ref_frame_config);
1836  } else {
1837  av_log(avctx, AV_LOG_WARNING,
1838  "Ignoring ref-frame-config for a non-VP9 codec\n");
1839  }
1840  }
1841 #endif
1842  }
1843 
1844  if (sd) {
1845  if (avctx->codec_id == AV_CODEC_ID_VP8) {
1846  vp8_encode_set_roi(avctx, frame->width, frame->height, sd);
1847  } else {
1848  vp9_encode_set_roi(avctx, frame->width, frame->height, sd);
1849  }
1850  }
1851 
1852  if (!(avctx->flags & AV_CODEC_FLAG_PASS1)) {
1853  res = frame_data_submit(avctx, ctx->fifo, frame);
1854  if (res < 0)
1855  return res;
1856  }
1857  }
1858 
1859  // this is for encoding with preset temporal layering patterns defined in
1860  // set_temporal_layer_pattern function.
1861  if (enccfg->ts_number_layers > 1 && ctx->ts_layer_flags) {
1862  if (flags & VPX_EFLAG_FORCE_KF) {
1863  // keyframe, reset temporal layering.
1864  ctx->current_temporal_idx = 0;
1865  flags = VPX_EFLAG_FORCE_KF;
1866  } else {
1867  flags = 0;
1868  }
1869 
1870  /* get the flags from the temporal layer configuration. */
1871  flags |= ctx->ts_layer_flags[ctx->current_temporal_idx];
1872 
1873  memset(&layer_id, 0, sizeof(layer_id));
1874 #if VPX_ENCODER_ABI_VERSION >= 12
1875  layer_id.spatial_layer_id = 0;
1876 #endif
1877  layer_id.temporal_layer_id = enccfg->ts_layer_id[ctx->current_temporal_idx];
1878 #ifdef VPX_CTRL_VP9E_SET_MAX_INTER_BITRATE_PCT
1879  layer_id.temporal_layer_id_per_spatial[0] = layer_id.temporal_layer_id;
1880 #endif
1881  layer_id_valid = 1;
1882  }
1883 
1884  if (layer_id_valid) {
1885  if (avctx->codec_id == AV_CODEC_ID_VP8) {
1886  codecctl_int(avctx, VP8E_SET_TEMPORAL_LAYER_ID, layer_id.temporal_layer_id);
1887  }
1888 #if CONFIG_LIBVPX_VP9_ENCODER && VPX_ENCODER_ABI_VERSION >= 12
1889  else if (avctx->codec_id == AV_CODEC_ID_VP9) {
1890  codecctl_intp(avctx, VP9E_SET_SVC_LAYER_ID, (int *)&layer_id);
1891  }
1892 #endif
1893  }
1894 
1895  if (frame && frame->duration > ULONG_MAX) {
1896  av_log(avctx, AV_LOG_WARNING,
1897  "Frame duration too large: %"PRId64"\n", frame->duration);
1898  } else if (frame && frame->duration)
1899  duration = frame->duration;
1900  else if (avctx->framerate.num > 0 && avctx->framerate.den > 0)
1901  duration = av_rescale_q(1, av_inv_q(avctx->framerate), avctx->time_base);
1902  else {
1903  duration = 1;
1904  }
1905 
1906  res = vpx_codec_encode(&ctx->encoder, rawimg, timestamp,
1907  duration, flags, ctx->deadline);
1908  if (res != VPX_CODEC_OK) {
1909  log_encoder_error(avctx, &ctx->encoder, "Error encoding frame");
1910  return AVERROR_INVALIDDATA;
1911  }
1912 
1913  if (ctx->is_alpha) {
1914  res = vpx_codec_encode(&ctx->encoder_alpha, rawimg_alpha, timestamp,
1915  duration, flags, ctx->deadline);
1916  if (res != VPX_CODEC_OK) {
1917  log_encoder_error(avctx, &ctx->encoder_alpha, "Error encoding alpha frame");
1918  return AVERROR_INVALIDDATA;
1919  }
1920  }
1921 
1922  coded_size = queue_frames(avctx, &ctx->encoder, &ctx->coded_frame_list, pkt);
1923  if (ctx->is_alpha) {
1924  queue_frames(avctx, &ctx->encoder_alpha, &ctx->alpha_coded_frame_list, NULL);
1925 
1926  if (ctx->coded_frame_list && ctx->alpha_coded_frame_list) {
1927  struct FrameListData *cx_frame = ctx->coded_frame_list;
1928  struct FrameListData *alpha_cx_frame = ctx->alpha_coded_frame_list;
1929  av_assert0(!coded_size);
1930  /* return the leading frame if we've already begun queueing */
1931  coded_size = storeframe(avctx, cx_frame, alpha_cx_frame, pkt);
1932  if (coded_size < 0)
1933  return coded_size;
1934  ctx->coded_frame_list = cx_frame->next;
1935  ctx->alpha_coded_frame_list = alpha_cx_frame->next;
1936  free_coded_frame(cx_frame);
1937  free_coded_frame(alpha_cx_frame);
1938  }
1939  }
1940 
1941  if (!frame && avctx->flags & AV_CODEC_FLAG_PASS1) {
1942  unsigned int b64_size = AV_BASE64_SIZE(ctx->twopass_stats.sz);
1943 
1944  avctx->stats_out = av_malloc(b64_size);
1945  if (!avctx->stats_out) {
1946  av_log(avctx, AV_LOG_ERROR, "Stat buffer alloc (%d bytes) failed\n",
1947  b64_size);
1948  return AVERROR(ENOMEM);
1949  }
1950  av_base64_encode(avctx->stats_out, b64_size, ctx->twopass_stats.buf,
1951  ctx->twopass_stats.sz);
1952  } else if (enccfg->ts_number_layers > 1 && ctx->ts_layer_flags) {
1953  ctx->current_temporal_idx = (ctx->current_temporal_idx + 1) % enccfg->ts_periodicity;
1954  }
1955 
1956  *got_packet = !!coded_size;
1957  return 0;
1958 }
1959 
1960 #define OFFSET(x) offsetof(VPxContext, x)
1961 #define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
1962 
1963 #define COMMON_OPTIONS \
1964  { "lag-in-frames", "Number of frames to look ahead for " \
1965  "alternate reference frame selection", OFFSET(lag_in_frames), AV_OPT_TYPE_INT, {.i64 = -1}, -1, INT_MAX, VE}, \
1966  { "arnr-maxframes", "altref noise reduction max frame count", OFFSET(arnr_max_frames), AV_OPT_TYPE_INT, {.i64 = -1}, -1, INT_MAX, VE}, \
1967  { "arnr-strength", "altref noise reduction filter strength", OFFSET(arnr_strength), AV_OPT_TYPE_INT, {.i64 = -1}, -1, INT_MAX, VE}, \
1968  { "arnr-type", "altref noise reduction filter type", OFFSET(arnr_type), AV_OPT_TYPE_INT, {.i64 = -1}, -1, INT_MAX, VE, .unit = "arnr_type"}, \
1969  { "backward", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = 1}, 0, 0, VE, .unit = "arnr_type" }, \
1970  { "forward", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = 2}, 0, 0, VE, .unit = "arnr_type" }, \
1971  { "centered", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = 3}, 0, 0, VE, .unit = "arnr_type" }, \
1972  { "tune", "Tune the encoding to a specific scenario", OFFSET(tune), AV_OPT_TYPE_INT, {.i64 = -1}, -1, INT_MAX, VE, .unit = "tune"}, \
1973  { "psnr", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = VP8_TUNE_PSNR}, 0, 0, VE, .unit = "tune"}, \
1974  { "ssim", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = VP8_TUNE_SSIM}, 0, 0, VE, .unit = "tune"}, \
1975  { "deadline", "Time to spend encoding, in microseconds.", OFFSET(deadline), AV_OPT_TYPE_INT, {.i64 = VPX_DL_GOOD_QUALITY}, INT_MIN, INT_MAX, VE, .unit = "quality"}, \
1976  { "best", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = VPX_DL_BEST_QUALITY}, 0, 0, VE, .unit = "quality"}, \
1977  { "good", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = VPX_DL_GOOD_QUALITY}, 0, 0, VE, .unit = "quality"}, \
1978  { "realtime", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = VPX_DL_REALTIME}, 0, 0, VE, .unit = "quality"}, \
1979  { "error-resilient", "Error resilience configuration", OFFSET(error_resilient), AV_OPT_TYPE_FLAGS, {.i64 = 0}, INT_MIN, INT_MAX, VE, .unit = "er"}, \
1980  { "max-intra-rate", "Maximum I-frame bitrate (pct) 0=unlimited", OFFSET(max_intra_rate), AV_OPT_TYPE_INT, {.i64 = -1}, -1, INT_MAX, VE}, \
1981  { "default", "Improve resiliency against losses of whole frames", 0, AV_OPT_TYPE_CONST, {.i64 = VPX_ERROR_RESILIENT_DEFAULT}, 0, 0, VE, .unit = "er"}, \
1982  { "partitions", "The frame partitions are independently decodable " \
1983  "by the bool decoder, meaning that partitions can be decoded even " \
1984  "though earlier partitions have been lost. Note that intra prediction" \
1985  " is still done over the partition boundary.", 0, AV_OPT_TYPE_CONST, {.i64 = VPX_ERROR_RESILIENT_PARTITIONS}, 0, 0, VE, .unit = "er"}, \
1986  { "crf", "Select the quality for constant quality mode", offsetof(VPxContext, crf), AV_OPT_TYPE_INT, {.i64 = -1}, -1, 63, VE }, \
1987  { "static-thresh", "A change threshold on blocks below which they will be skipped by the encoder", OFFSET(static_thresh), AV_OPT_TYPE_INT, { .i64 = 0 }, 0, INT_MAX, VE }, \
1988  { "drop-threshold", "Frame drop threshold", offsetof(VPxContext, drop_threshold), AV_OPT_TYPE_INT, {.i64 = 0 }, INT_MIN, INT_MAX, VE }, \
1989  { "noise-sensitivity", "Noise sensitivity", OFFSET(noise_sensitivity), AV_OPT_TYPE_INT, {.i64 = 0 }, 0, 4, VE}, \
1990  { "undershoot-pct", "Datarate undershoot (min) target (%)", OFFSET(rc_undershoot_pct), AV_OPT_TYPE_INT, { .i64 = -1 }, -1, 100, VE }, \
1991  { "overshoot-pct", "Datarate overshoot (max) target (%)", OFFSET(rc_overshoot_pct), AV_OPT_TYPE_INT, { .i64 = -1 }, -1, 1000, VE }, \
1992  { "ts-parameters", "Temporal scaling configuration using a :-separated list of key=value parameters", OFFSET(vpx_ts_parameters), AV_OPT_TYPE_DICT, {.str=NULL}, 0, 0, VE}, \
1993 
1994 #define LEGACY_OPTIONS \
1995  {"speed", "", offsetof(VPxContext, cpu_used), AV_OPT_TYPE_INT, {.i64 = 1}, -16, 16, VE}, \
1996  {"quality", "", offsetof(VPxContext, deadline), AV_OPT_TYPE_INT, {.i64 = VPX_DL_GOOD_QUALITY}, INT_MIN, INT_MAX, VE, .unit = "quality"}, \
1997  {"vp8flags", "", offsetof(VPxContext, flags), AV_OPT_TYPE_FLAGS, {.i64 = 0}, 0, UINT_MAX, VE, .unit = "flags"}, \
1998  {"error_resilient", "enable error resilience", 0, AV_OPT_TYPE_CONST, {.i64 = VP8F_ERROR_RESILIENT}, INT_MIN, INT_MAX, VE, .unit = "flags"}, \
1999  {"altref", "enable use of alternate reference frames (VP8/2-pass only)", 0, AV_OPT_TYPE_CONST, {.i64 = VP8F_AUTO_ALT_REF}, INT_MIN, INT_MAX, VE, .unit = "flags"}, \
2000  {"arnr_max_frames", "altref noise reduction max frame count", offsetof(VPxContext, arnr_max_frames), AV_OPT_TYPE_INT, {.i64 = 0}, 0, 15, VE}, \
2001  {"arnr_strength", "altref noise reduction filter strength", offsetof(VPxContext, arnr_strength), AV_OPT_TYPE_INT, {.i64 = 3}, 0, 6, VE}, \
2002  {"arnr_type", "altref noise reduction filter type", offsetof(VPxContext, arnr_type), AV_OPT_TYPE_INT, {.i64 = 3}, 1, 3, VE}, \
2003  {"rc_lookahead", "Number of frames to look ahead for alternate reference frame selection", offsetof(VPxContext, lag_in_frames), AV_OPT_TYPE_INT, {.i64 = 25}, 0, 25, VE}, \
2004  {"sharpness", "Increase sharpness at the expense of lower PSNR", offsetof(VPxContext, sharpness), AV_OPT_TYPE_INT, {.i64 = -1}, -1, 7, VE},
2005 
2006 #if CONFIG_LIBVPX_VP8_ENCODER
2007 static const AVOption vp8_options[] = {
2009  { "auto-alt-ref", "Enable use of alternate reference "
2010  "frames (2-pass only)", OFFSET(auto_alt_ref), AV_OPT_TYPE_INT, {.i64 = -1}, -1, 2, VE},
2011  { "cpu-used", "Quality/Speed ratio modifier", OFFSET(cpu_used), AV_OPT_TYPE_INT, {.i64 = 1}, -16, 16, VE},
2012  { "screen-content-mode", "Encoder screen content mode", OFFSET(screen_content_mode), AV_OPT_TYPE_INT, {.i64 = -1}, -1, 2, VE},
2014  { NULL }
2015 };
2016 #endif
2017 
2018 #if CONFIG_LIBVPX_VP9_ENCODER
2019 static const AVOption vp9_options[] = {
2021  { "auto-alt-ref", "Enable use of alternate reference "
2022  "frames (2-pass only)", OFFSET(auto_alt_ref), AV_OPT_TYPE_INT, {.i64 = -1}, -1, 6, VE},
2023  { "cpu-used", "Quality/Speed ratio modifier", OFFSET(cpu_used), AV_OPT_TYPE_INT, {.i64 = 1}, -8, 8, VE},
2024  { "lossless", "Lossless mode", OFFSET(lossless), AV_OPT_TYPE_INT, {.i64 = -1}, -1, 1, VE},
2025  { "tile-columns", "Number of tile columns to use, log2", OFFSET(tile_columns), AV_OPT_TYPE_INT, {.i64 = -1}, -1, 6, VE},
2026  { "tile-rows", "Number of tile rows to use, log2", OFFSET(tile_rows), AV_OPT_TYPE_INT, {.i64 = -1}, -1, 2, VE},
2027  { "frame-parallel", "Enable frame parallel decodability features", OFFSET(frame_parallel), AV_OPT_TYPE_BOOL,{.i64 = -1}, -1, 1, VE},
2028 #if VPX_ENCODER_ABI_VERSION >= 12
2029  { "aq-mode", "adaptive quantization mode", OFFSET(aq_mode), AV_OPT_TYPE_INT, {.i64 = -1}, -1, 4, VE, .unit = "aq_mode"},
2030 #else
2031  { "aq-mode", "adaptive quantization mode", OFFSET(aq_mode), AV_OPT_TYPE_INT, {.i64 = -1}, -1, 3, VE, .unit = "aq_mode"},
2032 #endif
2033  { "none", "Aq not used", 0, AV_OPT_TYPE_CONST, {.i64 = 0}, 0, 0, VE, .unit = "aq_mode" },
2034  { "variance", "Variance based Aq", 0, AV_OPT_TYPE_CONST, {.i64 = 1}, 0, 0, VE, .unit = "aq_mode" },
2035  { "complexity", "Complexity based Aq", 0, AV_OPT_TYPE_CONST, {.i64 = 2}, 0, 0, VE, .unit = "aq_mode" },
2036  { "cyclic", "Cyclic Refresh Aq", 0, AV_OPT_TYPE_CONST, {.i64 = 3}, 0, 0, VE, .unit = "aq_mode" },
2037 #if VPX_ENCODER_ABI_VERSION >= 12
2038  { "equator360", "360 video Aq", 0, AV_OPT_TYPE_CONST, {.i64 = 4}, 0, 0, VE, .unit = "aq_mode" },
2039  {"level", "Specify level", OFFSET(level), AV_OPT_TYPE_FLOAT, {.dbl=-1}, -1, 6.2, VE},
2040 #endif
2041 #ifdef VPX_CTRL_VP9E_SET_ROW_MT
2042  {"row-mt", "Row based multi-threading", OFFSET(row_mt), AV_OPT_TYPE_BOOL, {.i64 = -1}, -1, 1, VE},
2043 #endif
2044 #ifdef VPX_CTRL_VP9E_SET_TUNE_CONTENT
2045 #if VPX_ENCODER_ABI_VERSION >= 14
2046  { "tune-content", "Tune content type", OFFSET(tune_content), AV_OPT_TYPE_INT, {.i64 = -1}, -1, 2, VE, .unit = "tune_content" },
2047 #else
2048  { "tune-content", "Tune content type", OFFSET(tune_content), AV_OPT_TYPE_INT, {.i64 = -1}, -1, 1, VE, .unit = "tune_content" },
2049 #endif
2050  { "default", "Regular video content", 0, AV_OPT_TYPE_CONST, {.i64 = 0}, 0, 0, VE, .unit = "tune_content" },
2051  { "screen", "Screen capture content", 0, AV_OPT_TYPE_CONST, {.i64 = 1}, 0, 0, VE, .unit = "tune_content" },
2052 #if VPX_ENCODER_ABI_VERSION >= 14
2053  { "film", "Film content; improves grain retention", 0, AV_OPT_TYPE_CONST, {.i64 = 2}, 0, 0, VE, .unit = "tune_content" },
2054 #endif
2055 #endif
2056 #if VPX_ENCODER_ABI_VERSION >= 14
2057  { "corpus-complexity", "corpus vbr complexity midpoint", OFFSET(corpus_complexity), AV_OPT_TYPE_INT, {.i64 = -1}, -1, 10000, VE },
2058 #endif
2059 #ifdef VPX_CTRL_VP9E_SET_TPL
2060  { "enable-tpl", "Enable temporal dependency model", OFFSET(tpl_model), AV_OPT_TYPE_BOOL, {.i64 = -1}, -1, 1, VE },
2061 #endif
2062 #ifdef VPX_CTRL_VP9E_SET_MIN_GF_INTERVAL
2063  { "min-gf-interval", "Minimum golden/alternate reference frame interval", OFFSET(min_gf_interval), AV_OPT_TYPE_INT, {.i64 = -1}, -1, INT_MAX, VE },
2064 #endif
2066  { NULL }
2067 };
2068 #endif
2069 
2070 #undef COMMON_OPTIONS
2071 #undef LEGACY_OPTIONS
2072 
2073 static const FFCodecDefault defaults[] = {
2074  { "b", "0" },
2075  { "qmin", "-1" },
2076  { "qmax", "-1" },
2077  { "g", "-1" },
2078  { "keyint_min", "-1" },
2079  { NULL },
2080 };
2081 
2082 #if CONFIG_LIBVPX_VP8_ENCODER
2083 static av_cold int vp8_init(AVCodecContext *avctx)
2084 {
2085  return vpx_init(avctx, vpx_codec_vp8_cx());
2086 }
2087 
2088 static const AVClass class_vp8 = {
2089  .class_name = "libvpx-vp8 encoder",
2090  .item_name = av_default_item_name,
2091  .option = vp8_options,
2092  .version = LIBAVUTIL_VERSION_INT,
2093 };
2094 
2096  .p.name = "libvpx",
2097  CODEC_LONG_NAME("libvpx VP8"),
2098  .p.type = AVMEDIA_TYPE_VIDEO,
2099  .p.id = AV_CODEC_ID_VP8,
2100  .p.capabilities = AV_CODEC_CAP_DR1 | AV_CODEC_CAP_DELAY |
2103  .priv_data_size = sizeof(VPxContext),
2104  .init = vp8_init,
2106  .close = vpx_free,
2107  .caps_internal = FF_CODEC_CAP_NOT_INIT_THREADSAFE |
2111  .color_ranges = AVCOL_RANGE_MPEG | AVCOL_RANGE_JPEG,
2112  .p.priv_class = &class_vp8,
2113  .defaults = defaults,
2114  .p.wrapper_name = "libvpx",
2115 };
2116 #endif /* CONFIG_LIBVPX_VP8_ENCODER */
2117 
2118 #if CONFIG_LIBVPX_VP9_ENCODER
2119 static av_cold int vp9_init(AVCodecContext *avctx)
2120 {
2121  return vpx_init(avctx, vpx_codec_vp9_cx());
2122 }
2123 
2124 static const enum AVPixelFormat vp9_pix_fmts_highcol[] = {
2135 };
2136 
2137 static const enum AVPixelFormat vp9_pix_fmts_highbd[] = {
2164 };
2165 
2166 static int vp9_get_supported_config(const AVCodecContext *avctx,
2167  const AVCodec *codec,
2168  enum AVCodecConfig config,
2169  unsigned flags, const void **out,
2170  int *out_num)
2171 {
2173  vpx_codec_caps_t codec_caps = vpx_codec_get_caps(vpx_codec_vp9_cx());
2174  if (codec_caps & VPX_CODEC_CAP_HIGHBITDEPTH) {
2175  *out = vp9_pix_fmts_highbd;
2176  *out_num = FF_ARRAY_ELEMS(vp9_pix_fmts_highbd) - 1;
2177  } else {
2178  *out = vp9_pix_fmts_highcol;
2179  *out_num = FF_ARRAY_ELEMS(vp9_pix_fmts_highcol) - 1;
2180  }
2181  return 0;
2182  }
2183 
2184  return ff_default_get_supported_config(avctx, codec, config, flags, out, out_num);
2185 }
2186 
2187 static const AVClass class_vp9 = {
2188  .class_name = "libvpx-vp9 encoder",
2189  .item_name = av_default_item_name,
2190  .option = vp9_options,
2191  .version = LIBAVUTIL_VERSION_INT,
2192 };
2193 
2195  .p.name = "libvpx-vp9",
2196  CODEC_LONG_NAME("libvpx VP9"),
2197  .p.type = AVMEDIA_TYPE_VIDEO,
2198  .p.id = AV_CODEC_ID_VP9,
2199  .p.capabilities = AV_CODEC_CAP_DR1 | AV_CODEC_CAP_DELAY |
2202  .p.profiles = NULL_IF_CONFIG_SMALL(ff_vp9_profiles),
2203  .p.priv_class = &class_vp9,
2204  .p.wrapper_name = "libvpx",
2205  .priv_data_size = sizeof(VPxContext),
2206  .init = vp9_init,
2207  .color_ranges = AVCOL_RANGE_MPEG | AVCOL_RANGE_JPEG,
2209  .close = vpx_free,
2210  .caps_internal = FF_CODEC_CAP_NOT_INIT_THREADSAFE |
2213  .defaults = defaults,
2214  .get_supported_config = vp9_get_supported_config,
2215 };
2216 #endif /* CONFIG_LIBVPX_VP9_ENCODER */
error
static void error(const char *err)
Definition: target_bsf_fuzzer.c:32
flags
const SwsFlags flags[]
Definition: swscale.c:71
av_packet_unref
void av_packet_unref(AVPacket *pkt)
Wipe the packet.
Definition: packet.c:432
av_fifo_drain2
void av_fifo_drain2(AVFifo *f, size_t size)
Discard the specified amount of data from an AVFifo.
Definition: fifo.c:266
CODEC_PIXFMTS
#define CODEC_PIXFMTS(...)
Definition: codec_internal.h:392
AVCodec
AVCodec.
Definition: codec.h:172
AV_LOG_WARNING
#define AV_LOG_WARNING
Something somehow does not look correct.
Definition: log.h:216
AVPixelFormat
AVPixelFormat
Pixel format.
Definition: pixfmt.h:71
level
uint8_t level
Definition: svq3.c:208
FrameListData::pts
int64_t pts
time stamp to show frame (in timebase units)
Definition: libaomenc.c:61
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
AVCodecContext::keyint_min
int keyint_min
minimum GOP size
Definition: avcodec.h:1010
vp9_init
static av_cold int vp9_init(AVFormatContext *ctx, int st_index, PayloadContext *data)
Definition: rtpdec_vp9.c:34
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
set_color_range
static void set_color_range(AVCodecContext *avctx)
Definition: libaomenc.c:534
VPxEncoderContext::screen_content_mode
int screen_content_mode
Definition: libvpxenc.c:124
AVCodecContext::colorspace
enum AVColorSpace colorspace
YUV colorspace type.
Definition: avcodec.h:667
FrameData
Definition: ffmpeg.h:722
encoder_can_drop_frames
static int encoder_can_drop_frames(AVCodecContext *avctx)
Definition: libvpxenc.c:354
out
static FILE * out
Definition: movenc.c:55
log_encoder_error
static av_cold void log_encoder_error(void *logctx, struct vpx_codec_ctx *encoder, const char *desc)
Definition: libvpxenc.c:205
av_frame_get_side_data
AVFrameSideData * av_frame_get_side_data(const AVFrame *frame, enum AVFrameSideDataType type)
Definition: frame.c:659
AVCodecContext::rc_min_rate
int64_t rc_min_rate
minimum bitrate
Definition: avcodec.h:1289
vp8_ts_parse_int_array
static void vp8_ts_parse_int_array(int *dest, char *value, size_t value_len, int max_entries)
Definition: libvpxenc.c:560
frame_data_uninit
static void frame_data_uninit(FrameData *fd)
Definition: libvpxenc.c:340
av_pix_fmt_desc_get
const AVPixFmtDescriptor * av_pix_fmt_desc_get(enum AVPixelFormat pix_fmt)
Definition: pixdesc.c:3456
AVBufferRef::data
uint8_t * data
The data buffer.
Definition: buffer.h:90
VPxEncoderContext::rawimg_alpha
struct vpx_image rawimg_alpha
Definition: libvpxenc.c:84
AVPictureType
AVPictureType
Definition: avutil.h:276
int64_t
long long int64_t
Definition: coverity.c:34
ff_libvpx_vp9_encoder
FFCodec ff_libvpx_vp9_encoder
VPxEncoderContext
Definition: libvpxenc.c:79
VPxEncoderContext::is_alpha
uint8_t is_alpha
Definition: libvpxenc.c:85
av_fifo_peek
int av_fifo_peek(const AVFifo *f, void *buf, size_t nb_elems, size_t offset)
Read data from a FIFO without modifying FIFO state.
Definition: fifo.c:255
VPxEncoderContext::rawimg
struct vpx_image rawimg
Definition: libvpxenc.c:82
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:427
pixdesc.h
AVFrameSideData::buf
AVBufferRef * buf
Definition: frame.h:287
AVCodecContext::color_trc
enum AVColorTransferCharacteristic color_trc
Color Transfer Characteristic.
Definition: avcodec.h:660
AVCOL_RANGE_JPEG
@ AVCOL_RANGE_JPEG
Full range content.
Definition: pixfmt.h:777
AVPacket::data
uint8_t * data
Definition: packet.h:588
VP8F_ERROR_RESILIENT
#define VP8F_ERROR_RESILIENT
Enable measures appropriate for streaming over lossy links.
Definition: libvpxenc.c:100
AV_PIX_FMT_YUVA420P10
#define AV_PIX_FMT_YUVA420P10
Definition: pixfmt.h:590
AVOption
AVOption.
Definition: opt.h:429
encode.h
set_pix_fmt
static int set_pix_fmt(AVCodecContext *avctx, struct aom_image *img)
Definition: libaomdec.c:68
data
const char data[16]
Definition: mxf.c:149
AV_PIX_FMT_YUV420P10
#define AV_PIX_FMT_YUV420P10
Definition: pixfmt.h:539
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
AVCOL_SPC_RGB
@ AVCOL_SPC_RGB
order of coefficients is actually GBR, also IEC 61966-2-1 (sRGB), YZX and ST 428-1
Definition: pixfmt.h:701
VP8F_AUTO_ALT_REF
#define VP8F_AUTO_ALT_REF
Enable automatic alternate reference frame generation.
Definition: libvpxenc.c:101
AVPacket::duration
int64_t duration
Duration of this packet in AVStream->time_base units, 0 if unknown.
Definition: packet.h:606
VPxEncoderContext::have_sse
int have_sse
true if we have pending sse[]
Definition: libvpxenc.c:90
AV_PIX_FMT_YUV440P
@ AV_PIX_FMT_YUV440P
planar YUV 4:4:0 (1 Cr & Cb sample per 1x2 Y samples)
Definition: pixfmt.h:106
mathematics.h
FF_COMPLIANCE_EXPERIMENTAL
#define FF_COMPLIANCE_EXPERIMENTAL
Allow nonstandardized experimental things.
Definition: defs.h:62
AVDictionary
Definition: dict.c:32
AV_CODEC_FLAG_PSNR
#define AV_CODEC_FLAG_PSNR
error[?] variables will be set during encoding.
Definition: avcodec.h:306
av_buffer_ref
AVBufferRef * av_buffer_ref(const AVBufferRef *buf)
Create a new reference to an AVBuffer.
Definition: buffer.c:103
AV_CODEC_CONFIG_PIX_FORMAT
@ AV_CODEC_CONFIG_PIX_FORMAT
AVPixelFormat, terminated by AV_PIX_FMT_NONE.
Definition: avcodec.h:2549
VPxEncoderContext::fifo
AVFifo * fifo
Definition: libvpxenc.c:143
VPxEncoderContext::level
float level
Definition: libvpxenc.c:135
AVCodecContext::qmax
int qmax
maximum quantizer
Definition: avcodec.h:1253
VPxEncoderContext::aq_mode
int aq_mode
Definition: libvpxenc.c:131
AV_PIX_FMT_YUVA422P10
#define AV_PIX_FMT_YUVA422P10
Definition: pixfmt.h:591
tf_sess_config.config
config
Definition: tf_sess_config.py:33
AV_PKT_FLAG_KEY
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
Definition: packet.h:643
quality
trying all byte sequences megabyte in length and selecting the best looking sequence will yield cases to try But a word about quality
Definition: rate_distortion.txt:12
AV_WB64
#define AV_WB64(p, v)
Definition: intreadwrite.h:429
VPxEncoderContext::encoder_alpha
struct vpx_codec_ctx encoder_alpha
Definition: libvpxenc.c:83
AVCodecContext::framerate
AVRational framerate
Definition: avcodec.h:559
AVCOL_SPC_BT470BG
@ AVCOL_SPC_BT470BG
also ITU-R BT601-6 625 / ITU-R BT1358 625 / ITU-R BT1700 625 PAL & SECAM / IEC 61966-2-4 xvYCC601
Definition: pixfmt.h:706
VPxEncoderContext::auto_alt_ref
int auto_alt_ref
Definition: libvpxenc.c:103
AVCOL_SPC_RESERVED
@ AVCOL_SPC_RESERVED
reserved for future use by ITU-T and ISO/IEC just like 15-255 are
Definition: pixfmt.h:704
FrameListData::flags
uint32_t flags
flags for this frame
Definition: libaomenc.c:65
VPxEncoderContext::coded_frame_list
struct FrameListData * coded_frame_list
Definition: libvpxenc.c:91
AV_CODEC_FLAG_COPY_OPAQUE
#define AV_CODEC_FLAG_COPY_OPAQUE
Definition: avcodec.h:279
fifo.h
FFCodecDefault
Definition: codec_internal.h:96
FFCodec::p
AVCodec p
The public AVCodec.
Definition: codec_internal.h:131
VPxEncoderContext::deadline
int deadline
Definition: libvpxenc.c:88
AV_PIX_FMT_GBRAP
@ AV_PIX_FMT_GBRAP
planar GBRA 4:4:4:4 32bpp
Definition: pixfmt.h:212
AVPacket::opaque_ref
AVBufferRef * opaque_ref
AVBufferRef for free use by the API user.
Definition: packet.h:624
fail
#define fail()
Definition: checkasm.h:222
av_fifo_write
int av_fifo_write(AVFifo *f, const void *buf, size_t nb_elems)
Write data into a FIFO.
Definition: fifo.c:188
AVCodecContext::thread_count
int thread_count
thread count is used to decide how many independent tasks should be passed to execute()
Definition: avcodec.h:1573
AV_PIX_FMT_GBRP10
#define AV_PIX_FMT_GBRP10
Definition: pixfmt.h:558
VPxEncoderContext::drop_threshold
int drop_threshold
Definition: libvpxenc.c:132
set_vp8_defaults
static void set_vp8_defaults(AVCodecContext *avctx, struct vpx_codec_enc_cfg *enccfg)
Set the target bitrate to VPX library default.
Definition: libvpxenc.c:953
VPxEncoderContext::roi_warned
int roi_warned
If the driver does not support ROI then warn the first time we encounter a frame with ROI side data.
Definition: libvpxenc.c:148
AVCodecContext::flags
int flags
AV_CODEC_FLAG_*.
Definition: avcodec.h:496
codecctl_int
static av_cold int codecctl_int(AVCodecContext *avctx, enum vp8e_enc_control_id id, int val)
Definition: libvpxenc.c:464
realloc_alpha_uv
static int realloc_alpha_uv(AVCodecContext *avctx, int width, int height)
Definition: libvpxenc.c:1714
val
static double val(void *priv, double ch)
Definition: aeval.c:77
vpx_ts_param_parse
static int vpx_ts_param_parse(VPxContext *ctx, struct vpx_codec_enc_cfg *enccfg, char *key, char *value, enum AVCodecID codec_id)
Definition: libvpxenc.c:690
VPxEncoderContext::max_intra_rate
int max_intra_rate
Definition: libvpxenc.c:115
ff_encode_add_stats_side_data
int ff_encode_add_stats_side_data(AVPacket *pkt, int quality, const int64_t error[], int error_count, enum AVPictureType pict_type)
Definition: encode.c:919
FF_CODEC_ENCODE_CB
#define FF_CODEC_ENCODE_CB(func)
Definition: codec_internal.h:359
AVRational::num
int num
Numerator.
Definition: rational.h:59
LEGACY_OPTIONS
#define LEGACY_OPTIONS
Definition: libvpxenc.c:1994
AV_PIX_FMT_YUV444P10
#define AV_PIX_FMT_YUV444P10
Definition: pixfmt.h:542
vpx_encode
static int vpx_encode(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *frame, int *got_packet)
Definition: libvpxenc.c:1752
avassert.h
lrint
#define lrint
Definition: tablegen.h:53
AV_LOG_ERROR
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:210
AVFrameSideData::size
size_t size
Definition: frame.h:285
FF_ARRAY_ELEMS
#define FF_ARRAY_ELEMS(a)
Definition: sinewin_tablegen.c:29
av_cold
#define av_cold
Definition: attributes.h:111
AVRegionOfInterest
Structure describing a single Region Of Interest.
Definition: frame.h:353
AV_PROFILE_UNKNOWN
#define AV_PROFILE_UNKNOWN
Definition: defs.h:65
av_fifo_read
int av_fifo_read(AVFifo *f, void *buf, size_t nb_elems)
Read data from a FIFO.
Definition: fifo.c:240
AVCodecContext::rc_initial_buffer_occupancy
int rc_initial_buffer_occupancy
Number of bits which should be loaded into the rc buffer before decoding starts.
Definition: avcodec.h:1310
av_dict_get
AVDictionaryEntry * av_dict_get(const AVDictionary *m, const char *key, const AVDictionaryEntry *prev, int flags)
Get a dictionary entry with matching key.
Definition: dict.c:60
av_memcpy_backptr
void av_memcpy_backptr(uint8_t *dst, int back, int cnt)
Overlapping memcpy() implementation.
Definition: mem.c:447
AV_PIX_FMT_GBRAP10
#define AV_PIX_FMT_GBRAP10
Definition: pixfmt.h:562
av_fast_realloc
void * av_fast_realloc(void *ptr, unsigned int *size, size_t min_size)
Reallocate the given buffer if it is not large enough, otherwise do nothing.
Definition: mem.c:497
intreadwrite.h
AVCodecContext::stats_in
char * stats_in
pass2 encoding statistics input buffer Concatenated stuff from stats_out of pass1 should be placed he...
Definition: avcodec.h:1332
AV_PIX_FMT_GBRAP12
#define AV_PIX_FMT_GBRAP12
Definition: pixfmt.h:563
AV_PIX_FMT_YUVA420P
@ AV_PIX_FMT_YUVA420P
planar YUV 4:2:0, 20bpp, (1 Cr & Cb sample per 2x2 Y & A samples)
Definition: pixfmt.h:108
COMMON_OPTIONS
#define COMMON_OPTIONS
Definition: libvpxenc.c:1963
AVRegionOfInterest::bottom
int bottom
Definition: frame.h:369
AVFormatContext::flags
int flags
Flags modifying the (de)muxer behaviour.
Definition: avformat.h:1414
vpx_init
static av_cold int vpx_init(AVCodecContext *avctx, const struct vpx_codec_iface *iface)
Definition: libvpxenc.c:1010
AVCOL_SPC_SMPTE170M
@ AVCOL_SPC_SMPTE170M
also ITU-R BT601-6 525 / ITU-R BT1358 525 / ITU-R BT1700 NTSC / functionally identical to above
Definition: pixfmt.h:707
AVDictionaryEntry::key
char * key
Definition: dict.h:91
AV_CODEC_ID_VP9
@ AV_CODEC_ID_VP9
Definition: codec_id.h:222
AV_CODEC_CAP_OTHER_THREADS
#define AV_CODEC_CAP_OTHER_THREADS
Codec supports multithreading through a method other than slice- or frame-level multithreading.
Definition: codec.h:109
av_strtok
char * av_strtok(char *s, const char *delim, char **saveptr)
Split the string into several tokens which can be accessed by successive calls to av_strtok().
Definition: avstring.c:179
VPxEncoderContext::row_mt
int row_mt
Definition: libvpxenc.c:136
FrameListData::sse
uint64_t sse[4]
Definition: libaomenc.c:66
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
VPxEncoderContext::lag_in_frames
int lag_in_frames
Definition: libvpxenc.c:111
tile_rows
int tile_rows
Definition: h265_levels.c:217
av_assert0
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Definition: avassert.h:42
AV_PIX_FMT_YUVA444P12
#define AV_PIX_FMT_YUVA444P12
Definition: pixfmt.h:594
AV_LOG_DEBUG
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
Definition: log.h:231
VPxEncoderContext::arnr_type
int arnr_type
Definition: libvpxenc.c:107
AV_PIX_FMT_FLAG_ALPHA
#define AV_PIX_FMT_FLAG_ALPHA
The pixel format has an alpha channel.
Definition: pixdesc.h:147
ctx
static AVFormatContext * ctx
Definition: movenc.c:49
MAX_DELTA_Q
#define MAX_DELTA_Q
av_rescale_q
int64_t av_rescale_q(int64_t a, AVRational bq, AVRational cq)
Rescale a 64-bit integer by 2 rational numbers.
Definition: mathematics.c:142
VPxEncoderContext::static_thresh
int static_thresh
Definition: libvpxenc.c:114
codec_id
enum AVCodecID codec_id
Definition: vaapi_decode.c:410
AV_PIX_FMT_YUV420P
@ AV_PIX_FMT_YUV420P
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples)
Definition: pixfmt.h:73
VPxEncoderContext::rc_undershoot_pct
int rc_undershoot_pct
Definition: libvpxenc.c:116
AVCodecContext::rc_max_rate
int64_t rc_max_rate
maximum bitrate
Definition: avcodec.h:1282
AVCodecContext::error
uint64_t error[AV_NUM_DATA_POINTERS]
error
Definition: avcodec.h:1517
key
const char * key
Definition: hwcontext_opencl.c:189
MAX_VPX_THREADS
#define MAX_VPX_THREADS
Definition: libvpx.h:24
cx_pktcpy
static void cx_pktcpy(struct FrameListData *dst, const struct vpx_codec_cx_pkt *src, VPxContext *ctx)
Definition: libvpxenc.c:1350
VPxEncoderContext::current_temporal_idx
int current_temporal_idx
Definition: libvpxenc.c:121
AV_ROUND_NEAR_INF
@ AV_ROUND_NEAR_INF
Round to nearest and halfway cases away from zero.
Definition: mathematics.h:135
AVPacket::opaque
void * opaque
for some private data of the user
Definition: packet.h:613
AVCPBProperties
This structure describes the bitrate properties of an encoded bitstream.
Definition: defs.h:282
CODEC_LONG_NAME
#define CODEC_LONG_NAME(str)
Definition: codec_internal.h:332
tmp
static uint8_t tmp[40]
Definition: aes_ctr.c:52
AVCodecContext::codec_id
enum AVCodecID codec_id
Definition: avcodec.h:449
if
if(ret)
Definition: filter_design.txt:179
set_vpx_defaults
static void set_vpx_defaults(AVCodecContext *avctx, struct vpx_codec_enc_cfg *enccfg)
Called when the bitrate is not set.
Definition: libvpxenc.c:997
AVCodecContext::rc_buffer_size
int rc_buffer_size
decoder bitstream buffer size
Definition: avcodec.h:1267
VPxEncoderContext::ts_layer_flags
int * ts_layer_flags
Definition: libvpxenc.c:120
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
AVCodecContext::color_range
enum AVColorRange color_range
MPEG vs JPEG YUV range.
Definition: avcodec.h:677
av_buffer_unref
void av_buffer_unref(AVBufferRef **buf)
Free a given reference and automatically free the buffer if there are no more references to it.
Definition: buffer.c:139
IS_VP9
#define IS_VP9(avctx)
Definition: libvpxenc.c:51
frame_data_apply
static int frame_data_apply(AVCodecContext *avctx, AVFifo *fifo, AVPacket *pkt)
Definition: libvpxenc.c:413
VPxEncoderContext::twopass_stats
struct vpx_fixed_buf twopass_stats
Definition: libvpxenc.c:86
vpx_free
static av_cold int vpx_free(AVCodecContext *avctx)
Definition: libvpxenc.c:530
AVCodecContext::bit_rate
int64_t bit_rate
the average bitrate
Definition: avcodec.h:489
FrameData::duration
int64_t duration
Definition: librav1e.c:60
AVRegionOfInterest::self_size
uint32_t self_size
Must be set to the size of this data structure (that is, sizeof(AVRegionOfInterest)).
Definition: frame.h:358
av_default_item_name
const char * av_default_item_name(void *ptr)
Return the context name.
Definition: log.c:242
AV_PICTURE_TYPE_I
@ AV_PICTURE_TYPE_I
Intra.
Definition: avutil.h:278
profiles.h
AV_PIX_FMT_YUV440P10
#define AV_PIX_FMT_YUV440P10
Definition: pixfmt.h:541
list
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 list
Definition: filter_design.txt:25
VPxEncoderContext::noise_sensitivity
int noise_sensitivity
Definition: libvpxenc.c:133
FrameData::frame_opaque
void * frame_opaque
Definition: librav1e.c:62
FrameListData::buf
void * buf
compressed data buffer
Definition: libaomenc.c:59
VPxEncoderContext::crf
int crf
Definition: libvpxenc.c:113
VPxEncoderContext::tpl_model
int tpl_model
Definition: libvpxenc.c:139
AV_PIX_FMT_YUV422P10
#define AV_PIX_FMT_YUV422P10
Definition: pixfmt.h:540
av_base64_decode
int av_base64_decode(uint8_t *out, const char *in_str, int out_size)
Decode a base64-encoded string.
Definition: base64.c:81
VPxEncoderContext::encoder
struct vpx_codec_ctx encoder
Definition: libvpxenc.c:81
VPxEncoderContext::flags
int flags
VP8 specific flags, see VP8F_* below.
Definition: libvpxenc.c:99
base64.h
stats
static void stats(AVPacket *const *in, int n_in, unsigned *_max, unsigned *_sum)
Definition: vp9_superframe.c:34
AVCOL_RANGE_UNSPECIFIED
@ AVCOL_RANGE_UNSPECIFIED
Definition: pixfmt.h:743
free_frame_list
static av_cold void free_frame_list(struct FrameListData *list)
Definition: libvpxenc.c:329
AVCodecID
AVCodecID
Identify the syntax and semantics of the bitstream.
Definition: codec_id.h:49
vp8_encode_set_roi
static int vp8_encode_set_roi(AVCodecContext *avctx, int frame_width, int frame_height, const AVFrameSideData *sd)
Definition: libvpxenc.c:1692
av_cpu_count
int av_cpu_count(void)
Definition: cpu.c:228
AVCodecContext::qcompress
float qcompress
amount of qscale change between easy & hard scenes (0.0-1.0)
Definition: avcodec.h:1238
AVCodecContext::time_base
AVRational time_base
This is the fundamental unit of time (in seconds) in terms of which frame timestamps are represented.
Definition: avcodec.h:543
AVCOL_TRC_SMPTE2084
@ AVCOL_TRC_SMPTE2084
SMPTE ST 2084 for 10-, 12-, 14- and 16-bit systems.
Definition: pixfmt.h:683
av_rescale_rnd
int64_t av_rescale_rnd(int64_t a, int64_t b, int64_t c, enum AVRounding rnd)
Rescale a 64-bit integer with specified rounding.
Definition: mathematics.c:58
FrameListData::next
struct FrameListData * next
Definition: libaomenc.c:69
AVCodecContext::stats_out
char * stats_out
pass1 encoding statistics output buffer
Definition: avcodec.h:1324
VPxEncoderContext::rc_overshoot_pct
int rc_overshoot_pct
Definition: libvpxenc.c:117
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
AVPacket::size
int size
Definition: packet.h:589
AVFifo
Definition: fifo.c:35
NULL_IF_CONFIG_SMALL
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
Definition: internal.h:94
AVCodecContext::gop_size
int gop_size
the number of pictures in a group of pictures, or 0 for intra_only
Definition: avcodec.h:1017
height
#define height
Definition: dsp.h:89
codec_internal.h
dst
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
Definition: dsp.h:87
AV_PKT_DATA_DYNAMIC_HDR10_PLUS
@ AV_PKT_DATA_DYNAMIC_HDR10_PLUS
HDR10+ dynamic metadata associated with a video frame.
Definition: packet.h:296
cpu.h
i
#define i(width, name, range_min, range_max)
Definition: cbs_h264.c:63
FrameData::hdr10_plus
AVBufferRef * hdr10_plus
Definition: libvpxenc.c:76
fifo_free
static av_cold void fifo_free(AVFifo **fifo)
Definition: libvpxenc.c:346
AV_PIX_FMT_YUV422P12
#define AV_PIX_FMT_YUV422P12
Definition: pixfmt.h:544
size
int size
Definition: twinvq_data.h:10344
VPxEncoderContext::lossless
int lossless
Definition: libvpxenc.c:127
av_reallocp
int av_reallocp(void *ptr, size_t size)
Allocate, reallocate, or free a block of memory through a pointer to a pointer.
Definition: mem.c:188
AV_PIX_FMT_YUV444P12
#define AV_PIX_FMT_YUV444P12
Definition: pixfmt.h:546
AVFrameSideData::data
uint8_t * data
Definition: frame.h:284
VPxEncoderContext::tune_content
int tune_content
Definition: libvpxenc.c:137
VPxEncoderContext::corpus_complexity
int corpus_complexity
Definition: libvpxenc.c:138
VPxEncoderContext::tile_rows
int tile_rows
Definition: libvpxenc.c:129
AVCPBProperties::min_bitrate
int64_t min_bitrate
Minimum bitrate of the stream, in bits per second.
Definition: defs.h:292
FrameListData
Portion of struct vpx_codec_cx_pkt from vpx_encoder.h.
Definition: libaomenc.c:58
VPxEncoderContext::sharpness
int sharpness
Definition: libvpxenc.c:95
vp9_encode_set_roi
static int vp9_encode_set_roi(AVCodecContext *avctx, int frame_width, int frame_height, const AVFrameSideData *sd)
Definition: libvpxenc.c:1642
AVPacket::dts
int64_t dts
Decompression timestamp in AVStream->time_base units; the time at which the packet is decompressed.
Definition: packet.h:587
AV_CODEC_FLAG_PASS2
#define AV_CODEC_FLAG_PASS2
Use internal 2pass ratecontrol in second pass mode.
Definition: avcodec.h:294
FrameData::pts
int64_t pts
Definition: ffmpeg.h:731
AV_PIX_FMT_YUVA444P
@ AV_PIX_FMT_YUVA444P
planar YUV 4:4:4 32bpp, (1 Cr & Cb sample per 1x1 Y & A samples)
Definition: pixfmt.h:174
AV_PIX_FMT_YUVA444P10
#define AV_PIX_FMT_YUVA444P10
Definition: pixfmt.h:592
AVPacket::flags
int flags
A combination of AV_PKT_FLAG values.
Definition: packet.h:594
FrameData::frame_opaque_ref
AVBufferRef * frame_opaque_ref
Definition: librav1e.c:63
AVCPBProperties::avg_bitrate
int64_t avg_bitrate
Average bitrate of the stream, in bits per second.
Definition: defs.h:297
version
version
Definition: libkvazaar.c:313
AVRegionOfInterest::right
int right
Definition: frame.h:371
VPxEncoderContext::tune
int tune
Definition: libvpxenc.c:109
AVBufferRef::size
size_t size
Size of data in bytes.
Definition: buffer.h:94
AV_LOG_INFO
#define AV_LOG_INFO
Standard information.
Definition: log.h:221
AV_OPT_TYPE_FLOAT
@ AV_OPT_TYPE_FLOAT
Underlying C type is float.
Definition: opt.h:271
AVCOL_SPC_SMPTE240M
@ AVCOL_SPC_SMPTE240M
derived from 170M primaries and D65 white point, 170M is derived from BT470 System M's primaries
Definition: pixfmt.h:708
frame_data_submit
static int frame_data_submit(AVCodecContext *avctx, AVFifo *fifo, const AVFrame *frame)
Definition: libvpxenc.c:361
VPxEncoderContext::twopass_stats_size
unsigned twopass_stats_size
Definition: libvpxenc.c:87
AVRegionOfInterest::left
int left
Definition: frame.h:370
AV_BASE64_SIZE
#define AV_BASE64_SIZE(x)
Calculate the output size needed to base64-encode x bytes to a null-terminated string.
Definition: base64.h:66
VPxEncoderContext::vpx_ts_parameters
AVDictionary * vpx_ts_parameters
Definition: libvpxenc.c:119
VPxEncoderContext::tile_columns
int tile_columns
Definition: libvpxenc.c:128
ff_default_get_supported_config
int ff_default_get_supported_config(const AVCodecContext *avctx, const AVCodec *codec, enum AVCodecConfig config, unsigned flags, const void **out_configs, int *out_num_configs)
Definition: avcodec.c:768
AVPacket::pts
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
Definition: packet.h:581
AVCOL_SPC_BT2020_NCL
@ AVCOL_SPC_BT2020_NCL
ITU-R BT2020 non-constant luminance system.
Definition: pixfmt.h:711
AVRegionOfInterest::top
int top
Distance in pixels from the top edge of the frame to the top and bottom edges and from the left edge ...
Definition: frame.h:368
internal.h
AV_PIX_FMT_GBRP12
#define AV_PIX_FMT_GBRP12
Definition: pixfmt.h:559
av_malloc_array
#define av_malloc_array(a, b)
Definition: tableprint_vlc.h:32
common.h
AVCPBProperties::max_bitrate
int64_t max_bitrate
Maximum bitrate of the stream, in bits per second.
Definition: defs.h:287
value
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 value
Definition: writing_filters.txt:86
FFMIN
#define FFMIN(a, b)
Definition: macros.h:49
AVCodec::name
const char * name
Name of the codec implementation.
Definition: codec.h:179
av_inv_q
static av_always_inline AVRational av_inv_q(AVRational q)
Invert a rational.
Definition: rational.h:159
av_buffer_replace
int av_buffer_replace(AVBufferRef **pdst, const AVBufferRef *src)
Ensure dst refers to the same data as src.
Definition: buffer.c:233
AVCOL_SPC_UNSPECIFIED
@ AVCOL_SPC_UNSPECIFIED
Definition: pixfmt.h:703
AVCodecContext::height
int height
Definition: avcodec.h:600
AVCodecContext::pix_fmt
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
Definition: avcodec.h:639
AVCOL_RANGE_MPEG
@ AVCOL_RANGE_MPEG
Narrow or limited range content.
Definition: pixfmt.h:760
av_calloc
void * av_calloc(size_t nmemb, size_t size)
Definition: mem.c:264
defaults
static const FFCodecDefault defaults[]
Definition: libvpxenc.c:2073
avcodec.h
delta_q
#define delta_q(name)
Definition: cbs_av1.c:657
AV_PKT_DATA_MATROSKA_BLOCKADDITIONAL
@ AV_PKT_DATA_MATROSKA_BLOCKADDITIONAL
Data found in BlockAdditional element of matroska container.
Definition: packet.h:188
ret
ret
Definition: filter_design.txt:187
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
frame
these buffered frames must be flushed immediately if a new input produces new the filter must not call request_frame to get more It must just process the frame or queue it The task of requesting more frames is left to the filter s request_frame method or the application If a filter has several the filter must be ready for frames arriving randomly on any input any filter with several inputs will most likely require some kind of queuing mechanism It is perfectly acceptable to have a limited queue and to drop frames when the inputs are too unbalanced request_frame For filters that do not use the this method is called when a frame is wanted on an output For a it should directly call filter_frame on the corresponding output For a if there are queued frames already one of these frames should be pushed If the filter should request a frame on one of its repeatedly until at least one frame has been pushed Return or at least make progress towards producing a frame
Definition: filter_design.txt:265
AVCPBProperties::buffer_size
int64_t buffer_size
The size of the buffer to which the ratecontrol is applied, in bits.
Definition: defs.h:303
VPxEncoderContext::cpu_used
int cpu_used
Definition: libvpxenc.c:94
VPxEncoderContext::alpha_coded_frame_list
struct FrameListData * alpha_coded_frame_list
Definition: libvpxenc.c:92
av_malloc
void * av_malloc(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
Definition: mem.c:98
AVCodecContext::strict_std_compliance
int strict_std_compliance
strictly follow the standard (MPEG-4, ...).
Definition: avcodec.h:1369
av_fifo_alloc2
AVFifo * av_fifo_alloc2(size_t nb_elems, size_t elem_size, unsigned int flags)
Allocate and initialize an AVFifo with a given element size.
Definition: fifo.c:47
AV_PIX_FMT_YUV420P12
#define AV_PIX_FMT_YUV420P12
Definition: pixfmt.h:543
AV_FRAME_DATA_DYNAMIC_HDR_PLUS
@ AV_FRAME_DATA_DYNAMIC_HDR_PLUS
HDR dynamic metadata associated with a video frame.
Definition: frame.h:159
AVCodecContext
main external API structure.
Definition: avcodec.h:439
av_packet_new_side_data
uint8_t * av_packet_new_side_data(AVPacket *pkt, enum AVPacketSideDataType type, size_t size)
Allocate new information of a packet.
Definition: packet.c:231
ff_get_encode_buffer
int ff_get_encode_buffer(AVCodecContext *avctx, AVPacket *avpkt, int64_t size, int flags)
Get a buffer for a packet.
Definition: encode.c:105
AVCodecContext::qmin
int qmin
minimum quantizer
Definition: avcodec.h:1246
AVRational::den
int den
Denominator.
Definition: rational.h:60
storeframe
static int storeframe(AVCodecContext *avctx, struct FrameListData *cx_frame, struct FrameListData *alpha_cx_frame, AVPacket *pkt)
Store coded frame information in format suitable for return from encode2().
Definition: libvpxenc.c:1380
AV_PIX_FMT_NONE
@ AV_PIX_FMT_NONE
Definition: pixfmt.h:72
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:1630
av_get_token
char * av_get_token(const char **buf, const char *term)
Unescape the given string until a non escaped terminating char, and return the token corresponding to...
Definition: avstring.c:143
ctlidstr
static const char *const ctlidstr[]
String mappings for enum vp8e_enc_control_id.
Definition: libvpxenc.c:155
av_base64_encode
char * av_base64_encode(char *out, int out_size, const uint8_t *in, int in_size)
Encode data to base64 and null-terminate.
Definition: base64.c:147
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
Windows::Graphics::DirectX::Direct3D11::p
IDirect3DDxgiInterfaceAccess _COM_Outptr_ void ** p
Definition: vsrc_gfxcapture_winrt.hpp:53
VPxEncoderContext::frame_parallel
int frame_parallel
Definition: libvpxenc.c:130
ff_libvpx_vp8_encoder
const FFCodec ff_libvpx_vp8_encoder
AV_PIX_FMT_YUV444P
@ AV_PIX_FMT_YUV444P
planar YUV 4:4:4, 24bpp, (1 Cr & Cb sample per 1x1 Y samples)
Definition: pixfmt.h:78
VPxEncoderContext::error_resilient
int error_resilient
Definition: libvpxenc.c:112
AV_PIX_FMT_GBRP
@ AV_PIX_FMT_GBRP
planar GBR 4:4:4 24bpp
Definition: pixfmt.h:165
OFFSET
#define OFFSET(x)
Definition: libvpxenc.c:1960
desc
const char * desc
Definition: libsvtav1.c:82
AV_PICTURE_TYPE_P
@ AV_PICTURE_TYPE_P
Predicted.
Definition: avutil.h:279
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:200
coded_frame_add
static void coded_frame_add(void *list, struct FrameListData *cx_frame)
Definition: libvpxenc.c:313
AV_PIX_FMT_YUV422P
@ AV_PIX_FMT_YUV422P
planar YUV 4:2:2, 16bpp, (1 Cr & Cb sample per 2x1 Y samples)
Definition: pixfmt.h:77
mem.h
AVBufferRef
A reference to a data buffer.
Definition: buffer.h:82
FF_CODEC_CAP_AUTO_THREADS
#define FF_CODEC_CAP_AUTO_THREADS
Codec handles avctx->thread_count == 0 (auto) internally.
Definition: codec_internal.h:72
AVFrameSideData
Structure to hold side data for an AVFrame.
Definition: frame.h:282
AVPixFmtDescriptor
Descriptor that unambiguously describes how the bits of a pixel are stored in the up to 4 data planes...
Definition: pixdesc.h:69
set_temporal_layer_pattern
static void set_temporal_layer_pattern(int layering_mode, vpx_codec_enc_cfg_t *cfg, int *layer_flags, int *flag_periodicity)
Definition: libvpxenc.c:586
planes
static const struct @570 planes[]
dump_enc_cfg
static av_cold void dump_enc_cfg(AVCodecContext *avctx, const struct vpx_codec_enc_cfg *cfg, int level)
Definition: libvpxenc.c:215
AVDictionaryEntry
Definition: dict.h:90
VPxEncoderContext::arnr_max_frames
int arnr_max_frames
Definition: libvpxenc.c:105
AVCodecContext::slices
int slices
Number of slices.
Definition: avcodec.h:1033
AVPacket
This structure stores compressed data.
Definition: packet.h:565
AVCodecContext::priv_data
void * priv_data
Definition: avcodec.h:466
VPxEncoderContext::vpx_cs
int vpx_cs
Definition: libvpxenc.c:134
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
set_roi_map
static int set_roi_map(AVCodecContext *avctx, const AVFrameSideData *sd, int frame_width, int frame_height, vpx_roi_map_t *roi_map, int block_size, int segment_cnt)
Definition: libvpxenc.c:1535
queue_frames
static int queue_frames(AVCodecContext *avctx, struct vpx_codec_ctx *encoder, struct FrameListData **frame_list, AVPacket *pkt_out)
Queue multiple output frames from the encoder, returning the front-most.
Definition: libvpxenc.c:1440
AVCodecContext::width
int width
picture width / height.
Definition: avcodec.h:600
AV_FRAME_DATA_REGIONS_OF_INTEREST
@ AV_FRAME_DATA_REGIONS_OF_INTEREST
Regions Of Interest, the data is an array of AVRegionOfInterest type, the number of array element is ...
Definition: frame.h:165
AV_CODEC_ID_VP8
@ AV_CODEC_ID_VP8
Definition: codec_id.h:192
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:27
FrameListData::sz
size_t sz
length of compressed data
Definition: libaomenc.c:60
av_fifo_freep2
void av_fifo_freep2(AVFifo **f)
Free an AVFifo and reset pointer to NULL.
Definition: fifo.c:286
AVERROR_INVALIDDATA
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
Definition: error.h:61
libvpx.h
AV_PIX_FMT_YUV440P12
#define AV_PIX_FMT_YUV440P12
Definition: pixfmt.h:545
free_coded_frame
static av_cold void free_coded_frame(struct FrameListData *cx_frame)
Definition: libvpxenc.c:323
VPxEncoderContext::arnr_strength
int arnr_strength
Definition: libvpxenc.c:106
vp8_init
static av_cold int vp8_init(AVFormatContext *s, int st_index, PayloadContext *vp8)
Definition: rtpdec_vp8.c:263
ff_encode_add_cpb_side_data
AVCPBProperties * ff_encode_add_cpb_side_data(AVCodecContext *avctx)
Add a CPB properties side data to an encoding context.
Definition: encode.c:888
stride
#define stride
Definition: h264pred_template.c:536
AVDictionaryEntry::value
char * value
Definition: dict.h:92
pkt
static AVPacket * pkt
Definition: demux_decode.c:55
avstring.h
width
#define width
Definition: dsp.h:89
FF_QP2LAMBDA
#define FF_QP2LAMBDA
factor to convert from H.263 QP to lambda
Definition: avutil.h:226
AVCOL_SPC_BT709
@ AVCOL_SPC_BT709
also ITU-R BT1361 / IEC 61966-2-4 xvYCC709 / derived in SMPTE RP 177 Annex B
Definition: pixfmt.h:702
VE
#define VE
Definition: libvpxenc.c:1961
AVRegionOfInterest::qoffset
AVRational qoffset
Quantisation offset.
Definition: frame.h:395
AV_OPT_TYPE_CONST
@ AV_OPT_TYPE_CONST
Special option type for declaring named constants.
Definition: opt.h:299
snprintf
#define snprintf
Definition: snprintf.h:34
av_log2
int av_log2(unsigned v)
Definition: intmath.c:26
VPxEncoderContext::sse
uint64_t sse[4]
Definition: libvpxenc.c:89
AVCodecConfig
AVCodecConfig
Definition: avcodec.h:2548
av_dict_iterate
const AVDictionaryEntry * av_dict_iterate(const AVDictionary *m, const AVDictionaryEntry *prev)
Iterate over a dictionary.
Definition: dict.c:42
skip
static void BS_FUNC() skip(BSCTX *bc, unsigned int n)
Skip n bits in the buffer.
Definition: bitstream_template.h:383
src
#define src
Definition: vp8dsp.c:248
duration
static int64_t duration
Definition: ffplay.c:329
AV_FIFO_FLAG_AUTO_GROW
#define AV_FIFO_FLAG_AUTO_GROW
Automatically resize the FIFO on writes, so that the data fits.
Definition: fifo.h:63
AV_PIX_FMT_YUVA422P
@ AV_PIX_FMT_YUVA422P
planar YUV 4:2:2 24bpp, (1 Cr & Cb sample per 2x1 Y & A samples)
Definition: pixfmt.h:173
ff_vp9_profiles
const AVProfile ff_vp9_profiles[]
Definition: profiles.c:155
av_get_pix_fmt_name
const char * av_get_pix_fmt_name(enum AVPixelFormat pix_fmt)
Return the short name for a pixel format, NULL in case pix_fmt is unknown.
Definition: pixdesc.c:3376
AV_CODEC_FLAG_PASS1
#define AV_CODEC_FLAG_PASS1
Use internal 2pass ratecontrol in first pass mode.
Definition: avcodec.h:290
VPxEncoderContext::min_gf_interval
int min_gf_interval
Definition: libvpxenc.c:140
FrameListData::have_sse
int have_sse
true if we have pending sse[]
Definition: libaomenc.c:67
AV_WN16
#define AV_WN16(p, v)
Definition: intreadwrite.h:368