annotate escape124.c @ 6920:d02af7474bff libavcodec

Prevent 128*1<<trellis from becoming 0 and creating 0 sized arrays. fixes CID84 RUN2 CID85 RUN2 CID86 RUN2 CID87 RUN2 CID88 RUN2 CID89 RUN2 CID90 RUN2 CID91 RUN2 CID92 RUN2 CID93 RUN2 CID94 RUN2 CID95 RUN2 CID96 RUN2 CID97 RUN2 CID98 RUN2 CID99 RUN2 CID100 RUN2 CID101 RUN2 CID102 RUN2 CID103 RUN2 CID104 RUN2 CID105 RUN2 CID106 RUN2
author michael
date Wed, 28 May 2008 11:59:41 +0000
parents a4104482ceef
children e943e1409077
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
1 /*
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
2 * Escape 124 Video Decoder
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
3 * Copyright (C) 2008 Eli Friedman (eli.friedman@gmail.com)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
4 *
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
5 * This file is part of FFmpeg.
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
6 *
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
11 *
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
15 * Lesser General Public License for more details.
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
16 *
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
20 */
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
21
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
22 #include "avcodec.h"
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
23
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
24 #define ALT_BITSTREAM_READER_LE
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
25 #include "bitstream.h"
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
26
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
27 typedef union MacroBlock {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
28 uint16_t pixels[4];
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
29 uint32_t pixels32[2];
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
30 } MacroBlock;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
31
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
32 typedef union SuperBlock {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
33 uint16_t pixels[64];
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
34 uint32_t pixels32[32];
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
35 } SuperBlock;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
36
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
37 typedef struct CodeBook {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
38 unsigned depth;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
39 unsigned size;
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
40 MacroBlock* blocks;
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
41 } CodeBook;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
42
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
43 typedef struct Escape124Context {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
44 AVFrame frame;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
45
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
46 unsigned num_superblocks;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
47
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
48 CodeBook codebooks[3];
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
49 } Escape124Context;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
50
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
51 static int can_safely_read(GetBitContext* gb, int bits) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
52 return get_bits_count(gb) + bits <= gb->size_in_bits;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
53 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
54
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
55 /**
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
56 * Initialize the decoder
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
57 * @param avctx decoder context
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
58 * @return 0 success, negative on error
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
59 */
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
60 static av_cold int escape124_decode_init(AVCodecContext *avctx)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
61 {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
62 Escape124Context *s = avctx->priv_data;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
63
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
64 avctx->pix_fmt = PIX_FMT_RGB555;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
65
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
66 s->num_superblocks = ((unsigned)avctx->width / 8) *
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
67 ((unsigned)avctx->height / 8);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
68
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
69 return 0;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
70 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
71
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
72 static av_cold int escape124_decode_close(AVCodecContext *avctx)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
73 {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
74 unsigned i;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
75 Escape124Context *s = avctx->priv_data;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
76
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
77 for (i = 0; i < 3; i++)
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
78 av_free(s->codebooks[i].blocks);
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
79
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
80 if (s->frame.data[0])
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
81 avctx->release_buffer(avctx, &s->frame);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
82
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
83 return 0;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
84 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
85
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
86 static CodeBook unpack_codebook(GetBitContext* gb, unsigned depth,
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
87 unsigned size)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
88 {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
89 unsigned i, j;
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
90 CodeBook cb = { 0 };
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
91
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
92 if (!can_safely_read(gb, size * 34))
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
93 return cb;
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
94
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
95 if (size >= INT_MAX / sizeof(MacroBlock))
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
96 return cb;
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
97 cb.blocks = av_malloc(size ? size * sizeof(MacroBlock) : 1);
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
98 if (!cb.blocks)
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
99 return cb;
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
100
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
101 cb.depth = depth;
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
102 cb.size = size;
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
103 for (i = 0; i < size; i++) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
104 unsigned mask_bits = get_bits(gb, 4);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
105 unsigned color0 = get_bits(gb, 15);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
106 unsigned color1 = get_bits(gb, 15);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
107
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
108 for (j = 0; j < 4; j++) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
109 if (mask_bits & (1 << j))
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
110 cb.blocks[i].pixels[j] = color1;
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
111 else
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
112 cb.blocks[i].pixels[j] = color0;
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
113 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
114 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
115 return cb;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
116 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
117
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
118 static unsigned decode_skip_count(GetBitContext* gb)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
119 {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
120 unsigned value;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
121 // This function reads a maximum of 23 bits,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
122 // which is within the padding space
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
123 if (!can_safely_read(gb, 1))
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
124 return -1;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
125 value = get_bits1(gb);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
126 if (!value)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
127 return value;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
128
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
129 value += get_bits(gb, 3);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
130 if (value != (1 + ((1 << 3) - 1)))
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
131 return value;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
132
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
133 value += get_bits(gb, 7);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
134 if (value != (1 + ((1 << 3) - 1)) + ((1 << 7) - 1))
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
135 return value;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
136
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
137 return value + get_bits(gb, 12);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
138 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
139
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
140 static MacroBlock decode_macroblock(Escape124Context* s, GetBitContext* gb,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
141 int* codebook_index, int superblock_index)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
142 {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
143 // This function reads a maximum of 22 bits; the callers
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
144 // guard this function appropriately
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
145 unsigned block_index, depth;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
146
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
147 if (get_bits1(gb)) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
148 static const char transitions[3][2] = { {2, 1}, {0, 2}, {1, 0} };
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
149 *codebook_index = transitions[*codebook_index][get_bits1(gb)];
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
150 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
151
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
152 depth = s->codebooks[*codebook_index].depth;
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
153
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
154 // depth = 0 means that this shouldn't read any bits;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
155 // in theory, this is the same as get_bits(gb, 0), but
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
156 // that doesn't actually work.
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
157 block_index = depth ? get_bits(gb, depth) : 0;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
158
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
159 if (*codebook_index == 1) {
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
160 block_index += superblock_index << s->codebooks[1].depth;
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
161 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
162
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
163 // This condition can occur with invalid bitstreams and
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
164 // *codebook_index == 2
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
165 if (block_index >= s->codebooks[*codebook_index].size)
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
166 return (MacroBlock) { { 0 } };
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
167
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
168 return s->codebooks[*codebook_index].blocks[block_index];
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
169 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
170
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
171 static void insert_mb_into_sb(SuperBlock* sb, MacroBlock mb, unsigned index) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
172 // Formula: ((index / 4) * 16 + (index % 4) * 2) / 2
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
173 uint32_t *dst = sb->pixels32 + index + (index & -4);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
174
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
175 // This technically violates C99 aliasing rules, but it should be safe.
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
176 dst[0] = mb.pixels32[0];
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
177 dst[4] = mb.pixels32[1];
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
178 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
179
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
180 static void copy_superblock(uint16_t* dest, unsigned dest_stride,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
181 uint16_t* src, unsigned src_stride)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
182 {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
183 unsigned y;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
184 if (src)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
185 for (y = 0; y < 8; y++)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
186 memcpy(dest + y * dest_stride, src + y * src_stride,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
187 sizeof(uint16_t) * 8);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
188 else
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
189 for (y = 0; y < 8; y++)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
190 memset(dest + y * dest_stride, 0, sizeof(uint16_t) * 8);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
191 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
192
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
193 static const uint16_t mask_matrix[] = {0x1, 0x2, 0x10, 0x20,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
194 0x4, 0x8, 0x40, 0x80,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
195 0x100, 0x200, 0x1000, 0x2000,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
196 0x400, 0x800, 0x4000, 0x8000};
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
197
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
198 /**
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
199 * Decode a single frame
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
200 * @param avctx decoder context
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
201 * @param data decoded frame
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
202 * @param data_size size of the decoded frame
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
203 * @param buf input buffer
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
204 * @param buf_size input buffer size
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
205 * @return 0 success, -1 on error
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
206 */
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
207 static int escape124_decode_frame(AVCodecContext *avctx,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
208 void *data, int *data_size,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
209 const uint8_t *buf, int buf_size)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
210 {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
211 Escape124Context *s = avctx->priv_data;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
212
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
213 GetBitContext gb;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
214 unsigned frame_flags, frame_size;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
215 unsigned i;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
216
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
217 unsigned superblock_index, cb_index = 1,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
218 superblock_col_index = 0,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
219 superblocks_per_row = avctx->width / 8, skip = -1;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
220
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
221 uint16_t* old_frame_data, *new_frame_data;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
222 unsigned old_stride, new_stride;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
223
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
224 AVFrame new_frame = { { 0 } };
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
225
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
226 init_get_bits(&gb, buf, buf_size * 8);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
227
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
228 // This call also guards the potential depth reads for the
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
229 // codebook unpacking.
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
230 if (!can_safely_read(&gb, 64))
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
231 return -1;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
232
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
233 frame_flags = get_bits_long(&gb, 32);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
234 frame_size = get_bits_long(&gb, 32);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
235
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
236 // Leave last frame unchanged
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
237 // FIXME: Is this necessary? I haven't seen it in any real samples
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
238 if (!(frame_flags & 0x114) || !(frame_flags & 0x7800000)) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
239 av_log(NULL, AV_LOG_DEBUG, "Skipping frame\n");
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
240
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
241 *data_size = sizeof(AVFrame);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
242 *(AVFrame*)data = s->frame;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
243
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
244 return frame_size;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
245 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
246
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
247 for (i = 0; i < 3; i++) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
248 if (frame_flags & (1 << (17 + i))) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
249 unsigned cb_depth, cb_size;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
250 if (i == 2) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
251 // This codebook can be cut off at places other than
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
252 // powers of 2, leaving some of the entries undefined.
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
253 cb_size = get_bits_long(&gb, 20);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
254 cb_depth = av_log2(cb_size - 1) + 1;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
255 } else {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
256 cb_depth = get_bits(&gb, 4);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
257 if (i == 0) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
258 // This is the most basic codebook: pow(2,depth) entries
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
259 // for a depth-length key
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
260 cb_size = 1 << cb_depth;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
261 } else {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
262 // This codebook varies per superblock
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
263 // FIXME: I don't think this handles integer overflow
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
264 // properly
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
265 cb_size = s->num_superblocks << cb_depth;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
266 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
267 }
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
268 av_free(s->codebooks[i].blocks);
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
269 s->codebooks[i] = unpack_codebook(&gb, cb_depth, cb_size);
6556
8300baeb2b5f Remove flexible array member from Escape 124
superdump
parents: 6550
diff changeset
270 if (!s->codebooks[i].blocks)
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
271 return -1;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
272 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
273 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
274
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
275 new_frame.reference = 3;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
276 if (avctx->get_buffer(avctx, &new_frame)) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
277 av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
278 return -1;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
279 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
280
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
281 new_frame_data = (uint16_t*)new_frame.data[0];
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
282 new_stride = new_frame.linesize[0] / 2;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
283 old_frame_data = (uint16_t*)s->frame.data[0];
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
284 old_stride = s->frame.linesize[0] / 2;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
285
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
286 for (superblock_index = 0; superblock_index < s->num_superblocks;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
287 superblock_index++) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
288 MacroBlock mb;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
289 SuperBlock sb;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
290 unsigned multi_mask = 0;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
291
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
292 if (skip == -1) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
293 // Note that this call will make us skip the rest of the blocks
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
294 // if the frame prematurely ends
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
295 skip = decode_skip_count(&gb);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
296 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
297
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
298 if (skip) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
299 copy_superblock(new_frame_data, new_stride,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
300 old_frame_data, old_stride);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
301 } else {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
302 copy_superblock(sb.pixels, 8,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
303 old_frame_data, old_stride);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
304
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
305 while (can_safely_read(&gb, 1) && !get_bits1(&gb)) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
306 unsigned mask;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
307 mb = decode_macroblock(s, &gb, &cb_index, superblock_index);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
308 mask = get_bits(&gb, 16);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
309 multi_mask |= mask;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
310 for (i = 0; i < 16; i++) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
311 if (mask & mask_matrix[i]) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
312 insert_mb_into_sb(&sb, mb, i);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
313 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
314 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
315 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
316
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
317 if (can_safely_read(&gb, 1) && !get_bits1(&gb)) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
318 unsigned inv_mask = get_bits(&gb, 4);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
319 for (i = 0; i < 4; i++) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
320 if (inv_mask & (1 << i)) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
321 multi_mask ^= 0xF << i*4;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
322 } else {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
323 multi_mask ^= get_bits(&gb, 4) << i*4;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
324 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
325 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
326
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
327 for (i = 0; i < 16; i++) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
328 if (multi_mask & mask_matrix[i]) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
329 if (!can_safely_read(&gb, 1))
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
330 break;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
331 mb = decode_macroblock(s, &gb, &cb_index,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
332 superblock_index);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
333 insert_mb_into_sb(&sb, mb, i);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
334 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
335 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
336 } else if (frame_flags & (1 << 16)) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
337 while (can_safely_read(&gb, 1) && !get_bits1(&gb)) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
338 mb = decode_macroblock(s, &gb, &cb_index, superblock_index);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
339 insert_mb_into_sb(&sb, mb, get_bits(&gb, 4));
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
340 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
341 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
342
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
343 copy_superblock(new_frame_data, new_stride, sb.pixels, 8);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
344 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
345
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
346 superblock_col_index++;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
347 new_frame_data += 8;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
348 if (old_frame_data)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
349 old_frame_data += 8;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
350 if (superblock_col_index == superblocks_per_row) {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
351 new_frame_data += new_stride * 8 - superblocks_per_row * 8;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
352 if (old_frame_data)
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
353 old_frame_data += old_stride * 8 - superblocks_per_row * 8;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
354 superblock_col_index = 0;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
355 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
356 skip--;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
357 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
358
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
359 av_log(NULL, AV_LOG_DEBUG,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
360 "Escape sizes: %i, %i, %i\n",
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
361 frame_size, buf_size, get_bits_count(&gb) / 8);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
362
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
363 if (s->frame.data[0])
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
364 avctx->release_buffer(avctx, &s->frame);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
365
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
366 *(AVFrame*)data = s->frame = new_frame;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
367 *data_size = sizeof(AVFrame);
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
368
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
369 return frame_size;
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
370 }
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
371
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
372
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
373 AVCodec escape124_decoder = {
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
374 "escape124",
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
375 CODEC_TYPE_VIDEO,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
376 CODEC_ID_ESCAPE124,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
377 sizeof(Escape124Context),
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
378 escape124_decode_init,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
379 NULL,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
380 escape124_decode_close,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
381 escape124_decode_frame,
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
382 CODEC_CAP_DR1,
6710
a4104482ceef Add long names to many AVCodec declarations.
diego
parents: 6556
diff changeset
383 .long_name = "Escape 124",
6549
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
384 };
6b07b4eeabb9 Escape 124 (RPL) decoder
superdump
parents:
diff changeset
385