FFmpeg
ffv1dec.c
Go to the documentation of this file.
1 /*
2  * FFV1 decoder
3  *
4  * Copyright (c) 2003-2013 Michael Niedermayer <michaelni@gmx.at>
5  *
6  * This file is part of FFmpeg.
7  *
8  * FFmpeg is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Lesser General Public
10  * License as published by the Free Software Foundation; either
11  * version 2.1 of the License, or (at your option) any later version.
12  *
13  * FFmpeg is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16  * Lesser General Public License for more details.
17  *
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with FFmpeg; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21  */
22 
23 /**
24  * @file
25  * FF Video Codec 1 (a lossless codec) decoder
26  */
27 
28 #include "libavutil/avassert.h"
29 #include "libavutil/crc.h"
30 #include "libavutil/mem.h"
31 #include "libavutil/imgutils.h"
32 #include "libavutil/pixdesc.h"
33 #include "avcodec.h"
34 #include "codec_internal.h"
35 #include "get_bits.h"
36 #include "rangecoder.h"
37 #include "golomb.h"
38 #include "mathops.h"
39 #include "ffv1.h"
40 #include "progressframe.h"
41 #include "libavutil/refstruct.h"
42 #include "thread.h"
43 #include "decode.h"
44 #include "hwconfig.h"
45 #include "hwaccel_internal.h"
46 #include "config_components.h"
47 
48 static inline int get_vlc_symbol(GetBitContext *gb, VlcState *const state,
49  int bits)
50 {
51  int k, i, v, ret;
52 
53  i = state->count;
54  k = 0;
55  while (i < state->error_sum) { // FIXME: optimize
56  k++;
57  i += i;
58  }
59  if (k > bits) {
60  ff_dlog(NULL, "k-overflow bias:%d error:%d drift:%d count:%d k:%d",
61  state->bias, state->error_sum, state->drift, state->count, k);
62  k = bits;
63  }
64 
65  v = get_sr_golomb(gb, k, 12, bits);
66  ff_dlog(NULL, "v:%d bias:%d error:%d drift:%d count:%d k:%d",
67  v, state->bias, state->error_sum, state->drift, state->count, k);
68 
69  v ^= ((2 * state->drift + state->count) >> 31);
70 
71  ret = fold(v + state->bias, bits);
72 
74 
75  return ret;
76 }
77 
78 static int is_input_end(RangeCoder *c, GetBitContext *gb, int ac)
79 {
80  if (ac != AC_GOLOMB_RICE) {
81  if (c->overread > MAX_OVERREAD)
82  return AVERROR_INVALIDDATA;
83  } else {
84  if (get_bits_left(gb) < 1)
85  return AVERROR_INVALIDDATA;
86  }
87  return 0;
88 }
89 
90 #define TYPE int16_t
91 #define RENAME(name) name
92 #include "ffv1dec_template.c"
93 #undef TYPE
94 #undef RENAME
95 
96 #define TYPE int32_t
97 #define RENAME(name) name ## 32
98 #include "ffv1dec_template.c"
99 
101  GetBitContext *gb,
102  uint8_t *src, int w, int h, int stride, int plane_index,
103  int remap_index, int pixel_stride, int ac)
104 {
105  int x, y;
106  int16_t *sample[2];
107  int bits;
108  unsigned mask;
109 
110  if (sc->remap) {
111  bits = av_ceil_log2(sc->remap_count[remap_index]);
112  mask = (1<<bits)-1;
113 
114  av_assert0(sc->fltmap_size[remap_index] >= (mask + 1) * sizeof(*sc->fltmap[remap_index]));
115  } else {
116  bits = f->avctx->bits_per_raw_sample;
117  }
118 
119  sample[0] = sc->sample_buffer + 3;
120  sample[1] = sc->sample_buffer + w + 6 + 3;
121 
122  sc->run_index = 0;
123 
124  memset(sc->sample_buffer, 0, 2 * (w + 6) * sizeof(*sc->sample_buffer));
125 
126  for (y = 0; y < h; y++) {
127  int16_t *temp = sample[0]; // FIXME: try a normal buffer
128 
129  sample[0] = sample[1];
130  sample[1] = temp;
131 
132  sample[1][-1] = sample[0][0];
133  sample[0][w] = sample[0][w - 1];
134 
135  if (f->avctx->bits_per_raw_sample <= 8) {
136  int ret = decode_line(f, sc, gb, w, sample, plane_index, 8, ac);
137  if (ret < 0)
138  return ret;
139  if (sc->remap)
140  for (x = 0; x < w; x++)
141  sample[1][x] = sc->fltmap[remap_index][sample[1][x]];
142  for (x = 0; x < w; x++)
143  src[x*pixel_stride + stride * y] = sample[1][x];
144  } else {
145  int ret = decode_line(f, sc, gb, w, sample, plane_index, bits, ac);
146  if (ret < 0)
147  return ret;
148 
149  if (sc->remap) {
150  if (f->packed_at_lsb || f->avctx->bits_per_raw_sample == 16) {
151  for (x = 0; x < w; x++) {
152  ((uint16_t*)(src + stride*y))[x*pixel_stride] = sc->fltmap[remap_index][sample[1][x] & mask];
153  }
154  } else {
155  for (x = 0; x < w; x++) {
156  int v = sc->fltmap[remap_index][sample[1][x] & mask];
157  ((uint16_t*)(src + stride*y))[x*pixel_stride] = v << (16 - f->avctx->bits_per_raw_sample) | v >> (2 * f->avctx->bits_per_raw_sample - 16);
158  }
159  }
160  } else {
161  if (f->packed_at_lsb || f->avctx->bits_per_raw_sample == 16) {
162  for (x = 0; x < w; x++) {
163  ((uint16_t*)(src + stride*y))[x*pixel_stride] = sample[1][x];
164  }
165  } else {
166  for (x = 0; x < w; x++) {
167  ((uint16_t*)(src + stride*y))[x*pixel_stride] = sample[1][x] << (16 - f->avctx->bits_per_raw_sample) | ((uint16_t **)sample)[1][x] >> (2 * f->avctx->bits_per_raw_sample - 16);
168  }
169  }
170  }
171  }
172  }
173  return 0;
174 }
175 
178 {
179  RangeCoder *c = &sc->c;
180  uint8_t state[CONTEXT_SIZE];
181  unsigned ps, context_count;
182  int sx, sy, sw, sh;
183 
184  memset(state, 128, sizeof(state));
185  sx = ff_ffv1_get_symbol(c, state, 0);
186  sy = ff_ffv1_get_symbol(c, state, 0);
187  sw = ff_ffv1_get_symbol(c, state, 0) + 1U;
188  sh = ff_ffv1_get_symbol(c, state, 0) + 1U;
189 
190  av_assert0(f->version > 2);
191 
192 
193  if (sx < 0 || sy < 0 || sw <= 0 || sh <= 0)
194  return AVERROR_INVALIDDATA;
195  if (sx > f->num_h_slices - sw || sy > f->num_v_slices - sh)
196  return AVERROR_INVALIDDATA;
197 
198  sc->slice_x = ff_slice_coord(f, f->width , sx , f->num_h_slices, f->chroma_h_shift);
199  sc->slice_y = ff_slice_coord(f, f->height, sy , f->num_v_slices, f->chroma_v_shift);
200  sc->slice_width = ff_slice_coord(f, f->width , sx + sw, f->num_h_slices, f->chroma_h_shift) - sc->slice_x;
201  sc->slice_height = ff_slice_coord(f, f->height, sy + sh, f->num_v_slices, f->chroma_v_shift) - sc->slice_y;
202 
203  av_assert0((unsigned)sc->slice_width <= f->width &&
204  (unsigned)sc->slice_height <= f->height);
205  av_assert0 ( (unsigned)sc->slice_x + (uint64_t)sc->slice_width <= f->width
206  && (unsigned)sc->slice_y + (uint64_t)sc->slice_height <= f->height);
207 
208  if (f->ac == AC_GOLOMB_RICE && sc->slice_width >= (1<<23))
209  return AVERROR_INVALIDDATA;
210 
211  for (unsigned i = 0; i < f->plane_count; i++) {
212  PlaneContext * const p = &sc->plane[i];
213  int idx = ff_ffv1_get_symbol(c, state, 0);
214  if (idx >= (unsigned)f->quant_table_count) {
215  av_log(f->avctx, AV_LOG_ERROR, "quant_table_index out of range\n");
216  return -1;
217  }
218  p->quant_table_index = idx;
219  context_count = f->context_count[idx];
220 
221  if (p->context_count < context_count) {
222  av_freep(&p->state);
223  av_freep(&p->vlc_state);
224  }
225  p->context_count = context_count;
226  }
227 
228  ps = ff_ffv1_get_symbol(c, state, 0);
229  if (ps == 1) {
232  } else if (ps == 2) {
235  } else if (ps == 3) {
236  frame->flags &= ~AV_FRAME_FLAG_INTERLACED;
237  }
238  frame->sample_aspect_ratio.num = ff_ffv1_get_symbol(c, state, 0);
239  frame->sample_aspect_ratio.den = ff_ffv1_get_symbol(c, state, 0);
240 
241  if (av_image_check_sar(f->width, f->height,
242  frame->sample_aspect_ratio) < 0) {
243  av_log(f->avctx, AV_LOG_WARNING, "ignoring invalid SAR: %u/%u\n",
244  frame->sample_aspect_ratio.num,
245  frame->sample_aspect_ratio.den);
246  frame->sample_aspect_ratio = (AVRational){ 0, 1 };
247  }
248 
249  if (f->version > 3) {
252  if (sc->slice_coding_mode != 1 && f->colorspace != 0) {
255  if ((uint64_t)sc->slice_rct_by_coef + (uint64_t)sc->slice_rct_ry_coef > 4) {
256  av_log(f->avctx, AV_LOG_ERROR, "slice_rct_y_coef out of range\n");
257  return AVERROR_INVALIDDATA;
258  }
259  }
260  if (f->combined_version >= 0x40004) {
261  sc->remap = ff_ffv1_get_symbol(c, state, 0);
262  if (sc->remap > 2U ||
263  sc->remap && !f->flt) {
264  av_log(f->avctx, AV_LOG_ERROR, "unsupported remap %d\n", sc->remap);
265  return AVERROR_INVALIDDATA;
266  }
267  }
268  }
269  if (f->avctx->bits_per_raw_sample == 32) {
270  if (!sc->remap) {
271  av_log(f->avctx, AV_LOG_ERROR, "unsupported remap\n");
272  return AVERROR_INVALIDDATA;
273  }
274  }
275 
276  return 0;
277 }
278 
280 {
281  sc->slice_damaged = 1;
282 
283  // only set this for frame threading, as for slice threading its value is
284  // not used and setting it would be a race
285  if (f->avctx->active_thread_type & FF_THREAD_FRAME)
286  f->frame_damaged = 1;
287 }
288 
289 static int decode_current_mul(RangeCoder *rc, uint8_t state[32], int *mul, int mul_count, int64_t i)
290 {
291  int ndx = (i * mul_count) >> 32;
292  av_assert2(ndx <= 4096U);
293 
294  if (mul[ndx] < 0)
295  mul[ndx] = ff_ffv1_get_symbol(rc, state, 0) & 0x3FFFFFFF;
296 
297  return mul[ndx];
298 }
299 
301 {
302  unsigned int end = (1LL<<f->avctx->bits_per_raw_sample) - 1;
303  int flip = sc->remap == 2 ? (end>>1) : 0;
304 
305  for (int p = 0; p < 1 + 2*f->chroma_planes + f->transparency; p++) {
306  int j = 0;
307  int lu = 0;
308  uint8_t state[2][3][32];
309  int64_t i;
310  int mul[4096+1];
311  int mul_count;
312 
313  const int is_chroma = (p == 1 || p == 2) && f->chroma_planes;
314  const int plane_width = AV_CEIL_RSHIFT(sc->slice_width , is_chroma ? f->chroma_h_shift : 0);
315  const int plane_height = AV_CEIL_RSHIFT(sc->slice_height, is_chroma ? f->chroma_v_shift : 0);
316  const int pixel_num = FFMIN(plane_width * plane_height, end + 1LL);
317  const size_t fltmap_ceil = 1ULL << av_ceil_log2(pixel_num);
318 
319  if (f->avctx->bits_per_raw_sample == 32) {
320  av_fast_malloc(&sc->fltmap32[p], &sc->fltmap32_size[p], fltmap_ceil * sizeof(*sc->fltmap32[p]));
321  if (!sc->fltmap32[p])
322  return AVERROR(ENOMEM);
323  } else {
324  av_fast_malloc(&sc->fltmap[p] , &sc->fltmap_size[p] , fltmap_ceil * sizeof(*sc->fltmap[p]));
325  if (!sc->fltmap[p])
326  return AVERROR(ENOMEM);
327  }
328 
329  memset(state, 128, sizeof(state));
330  mul_count = ff_ffv1_get_symbol(&sc->c, state[0][0], 0);
331 
332  if (mul_count > 4096U)
333  return AVERROR_INVALIDDATA;
334  for (int i = 0; i<mul_count; i++) {
335  mul[i] = -1;
336 
337  }
338  mul[mul_count] = 1;
339 
340  memset(state, 128, sizeof(state));
341  int current_mul = 1;
342  for (i=0; i <= end ;) {
343  unsigned run = get_symbol_inline(&sc->c, state[lu][0], 0);
344  unsigned run0 = lu ? 0 : run;
345  unsigned run1 = lu ? run : 1;
346 
347  i += run0 * current_mul;
348 
349  while (run1--) {
350  if (current_mul > 1) {
351  int delta = get_symbol_inline(&sc->c, state[lu][1], 1);
352  if (delta <= -current_mul || delta > current_mul/2)
353  return AVERROR_INVALIDDATA; //not sure we should check this
354  i += current_mul - 1 + delta;
355  }
356  if (i - 1 >= end)
357  break;
358  if (j >= pixel_num)
359  return AVERROR_INVALIDDATA;
360  if (end <= 0xFFFF) {
361  sc->fltmap [p][j++] = i ^ ((i& 0x8000) ? 0 : flip);
362  } else
363  sc->fltmap32[p][j++] = i ^ ((i&0x80000000) ? 0 : flip);
364  i++;
365  current_mul = decode_current_mul(&sc->c, state[0][2], mul, mul_count, i);
366  }
367  if (lu) {
368  i += current_mul;
369  }
370  lu ^= !run;
371  }
372  sc->remap_count[p] = j;
373  }
374  return 0;
375 }
376 
378  GetBitContext *gb,
379  uint8_t *src, int w, int h, int stride)
380 {
381  int x, y, p;
382  TYPE *sample[4][2];
383  int ac = f->ac;
384  unsigned mask[4];
385 
386  int bits[4], offset;
387  ff_ffv1_compute_bits_per_plane(f, sc, bits, &offset, mask, f->avctx->bits_per_raw_sample);
388 
389  w >>= 1;
390 
391  if (sc->slice_coding_mode == 1)
392  ac = 1;
393 
394  for (x = 0; x < 4; x++) {
395  sample[x][0] = RENAME(sc->sample_buffer) + x * 2 * (w + 6) + 3;
396  sample[x][1] = RENAME(sc->sample_buffer) + (x * 2 + 1) * (w + 6) + 3;
397  }
398 
399  sc->run_index = 0;
400 
401  memset(RENAME(sc->sample_buffer), 0, 8 * (w + 6) * sizeof(*RENAME(sc->sample_buffer)));
402 
403  for (y = 0; y < h; y += 2) {
404  for (p = 0; p < 4; p++) {
405  int ret;
406  TYPE *temp = sample[p][0]; // FIXME: try a normal buffer
407 
408  sample[p][0] = sample[p][1];
409  sample[p][1] = temp;
410 
411  sample[p][1][-1]= sample[p][0][0 ];
412  sample[p][0][ w]= sample[p][0][w-1];
413  ret = RENAME(decode_line)(f, sc, gb, w, sample[p],
414  p == 1 ? 2 : (p > 1), bits[p], ac);
415  if (ret < 0)
416  return ret;
417  }
418 
419  for (x = 0; x < w; x++) {
420  int g_r = sample[0][1][x];
421  int g_b = sample[1][1][x];
422  int b = sample[2][1][x];
423  int r = sample[3][1][x];
424 
425  if (sc->slice_coding_mode != 1) {
426  b -= offset;
427  r -= offset;
428  g_r -= (b * sc->slice_rct_by_coef + r * sc->slice_rct_ry_coef) >> 2;
429  b += g_r;
430  r += g_r;
431 
432  /* Recover green pair: encoder stored gm = gb + (gd >> 1), gd = gr - gb */
433  int gd = g_b - offset;
434  g_b = g_r - (gd >> 1);
435  g_r = g_b + gd;
436  }
437 
438  *((uint16_t*)(src + (x*2 + 0)*2 + stride*(y + 0))) = r;
439  *((uint16_t*)(src + (x*2 + 1)*2 + stride*(y + 0))) = g_r;
440  *((uint16_t*)(src + (x*2 + 0)*2 + stride*(y + 1))) = g_b;
441  *((uint16_t*)(src + (x*2 + 1)*2 + stride*(y + 1))) = b;
442  }
443  }
444  return 0;
445 }
446 
447 static int decode_slice(AVCodecContext *c, void *arg)
448 {
449  FFV1Context *f = c->priv_data;
450  FFV1SliceContext *sc = arg;
451  int width, height, x, y, ret;
452  const int ps = av_pix_fmt_desc_get(f->pix_fmt)->comp[0].step;
453  AVFrame * const p = f->picture.f;
454  const int si = sc - f->slices;
455  GetBitContext gb;
456  int ac = f->ac || sc->slice_coding_mode == 1;
457 
458  if (!(p->flags & AV_FRAME_FLAG_KEY) && f->last_picture.f)
459  ff_progress_frame_await(&f->last_picture, si);
460 
461  if (f->slice_damaged[si])
462  slice_set_damaged(f, sc);
463 
464  sc->slice_rct_by_coef = 1;
465  sc->slice_rct_ry_coef = 1;
466 
467  if (f->version > 2) {
468  if (ff_ffv1_init_slice_state(f, sc) < 0)
469  return AVERROR(ENOMEM);
470  if (decode_slice_header(f, sc, p) < 0) {
471  sc->slice_x = sc->slice_y = sc->slice_height = sc->slice_width = 0;
472  slice_set_damaged(f, sc);
473  return AVERROR_INVALIDDATA;
474  }
475  }
476  if ((ret = ff_ffv1_init_slice_state(f, sc)) < 0)
477  return ret;
478  if ((p->flags & AV_FRAME_FLAG_KEY) || sc->slice_reset_contexts) {
480  } else if (sc->slice_damaged) {
481  return AVERROR_INVALIDDATA;
482  }
483 
484  width = sc->slice_width;
485  height = sc->slice_height;
486  x = sc->slice_x;
487  y = sc->slice_y;
488 
489  if (sc->remap) {
490  ret = decode_remap(f, sc);
491  if (ret < 0)
492  return ret;
493  }
494 
495  if (ac == AC_GOLOMB_RICE) {
496  if (f->combined_version >= 0x30002)
497  get_rac(&sc->c, (uint8_t[]) { 129 });
498  sc->ac_byte_count = f->version > 2 || (!x && !y) ? sc->c.bytestream - sc->c.bytestream_start - 1 : 0;
499  init_get_bits(&gb,
500  sc->c.bytestream_start + sc->ac_byte_count,
501  (sc->c.bytestream_end - sc->c.bytestream_start - sc->ac_byte_count) * 8);
502  }
503 
504  av_assert1(width && height);
505  if (f->colorspace == 0 && (f->chroma_planes || !f->transparency)) {
506  const int chroma_width = AV_CEIL_RSHIFT(width, f->chroma_h_shift);
507  const int chroma_height = AV_CEIL_RSHIFT(height, f->chroma_v_shift);
508  const int cx = x >> f->chroma_h_shift;
509  const int cy = y >> f->chroma_v_shift;
510  decode_plane(f, sc, &gb, p->data[0] + ps*x + y*p->linesize[0], width, height, p->linesize[0], 0, 0, 1, ac);
511 
512  if (f->chroma_planes) {
513  decode_plane(f, sc, &gb, p->data[1] + ps*cx+cy*p->linesize[1], chroma_width, chroma_height, p->linesize[1], 1, 1, 1, ac);
514  decode_plane(f, sc, &gb, p->data[2] + ps*cx+cy*p->linesize[2], chroma_width, chroma_height, p->linesize[2], 1, 2, 1, ac);
515  }
516  if (f->transparency)
517  decode_plane(f, sc, &gb, p->data[3] + ps*x + y*p->linesize[3], width, height, p->linesize[3], (f->version >= 4 && !f->chroma_planes) ? 1 : 2,
518  (f->version >= 4 && !f->chroma_planes) ? 1 : 3, 1, ac);
519  } else if (f->colorspace == 0) {
520  decode_plane(f, sc, &gb, p->data[0] + ps*x + y*p->linesize[0] , width, height, p->linesize[0], 0, 0, 2, ac);
521  decode_plane(f, sc, &gb, p->data[0] + ps*x + y*p->linesize[0] + (ps>>1), width, height, p->linesize[0], 1, 1, 2, ac);
522  } else if (f->bayer) {
523  decode_bayer_frame(f, sc, &gb, p->data[0] + ps * x + y * p->linesize[0],
524  width, height, p->linesize[0]);
525  } else if (f->use32bit) {
526  uint8_t *planes[4] = { p->data[0] + ps * x + y * p->linesize[0],
527  p->data[1] + ps * x + y * p->linesize[1],
528  p->data[2] + ps * x + y * p->linesize[2] };
529  if (f->transparency)
530  planes[3] = p->data[3] + ps * x + y * p->linesize[3];
531  decode_rgb_frame32(f, sc, &gb, planes, width, height, p->linesize);
532  } else {
533  uint8_t *planes[4] = { p->data[0] + ps * x + y * p->linesize[0] };
534  if (f->avctx->bits_per_raw_sample > 8) {
535  planes[1] = p->data[1] + ps * x + y * p->linesize[1];
536  planes[2] = p->data[2] + ps * x + y * p->linesize[2];
537  if (f->transparency)
538  planes[3] = p->data[3] + ps * x + y * p->linesize[3];
539  }
540  decode_rgb_frame(f, sc, &gb, planes, width, height, p->linesize);
541  }
542  if (ac != AC_GOLOMB_RICE && f->version > 2) {
543  int v;
544  get_rac(&sc->c, (uint8_t[]) { 129 });
545  v = sc->c.bytestream_end - sc->c.bytestream - 2 - 5*!!f->ec;
546  if (v) {
547  av_log(f->avctx, AV_LOG_ERROR, "bytestream end mismatching by %d\n", v);
548  slice_set_damaged(f, sc);
549  }
550  }
551 
552  if (sc->slice_damaged && (f->avctx->err_recognition & AV_EF_EXPLODE))
553  return AVERROR_INVALIDDATA;
554 
555  if ((c->active_thread_type & FF_THREAD_FRAME) && !f->frame_damaged)
556  ff_progress_frame_report(&f->picture, si);
557 
558  return 0;
559 }
560 
562 {
563  enum AVPixelFormat pix_fmts[] = {
564 #if CONFIG_FFV1_VULKAN_HWACCEL
566 #endif
567  f->pix_fmt,
569  };
570 
571  return ff_get_format(f->avctx, pix_fmts);
572 }
573 
575 {
576  uint8_t state[CONTEXT_SIZE];
577  int context_count = -1; //-1 to avoid warning
578  int ret;
579 
580  memset(state, 128, sizeof(state));
581 
583  if (ret < 0)
584  return ret;
585 
586  if (f->configured_pix_fmt != f->pix_fmt ||
587  f->configured_width != f->width ||
588  f->configured_height != f->height ||
589  f->configured_ac != f->ac) {
590  f->avctx->pix_fmt = get_pixel_format(f);
591  if (f->avctx->pix_fmt < 0)
592  return AVERROR(EINVAL);
593  f->configured_pix_fmt = f->pix_fmt;
594  f->configured_width = f->width;
595  f->configured_height = f->height;
596  f->configured_ac = f->ac;
597  }
598 
599  ff_dlog(f->avctx, "%d %d %d\n",
600  f->chroma_h_shift, f->chroma_v_shift, f->pix_fmt);
601  if (f->version < 2) {
602  context_count = ff_ffv1_read_quant_tables(c, f->quant_tables[0]);
603  if (context_count < 0) {
604  av_log(f->avctx, AV_LOG_ERROR, "read_quant_table error\n");
605  return AVERROR_INVALIDDATA;
606  }
607  f->slice_count = f->max_slice_count;
608  } else if (f->version < 3) {
609  f->slice_count = ff_ffv1_get_symbol(c, state, 0);
610  } else {
611  const uint8_t *p = c->bytestream_end;
612  for (f->slice_count = 0;
613  f->slice_count < MAX_SLICES && 3 + 5*!!f->ec < p - c->bytestream_start;
614  f->slice_count++) {
615  int trailer = 3 + 5*!!f->ec;
616  int size = AV_RB24(p-trailer);
617  if (size + trailer > p - c->bytestream_start)
618  break;
619  p -= size + trailer;
620  }
621  }
622  if (f->slice_count > (unsigned)MAX_SLICES || f->slice_count <= 0 || f->slice_count > f->max_slice_count) {
623  av_log(f->avctx, AV_LOG_ERROR, "slice count %d is invalid (max=%d)\n", f->slice_count, f->max_slice_count);
624  return AVERROR_INVALIDDATA;
625  }
626 
627  av_refstruct_unref(&f->slice_damaged);
628  f->slice_damaged = av_refstruct_allocz(f->slice_count * sizeof(*f->slice_damaged));
629  if (!f->slice_damaged)
630  return AVERROR(ENOMEM);
631 
632  for (int j = 0; j < f->slice_count; j++) {
633  FFV1SliceContext *sc = &f->slices[j];
634 
635  if (f->version == 2) {
636  int sx = ff_ffv1_get_symbol(c, state, 0);
637  int sy = ff_ffv1_get_symbol(c, state, 0);
638  int sw = ff_ffv1_get_symbol(c, state, 0) + 1U;
639  int sh = ff_ffv1_get_symbol(c, state, 0) + 1U;
640 
641  if (sx < 0 || sy < 0 || sw <= 0 || sh <= 0)
642  return AVERROR_INVALIDDATA;
643  if (sx > f->num_h_slices - sw || sy > f->num_v_slices - sh)
644  return AVERROR_INVALIDDATA;
645 
646  sc->slice_x = sx * (int64_t)f->width / f->num_h_slices;
647  sc->slice_y = sy * (int64_t)f->height / f->num_v_slices;
648  sc->slice_width = (sx + sw) * (int64_t)f->width / f->num_h_slices - sc->slice_x;
649  sc->slice_height = (sy + sh) * (int64_t)f->height / f->num_v_slices - sc->slice_y;
650 
651  av_assert0((unsigned)sc->slice_width <= f->width &&
652  (unsigned)sc->slice_height <= f->height);
653  av_assert0 ( (unsigned)sc->slice_x + (uint64_t)sc->slice_width <= f->width
654  && (unsigned)sc->slice_y + (uint64_t)sc->slice_height <= f->height);
655  }
656 
658  sc->plane = ff_ffv1_planes_alloc();
659  if (!sc->plane)
660  return AVERROR(ENOMEM);
661 
662  for (int i = 0; i < f->plane_count; i++) {
663  PlaneContext *const p = &sc->plane[i];
664 
665  if (f->version == 2) {
666  int idx = ff_ffv1_get_symbol(c, state, 0);
667  if (idx >= (unsigned)f->quant_table_count) {
668  av_log(f->avctx, AV_LOG_ERROR,
669  "quant_table_index out of range\n");
670  return AVERROR_INVALIDDATA;
671  }
672  p->quant_table_index = idx;
673  context_count = f->context_count[idx];
674  }
675 
676  if (f->version <= 2) {
677  av_assert0(context_count >= 0);
678  p->context_count = context_count;
679  }
680  }
681  }
682  return 0;
683 }
684 
686 {
687  FFV1Context *f = avctx->priv_data;
688  int ret;
689 
690  f->pix_fmt = AV_PIX_FMT_NONE;
691  f->configured_pix_fmt = AV_PIX_FMT_NONE;
692 
693  if ((ret = ff_ffv1_common_init(avctx, f)) < 0)
694  return ret;
695 
696  if (avctx->extradata_size > 0 && (ret = ff_ffv1_read_extra_header(f)) < 0)
697  return ret;
698 
699  if ((ret = ff_ffv1_init_slice_contexts(f)) < 0)
700  return ret;
701 
702  return 0;
703 }
704 
705 static int find_next_slice(AVCodecContext *avctx,
706  uint8_t *buf, uint8_t *buf_end, int idx,
707  uint8_t **pos, uint32_t *len)
708 {
709  FFV1Context *f = avctx->priv_data;
710 
711  /* Length field */
712  uint32_t v = buf_end - buf;
713  if (idx || f->version > 2) {
714  /* Three bytes of length, plus flush bit + CRC */
715  uint32_t trailer = 3 + 5*!!f->ec;
716  if (trailer > buf_end - buf)
717  v = INT_MAX;
718  else
719  v = AV_RB24(buf_end - trailer) + trailer;
720  }
721 
722  if (buf_end - buf < v) {
723  av_log(avctx, AV_LOG_ERROR, "Slice pointer chain broken\n");
724  ff_progress_frame_report(&f->picture, INT_MAX);
725  return AVERROR_INVALIDDATA;
726  }
727 
728  *len = v;
729  if (idx)
730  *pos = buf_end - v;
731  else
732  *pos = buf;
733 
734  return 0;
735 }
736 
738  uint8_t *buf, size_t buf_size)
739 {
740  int ret;
741  FFV1Context *f = avctx->priv_data;
742 
743  uint8_t keystate = 128;
744  ff_init_range_decoder(c, buf, buf_size);
745  ff_build_rac_states(c, 0.05 * (1LL << 32), 256 - 8);
746 
747  if (get_rac(c, &keystate)) {
748  f->key_frame = AV_FRAME_FLAG_KEY;
749  f->key_frame_ok = 0;
750  if ((ret = read_header(f, c)) < 0)
751  return ret;
752  f->key_frame_ok = 1;
753  } else {
754  if (!f->key_frame_ok) {
755  av_log(avctx, AV_LOG_ERROR,
756  "Cannot decode non-keyframe without valid keyframe\n");
757  return AVERROR_INVALIDDATA;
758  }
759  f->key_frame = 0;
760  }
761 
762  if (f->ac != AC_GOLOMB_RICE) {
763  if (buf_size < avctx->width * avctx->height / (128*8))
764  return AVERROR_INVALIDDATA;
765  } else {
766  int w = avctx->width;
767  int s = 1 + w / (1<<23);
768  int i;
769 
770  w /= s;
771 
772  for (i = 0; w > (1<<ff_log2_run[i]); i++)
773  w -= ff_log2_run[i];
774  if (buf_size < (avctx->height + i + 6) / 8 * s)
775  return AVERROR_INVALIDDATA;
776  }
777 
778  return 0;
779 }
780 
782  AVPacket *avpkt)
783 {
784  FFV1Context *f = avctx->priv_data;
785  AVFrame *p = f->picture.f;
786 
787  uint8_t *buf = avpkt->data;
788  size_t buf_size = avpkt->size;
789  uint8_t *buf_end = buf + buf_size;
790 
791  for (int i = f->slice_count - 1; i >= 0; i--) {
792  FFV1SliceContext *sc = &f->slices[i];
793 
794  uint8_t *pos;
795  uint32_t len;
796  int err = find_next_slice(avctx, buf, buf_end, i,
797  &pos, &len);
798  if (err < 0)
799  return err;
800 
801  buf_end -= len;
802 
803  sc->slice_damaged = 0;
804 
805  if (f->ec) {
806  unsigned crc = av_crc(av_crc_get_table(AV_CRC_32_IEEE), f->crcref, pos, len);
807  if (crc != f->crcref) {
808  int64_t ts = avpkt->pts != AV_NOPTS_VALUE ? avpkt->pts : avpkt->dts;
809  av_log(f->avctx, AV_LOG_ERROR, "slice CRC mismatch %X!", crc);
810  if (ts != AV_NOPTS_VALUE && avctx->pkt_timebase.num) {
811  av_log(f->avctx, AV_LOG_ERROR, "at %f seconds\n", ts*av_q2d(avctx->pkt_timebase));
812  } else if (ts != AV_NOPTS_VALUE) {
813  av_log(f->avctx, AV_LOG_ERROR, "at %"PRId64"\n", ts);
814  } else {
815  av_log(f->avctx, AV_LOG_ERROR, "\n");
816  }
817  slice_set_damaged(f, sc);
818  }
819  if (avctx->debug & FF_DEBUG_PICT_INFO) {
820  av_log(avctx, AV_LOG_DEBUG, "slice %d, CRC: 0x%08"PRIX32"\n", i, AV_RB32(pos + len - 4));
821  }
822  }
823 
824  if (i) {
825  ff_init_range_decoder(&sc->c, pos, len);
826  ff_build_rac_states(&sc->c, 0.05 * (1LL << 32), 256 - 8);
827  } else {
828  sc->c = c;
829  sc->c.bytestream_end = pos + len;
830  }
831  }
832 
833  avctx->execute(avctx,
834  decode_slice,
835  f->slices,
836  NULL,
837  f->slice_count,
838  sizeof(*f->slices));
839 
840  for (int i = f->slice_count - 1; i >= 0; i--) {
841  FFV1SliceContext *sc = &f->slices[i];
842  if (sc->slice_damaged && f->last_picture.f) {
843  const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(f->pix_fmt);
844  const uint8_t *src[4];
845  uint8_t *dst[4];
846  ff_progress_frame_await(&f->last_picture, INT_MAX);
847  for (int j = 0; j < desc->nb_components; j++) {
848  int pixshift = desc->comp[j].depth > 8;
849  int sh = (j == 1 || j == 2) ? f->chroma_h_shift : 0;
850  int sv = (j == 1 || j == 2) ? f->chroma_v_shift : 0;
851  dst[j] = p->data[j] + p->linesize[j] *
852  (sc->slice_y >> sv) + ((sc->slice_x >> sh) << pixshift);
853  src[j] = f->last_picture.f->data[j] + f->last_picture.f->linesize[j] *
854  (sc->slice_y >> sv) + ((sc->slice_x >> sh) << pixshift);
855 
856  }
857 
858  av_image_copy(dst, p->linesize, src,
859  f->last_picture.f->linesize,
860  f->pix_fmt,
861  sc->slice_width,
862  sc->slice_height);
863 
864  f->slice_damaged[i] = 1;
865  }
866  }
867 
868  return 0;
869 }
870 
871 static int decode_frame(AVCodecContext *avctx, AVFrame *rframe,
872  int *got_frame, AVPacket *avpkt)
873 {
874  FFV1Context *f = avctx->priv_data;
875  int ret;
876  AVFrame *p;
877  const FFHWAccel *hwaccel = NULL;
878 
879  /* This is copied onto the first slice's range coder context */
880  RangeCoder c;
881 
882  ff_progress_frame_unref(&f->last_picture);
883  av_refstruct_unref(&f->hwaccel_last_picture_private);
884 
885  FFSWAP(ProgressFrame, f->picture, f->last_picture);
886  FFSWAP(void *, f->hwaccel_picture_private, f->hwaccel_last_picture_private);
887 
888  f->avctx = avctx;
889  f->frame_damaged = 0;
890 
891  ret = decode_header(avctx, &c, avpkt->data, avpkt->size);
892  if (ret < 0)
893  return ret;
894 
895  if (avctx->debug & FF_DEBUG_PICT_INFO)
896  av_log(avctx, AV_LOG_DEBUG, "ver:%d keyframe:%d coder:%d ec:%d slices:%d bps:%d\n",
897  f->version, !!f->key_frame, f->ac, f->ec, f->slice_count, f->avctx->bits_per_raw_sample);
898 
899  if (avctx->skip_frame >= AVDISCARD_ALL)
900  return avpkt->size;
901 
902  if (avctx->hwaccel)
903  hwaccel = ffhwaccel(avctx->hwaccel);
904 
905  ret = ff_progress_frame_get_buffer(avctx, &f->picture,
907  if (ret < 0)
908  return ret;
909 
910  ret = ff_hwaccel_frame_priv_alloc(avctx, &f->hwaccel_picture_private);
911  if (ret < 0)
912  return ret;
913 
914  p = f->picture.f;
915 
916  p->pict_type = AV_PICTURE_TYPE_I; //FIXME I vs. P
917  p->flags = (p->flags & ~AV_FRAME_FLAG_KEY) | f->key_frame;
918 
919  if (f->version < 3 && avctx->field_order > AV_FIELD_PROGRESSIVE) {
920  /* we have interlaced material flagged in container */
921  p->flags |= AV_FRAME_FLAG_INTERLACED;
922  if (avctx->field_order == AV_FIELD_TT || avctx->field_order == AV_FIELD_TB)
924  }
925 
926  /* Start */
927  if (hwaccel) {
928  ret = hwaccel->start_frame(avctx, avpkt->buf, avpkt->data, avpkt->size);
929  if (ret < 0)
930  return ret;
931  }
932 
933  ff_thread_finish_setup(avctx);
934 
935  /* Decode slices */
936  if (hwaccel) {
937  uint8_t *buf_end = avpkt->data + avpkt->size;
938 
939  if (!(p->flags & AV_FRAME_FLAG_KEY) && f->last_picture.f)
940  ff_progress_frame_await(&f->last_picture, f->slice_count - 1);
941 
942  for (int i = f->slice_count - 1; i >= 0; i--) {
943  uint8_t *pos;
944  uint32_t len;
945  ret = find_next_slice(avctx, avpkt->data, buf_end, i,
946  &pos, &len);
947  if (ret < 0)
948  return ret;
949 
950  buf_end -= len;
951 
952  ret = hwaccel->decode_slice(avctx, pos, len);
953  if (ret < 0)
954  return ret;
955  }
956  } else {
957  ret = decode_slices(avctx, c, avpkt);
958  if (ret < 0)
959  return ret;
960  }
961 
962  /* Finalize */
963  if (hwaccel) {
964  ret = hwaccel->end_frame(avctx);
965  if (ret < 0)
966  return ret;
967  }
968 
969  ff_progress_frame_report(&f->picture, INT_MAX);
970 
971  ff_progress_frame_unref(&f->last_picture);
972  av_refstruct_unref(&f->hwaccel_last_picture_private);
973  if ((ret = av_frame_ref(rframe, f->picture.f)) < 0)
974  return ret;
975 
976  *got_frame = 1;
977 
978  return avpkt->size;
979 }
980 
981 #if HAVE_THREADS
983 {
984  FFV1Context *fsrc = src->priv_data;
985  FFV1Context *fdst = dst->priv_data;
986 
987  if (dst == src)
988  return 0;
989 
990  fdst->version = fsrc->version;
991  fdst->micro_version = fsrc->micro_version;
992  fdst->combined_version = fsrc->combined_version;
993  fdst->chroma_planes = fsrc->chroma_planes;
994  fdst->chroma_h_shift = fsrc->chroma_h_shift;
995  fdst->chroma_v_shift = fsrc->chroma_v_shift;
996  fdst->transparency = fsrc->transparency;
997  fdst->plane_count = fsrc->plane_count;
998  fdst->ac = fsrc->ac;
999  fdst->colorspace = fsrc->colorspace;
1000  fdst->pix_fmt = fsrc->pix_fmt;
1001  fdst->configured_pix_fmt = fsrc->configured_pix_fmt;
1002  fdst->configured_ac = fsrc->configured_ac;
1003  fdst->configured_width = fsrc->configured_width;
1004  fdst->configured_height = fsrc->configured_height;
1005 
1006  fdst->ec = fsrc->ec;
1007  fdst->intra = fsrc->intra;
1008  fdst->key_frame_ok = fsrc->key_frame_ok;
1009 
1010  fdst->packed_at_lsb = fsrc->packed_at_lsb;
1011  fdst->slice_count = fsrc->slice_count;
1012  fdst->use32bit = fsrc->use32bit;
1013  memcpy(fdst->state_transition, fsrc->state_transition,
1014  sizeof(fdst->state_transition));
1015 
1016  // in version 1 there is a single per-keyframe quant table, so
1017  // we need to propagate it between threads
1018  if (fsrc->version < 2)
1019  memcpy(fdst->quant_tables[0], fsrc->quant_tables[0], sizeof(fsrc->quant_tables[0]));
1020 
1021  for (int i = 0; i < fdst->num_h_slices * fdst->num_v_slices; i++) {
1022  FFV1SliceContext *sc = &fdst->slices[i];
1023  const FFV1SliceContext *sc0 = &fsrc->slices[i];
1024 
1025  av_refstruct_replace(&sc->plane, sc0->plane);
1026 
1027  if (fsrc->version < 3) {
1028  sc->slice_x = sc0->slice_x;
1029  sc->slice_y = sc0->slice_y;
1030  sc->slice_width = sc0->slice_width;
1031  sc->slice_height = sc0->slice_height;
1032  }
1033  }
1034 
1036 
1037  av_assert1(fdst->max_slice_count == fsrc->max_slice_count);
1038 
1039  ff_progress_frame_replace(&fdst->picture, &fsrc->picture);
1041  fsrc->hwaccel_picture_private);
1042 
1043  return 0;
1044 }
1045 #endif
1046 
1048 {
1049  FFV1Context *const s = avctx->priv_data;
1050 
1051  ff_progress_frame_unref(&s->picture);
1052  av_refstruct_unref(&s->hwaccel_picture_private);
1053 
1054  ff_progress_frame_unref(&s->last_picture);
1055  av_refstruct_unref(&s->hwaccel_last_picture_private);
1056 
1057  ff_ffv1_close(s);
1058 
1059  return 0;
1060 }
1061 
1063  .p.name = "ffv1",
1064  CODEC_LONG_NAME("FFmpeg video codec #1"),
1065  .p.type = AVMEDIA_TYPE_VIDEO,
1066  .p.id = AV_CODEC_ID_FFV1,
1067  .priv_data_size = sizeof(FFV1Context),
1068  .init = decode_init,
1072  .p.capabilities = AV_CODEC_CAP_DR1 |
1074  .caps_internal = FF_CODEC_CAP_INIT_CLEANUP |
1077  .hw_configs = (const AVCodecHWConfigInternal *const []) {
1078 #if CONFIG_FFV1_VULKAN_HWACCEL
1079  HWACCEL_VULKAN(ffv1),
1080 #endif
1081  NULL
1082  },
1083 };
hwconfig.h
ff_progress_frame_report
void ff_progress_frame_report(ProgressFrame *f, int n)
Notify later decoding threads when part of their reference frame is ready.
Definition: decode.c:1970
AVCodecContext::hwaccel
const struct AVHWAccel * hwaccel
Hardware accelerator in use.
Definition: avcodec.h:1423
FFV1Context::chroma_v_shift
int chroma_v_shift
Definition: ffv1.h:132
AV_LOG_WARNING
#define AV_LOG_WARNING
Something somehow does not look correct.
Definition: log.h:216
FFV1SliceContext::slice_height
int slice_height
Definition: ffv1.h:78
AVPixelFormat
AVPixelFormat
Pixel format.
Definition: pixfmt.h:71
FFV1Context::key_frame_ok
int key_frame_ok
Definition: ffv1.h:164
AV_EF_EXPLODE
#define AV_EF_EXPLODE
abort decoding on minor error detection
Definition: defs.h:51
update_vlc_state
static void update_vlc_state(VlcState *const state, const int v)
Definition: ffv1.h:227
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:43
get_bits_left
static int get_bits_left(GetBitContext *gb)
Definition: get_bits.h:688
r
const char * r
Definition: vf_curves.c:127
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
decode_slice
static int decode_slice(AVCodecContext *c, void *arg)
Definition: ffv1dec.c:447
ff_get_format
int ff_get_format(AVCodecContext *avctx, const enum AVPixelFormat *fmt)
Select the (possibly hardware accelerated) pixel format.
Definition: decode.c:1220
av_pix_fmt_desc_get
const AVPixFmtDescriptor * av_pix_fmt_desc_get(enum AVPixelFormat pix_fmt)
Definition: pixdesc.c:3456
MAX_OVERREAD
#define MAX_OVERREAD
Definition: lagarithrac.h:49
AV_FIELD_PROGRESSIVE
@ AV_FIELD_PROGRESSIVE
Definition: defs.h:213
FFV1SliceContext::plane
PlaneContext * plane
Definition: ffv1.h:90
FFV1Context::ec
int ec
Definition: ffv1.h:162
state
static struct @584 state
int64_t
long long int64_t
Definition: coverity.c:34
mask
int mask
Definition: mediacodecdec_common.c:154
get_sr_golomb
static int get_sr_golomb(GetBitContext *gb, int k, int limit, int esc_len)
read signed golomb rice code (ffv1).
Definition: golomb.h:532
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:459
decode_plane
static int decode_plane(FFV1Context *f, FFV1SliceContext *sc, GetBitContext *gb, uint8_t *src, int w, int h, int stride, int plane_index, int remap_index, int pixel_stride, int ac)
Definition: ffv1dec.c:100
pixdesc.h
FFV1Context::configured_pix_fmt
enum AVPixelFormat configured_pix_fmt
Definition: ffv1.h:141
decode_header
static int decode_header(AVCodecContext *avctx, RangeCoder *c, uint8_t *buf, size_t buf_size)
Definition: ffv1dec.c:737
AVPacket::data
uint8_t * data
Definition: packet.h:603
AVCodecContext::field_order
enum AVFieldOrder field_order
Field order.
Definition: avcodec.h:694
b
#define b
Definition: input.c:43
FFV1Context::configured_height
int configured_height
Definition: ffv1.h:142
ff_progress_frame_get_buffer
int ff_progress_frame_get_buffer(AVCodecContext *avctx, ProgressFrame *f, int flags)
Wrapper around ff_progress_frame_alloc() and ff_thread_get_buffer().
Definition: decode.c:1930
rangecoder.h
AVComponentDescriptor::step
int step
Number of elements between 2 horizontally consecutive pixels.
Definition: pixdesc.h:40
FFCodec
Definition: codec_internal.h:127
decode_remap
static int decode_remap(FFV1Context *f, FFV1SliceContext *sc)
Definition: ffv1dec.c:300
FFV1Context::num_h_slices
int num_h_slices
Definition: ffv1.h:177
FFV1Context::hwaccel_picture_private
void * hwaccel_picture_private
Definition: ffv1.h:138
RangeCoder::bytestream_end
uint8_t * bytestream_end
Definition: rangecoder.h:44
FFV1SliceContext::fltmap_size
unsigned int fltmap_size[4]
Definition: ffv1.h:114
decode_line
static av_always_inline int RENAME() decode_line(FFV1Context *f, FFV1SliceContext *sc, GetBitContext *gb, int w, TYPE *sample[2], int plane_index, int bits, int ac)
Definition: ffv1dec_template.c:26
FFV1Context::quant_tables
int16_t quant_tables[MAX_QUANT_TABLES][MAX_CONTEXT_INPUTS][MAX_QUANT_TABLE_SIZE]
Definition: ffv1.h:148
init_get_bits
static int init_get_bits(GetBitContext *s, const uint8_t *buffer, int bit_size)
Initialize GetBitContext.
Definition: get_bits.h:517
thread.h
FFV1Context::chroma_h_shift
int chroma_h_shift
Definition: ffv1.h:132
FFV1SliceContext::slice_x
int slice_x
Definition: ffv1.h:79
AV_PIX_FMT_VULKAN
@ AV_PIX_FMT_VULKAN
Vulkan hardware images.
Definition: pixfmt.h:379
ff_ffv1_read_extra_header
int ff_ffv1_read_extra_header(FFV1Context *f)
Definition: ffv1_parse.c:70
ff_ffv1_clear_slice_state
void ff_ffv1_clear_slice_state(const FFV1Context *f, FFV1SliceContext *sc)
Definition: ffv1.c:200
FF_DEBUG_PICT_INFO
#define FF_DEBUG_PICT_INFO
Definition: avcodec.h:1393
AV_FRAME_FLAG_TOP_FIELD_FIRST
#define AV_FRAME_FLAG_TOP_FIELD_FIRST
A flag to mark frames where the top field is displayed first if the content is interlaced.
Definition: frame.h:687
crc.h
golomb.h
exp golomb vlc stuff
close
static av_cold void close(AVCodecParserContext *s)
Definition: apv_parser.c:197
decode_current_mul
static int decode_current_mul(RangeCoder *rc, uint8_t state[32], int *mul, int mul_count, int64_t i)
Definition: ffv1dec.c:289
AV_FIELD_TT
@ AV_FIELD_TT
Top coded_first, top displayed first.
Definition: defs.h:214
FFCodec::p
AVCodec p
The public AVCodec.
Definition: codec_internal.h:131
FFHWAccel
Definition: hwaccel_internal.h:34
FFV1Context::combined_version
int combined_version
Definition: ffv1.h:129
av_ceil_log2
#define av_ceil_log2
Definition: common.h:97
AVCodecContext::skip_frame
enum AVDiscard skip_frame
Skip decoding for selected frames.
Definition: avcodec.h:1680
ffv1_decode_close
static av_cold int ffv1_decode_close(AVCodecContext *avctx)
Definition: ffv1dec.c:1047
GetBitContext
Definition: get_bits.h:109
MAX_SLICES
#define MAX_SLICES
Definition: d3d12va_hevc.c:33
CONTEXT_SIZE
#define CONTEXT_SIZE
Definition: ffv1.h:45
FFV1Context::chroma_planes
int chroma_planes
Definition: ffv1.h:131
AVRational::num
int num
Numerator.
Definition: rational.h:59
progressframe.h
AV_FIELD_TB
@ AV_FIELD_TB
Top coded first, bottom displayed first.
Definition: defs.h:216
refstruct.h
decode_rgb_frame
static int RENAME() decode_rgb_frame(FFV1Context *f, FFV1SliceContext *sc, GetBitContext *gb, uint8_t *src[4], int w, int h, int stride[4])
Definition: ffv1dec_template.c:140
av_refstruct_allocz
static void * av_refstruct_allocz(size_t size)
Equivalent to av_refstruct_alloc_ext(size, 0, NULL, NULL)
Definition: refstruct.h:105
avassert.h
FF_CODEC_CAP_USES_PROGRESSFRAMES
#define FF_CODEC_CAP_USES_PROGRESSFRAMES
The decoder might make use of the ProgressFrame API.
Definition: codec_internal.h:69
AV_LOG_ERROR
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:210
av_cold
#define av_cold
Definition: attributes.h:119
AV_FRAME_FLAG_KEY
#define AV_FRAME_FLAG_KEY
A flag to mark frames that are keyframes.
Definition: frame.h:674
FFV1SliceContext::sample_buffer
int16_t * sample_buffer
Definition: ffv1.h:74
FFV1Context::use32bit
int use32bit
Definition: ffv1.h:160
AVCodecContext::extradata_size
int extradata_size
Definition: avcodec.h:527
FF_CODEC_DECODE_CB
#define FF_CODEC_DECODE_CB(func)
Definition: codec_internal.h:347
ff_hwaccel_frame_priv_alloc
int ff_hwaccel_frame_priv_alloc(AVCodecContext *avctx, void **hwaccel_picture_private)
Allocate a hwaccel frame private data if the provided avctx uses a hwaccel method that needs it.
Definition: decode.c:2327
s
#define s(width, name)
Definition: cbs_vp9.c:198
FFV1Context::slice_count
int slice_count
Definition: ffv1.h:174
AV_CEIL_RSHIFT
#define AV_CEIL_RSHIFT(a, b)
Definition: common.h:60
AV_GET_BUFFER_FLAG_REF
#define AV_GET_BUFFER_FLAG_REF
The decoder will keep a reference to the frame and may reuse it later.
Definition: avcodec.h:415
decode_frame
static int decode_frame(AVCodecContext *avctx, AVFrame *rframe, int *got_frame, AVPacket *avpkt)
Definition: ffv1dec.c:871
av_q2d
static double av_q2d(AVRational a)
Convert an AVRational to a double.
Definition: rational.h:104
FFV1Context::max_slice_count
int max_slice_count
Definition: ffv1.h:175
bits
uint8_t bits
Definition: vp3data.h:128
FFV1Context::intra
int intra
Definition: ffv1.h:163
av_assert0
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Definition: avassert.h:42
pix_fmts
static enum AVPixelFormat pix_fmts[]
Definition: libkvazaar.c:296
is_input_end
static int is_input_end(RangeCoder *c, GetBitContext *gb, int ac)
Definition: ffv1dec.c:78
AV_LOG_DEBUG
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
Definition: log.h:231
FFV1SliceContext::fltmap32_size
unsigned int fltmap32_size[4]
Definition: ffv1.h:115
ff_progress_frame_unref
void ff_progress_frame_unref(ProgressFrame *f)
Give up a reference to the underlying frame contained in a ProgressFrame and reset the ProgressFrame,...
Definition: decode.c:1953
ff_progress_frame_await
the pkt_dts and pkt_pts fields in AVFrame will work as usual Restrictions on codec whose streams don t reset across will not work because their bitstreams cannot be decoded in parallel *The contents of buffers must not be read before ff_progress_frame_await() has been called on them. reget_buffer() and buffer age optimizations no longer work. *The contents of buffers must not be written to after ff_progress_frame_report() has been called on them. This includes draw_edges(). Porting codecs to frame threading
decode.h
get_bits.h
fold
static av_always_inline int fold(int diff, int bits)
Definition: ffv1.h:216
FFV1Context::ac
int ac
1=range coder <-> 0=golomb rice
Definition: ffv1.h:147
get_vlc_symbol
static int get_vlc_symbol(GetBitContext *gb, VlcState *const state, int bits)
Definition: ffv1dec.c:48
FFV1Context::plane_count
int plane_count
Definition: ffv1.h:146
FFV1Context::slice_damaged
uint8_t * slice_damaged
Definition: ffv1.h:187
CODEC_LONG_NAME
#define CODEC_LONG_NAME(str)
Definition: codec_internal.h:332
arg
const char * arg
Definition: jacosubdec.c:65
if
if(ret)
Definition: filter_design.txt:179
AV_CODEC_CAP_FRAME_THREADS
#define AV_CODEC_CAP_FRAME_THREADS
Codec supports frame-level multithreading.
Definition: codec.h:95
AVDISCARD_ALL
@ AVDISCARD_ALL
discard all
Definition: defs.h:232
TYPE
#define TYPE
Definition: ffv1dec.c:96
AVPacket::buf
AVBufferRef * buf
A reference to the reference-counted buffer where the packet data is stored.
Definition: packet.h:586
FFV1Context::configured_ac
int configured_ac
Definition: ffv1.h:143
NULL
#define NULL
Definition: coverity.c:32
AC_GOLOMB_RICE
#define AC_GOLOMB_RICE
Definition: ffv1.h:52
run
uint8_t run
Definition: svq3.c:207
hwaccel_internal.h
FFV1Context::num_v_slices
int num_v_slices
Definition: ffv1.h:176
FFV1SliceContext::fltmap32
uint32_t * fltmap32[4]
Definition: ffv1.h:113
FFV1Context::colorspace
int colorspace
Definition: ffv1.h:152
AVRational
Rational number (pair of numerator and denominator).
Definition: rational.h:58
AV_PICTURE_TYPE_I
@ AV_PICTURE_TYPE_I
Intra.
Definition: avutil.h:278
ff_ffv1_decoder
const FFCodec ff_ffv1_decoder
Definition: ffv1dec.c:1062
FFV1Context::slices
FFV1SliceContext * slices
Definition: ffv1.h:179
FFV1Context::state_transition
uint8_t state_transition[256]
Definition: ffv1.h:150
mathops.h
ff_ffv1_get_symbol
int ff_ffv1_get_symbol(RangeCoder *c, uint8_t *state, int is_signed)
Definition: ffv1.c:263
PlaneContext
Definition: ffv1.h:64
UPDATE_THREAD_CONTEXT
#define UPDATE_THREAD_CONTEXT(func)
Definition: codec_internal.h:341
c
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C it is not safe even if the output of undefined operations is unused The unsafety may seem nit picking but Optimizing compilers have in fact optimized code on the assumption that no undefined Behavior occurs Optimizing code based on wrong assumptions can and has in some cases lead to effects beyond the output of computations The signed integer overflow problem in speed critical code Code which is highly optimized and works with signed integers sometimes has the problem that often the output of the computation does not c
Definition: undefined.txt:32
decode_slices
static int decode_slices(AVCodecContext *avctx, RangeCoder c, AVPacket *avpkt)
Definition: ffv1dec.c:781
VlcState
Definition: ffv1.h:57
ff_dlog
#define ff_dlog(a,...)
Definition: tableprint_vlc.h:28
FFV1SliceContext::slice_width
int slice_width
Definition: ffv1.h:77
ff_init_range_decoder
av_cold void ff_init_range_decoder(RangeCoder *c, const uint8_t *buf, int buf_size)
Definition: rangecoder.c:53
AV_CODEC_ID_FFV1
@ AV_CODEC_ID_FFV1
Definition: codec_id.h:85
f
f
Definition: af_crystalizer.c:122
init
int(* init)(AVBSFContext *ctx)
Definition: dts2pts.c:579
get_pixel_format
static enum AVPixelFormat get_pixel_format(FFV1Context *f)
Definition: ffv1dec.c:561
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
flip
static void flip(AVCodecContext *avctx, AVFrame *frame)
Definition: rawdec.c:131
AVPacket::size
int size
Definition: packet.h:604
height
#define height
Definition: dsp.h:89
av_frame_ref
int av_frame_ref(AVFrame *dst, const AVFrame *src)
Set up a new reference to the data described by the source frame.
Definition: frame.c:278
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
i
#define i(width, name, range_min, range_max)
Definition: cbs_h264.c:63
for
for(k=2;k<=8;++k)
Definition: h264pred_template.c:424
AVCodecContext::pkt_timebase
AVRational pkt_timebase
Timebase in which pkt_dts/pts and AVPacket.dts/pts are expressed.
Definition: avcodec.h:554
sample
#define sample
Definition: flacdsp_template.c:44
size
int size
Definition: twinvq_data.h:10344
ff_build_rac_states
void ff_build_rac_states(RangeCoder *c, int factor, int max_p)
Definition: rangecoder.c:68
AV_NOPTS_VALUE
#define AV_NOPTS_VALUE
Undefined timestamp value.
Definition: avutil.h:247
slice_set_damaged
static void slice_set_damaged(FFV1Context *f, FFV1SliceContext *sc)
Definition: ffv1dec.c:279
AV_RB32
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_RB32
Definition: bytestream.h:96
FF_CODEC_CAP_SKIP_FRAME_FILL_PARAM
#define FF_CODEC_CAP_SKIP_FRAME_FILL_PARAM
The decoder extracts and fills its parameters even if the frame is skipped due to the skip_frame sett...
Definition: codec_internal.h:55
get_symbol_inline
static av_flatten int get_symbol_inline(RangeCoder *c, uint8_t *state, int is_signed)
Definition: ffv1.h:256
AVCodecHWConfigInternal
Definition: hwconfig.h:25
RangeCoder::bytestream
uint8_t * bytestream
Definition: rangecoder.h:43
FFV1Context::picture
ProgressFrame picture
Definition: ffv1.h:137
AVPacket::dts
int64_t dts
Decompression timestamp in AVStream->time_base units; the time at which the packet is decompressed.
Definition: packet.h:602
FFV1SliceContext::slice_rct_by_coef
int slice_rct_by_coef
Definition: ffv1.h:85
av_crc_get_table
const AVCRC * av_crc_get_table(AVCRCId crc_id)
Get an initialized standard CRC table.
Definition: crc.c:389
AV_CODEC_CAP_SLICE_THREADS
#define AV_CODEC_CAP_SLICE_THREADS
Codec supports slice-based (or partition-based) multithreading.
Definition: codec.h:99
offset
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf offset
Definition: writing_filters.txt:86
ff_ffv1_init_slice_state
av_cold int ff_ffv1_init_slice_state(const FFV1Context *f, FFV1SliceContext *sc)
Definition: ffv1.c:72
read_header
static int read_header(FFV1Context *f, RangeCoder *c)
Definition: ffv1dec.c:574
FF_THREAD_FRAME
#define FF_THREAD_FRAME
Decode more than one frame at once.
Definition: avcodec.h:1590
FFV1SliceContext::c
RangeCoder c
Definition: ffv1.h:92
av_refstruct_unref
void av_refstruct_unref(void *objp)
Decrement the reference count of the underlying object and automatically free the object if there are...
Definition: refstruct.c:120
av_assert2
#define av_assert2(cond)
assert() equivalent, that does lie in speed critical code.
Definition: avassert.h:68
AVPacket::pts
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
Definition: packet.h:596
FFV1SliceContext::slice_rct_ry_coef
int slice_rct_ry_coef
Definition: ffv1.h:86
FFV1SliceContext::remap_count
int remap_count[4]
Definition: ffv1.h:109
av_assert1
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code.
Definition: avassert.h:58
delta
float delta
Definition: vorbis_enc_data.h:430
ff_ffv1_common_init
av_cold int ff_ffv1_common_init(AVCodecContext *avctx, FFV1Context *s)
Definition: ffv1.c:36
FFMIN
#define FFMIN(a, b)
Definition: macros.h:49
ffv1.h
AVCodec::name
const char * name
Name of the codec implementation.
Definition: codec.h:179
FFV1SliceContext
Definition: ffv1.h:73
len
int len
Definition: vorbis_enc_data.h:426
get_rac
static int get_rac(RangeCoder *c, uint8_t *const state)
Definition: rangecoder.h:118
AV_CRC_32_IEEE
@ AV_CRC_32_IEEE
Definition: crc.h:52
AVCodecContext::height
int height
Definition: avcodec.h:604
AV_FRAME_FLAG_INTERLACED
#define AV_FRAME_FLAG_INTERLACED
A flag to mark frames whose content is interlaced.
Definition: frame.h:682
planes
static const struct @586 planes[]
FFV1Context::packed_at_lsb
int packed_at_lsb
Definition: ffv1.h:169
ff_ffv1_read_quant_tables
int ff_ffv1_read_quant_tables(RangeCoder *c, int16_t quant_table[MAX_CONTEXT_INPUTS][256])
Definition: ffv1_parse.c:52
avcodec.h
FFV1SliceContext::fltmap
uint16_t * fltmap[4]
Definition: ffv1.h:112
ret
ret
Definition: filter_design.txt:187
find_next_slice
static int find_next_slice(AVCodecContext *avctx, uint8_t *buf, uint8_t *buf_end, int idx, uint8_t **pos, uint32_t *len)
Definition: ffv1dec.c:705
FFSWAP
#define FFSWAP(type, a, b)
Definition: macros.h:52
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
decode_slice_header
static int decode_slice_header(const FFV1Context *f, FFV1SliceContext *sc, AVFrame *frame)
Definition: ffv1dec.c:176
FFV1SliceContext::slice_y
int slice_y
Definition: ffv1.h:80
hwaccel
static const char * hwaccel
Definition: ffplay.c:356
pos
unsigned int pos
Definition: spdifenc.c:414
ff_ffv1_close
av_cold void ff_ffv1_close(FFV1Context *s)
Definition: ffv1.c:268
ff_thread_finish_setup
the pkt_dts and pkt_pts fields in AVFrame will work as usual Restrictions on codec whose streams don t reset across will not work because their bitstreams cannot be decoded in parallel *The contents of buffers must not be read before as well as code calling up to before the decode process starts Call ff_thread_finish_setup() afterwards. If some code can 't be moved
ff_slice_coord
int ff_slice_coord(const FFV1Context *f, int width, int sx, int num_h_slices, int chroma_shift)
This is intended for both width and height.
Definition: ffv1.c:127
U
#define U(x)
Definition: vpx_arith.h:37
ff_ffv1_planes_alloc
PlaneContext * ff_ffv1_planes_alloc(void)
Definition: ffv1.c:66
ff_progress_frame_replace
void ff_progress_frame_replace(ProgressFrame *dst, const ProgressFrame *src)
Do nothing if dst and src already refer to the same AVFrame; otherwise unreference dst and if src is ...
Definition: decode.c:1960
HWACCEL_VULKAN
#define HWACCEL_VULKAN(codec)
Definition: hwconfig.h:76
FFV1Context::pix_fmt
enum AVPixelFormat pix_fmt
Definition: ffv1.h:140
AVCodecContext
main external API structure.
Definition: avcodec.h:443
RangeCoder::bytestream_start
uint8_t * bytestream_start
Definition: rangecoder.h:42
AVCodecContext::execute
int(* execute)(struct AVCodecContext *c, int(*func)(struct AVCodecContext *c2, void *arg), void *arg2, int *ret, int count, int size)
The codec may call this to execute several independent things.
Definition: avcodec.h:1609
decode_init
static av_cold int decode_init(AVCodecContext *avctx)
Definition: ffv1dec.c:685
av_crc
uint32_t av_crc(const AVCRC *ctx, uint32_t crc, const uint8_t *buffer, size_t length)
Calculate the CRC of a block.
Definition: crc.c:421
av_refstruct_replace
void av_refstruct_replace(void *dstp, const void *src)
Ensure *dstp refers to the same object as src.
Definition: refstruct.c:160
AV_PIX_FMT_NONE
@ AV_PIX_FMT_NONE
Definition: pixfmt.h:72
ffhwaccel
static const FFHWAccel * ffhwaccel(const AVHWAccel *codec)
Definition: hwaccel_internal.h:168
update_thread_context
the pkt_dts and pkt_pts fields in AVFrame will work as usual Restrictions on codec whose streams don t reset across will not work because their bitstreams cannot be decoded in parallel *The contents of buffers must not be read before as well as code calling up to before the decode process starts Call have update_thread_context() run it in the next thread. Add AV_CODEC_CAP_FRAME_THREADS to the codec capabilities. There will be very little speed gain at this point but it should work. Use ff_thread_get_buffer()(or ff_progress_frame_get_buffer() in case you have inter-frame dependencies and use the ProgressFrame API) to allocate frame buffers. Call ff_progress_frame_report() after some part of the current picture has decoded. A good place to put this is where draw_horiz_band() is called - add this if it isn 't called anywhere
FFV1SliceContext::remap
int remap
Definition: ffv1.h:87
ff_ffv1_parse_header
int ff_ffv1_parse_header(FFV1Context *f, RangeCoder *c, uint8_t *state)
Definition: ffv1_parse.c:216
AVPixFmtDescriptor::comp
AVComponentDescriptor comp[4]
Parameters that describe how pixels are packed.
Definition: pixdesc.h:105
temp
else temp
Definition: vf_mcdeint.c:271
Windows::Graphics::DirectX::Direct3D11::p
IDirect3DDxgiInterfaceAccess _COM_Outptr_ void ** p
Definition: vsrc_gfxcapture_winrt.hpp:53
AVCodecContext::debug
int debug
debug
Definition: avcodec.h:1392
desc
const char * desc
Definition: libsvtav1.c:83
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:200
mem.h
AVPixFmtDescriptor
Descriptor that unambiguously describes how the bits of a pixel are stored in the up to 4 data planes...
Definition: pixdesc.h:69
w
uint8_t w
Definition: llvidencdsp.c:39
FFV1Context
Definition: ffv1.h:122
FFV1Context::transparency
int transparency
Definition: ffv1.h:133
ProgressFrame
The ProgressFrame structure.
Definition: progressframe.h:73
AVPacket
This structure stores compressed data.
Definition: packet.h:580
AVCodecContext::priv_data
void * priv_data
Definition: avcodec.h:470
FFV1SliceContext::run_index
int run_index
Definition: ffv1.h:83
av_freep
#define av_freep(p)
Definition: tableprint_vlc.h:35
av_fast_malloc
void av_fast_malloc(void *ptr, unsigned int *size, size_t min_size)
Allocate a buffer, reusing the given one if large enough.
Definition: mem.c:557
ffv1dec_template.c
AVCodecContext::width
int width
picture width / height.
Definition: avcodec.h:604
ff_ffv1_init_slice_contexts
av_cold int ff_ffv1_init_slice_contexts(FFV1Context *f)
Definition: ffv1.c:142
ff_log2_run
const uint8_t ff_log2_run[41]
Definition: mathtables.c:155
imgutils.h
decode_bayer_frame
static int decode_bayer_frame(FFV1Context *f, FFV1SliceContext *sc, GetBitContext *gb, uint8_t *src, int w, int h, int stride)
Definition: ffv1dec.c:377
FFV1SliceContext::slice_reset_contexts
int slice_reset_contexts
Definition: ffv1.h:99
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:27
AVERROR_INVALIDDATA
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
Definition: error.h:61
FFV1Context::micro_version
int micro_version
Definition: ffv1.h:128
h
h
Definition: vp9dsp_template.c:2070
RangeCoder
Definition: mss3.c:63
stride
#define stride
Definition: h264pred_template.c:536
av_image_check_sar
int av_image_check_sar(unsigned int w, unsigned int h, AVRational sar)
Check if the given sample aspect ratio of an image is valid.
Definition: imgutils.c:323
width
#define width
Definition: dsp.h:89
FFV1Context::configured_width
int configured_width
Definition: ffv1.h:142
av_image_copy
void av_image_copy(uint8_t *const dst_data[4], const int dst_linesizes[4], const uint8_t *const src_data[4], const int src_linesizes[4], enum AVPixelFormat pix_fmt, int width, int height)
Copy image in src_data to dst_data.
Definition: imgutils.c:422
FFV1SliceContext::ac_byte_count
int ac_byte_count
number of bytes used for AC coding
Definition: ffv1.h:94
AV_RB24
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_WB32 unsigned int_TMPL AV_RB24
Definition: bytestream.h:97
FFV1SliceContext::slice_damaged
int slice_damaged
Definition: ffv1.h:100
FFV1SliceContext::slice_coding_mode
int slice_coding_mode
Definition: ffv1.h:84
ff_ffv1_compute_bits_per_plane
void ff_ffv1_compute_bits_per_plane(const FFV1Context *f, FFV1SliceContext *sc, int bits[4], int *offset, int mask[4], int bits_per_raw_sample)
Definition: ffv1.c:224
src
#define src
Definition: vp8dsp.c:248
FFV1Context::version
int version
Definition: ffv1.h:127
RENAME
#define RENAME(name)
Definition: ffv1dec.c:97