flashsv.c
Go to the documentation of this file.
1 /*
2  * Flash Screen Video decoder
3  * Copyright (C) 2004 Alex Beregszaszi
4  * Copyright (C) 2006 Benjamin Larsson
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  * Flash Screen Video decoder
26  * @author Alex Beregszaszi
27  * @author Benjamin Larsson
28  * @author Daniel Verkamp
29  * @author Konstantin Shishkov
30  *
31  * A description of the bitstream format for Flash Screen Video version 1/2
32  * is part of the SWF File Format Specification (version 10), which can be
33  * downloaded from http://www.adobe.com/devnet/swf.html.
34  */
35 
36 #include <stdio.h>
37 #include <stdlib.h>
38 #include <zlib.h>
39 
40 #include "libavutil/intreadwrite.h"
41 #include "avcodec.h"
42 #include "bytestream.h"
43 #include "get_bits.h"
44 #include "internal.h"
45 
46 typedef struct BlockInfo {
48  int size;
49 } BlockInfo;
50 
51 typedef struct FlashSVContext {
54  int image_width, image_height;
55  int block_width, block_height;
58  z_stream zstream;
59  int ver;
60  const uint32_t *pal;
68  int zlibprime_curr, zlibprime_prev;
69  int diff_start, diff_height;
71 
72 
73 static int decode_hybrid(const uint8_t *sptr, uint8_t *dptr, int dx, int dy,
74  int h, int w, int stride, const uint32_t *pal)
75 {
76  int x, y;
77  const uint8_t *orig_src = sptr;
78 
79  for (y = dx+h; y > dx; y--) {
80  uint8_t *dst = dptr + (y * stride) + dy * 3;
81  for (x = 0; x < w; x++) {
82  if (*sptr & 0x80) {
83  /* 15-bit color */
84  unsigned c = AV_RB16(sptr) & ~0x8000;
85  unsigned b = c & 0x1F;
86  unsigned g = (c >> 5) & 0x1F;
87  unsigned r = c >> 10;
88  /* 000aaabb -> aaabbaaa */
89  *dst++ = (b << 3) | (b >> 2);
90  *dst++ = (g << 3) | (g >> 2);
91  *dst++ = (r << 3) | (r >> 2);
92  sptr += 2;
93  } else {
94  /* palette index */
95  uint32_t c = pal[*sptr++];
96  bytestream_put_le24(&dst, c);
97  }
98  }
99  }
100  return sptr - orig_src;
101 }
102 
104 {
105  FlashSVContext *s = avctx->priv_data;
106  int zret; // Zlib return code
107 
108  s->avctx = avctx;
109  s->zstream.zalloc = Z_NULL;
110  s->zstream.zfree = Z_NULL;
111  s->zstream.opaque = Z_NULL;
112  zret = inflateInit(&s->zstream);
113  if (zret != Z_OK) {
114  av_log(avctx, AV_LOG_ERROR, "Inflate init error: %d\n", zret);
115  return 1;
116  }
117  avctx->pix_fmt = AV_PIX_FMT_BGR24;
119 
120  return 0;
121 }
122 
123 
125 {
126  z_stream zs;
127  int zret; // Zlib return code
128 
129  if (!src)
130  return AVERROR_INVALIDDATA;
131 
132  zs.zalloc = NULL;
133  zs.zfree = NULL;
134  zs.opaque = NULL;
135 
136  s->zstream.next_in = src;
137  s->zstream.avail_in = size;
138  s->zstream.next_out = s->tmpblock;
139  s->zstream.avail_out = s->block_size * 3;
140  inflate(&s->zstream, Z_SYNC_FLUSH);
141 
142  if (deflateInit(&zs, 0) != Z_OK)
143  return -1;
144  zs.next_in = s->tmpblock;
145  zs.avail_in = s->block_size * 3 - s->zstream.avail_out;
146  zs.next_out = s->deflate_block;
147  zs.avail_out = s->deflate_block_size;
148  deflate(&zs, Z_SYNC_FLUSH);
149  deflateEnd(&zs);
150 
151  if ((zret = inflateReset(&s->zstream)) != Z_OK) {
152  av_log(s->avctx, AV_LOG_ERROR, "Inflate reset error: %d\n", zret);
153  return AVERROR_UNKNOWN;
154  }
155 
156  s->zstream.next_in = s->deflate_block;
157  s->zstream.avail_in = s->deflate_block_size - zs.avail_out;
158  s->zstream.next_out = s->tmpblock;
159  s->zstream.avail_out = s->block_size * 3;
160  inflate(&s->zstream, Z_SYNC_FLUSH);
161 
162  return 0;
163 }
164 
165 static int flashsv_decode_block(AVCodecContext *avctx, AVPacket *avpkt,
166  GetBitContext *gb, int block_size,
167  int width, int height, int x_pos, int y_pos,
168  int blk_idx)
169 {
170  struct FlashSVContext *s = avctx->priv_data;
171  uint8_t *line = s->tmpblock;
172  int k;
173  int ret = inflateReset(&s->zstream);
174  if (ret != Z_OK) {
175  av_log(avctx, AV_LOG_ERROR, "Inflate reset error: %d\n", ret);
176  return AVERROR_UNKNOWN;
177  }
178  if (s->zlibprime_curr || s->zlibprime_prev) {
179  ret = flashsv2_prime(s,
180  s->blocks[blk_idx].pos,
181  s->blocks[blk_idx].size);
182  if (ret < 0)
183  return ret;
184  }
185  s->zstream.next_in = avpkt->data + get_bits_count(gb) / 8;
186  s->zstream.avail_in = block_size;
187  s->zstream.next_out = s->tmpblock;
188  s->zstream.avail_out = s->block_size * 3;
189  ret = inflate(&s->zstream, Z_FINISH);
190  if (ret == Z_DATA_ERROR) {
191  av_log(avctx, AV_LOG_ERROR, "Zlib resync occurred\n");
192  inflateSync(&s->zstream);
193  ret = inflate(&s->zstream, Z_FINISH);
194  }
195 
196  if (ret != Z_OK && ret != Z_STREAM_END) {
197  //return -1;
198  }
199 
200  if (s->is_keyframe) {
201  s->blocks[blk_idx].pos = s->keyframedata + (get_bits_count(gb) / 8);
202  s->blocks[blk_idx].size = block_size;
203  }
204  if (!s->color_depth) {
205  /* Flash Screen Video stores the image upside down, so copy
206  * lines to destination in reverse order. */
207  for (k = 1; k <= s->diff_height; k++) {
208  memcpy(s->frame.data[0] + x_pos * 3 +
209  (s->image_height - y_pos - s->diff_start - k) * s->frame.linesize[0],
210  line, width * 3);
211  /* advance source pointer to next line */
212  line += width * 3;
213  }
214  } else {
215  /* hybrid 15-bit/palette mode */
216  decode_hybrid(s->tmpblock, s->frame.data[0],
217  s->image_height - (y_pos + 1 + s->diff_start + s->diff_height),
218  x_pos, s->diff_height, width,
219  s->frame.linesize[0], s->pal);
220  }
221  skip_bits_long(gb, 8 * block_size); /* skip the consumed bits */
222  return 0;
223 }
224 
225 static int calc_deflate_block_size(int tmpblock_size)
226 {
227  z_stream zstream;
228  int size;
229 
230  zstream.zalloc = Z_NULL;
231  zstream.zfree = Z_NULL;
232  zstream.opaque = Z_NULL;
233  if (deflateInit(&zstream, 0) != Z_OK)
234  return -1;
235  size = deflateBound(&zstream, tmpblock_size);
236  deflateEnd(&zstream);
237 
238  return size;
239 }
240 
242  int *got_frame, AVPacket *avpkt)
243 {
244  int buf_size = avpkt->size;
245  FlashSVContext *s = avctx->priv_data;
246  int h_blocks, v_blocks, h_part, v_part, i, j, ret;
247  GetBitContext gb;
248  int last_blockwidth = s->block_width;
249  int last_blockheight= s->block_height;
250 
251  /* no supplementary picture */
252  if (buf_size == 0)
253  return 0;
254  if (buf_size < 4)
255  return -1;
256 
257  init_get_bits(&gb, avpkt->data, buf_size * 8);
258 
259  /* start to parse the bitstream */
260  s->block_width = 16 * (get_bits(&gb, 4) + 1);
261  s->image_width = get_bits(&gb, 12);
262  s->block_height = 16 * (get_bits(&gb, 4) + 1);
263  s->image_height = get_bits(&gb, 12);
264 
265  if ( last_blockwidth != s->block_width
266  || last_blockheight!= s->block_height)
267  av_freep(&s->blocks);
268 
269  if (s->ver == 2) {
270  skip_bits(&gb, 6);
271  if (get_bits1(&gb)) {
272  avpriv_request_sample(avctx, "iframe");
273  return AVERROR_PATCHWELCOME;
274  }
275  if (get_bits1(&gb)) {
276  avpriv_request_sample(avctx, "Custom palette");
277  return AVERROR_PATCHWELCOME;
278  }
279  }
280 
281  /* calculate number of blocks and size of border (partial) blocks */
282  h_blocks = s->image_width / s->block_width;
283  h_part = s->image_width % s->block_width;
284  v_blocks = s->image_height / s->block_height;
285  v_part = s->image_height % s->block_height;
286 
287  /* the block size could change between frames, make sure the buffer
288  * is large enough, if not, get a larger one */
289  if (s->block_size < s->block_width * s->block_height) {
290  int tmpblock_size = 3 * s->block_width * s->block_height;
291 
292  s->tmpblock = av_realloc(s->tmpblock, tmpblock_size);
293  if (!s->tmpblock) {
294  av_log(avctx, AV_LOG_ERROR, "Can't allocate decompression buffer.\n");
295  return AVERROR(ENOMEM);
296  }
297  if (s->ver == 2) {
298  s->deflate_block_size = calc_deflate_block_size(tmpblock_size);
299  if (s->deflate_block_size <= 0) {
300  av_log(avctx, AV_LOG_ERROR, "Can't determine deflate buffer size.\n");
301  return -1;
302  }
304  if (!s->deflate_block) {
305  av_log(avctx, AV_LOG_ERROR, "Can't allocate deflate buffer.\n");
306  return AVERROR(ENOMEM);
307  }
308  }
309  }
310  s->block_size = s->block_width * s->block_height;
311 
312  /* initialize the image size once */
313  if (avctx->width == 0 && avctx->height == 0) {
315  }
316 
317  /* check for changes of image width and image height */
318  if (avctx->width != s->image_width || avctx->height != s->image_height) {
319  av_log(avctx, AV_LOG_ERROR,
320  "Frame width or height differs from first frame!\n");
321  av_log(avctx, AV_LOG_ERROR, "fh = %d, fv %d vs ch = %d, cv = %d\n",
322  avctx->height, avctx->width, s->image_height, s->image_width);
323  return AVERROR_INVALIDDATA;
324  }
325 
326  /* we care for keyframes only in Screen Video v2 */
327  s->is_keyframe = (avpkt->flags & AV_PKT_FLAG_KEY) && (s->ver == 2);
328  if (s->is_keyframe) {
329  s->keyframedata = av_realloc(s->keyframedata, avpkt->size);
330  memcpy(s->keyframedata, avpkt->data, avpkt->size);
331  }
332  if(s->ver == 2 && !s->blocks)
333  s->blocks = av_mallocz((v_blocks + !!v_part) * (h_blocks + !!h_part)
334  * sizeof(s->blocks[0]));
335 
336  av_dlog(avctx, "image: %dx%d block: %dx%d num: %dx%d part: %dx%d\n",
338  h_blocks, v_blocks, h_part, v_part);
339 
340  if ((ret = ff_reget_buffer(avctx, &s->frame)) < 0)
341  return ret;
342 
343  /* loop over all block columns */
344  for (j = 0; j < v_blocks + (v_part ? 1 : 0); j++) {
345 
346  int y_pos = j * s->block_height; // vertical position in frame
347  int cur_blk_height = (j < v_blocks) ? s->block_height : v_part;
348 
349  /* loop over all block rows */
350  for (i = 0; i < h_blocks + (h_part ? 1 : 0); i++) {
351  int x_pos = i * s->block_width; // horizontal position in frame
352  int cur_blk_width = (i < h_blocks) ? s->block_width : h_part;
353  int has_diff = 0;
354 
355  /* get the size of the compressed zlib chunk */
356  int size = get_bits(&gb, 16);
357 
358  s->color_depth = 0;
359  s->zlibprime_curr = 0;
360  s->zlibprime_prev = 0;
361  s->diff_start = 0;
362  s->diff_height = cur_blk_height;
363 
364  if (8 * size > get_bits_left(&gb)) {
365  av_frame_unref(&s->frame);
366  return AVERROR_INVALIDDATA;
367  }
368 
369  if (s->ver == 2 && size) {
370  skip_bits(&gb, 3);
371  s->color_depth = get_bits(&gb, 2);
372  has_diff = get_bits1(&gb);
373  s->zlibprime_curr = get_bits1(&gb);
374  s->zlibprime_prev = get_bits1(&gb);
375 
376  if (s->color_depth != 0 && s->color_depth != 2) {
377  av_log(avctx, AV_LOG_ERROR,
378  "%dx%d invalid color depth %d\n", i, j, s->color_depth);
379  return AVERROR_INVALIDDATA;
380  }
381 
382  if (has_diff) {
383  if (!s->keyframe) {
384  av_log(avctx, AV_LOG_ERROR,
385  "inter frame without keyframe\n");
386  return AVERROR_INVALIDDATA;
387  }
388  s->diff_start = get_bits(&gb, 8);
389  s->diff_height = get_bits(&gb, 8);
390  av_log(avctx, AV_LOG_DEBUG,
391  "%dx%d diff start %d height %d\n",
392  i, j, s->diff_start, s->diff_height);
393  size -= 2;
394  }
395 
396  if (s->zlibprime_prev)
397  av_log(avctx, AV_LOG_DEBUG, "%dx%d zlibprime_prev\n", i, j);
398 
399  if (s->zlibprime_curr) {
400  int col = get_bits(&gb, 8);
401  int row = get_bits(&gb, 8);
402  av_log(avctx, AV_LOG_DEBUG, "%dx%d zlibprime_curr %dx%d\n", i, j, col, row);
403  size -= 2;
404  avpriv_request_sample(avctx, "zlibprime_curr");
405  return AVERROR_PATCHWELCOME;
406  }
407  if (!s->blocks && (s->zlibprime_curr || s->zlibprime_prev)) {
408  av_log(avctx, AV_LOG_ERROR, "no data available for zlib "
409  "priming\n");
410  return AVERROR_INVALIDDATA;
411  }
412  size--; // account for flags byte
413  }
414 
415  if (has_diff) {
416  int k;
417  int off = (s->image_height - y_pos - 1) * s->frame.linesize[0];
418 
419  for (k = 0; k < cur_blk_height; k++)
420  memcpy(s->frame.data[0] + off - k*s->frame.linesize[0] + x_pos*3,
421  s->keyframe + off - k*s->frame.linesize[0] + x_pos*3,
422  cur_blk_width * 3);
423  }
424 
425  /* skip unchanged blocks, which have size 0 */
426  if (size) {
427  if (flashsv_decode_block(avctx, avpkt, &gb, size,
428  cur_blk_width, cur_blk_height,
429  x_pos, y_pos,
430  i + j * (h_blocks + !!h_part)))
431  av_log(avctx, AV_LOG_ERROR,
432  "error in decompression of block %dx%d\n", i, j);
433  }
434  }
435  }
436  if (s->is_keyframe && s->ver == 2) {
437  if (!s->keyframe) {
438  s->keyframe = av_malloc(s->frame.linesize[0] * avctx->height);
439  if (!s->keyframe) {
440  av_log(avctx, AV_LOG_ERROR, "Cannot allocate image data\n");
441  return AVERROR(ENOMEM);
442  }
443  }
444  memcpy(s->keyframe, s->frame.data[0], s->frame.linesize[0] * avctx->height);
445  }
446 
447  if ((ret = av_frame_ref(data, &s->frame)) < 0)
448  return ret;
449 
450  *got_frame = 1;
451 
452  if ((get_bits_count(&gb) / 8) != buf_size)
453  av_log(avctx, AV_LOG_ERROR, "buffer not fully consumed (%d != %d)\n",
454  buf_size, (get_bits_count(&gb) / 8));
455 
456  /* report that the buffer was completely consumed */
457  return buf_size;
458 }
459 
460 
462 {
463  FlashSVContext *s = avctx->priv_data;
464  inflateEnd(&s->zstream);
465  /* release the frame if needed */
466  av_frame_unref(&s->frame);
467 
468  /* free the tmpblock */
469  av_free(s->tmpblock);
470 
471  return 0;
472 }
473 
474 
475 #if CONFIG_FLASHSV_DECODER
476 AVCodec ff_flashsv_decoder = {
477  .name = "flashsv",
478  .type = AVMEDIA_TYPE_VIDEO,
479  .id = AV_CODEC_ID_FLASHSV,
480  .priv_data_size = sizeof(FlashSVContext),
484  .capabilities = CODEC_CAP_DR1,
485  .pix_fmts = (const enum AVPixelFormat[]){ AV_PIX_FMT_BGR24, AV_PIX_FMT_NONE },
486  .long_name = NULL_IF_CONFIG_SMALL("Flash Screen Video v1"),
487 };
488 #endif /* CONFIG_FLASHSV_DECODER */
489 
490 #if CONFIG_FLASHSV2_DECODER
491 static const uint32_t ff_flashsv2_default_palette[128] = {
492  0x000000, 0x333333, 0x666666, 0x999999, 0xCCCCCC, 0xFFFFFF,
493  0x330000, 0x660000, 0x990000, 0xCC0000, 0xFF0000, 0x003300,
494  0x006600, 0x009900, 0x00CC00, 0x00FF00, 0x000033, 0x000066,
495  0x000099, 0x0000CC, 0x0000FF, 0x333300, 0x666600, 0x999900,
496  0xCCCC00, 0xFFFF00, 0x003333, 0x006666, 0x009999, 0x00CCCC,
497  0x00FFFF, 0x330033, 0x660066, 0x990099, 0xCC00CC, 0xFF00FF,
498  0xFFFF33, 0xFFFF66, 0xFFFF99, 0xFFFFCC, 0xFF33FF, 0xFF66FF,
499  0xFF99FF, 0xFFCCFF, 0x33FFFF, 0x66FFFF, 0x99FFFF, 0xCCFFFF,
500  0xCCCC33, 0xCCCC66, 0xCCCC99, 0xCCCCFF, 0xCC33CC, 0xCC66CC,
501  0xCC99CC, 0xCCFFCC, 0x33CCCC, 0x66CCCC, 0x99CCCC, 0xFFCCCC,
502  0x999933, 0x999966, 0x9999CC, 0x9999FF, 0x993399, 0x996699,
503  0x99CC99, 0x99FF99, 0x339999, 0x669999, 0xCC9999, 0xFF9999,
504  0x666633, 0x666699, 0x6666CC, 0x6666FF, 0x663366, 0x669966,
505  0x66CC66, 0x66FF66, 0x336666, 0x996666, 0xCC6666, 0xFF6666,
506  0x333366, 0x333399, 0x3333CC, 0x3333FF, 0x336633, 0x339933,
507  0x33CC33, 0x33FF33, 0x663333, 0x993333, 0xCC3333, 0xFF3333,
508  0x003366, 0x336600, 0x660033, 0x006633, 0x330066, 0x663300,
509  0x336699, 0x669933, 0x993366, 0x339966, 0x663399, 0x996633,
510  0x6699CC, 0x99CC66, 0xCC6699, 0x66CC99, 0x9966CC, 0xCC9966,
511  0x99CCFF, 0xCCFF99, 0xFF99CC, 0x99FFCC, 0xCC99FF, 0xFFCC99,
512  0x111111, 0x222222, 0x444444, 0x555555, 0xAAAAAA, 0xBBBBBB,
513  0xDDDDDD, 0xEEEEEE
514 };
515 
516 static av_cold int flashsv2_decode_init(AVCodecContext *avctx)
517 {
518  FlashSVContext *s = avctx->priv_data;
519  flashsv_decode_init(avctx);
520  s->pal = ff_flashsv2_default_palette;
521  s->ver = 2;
522 
523  return 0;
524 }
525 
526 static av_cold int flashsv2_decode_end(AVCodecContext *avctx)
527 {
528  FlashSVContext *s = avctx->priv_data;
529 
530  av_freep(&s->keyframedata);
531  av_freep(&s->blocks);
532  av_freep(&s->keyframe);
533  av_freep(&s->deflate_block);
534  flashsv_decode_end(avctx);
535 
536  return 0;
537 }
538 
539 AVCodec ff_flashsv2_decoder = {
540  .name = "flashsv2",
541  .type = AVMEDIA_TYPE_VIDEO,
542  .id = AV_CODEC_ID_FLASHSV2,
543  .priv_data_size = sizeof(FlashSVContext),
544  .init = flashsv2_decode_init,
545  .close = flashsv2_decode_end,
547  .capabilities = CODEC_CAP_DR1,
548  .pix_fmts = (const enum AVPixelFormat[]){ AV_PIX_FMT_BGR24, AV_PIX_FMT_NONE },
549  .long_name = NULL_IF_CONFIG_SMALL("Flash Screen Video v2"),
550 };
551 #endif /* CONFIG_FLASHSV2_DECODER */
int zlibprime_prev
Definition: flashsv.c:68
void * av_mallocz(size_t size)
Allocate a block of size bytes with alignment suitable for all memory accesses (including vectors if ...
Definition: mem.c:205
const char * s
Definition: avisynth_c.h:668
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
Definition: error.h:59
This structure describes decoded (raw) audio or video data.
Definition: frame.h:76
int size
Definition: flashsv.c:48
static unsigned int get_bits(GetBitContext *s, int n)
Read 1-25 bits.
Definition: get_bits.h:240
uint8_t * keyframe
Definition: flashsv.c:63
static void skip_bits_long(GetBitContext *s, int n)
Definition: get_bits.h:198
static av_cold int init(AVCodecContext *avctx)
Definition: avrndec.c:35
void avcodec_set_dimensions(AVCodecContext *s, int width, int height)
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
void * av_realloc(void *ptr, size_t size)
Allocate or reallocate a block of memory.
Definition: mem.c:141
av_dlog(ac->avr,"%d samples - audio_convert: %s to %s (%s)\n", len, av_get_sample_fmt_name(ac->in_fmt), av_get_sample_fmt_name(ac->out_fmt), use_generic?ac->func_descr_generic:ac->func_descr)
int stride
Definition: mace.c:144
const uint32_t * pal
Definition: flashsv.c:60
output residual component w
void av_freep(void *arg)
Free a memory block which has been allocated with av_malloc(z)() or av_realloc() and set the pointer ...
Definition: mem.c:198
static av_cold int flashsv_decode_end(AVCodecContext *avctx)
Definition: flashsv.c:461
AVCodecContext * avctx
Definition: flashsv.c:52
void void avpriv_request_sample(void *avc, const char *msg,...) av_printf_format(2
Log a generic warning message about a missing feature.
uint8_t
#define av_cold
Definition: attributes.h:78
#define b
Definition: input.c:42
#define CODEC_CAP_DR1
Codec uses get_buffer() for allocating buffers and supports custom allocators.
uint8_t * data
static int get_bits_count(const GetBitContext *s)
Definition: get_bits.h:193
bitstream reader API header.
int image_width
Definition: flashsv.c:54
int diff_start
Definition: flashsv.c:69
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
Discrete Time axis x
static int decode_hybrid(const uint8_t *sptr, uint8_t *dptr, int dx, int dy, int h, int w, int stride, const uint32_t *pal)
Definition: flashsv.c:73
static int get_bits_left(GetBitContext *gb)
Definition: get_bits.h:557
static av_cold int flashsv_decode_init(AVCodecContext *avctx)
Definition: flashsv.c:103
void av_free(void *ptr)
Free a memory block which has been allocated with av_malloc(z)() or av_realloc(). ...
Definition: mem.c:183
int block_width
Definition: flashsv.c:55
#define AV_RB16
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
Spectrum Plot time data
const char * r
Definition: vf_curves.c:94
Definition: graph2dot.c:48
void av_log(void *avcl, int level, const char *fmt,...)
Definition: log.c:246
const char * name
Name of the codec implementation.
external API header
int flags
A combination of AV_PKT_FLAG values.
int ff_reget_buffer(AVCodecContext *avctx, AVFrame *frame)
Identical in function to av_frame_make_writable(), except it uses ff_get_buffer() to allocate the buf...
FFT buffer for g
Definition: stft_peak.m:17
ret
Definition: avfilter.c:821
int width
picture width / height.
static int flashsv2_prime(FlashSVContext *s, uint8_t *src, int size)
Definition: flashsv.c:124
struct FlashSVContext FlashSVContext
packed RGB 8:8:8, 24bpp, BGRBGR...
Definition: pixfmt.h:71
static int flashsv_decode_frame(AVCodecContext *avctx, void *data, int *got_frame, AVPacket *avpkt)
Definition: flashsv.c:241
AVFrame frame
Definition: flashsv.c:53
#define AVERROR_PATCHWELCOME
Not yet implemented in FFmpeg, patches welcome.
Definition: error.h:62
for k
NULL
Definition: eval.c:55
static int width
Definition: tests/utils.c:158
int block_size
Definition: flashsv.c:57
AVS_Value src
Definition: avisynth_c.h:523
int linesize[AV_NUM_DATA_POINTERS]
For video, size in bytes of each picture line.
Definition: frame.h:101
uint8_t pos
Definition: dvdec.c:51
main external API structure.
static void close(AVCodecParserContext *s)
Definition: h264_parser.c:375
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:148
static unsigned int get_bits1(GetBitContext *s)
Definition: get_bits.h:273
static int calc_deflate_block_size(int tmpblock_size)
Definition: flashsv.c:225
BYTE int const BYTE int int int height
Definition: avisynth_c.h:713
int zlibprime_curr
Definition: flashsv.c:68
void * av_malloc(size_t size)
Allocate a block of size bytes with alignment suitable for all memory accesses (including vectors if ...
Definition: mem.c:73
void avcodec_get_frame_defaults(AVFrame *frame)
Set the fields of the given AVFrame to default values.
static void skip_bits(GetBitContext *s, int n)
Definition: get_bits.h:265
synthesis window for stochastic i
int is_keyframe
Definition: flashsv.c:61
z_stream zstream
Definition: flashsv.c:58
static int init_get_bits(GetBitContext *s, const uint8_t *buffer, int bit_size)
Initialize GetBitContext.
Definition: get_bits.h:379
void av_frame_unref(AVFrame *frame)
Unreference all the buffers referenced by frame and reset the frame fields.
Definition: frame.c:330
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFilterBuffer 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.Buffer references ownership and permissions
int color_depth
Definition: flashsv.c:67
int av_frame_ref(AVFrame *dst, AVFrame *src)
Setup a new reference to the data described by an given frame.
Definition: frame.c:228
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
Definition: frame.h:87
int deflate_block_size
Definition: flashsv.c:66
uint8_t * pos
Definition: flashsv.c:47
common internal api header.
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
Definition: log.h:162
static double c[64]
uint8_t * deflate_block
Definition: flashsv.c:65
function y
Definition: D.m:1
#define AVERROR_UNKNOWN
Unknown error, typically from an external library.
Definition: error.h:71
BlockInfo * blocks
Definition: flashsv.c:64
uint8_t * tmpblock
Definition: flashsv.c:56
uint8_t * keyframedata
Definition: flashsv.c:62
else dst[i][x+y *dst_stride[i]]
Definition: vf_mcdeint.c:160
static int flashsv_decode_block(AVCodecContext *avctx, AVPacket *avpkt, GetBitContext *gb, int block_size, int width, int height, int x_pos, int y_pos, int blk_idx)
Definition: flashsv.c:165
int block_height
Definition: flashsv.c:55
static int decode(AVCodecContext *avctx, void *data, int *got_frame, AVPacket *avpkt)
Definition: crystalhd.c:868
struct BlockInfo BlockInfo
AVPixelFormat
Pixel format.
Definition: pixfmt.h:66
This structure stores compressed data.
int diff_height
Definition: flashsv.c:69
for(j=16;j >0;--j)
int image_height
Definition: flashsv.c:54