Line | Branch | Exec | Source |
---|---|---|---|
1 | /* | ||
2 | * Copyright (C) 2006 Aurelien Jacobs <aurel@gnuage.org> | ||
3 | * | ||
4 | * This file is part of FFmpeg. | ||
5 | * | ||
6 | * FFmpeg is free software; you can redistribute it and/or | ||
7 | * modify it under the terms of the GNU Lesser General Public | ||
8 | * License as published by the Free Software Foundation; either | ||
9 | * version 2.1 of the License, or (at your option) any later version. | ||
10 | * | ||
11 | * FFmpeg is distributed in the hope that it will be useful, | ||
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
14 | * Lesser General Public License for more details. | ||
15 | * | ||
16 | * You should have received a copy of the GNU Lesser General Public | ||
17 | * License along with FFmpeg; if not, write to the Free Software | ||
18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | ||
19 | */ | ||
20 | |||
21 | /** | ||
22 | * @file | ||
23 | * VP6 compatible video decoder | ||
24 | * | ||
25 | * The VP6F decoder accepts an optional 1 byte extradata. It is composed of: | ||
26 | * - upper 4 bits: difference between encoded width and visible width | ||
27 | * - lower 4 bits: difference between encoded height and visible height | ||
28 | */ | ||
29 | |||
30 | #include <stdlib.h> | ||
31 | |||
32 | #include "avcodec.h" | ||
33 | #include "codec_internal.h" | ||
34 | #include "decode.h" | ||
35 | #include "get_bits.h" | ||
36 | #include "huffman.h" | ||
37 | |||
38 | #include "vp56.h" | ||
39 | #include "vp56data.h" | ||
40 | #include "vp6data.h" | ||
41 | #include "vpx_rac.h" | ||
42 | |||
43 | #define VP6_MAX_HUFF_SIZE 12 | ||
44 | |||
45 | static int vp6_parse_coeff(VP56Context *s); | ||
46 | static int vp6_parse_coeff_huffman(VP56Context *s); | ||
47 | |||
48 | 1016 | static int vp6_parse_header(VP56Context *s, const uint8_t *buf, int buf_size) | |
49 | { | ||
50 | 1016 | VPXRangeCoder *c = &s->c; | |
51 | 1016 | int parse_filter_info = 0; | |
52 | 1016 | int coeff_offset = 0; | |
53 | 1016 | int vrt_shift = 0; | |
54 | int sub_version; | ||
55 | int rows, cols; | ||
56 | 1016 | int res = 0; | |
57 | int ret; | ||
58 | 1016 | int separated_coeff = buf[0] & 1; | |
59 | |||
60 |
2/2✓ Branch 0 taken 41 times.
✓ Branch 1 taken 975 times.
|
1016 | if (!(buf[0] & 0x80)) |
61 | 41 | s->frames[VP56_FRAME_CURRENT]->flags |= AV_FRAME_FLAG_KEY; | |
62 | else | ||
63 | 975 | s->frames[VP56_FRAME_CURRENT]->flags &= ~AV_FRAME_FLAG_KEY; | |
64 | 1016 | ff_vp56_init_dequant(s, (buf[0] >> 1) & 0x3F); | |
65 | |||
66 |
2/2✓ Branch 0 taken 41 times.
✓ Branch 1 taken 975 times.
|
1016 | if (s->frames[VP56_FRAME_CURRENT]->flags & AV_FRAME_FLAG_KEY) { |
67 | 41 | sub_version = buf[1] >> 3; | |
68 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 41 times.
|
41 | if (sub_version > 8) |
69 | ✗ | return AVERROR_INVALIDDATA; | |
70 | 41 | s->filter_header = buf[1] & 0x06; | |
71 | 41 | s->interlaced = buf[1] & 1; | |
72 |
2/2✓ Branch 0 taken 2 times.
✓ Branch 1 taken 39 times.
|
41 | if (s->interlaced) |
73 | 2 | s->def_coeff_reorder = vp6_il_coeff_reorder; | |
74 | else | ||
75 | 39 | s->def_coeff_reorder = vp6_def_coeff_reorder; | |
76 |
3/4✓ Branch 0 taken 28 times.
✓ Branch 1 taken 13 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 28 times.
|
41 | if (separated_coeff || !s->filter_header) { |
77 | 13 | coeff_offset = AV_RB16(buf+2) - 2; | |
78 | 13 | buf += 2; | |
79 | 13 | buf_size -= 2; | |
80 | } | ||
81 | |||
82 | 41 | rows = buf[2]; /* number of stored macroblock rows */ | |
83 | 41 | cols = buf[3]; /* number of stored macroblock cols */ | |
84 | /* buf[4] is number of displayed macroblock rows */ | ||
85 | /* buf[5] is number of displayed macroblock cols */ | ||
86 |
2/4✓ Branch 0 taken 41 times.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 3 taken 41 times.
|
41 | if (!rows || !cols) { |
87 | ✗ | av_log(s->avctx, AV_LOG_ERROR, "Invalid size %dx%d\n", cols << 4, rows << 4); | |
88 | ✗ | return AVERROR_INVALIDDATA; | |
89 | } | ||
90 | |||
91 |
2/2✓ Branch 0 taken 28 times.
✓ Branch 1 taken 13 times.
|
41 | if (!s->macroblocks || /* first frame */ |
92 |
1/2✓ Branch 0 taken 28 times.
✗ Branch 1 not taken.
|
28 | 16*cols != s->avctx->coded_width || |
93 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 28 times.
|
28 | 16*rows != s->avctx->coded_height) { |
94 |
2/2✓ Branch 0 taken 11 times.
✓ Branch 1 taken 2 times.
|
13 | if (s->avctx->extradata_size == 0 && |
95 |
2/2✓ Branch 0 taken 6 times.
✓ Branch 1 taken 5 times.
|
11 | FFALIGN(s->avctx->width, 16) == 16 * cols && |
96 |
1/2✓ Branch 0 taken 6 times.
✗ Branch 1 not taken.
|
6 | FFALIGN(s->avctx->height, 16) == 16 * rows) { |
97 | // We assume this is properly signalled container cropping, | ||
98 | // in an F4V file. Just set the coded_width/height, don't | ||
99 | // touch the cropped ones. | ||
100 | 6 | s->avctx->coded_width = 16 * cols; | |
101 | 6 | s->avctx->coded_height = 16 * rows; | |
102 | } else { | ||
103 | 7 | ret = ff_set_dimensions(s->avctx, 16 * cols, 16 * rows); | |
104 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 7 times.
|
7 | if (ret < 0) |
105 | ✗ | return ret; | |
106 | |||
107 |
2/2✓ Branch 0 taken 2 times.
✓ Branch 1 taken 5 times.
|
7 | if (s->avctx->extradata_size == 1) { |
108 | 2 | s->avctx->width -= s->avctx->extradata[0] >> 4; | |
109 | 2 | s->avctx->height -= s->avctx->extradata[0] & 0x0F; | |
110 | } | ||
111 | } | ||
112 | 13 | res = VP56_SIZE_CHANGE; | |
113 | } | ||
114 | |||
115 | 41 | ret = ff_vpx_init_range_decoder(c, buf+6, buf_size-6); | |
116 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 41 times.
|
41 | if (ret < 0) |
117 | ✗ | goto fail; | |
118 | 41 | vp56_rac_gets(c, 2); | |
119 | |||
120 | 41 | parse_filter_info = s->filter_header; | |
121 |
2/2✓ Branch 0 taken 16 times.
✓ Branch 1 taken 25 times.
|
41 | if (sub_version < 8) |
122 | 16 | vrt_shift = 5; | |
123 | 41 | s->sub_version = sub_version; | |
124 | 41 | s->golden_frame = 0; | |
125 | } else { | ||
126 |
3/6✓ Branch 0 taken 975 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 975 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 975 times.
|
975 | if (!s->sub_version || !s->avctx->coded_width || !s->avctx->coded_height) |
127 | ✗ | return AVERROR_INVALIDDATA; | |
128 | |||
129 |
3/4✓ Branch 0 taken 549 times.
✓ Branch 1 taken 426 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 549 times.
|
975 | if (separated_coeff || !s->filter_header) { |
130 | 426 | coeff_offset = AV_RB16(buf+1) - 2; | |
131 | 426 | buf += 2; | |
132 | 426 | buf_size -= 2; | |
133 | } | ||
134 | 975 | ret = ff_vpx_init_range_decoder(c, buf+1, buf_size-1); | |
135 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 975 times.
|
975 | if (ret < 0) |
136 | ✗ | return ret; | |
137 | |||
138 | 975 | s->golden_frame = vpx_rac_get(c); | |
139 |
2/2✓ Branch 0 taken 549 times.
✓ Branch 1 taken 426 times.
|
975 | if (s->filter_header) { |
140 | 549 | s->deblock_filtering = vpx_rac_get(c); | |
141 |
1/2✓ Branch 0 taken 549 times.
✗ Branch 1 not taken.
|
549 | if (s->deblock_filtering) |
142 | 549 | vpx_rac_get(c); | |
143 |
2/2✓ Branch 0 taken 429 times.
✓ Branch 1 taken 120 times.
|
549 | if (s->sub_version > 7) |
144 | 429 | parse_filter_info = vpx_rac_get(c); | |
145 | } | ||
146 | } | ||
147 | |||
148 |
2/2✓ Branch 0 taken 167 times.
✓ Branch 1 taken 849 times.
|
1016 | if (parse_filter_info) { |
149 |
1/2✓ Branch 1 taken 167 times.
✗ Branch 2 not taken.
|
167 | if (vpx_rac_get(c)) { |
150 | 167 | s->filter_mode = 2; | |
151 | 167 | s->sample_variance_threshold = vp56_rac_gets(c, 5) << vrt_shift; | |
152 | 167 | s->max_vector_length = 2 << vp56_rac_gets(c, 3); | |
153 | ✗ | } else if (vpx_rac_get(c)) { | |
154 | ✗ | s->filter_mode = 1; | |
155 | } else { | ||
156 | ✗ | s->filter_mode = 0; | |
157 | } | ||
158 |
2/2✓ Branch 0 taken 164 times.
✓ Branch 1 taken 3 times.
|
167 | if (s->sub_version > 7) |
159 | 164 | s->filter_selection = vp56_rac_gets(c, 4); | |
160 | else | ||
161 | 3 | s->filter_selection = 16; | |
162 | } | ||
163 | |||
164 | 1016 | s->use_huffman = vpx_rac_get(c); | |
165 | |||
166 | 1016 | s->parse_coeff = vp6_parse_coeff; | |
167 |
2/2✓ Branch 0 taken 439 times.
✓ Branch 1 taken 577 times.
|
1016 | if (coeff_offset) { |
168 | 439 | buf += coeff_offset; | |
169 | 439 | buf_size -= coeff_offset; | |
170 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 439 times.
|
439 | if (buf_size < 0) { |
171 | ✗ | ret = AVERROR_INVALIDDATA; | |
172 | ✗ | goto fail; | |
173 | } | ||
174 |
2/2✓ Branch 0 taken 117 times.
✓ Branch 1 taken 322 times.
|
439 | if (s->use_huffman) { |
175 | 117 | s->parse_coeff = vp6_parse_coeff_huffman; | |
176 | 117 | ret = init_get_bits8(&s->gb, buf, buf_size); | |
177 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 117 times.
|
117 | if (ret < 0) |
178 | ✗ | return ret; | |
179 | } else { | ||
180 | 322 | ret = ff_vpx_init_range_decoder(&s->cc, buf, buf_size); | |
181 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 322 times.
|
322 | if (ret < 0) |
182 | ✗ | goto fail; | |
183 | 322 | s->ccp = &s->cc; | |
184 | } | ||
185 | } else { | ||
186 | 577 | s->ccp = &s->c; | |
187 | } | ||
188 | |||
189 | 1016 | return res; | |
190 | ✗ | fail: | |
191 | ✗ | if (res == VP56_SIZE_CHANGE) | |
192 | ✗ | ff_set_dimensions(s->avctx, 0, 0); | |
193 | ✗ | return ret; | |
194 | } | ||
195 | |||
196 | 344 | static void vp6_coeff_order_table_init(VP56Context *s) | |
197 | { | ||
198 | 344 | int i, pos, idx = 1; | |
199 | |||
200 | 344 | s->modelp->coeff_index_to_pos[0] = 0; | |
201 |
2/2✓ Branch 0 taken 5504 times.
✓ Branch 1 taken 344 times.
|
5848 | for (i=0; i<16; i++) |
202 |
2/2✓ Branch 0 taken 346752 times.
✓ Branch 1 taken 5504 times.
|
352256 | for (pos=1; pos<64; pos++) |
203 |
2/2✓ Branch 0 taken 21672 times.
✓ Branch 1 taken 325080 times.
|
346752 | if (s->modelp->coeff_reorder[pos] == i) |
204 | 21672 | s->modelp->coeff_index_to_pos[idx++] = pos; | |
205 | |||
206 |
2/2✓ Branch 0 taken 22016 times.
✓ Branch 1 taken 344 times.
|
22360 | for (idx = 0; idx < 64; idx++) { |
207 | 22016 | int max = 0; | |
208 |
2/2✓ Branch 0 taken 715520 times.
✓ Branch 1 taken 22016 times.
|
737536 | for (i = 0; i <= idx; i++) { |
209 | 715520 | int v = s->modelp->coeff_index_to_pos[i]; | |
210 |
2/2✓ Branch 0 taken 257658 times.
✓ Branch 1 taken 457862 times.
|
715520 | if (v > max) |
211 | 257658 | max = v; | |
212 | } | ||
213 |
2/2✓ Branch 0 taken 2560 times.
✓ Branch 1 taken 19456 times.
|
22016 | if (s->sub_version > 6) |
214 | 2560 | max++; | |
215 | 22016 | s->modelp->coeff_index_to_idct_selector[idx] = max; | |
216 | } | ||
217 | 344 | } | |
218 | |||
219 | 41 | static void vp6_default_models_init(VP56Context *s) | |
220 | { | ||
221 | 41 | VP56Model *model = s->modelp; | |
222 | |||
223 | 41 | model->vector_dct[0] = 0xA2; | |
224 | 41 | model->vector_dct[1] = 0xA4; | |
225 | 41 | model->vector_sig[0] = 0x80; | |
226 | 41 | model->vector_sig[1] = 0x80; | |
227 | |||
228 | 41 | memcpy(model->mb_types_stats, ff_vp56_def_mb_types_stats, sizeof(model->mb_types_stats)); | |
229 | 41 | memcpy(model->vector_fdv, vp6_def_fdv_vector_model, sizeof(model->vector_fdv)); | |
230 | 41 | memcpy(model->vector_pdv, vp6_def_pdv_vector_model, sizeof(model->vector_pdv)); | |
231 | 41 | memcpy(model->coeff_runv, vp6_def_runv_coeff_model, sizeof(model->coeff_runv)); | |
232 | 41 | memcpy(model->coeff_reorder, s->def_coeff_reorder, sizeof(model->coeff_reorder)); | |
233 | |||
234 | 41 | vp6_coeff_order_table_init(s); | |
235 | 41 | } | |
236 | |||
237 | 975 | static void vp6_parse_vector_models(VP56Context *s) | |
238 | { | ||
239 | 975 | VPXRangeCoder *c = &s->c; | |
240 | 975 | VP56Model *model = s->modelp; | |
241 | int comp, node; | ||
242 | |||
243 |
2/2✓ Branch 0 taken 1950 times.
✓ Branch 1 taken 975 times.
|
2925 | for (comp=0; comp<2; comp++) { |
244 |
2/2✓ Branch 1 taken 109 times.
✓ Branch 2 taken 1841 times.
|
1950 | if (vpx_rac_get_prob_branchy(c, vp6_sig_dct_pct[comp][0])) |
245 | 109 | model->vector_dct[comp] = vp56_rac_gets_nn(c, 7); | |
246 |
2/2✓ Branch 1 taken 17 times.
✓ Branch 2 taken 1933 times.
|
1950 | if (vpx_rac_get_prob_branchy(c, vp6_sig_dct_pct[comp][1])) |
247 | 17 | model->vector_sig[comp] = vp56_rac_gets_nn(c, 7); | |
248 | } | ||
249 | |||
250 |
2/2✓ Branch 0 taken 1950 times.
✓ Branch 1 taken 975 times.
|
2925 | for (comp=0; comp<2; comp++) |
251 |
2/2✓ Branch 0 taken 13650 times.
✓ Branch 1 taken 1950 times.
|
15600 | for (node=0; node<7; node++) |
252 |
2/2✓ Branch 1 taken 24 times.
✓ Branch 2 taken 13626 times.
|
13650 | if (vpx_rac_get_prob_branchy(c, vp6_pdv_pct[comp][node])) |
253 | 24 | model->vector_pdv[comp][node] = vp56_rac_gets_nn(c, 7); | |
254 | |||
255 |
2/2✓ Branch 0 taken 1950 times.
✓ Branch 1 taken 975 times.
|
2925 | for (comp=0; comp<2; comp++) |
256 |
2/2✓ Branch 0 taken 15600 times.
✓ Branch 1 taken 1950 times.
|
17550 | for (node=0; node<8; node++) |
257 |
2/2✓ Branch 1 taken 10 times.
✓ Branch 2 taken 15590 times.
|
15600 | if (vpx_rac_get_prob_branchy(c, vp6_fdv_pct[comp][node])) |
258 | 10 | model->vector_fdv[comp][node] = vp56_rac_gets_nn(c, 7); | |
259 | 975 | } | |
260 | |||
261 | /* nodes must ascend by count, but with descending symbol order */ | ||
262 | 149929 | static int vp6_huff_cmp(const void *va, const void *vb) | |
263 | { | ||
264 | 149929 | const Node *a = va, *b = vb; | |
265 | 149929 | return (a->count - b->count)*16 + (b->sym - a->sym); | |
266 | } | ||
267 | |||
268 | 4680 | static int vp6_build_huff_tree(VP56Context *s, uint8_t coeff_model[], | |
269 | const uint8_t *map, unsigned size, VLC *vlc) | ||
270 | { | ||
271 | 4680 | Node nodes[2*VP6_MAX_HUFF_SIZE], *tmp = &nodes[size]; | |
272 | int a, b, i; | ||
273 | |||
274 | /* first compute probabilities from model */ | ||
275 | 4680 | tmp[0].count = 256; | |
276 |
2/2✓ Branch 0 taken 50778 times.
✓ Branch 1 taken 4680 times.
|
55458 | for (i=0; i<size-1; i++) { |
277 | 50778 | a = tmp[i].count * coeff_model[i] >> 8; | |
278 | 50778 | b = tmp[i].count * (255 - coeff_model[i]) >> 8; | |
279 | 50778 | nodes[map[2*i ]].count = a + !a; | |
280 | 50778 | nodes[map[2*i+1]].count = b + !b; | |
281 | } | ||
282 | |||
283 | 4680 | ff_vlc_free(vlc); | |
284 | /* then build the huffman tree according to probabilities */ | ||
285 | 4680 | return ff_huff_build_tree(s->avctx, vlc, size, FF_HUFFMAN_BITS, | |
286 | nodes, vp6_huff_cmp, | ||
287 | FF_HUFFMAN_FLAG_HNODE_FIRST); | ||
288 | } | ||
289 | |||
290 | 1016 | static int vp6_parse_coeff_models(VP56Context *s) | |
291 | { | ||
292 | 1016 | VPXRangeCoder *c = &s->c; | |
293 | 1016 | VP56Model *model = s->modelp; | |
294 | int def_prob[11]; | ||
295 | int node, cg, ctx, pos; | ||
296 | int ct; /* code type */ | ||
297 | int pt; /* plane type (0 for Y, 1 for U or V) */ | ||
298 | |||
299 | 1016 | memset(def_prob, 0x80, sizeof(def_prob)); | |
300 | |||
301 |
2/2✓ Branch 0 taken 2032 times.
✓ Branch 1 taken 1016 times.
|
3048 | for (pt=0; pt<2; pt++) |
302 |
2/2✓ Branch 0 taken 22352 times.
✓ Branch 1 taken 2032 times.
|
24384 | for (node=0; node<11; node++) |
303 |
2/2✓ Branch 1 taken 1216 times.
✓ Branch 2 taken 21136 times.
|
22352 | if (vpx_rac_get_prob_branchy(c, vp6_dccv_pct[pt][node])) { |
304 | 1216 | def_prob[node] = vp56_rac_gets_nn(c, 7); | |
305 | 1216 | model->coeff_dccv[pt][node] = def_prob[node]; | |
306 |
2/2✓ Branch 0 taken 601 times.
✓ Branch 1 taken 20535 times.
|
21136 | } else if (s->frames[VP56_FRAME_CURRENT]->flags & AV_FRAME_FLAG_KEY) { |
307 | 601 | model->coeff_dccv[pt][node] = def_prob[node]; | |
308 | } | ||
309 | |||
310 |
2/2✓ Branch 1 taken 303 times.
✓ Branch 2 taken 713 times.
|
1016 | if (vpx_rac_get(c)) { |
311 |
2/2✓ Branch 0 taken 19089 times.
✓ Branch 1 taken 303 times.
|
19392 | for (pos=1; pos<64; pos++) |
312 |
2/2✓ Branch 1 taken 15976 times.
✓ Branch 2 taken 3113 times.
|
19089 | if (vpx_rac_get_prob_branchy(c, vp6_coeff_reorder_pct[pos])) |
313 | 15976 | model->coeff_reorder[pos] = vp56_rac_gets(c, 4); | |
314 | 303 | vp6_coeff_order_table_init(s); | |
315 | } | ||
316 | |||
317 |
2/2✓ Branch 0 taken 2032 times.
✓ Branch 1 taken 1016 times.
|
3048 | for (cg=0; cg<2; cg++) |
318 |
2/2✓ Branch 0 taken 28448 times.
✓ Branch 1 taken 2032 times.
|
30480 | for (node=0; node<14; node++) |
319 |
2/2✓ Branch 1 taken 884 times.
✓ Branch 2 taken 27564 times.
|
28448 | if (vpx_rac_get_prob_branchy(c, vp6_runv_pct[cg][node])) |
320 | 884 | model->coeff_runv[cg][node] = vp56_rac_gets_nn(c, 7); | |
321 | |||
322 |
2/2✓ Branch 0 taken 3048 times.
✓ Branch 1 taken 1016 times.
|
4064 | for (ct=0; ct<3; ct++) |
323 |
2/2✓ Branch 0 taken 6096 times.
✓ Branch 1 taken 3048 times.
|
9144 | for (pt=0; pt<2; pt++) |
324 |
2/2✓ Branch 0 taken 36576 times.
✓ Branch 1 taken 6096 times.
|
42672 | for (cg=0; cg<6; cg++) |
325 |
2/2✓ Branch 0 taken 402336 times.
✓ Branch 1 taken 36576 times.
|
438912 | for (node=0; node<11; node++) |
326 |
2/2✓ Branch 1 taken 5413 times.
✓ Branch 2 taken 396923 times.
|
402336 | if (vpx_rac_get_prob_branchy(c, vp6_ract_pct[ct][pt][cg][node])) { |
327 | 5413 | def_prob[node] = vp56_rac_gets_nn(c, 7); | |
328 | 5413 | model->coeff_ract[pt][ct][cg][node] = def_prob[node]; | |
329 |
2/2✓ Branch 0 taken 14606 times.
✓ Branch 1 taken 382317 times.
|
396923 | } else if (s->frames[VP56_FRAME_CURRENT]->flags & AV_FRAME_FLAG_KEY) { |
330 | 14606 | model->coeff_ract[pt][ct][cg][node] = def_prob[node]; | |
331 | } | ||
332 | |||
333 |
2/2✓ Branch 0 taken 117 times.
✓ Branch 1 taken 899 times.
|
1016 | if (s->use_huffman) { |
334 |
2/2✓ Branch 0 taken 234 times.
✓ Branch 1 taken 117 times.
|
351 | for (pt=0; pt<2; pt++) { |
335 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 234 times.
|
234 | if (vp6_build_huff_tree(s, model->coeff_dccv[pt], |
336 | vp6_huff_coeff_map, 12, &s->dccv_vlc[pt])) | ||
337 | ✗ | return -1; | |
338 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 234 times.
|
234 | if (vp6_build_huff_tree(s, model->coeff_runv[pt], |
339 | vp6_huff_run_map, 9, &s->runv_vlc[pt])) | ||
340 | ✗ | return -1; | |
341 |
2/2✓ Branch 0 taken 702 times.
✓ Branch 1 taken 234 times.
|
936 | for (ct=0; ct<3; ct++) |
342 |
2/2✓ Branch 0 taken 4212 times.
✓ Branch 1 taken 702 times.
|
4914 | for (cg = 0; cg < 6; cg++) |
343 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 4212 times.
|
4212 | if (vp6_build_huff_tree(s, model->coeff_ract[pt][ct][cg], |
344 | vp6_huff_coeff_map, 12, | ||
345 | &s->ract_vlc[pt][ct][cg])) | ||
346 | ✗ | return -1; | |
347 | } | ||
348 | 117 | memset(s->nb_null, 0, sizeof(s->nb_null)); | |
349 | } else { | ||
350 | /* coeff_dcct is a linear combination of coeff_dccv */ | ||
351 |
2/2✓ Branch 0 taken 1798 times.
✓ Branch 1 taken 899 times.
|
2697 | for (pt=0; pt<2; pt++) |
352 |
2/2✓ Branch 0 taken 5394 times.
✓ Branch 1 taken 1798 times.
|
7192 | for (ctx=0; ctx<3; ctx++) |
353 |
2/2✓ Branch 0 taken 26970 times.
✓ Branch 1 taken 5394 times.
|
32364 | for (node=0; node<5; node++) |
354 | 26970 | model->coeff_dcct[pt][ctx][node] = av_clip(((model->coeff_dccv[pt][node] * vp6_dccv_lc[ctx][node][0] + 128) >> 8) + vp6_dccv_lc[ctx][node][1], 1, 255); | |
355 | } | ||
356 | 1016 | return 0; | |
357 | } | ||
358 | |||
359 | 19434 | static void vp6_parse_vector_adjustment(VP56Context *s, VP56mv *vect) | |
360 | { | ||
361 | 19434 | VPXRangeCoder *c = &s->c; | |
362 | 19434 | VP56Model *model = s->modelp; | |
363 | int comp; | ||
364 | |||
365 | 19434 | *vect = (VP56mv) {0,0}; | |
366 |
2/2✓ Branch 0 taken 16652 times.
✓ Branch 1 taken 2782 times.
|
19434 | if (s->vector_candidate_pos < 2) |
367 | 16652 | *vect = s->vector_candidate[0]; | |
368 | |||
369 |
2/2✓ Branch 0 taken 38868 times.
✓ Branch 1 taken 19434 times.
|
58302 | for (comp=0; comp<2; comp++) { |
370 | 38868 | int i, delta = 0; | |
371 | |||
372 |
2/2✓ Branch 1 taken 8755 times.
✓ Branch 2 taken 30113 times.
|
38868 | if (vpx_rac_get_prob_branchy(c, model->vector_dct[comp])) { |
373 | static const uint8_t prob_order[] = {0, 1, 2, 7, 6, 5, 4}; | ||
374 |
2/2✓ Branch 0 taken 61285 times.
✓ Branch 1 taken 8755 times.
|
70040 | for (i=0; i<sizeof(prob_order); i++) { |
375 | 61285 | int j = prob_order[i]; | |
376 | 61285 | delta |= vpx_rac_get_prob(c, model->vector_fdv[comp][j])<<j; | |
377 | } | ||
378 |
2/2✓ Branch 0 taken 4348 times.
✓ Branch 1 taken 4407 times.
|
8755 | if (delta & 0xF0) |
379 | 4348 | delta |= vpx_rac_get_prob(c, model->vector_fdv[comp][3])<<3; | |
380 | else | ||
381 | 4407 | delta |= 8; | |
382 | } else { | ||
383 | 30113 | delta = vp56_rac_get_tree(c, ff_vp56_pva_tree, | |
384 | 30113 | model->vector_pdv[comp]); | |
385 | } | ||
386 | |||
387 |
4/4✓ Branch 0 taken 29698 times.
✓ Branch 1 taken 9170 times.
✓ Branch 3 taken 14327 times.
✓ Branch 4 taken 15371 times.
|
38868 | if (delta && vpx_rac_get_prob_branchy(c, model->vector_sig[comp])) |
388 | 14327 | delta = -delta; | |
389 | |||
390 |
2/2✓ Branch 0 taken 19434 times.
✓ Branch 1 taken 19434 times.
|
38868 | if (!comp) |
391 | 19434 | vect->x += delta; | |
392 | else | ||
393 | 19434 | vect->y += delta; | |
394 | } | ||
395 | 19434 | } | |
396 | |||
397 | /** | ||
398 | * Read number of consecutive blocks with null DC or AC. | ||
399 | * This value is < 74. | ||
400 | */ | ||
401 | 28576 | static unsigned vp6_get_nb_null(VP56Context *s) | |
402 | { | ||
403 | 28576 | unsigned val = get_bits(&s->gb, 2); | |
404 |
2/2✓ Branch 0 taken 4892 times.
✓ Branch 1 taken 23684 times.
|
28576 | if (val == 2) |
405 | 4892 | val += get_bits(&s->gb, 2); | |
406 |
2/2✓ Branch 0 taken 806 times.
✓ Branch 1 taken 22878 times.
|
23684 | else if (val == 3) { |
407 | 806 | val = get_bits1(&s->gb) << 2; | |
408 | 806 | val = 6+val + get_bits(&s->gb, 2+val); | |
409 | } | ||
410 | 28576 | return val; | |
411 | } | ||
412 | |||
413 | 16848 | static int vp6_parse_coeff_huffman(VP56Context *s) | |
414 | { | ||
415 | 16848 | VP56Model *model = s->modelp; | |
416 | 16848 | uint8_t *permute = s->idct_scantable; | |
417 | VLC *vlc_coeff; | ||
418 | int coeff, sign, coeff_idx; | ||
419 | int b, cg, idx; | ||
420 | 16848 | int pt = 0; /* plane type (0 for Y, 1 for U or V) */ | |
421 | |||
422 |
2/2✓ Branch 0 taken 101088 times.
✓ Branch 1 taken 16848 times.
|
117936 | for (b=0; b<6; b++) { |
423 | 101088 | int ct = 0; /* code type */ | |
424 |
2/2✓ Branch 0 taken 33696 times.
✓ Branch 1 taken 67392 times.
|
101088 | if (b > 3) pt = 1; |
425 | 101088 | vlc_coeff = &s->dccv_vlc[pt]; | |
426 | |||
427 | 101088 | for (coeff_idx = 0;;) { | |
428 | 1161120 | int run = 1; | |
429 |
4/4✓ Branch 0 taken 202176 times.
✓ Branch 1 taken 958944 times.
✓ Branch 2 taken 28871 times.
✓ Branch 3 taken 173305 times.
|
1161120 | if (coeff_idx<2 && s->nb_null[coeff_idx][pt]) { |
430 | 28871 | s->nb_null[coeff_idx][pt]--; | |
431 |
2/2✓ Branch 0 taken 11362 times.
✓ Branch 1 taken 17509 times.
|
28871 | if (coeff_idx) |
432 | 11362 | break; | |
433 | } else { | ||
434 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 1132249 times.
|
1132249 | if (get_bits_left(&s->gb) <= 0) |
435 | ✗ | return AVERROR_INVALIDDATA; | |
436 | 1132249 | coeff = get_vlc2(&s->gb, vlc_coeff->table, FF_HUFFMAN_BITS, 3); | |
437 |
2/2✓ Branch 0 taken 345601 times.
✓ Branch 1 taken 786648 times.
|
1132249 | if (coeff == 0) { |
438 |
2/2✓ Branch 0 taken 326823 times.
✓ Branch 1 taken 18778 times.
|
345601 | if (coeff_idx) { |
439 | 326823 | int pt = (coeff_idx >= 6); | |
440 | 326823 | run += get_vlc2(&s->gb, s->runv_vlc[pt].table, FF_HUFFMAN_BITS, 3); | |
441 |
2/2✓ Branch 0 taken 60162 times.
✓ Branch 1 taken 266661 times.
|
326823 | if (run >= 9) |
442 | 60162 | run += get_bits(&s->gb, 6); | |
443 | } else | ||
444 | 18778 | s->nb_null[0][pt] = vp6_get_nb_null(s); | |
445 | 345601 | ct = 0; | |
446 |
2/2✓ Branch 0 taken 88872 times.
✓ Branch 1 taken 697776 times.
|
786648 | } else if (coeff == 11) { /* end of block */ |
447 |
2/2✓ Branch 0 taken 9798 times.
✓ Branch 1 taken 79074 times.
|
88872 | if (coeff_idx == 1) /* first AC coeff ? */ |
448 | 9798 | s->nb_null[1][pt] = vp6_get_nb_null(s); | |
449 | 88872 | break; | |
450 | } else { | ||
451 | 697776 | int coeff2 = ff_vp56_coeff_bias[coeff]; | |
452 |
2/2✓ Branch 0 taken 39048 times.
✓ Branch 1 taken 658728 times.
|
697776 | if (coeff > 4) |
453 |
2/2✓ Branch 0 taken 38623 times.
✓ Branch 1 taken 425 times.
|
39048 | coeff2 += get_bits(&s->gb, coeff <= 9 ? coeff - 4 : 11); |
454 |
2/2✓ Branch 0 taken 188610 times.
✓ Branch 1 taken 509166 times.
|
697776 | ct = 1 + (coeff2 > 1); |
455 | 697776 | sign = get_bits1(&s->gb); | |
456 | 697776 | coeff2 = (coeff2 ^ -sign) + sign; | |
457 |
2/2✓ Branch 0 taken 632975 times.
✓ Branch 1 taken 64801 times.
|
697776 | if (coeff_idx) |
458 | 632975 | coeff2 *= s->dequant_ac; | |
459 | 697776 | idx = model->coeff_index_to_pos[coeff_idx]; | |
460 | 697776 | s->block_coeff[b][permute[idx]] = coeff2; | |
461 | } | ||
462 | } | ||
463 | 1060886 | coeff_idx+=run; | |
464 |
2/2✓ Branch 0 taken 854 times.
✓ Branch 1 taken 1060032 times.
|
1060886 | if (coeff_idx >= 64) |
465 | 854 | break; | |
466 | 1060032 | cg = FFMIN(vp6_coeff_groups[coeff_idx], 3); | |
467 | 1060032 | vlc_coeff = &s->ract_vlc[pt][ct][cg]; | |
468 | } | ||
469 | 101088 | s->idct_selector[b] = model->coeff_index_to_idct_selector[FFMIN(coeff_idx, 63)]; | |
470 | } | ||
471 | 16848 | return 0; | |
472 | } | ||
473 | |||
474 | 80568 | static int vp6_parse_coeff(VP56Context *s) | |
475 | { | ||
476 | 80568 | VPXRangeCoder *c = s->ccp; | |
477 | 80568 | VP56Model *model = s->modelp; | |
478 | 80568 | uint8_t *permute = s->idct_scantable; | |
479 | uint8_t *model1, *model2, *model3; | ||
480 | int coeff, sign, coeff_idx; | ||
481 | int b, i, cg, idx, ctx; | ||
482 | 80568 | int pt = 0; /* plane type (0 for Y, 1 for U or V) */ | |
483 | |||
484 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 80568 times.
|
80568 | if (vpx_rac_is_end(c)) { |
485 | ✗ | av_log(s->avctx, AV_LOG_ERROR, "End of AC stream reached in vp6_parse_coeff\n"); | |
486 | ✗ | return AVERROR_INVALIDDATA; | |
487 | } | ||
488 | |||
489 |
2/2✓ Branch 0 taken 483408 times.
✓ Branch 1 taken 80568 times.
|
563976 | for (b=0; b<6; b++) { |
490 | 483408 | int ct = 1; /* code type */ | |
491 | 483408 | int run = 1; | |
492 | |||
493 |
2/2✓ Branch 0 taken 161136 times.
✓ Branch 1 taken 322272 times.
|
483408 | if (b > 3) pt = 1; |
494 | |||
495 | 483408 | ctx = s->left_block[ff_vp56_b6to4[b]].not_null_dc | |
496 | 483408 | + s->above_blocks[s->above_block_idx[b]].not_null_dc; | |
497 | 483408 | model1 = model->coeff_dccv[pt]; | |
498 | 483408 | model2 = model->coeff_dcct[pt][ctx]; | |
499 | |||
500 | 483408 | coeff_idx = 0; | |
501 | for (;;) { | ||
502 |
6/6✓ Branch 0 taken 1167692 times.
✓ Branch 1 taken 966816 times.
✓ Branch 2 taken 796879 times.
✓ Branch 3 taken 370813 times.
✓ Branch 5 taken 513262 times.
✓ Branch 6 taken 1250433 times.
|
2134508 | if ((coeff_idx>1 && ct==0) || vpx_rac_get_prob_branchy(c, model2[0])) { |
503 | /* parse a coeff */ | ||
504 |
2/2✓ Branch 1 taken 250770 times.
✓ Branch 2 taken 633305 times.
|
884075 | if (vpx_rac_get_prob_branchy(c, model2[2])) { |
505 |
2/2✓ Branch 1 taken 48244 times.
✓ Branch 2 taken 202526 times.
|
250770 | if (vpx_rac_get_prob_branchy(c, model2[3])) { |
506 | 48244 | idx = vp56_rac_get_tree(c, ff_vp56_pc_tree, model1); | |
507 | 48244 | coeff = ff_vp56_coeff_bias[idx+5]; | |
508 |
2/2✓ Branch 0 taken 96946 times.
✓ Branch 1 taken 48244 times.
|
145190 | for (i=ff_vp56_coeff_bit_length[idx]; i>=0; i--) |
509 | 96946 | coeff += vpx_rac_get_prob(c, ff_vp56_coeff_parse_table[idx][i]) << i; | |
510 | } else { | ||
511 |
2/2✓ Branch 1 taken 69876 times.
✓ Branch 2 taken 132650 times.
|
202526 | if (vpx_rac_get_prob_branchy(c, model2[4])) |
512 | 69876 | coeff = 3 + vpx_rac_get_prob(c, model1[5]); | |
513 | else | ||
514 | 132650 | coeff = 2; | |
515 | } | ||
516 | 250770 | ct = 2; | |
517 | } else { | ||
518 | 633305 | ct = 1; | |
519 | 633305 | coeff = 1; | |
520 | } | ||
521 | 884075 | sign = vpx_rac_get(c); | |
522 | 884075 | coeff = (coeff ^ -sign) + sign; | |
523 |
2/2✓ Branch 0 taken 799297 times.
✓ Branch 1 taken 84778 times.
|
884075 | if (coeff_idx) |
524 | 799297 | coeff *= s->dequant_ac; | |
525 | 884075 | idx = model->coeff_index_to_pos[coeff_idx]; | |
526 | 884075 | s->block_coeff[b][permute[idx]] = coeff; | |
527 | 884075 | run = 1; | |
528 | } else { | ||
529 | /* parse a run */ | ||
530 | 1250433 | ct = 0; | |
531 |
2/2✓ Branch 0 taken 851803 times.
✓ Branch 1 taken 398630 times.
|
1250433 | if (coeff_idx > 0) { |
532 |
2/2✓ Branch 1 taken 480990 times.
✓ Branch 2 taken 370813 times.
|
851803 | if (!vpx_rac_get_prob_branchy(c, model2[1])) |
533 | 480990 | break; | |
534 | |||
535 | 370813 | model3 = model->coeff_runv[coeff_idx >= 6]; | |
536 | 370813 | run = vp56_rac_get_tree(c, vp6_pcr_tree, model3); | |
537 |
2/2✓ Branch 0 taken 52715 times.
✓ Branch 1 taken 318098 times.
|
370813 | if (!run) |
538 |
2/2✓ Branch 0 taken 316290 times.
✓ Branch 1 taken 52715 times.
|
369005 | for (run=9, i=0; i<6; i++) |
539 | 316290 | run += vpx_rac_get_prob(c, model3[i+8]) << i; | |
540 | } | ||
541 | } | ||
542 | 1653518 | coeff_idx += run; | |
543 |
2/2✓ Branch 0 taken 2418 times.
✓ Branch 1 taken 1651100 times.
|
1653518 | if (coeff_idx >= 64) |
544 | 2418 | break; | |
545 | 1651100 | cg = vp6_coeff_groups[coeff_idx]; | |
546 | 1651100 | model1 = model2 = model->coeff_ract[pt][ct][cg]; | |
547 | } | ||
548 | |||
549 | 483408 | s->left_block[ff_vp56_b6to4[b]].not_null_dc = | |
550 | 483408 | s->above_blocks[s->above_block_idx[b]].not_null_dc = !!s->block_coeff[b][0]; | |
551 | 483408 | s->idct_selector[b] = model->coeff_index_to_idct_selector[FFMIN(coeff_idx, 63)]; | |
552 | } | ||
553 | 80568 | return 0; | |
554 | } | ||
555 | |||
556 | 84965 | static int vp6_block_variance(uint8_t *src, ptrdiff_t stride) | |
557 | { | ||
558 | 84965 | int sum = 0, square_sum = 0; | |
559 | int y, x; | ||
560 | |||
561 |
2/2✓ Branch 0 taken 339860 times.
✓ Branch 1 taken 84965 times.
|
424825 | for (y=0; y<8; y+=2) { |
562 |
2/2✓ Branch 0 taken 1359440 times.
✓ Branch 1 taken 339860 times.
|
1699300 | for (x=0; x<8; x+=2) { |
563 | 1359440 | sum += src[x]; | |
564 | 1359440 | square_sum += src[x]*src[x]; | |
565 | } | ||
566 | 339860 | src += 2*stride; | |
567 | } | ||
568 | 84965 | return (16*square_sum - sum*sum) >> 8; | |
569 | } | ||
570 | |||
571 | 32669 | static void vp6_filter_hv4(uint8_t *dst, uint8_t *src, ptrdiff_t stride, | |
572 | int delta, const int16_t *weights) | ||
573 | { | ||
574 | int x, y; | ||
575 | |||
576 |
2/2✓ Branch 0 taken 261352 times.
✓ Branch 1 taken 32669 times.
|
294021 | for (y=0; y<8; y++) { |
577 |
2/2✓ Branch 0 taken 2090816 times.
✓ Branch 1 taken 261352 times.
|
2352168 | for (x=0; x<8; x++) { |
578 | 2090816 | dst[x] = av_clip_uint8(( src[x-delta ] * weights[0] | |
579 | 2090816 | + src[x ] * weights[1] | |
580 | 2090816 | + src[x+delta ] * weights[2] | |
581 | 2090816 | + src[x+2*delta] * weights[3] + 64) >> 7); | |
582 | } | ||
583 | 261352 | src += stride; | |
584 | 261352 | dst += stride; | |
585 | } | ||
586 | 32669 | } | |
587 | |||
588 | 54829 | static void vp6_filter_diag2(VP56Context *s, uint8_t *dst, uint8_t *src, | |
589 | ptrdiff_t stride, int h_weight, int v_weight) | ||
590 | { | ||
591 | 54829 | uint8_t *tmp = s->edge_emu_buffer+16; | |
592 | 54829 | s->h264chroma.put_h264_chroma_pixels_tab[0](tmp, src, stride, 9, h_weight, 0); | |
593 | 54829 | s->h264chroma.put_h264_chroma_pixels_tab[0](dst, tmp, stride, 8, 0, v_weight); | |
594 | 54829 | } | |
595 | |||
596 | 177543 | static void vp6_filter(VP56Context *s, uint8_t *dst, uint8_t *src, | |
597 | int offset1, int offset2, ptrdiff_t stride, | ||
598 | VP56mv mv, int mask, int select, int luma) | ||
599 | { | ||
600 | 177543 | int filter4 = 0; | |
601 | 177543 | int x8 = mv.x & mask; | |
602 | 177543 | int y8 = mv.y & mask; | |
603 | |||
604 |
2/2✓ Branch 0 taken 120187 times.
✓ Branch 1 taken 57356 times.
|
177543 | if (luma) { |
605 | 120187 | x8 *= 2; | |
606 | 120187 | y8 *= 2; | |
607 | 120187 | filter4 = s->filter_mode; | |
608 |
2/2✓ Branch 0 taken 105390 times.
✓ Branch 1 taken 14797 times.
|
120187 | if (filter4 == 2) { |
609 |
1/2✓ Branch 0 taken 105390 times.
✗ Branch 1 not taken.
|
105390 | if (s->max_vector_length && |
610 |
2/2✓ Branch 0 taken 92625 times.
✓ Branch 1 taken 12765 times.
|
105390 | (FFABS(mv.x) > s->max_vector_length || |
611 |
2/2✓ Branch 0 taken 7660 times.
✓ Branch 1 taken 84965 times.
|
92625 | FFABS(mv.y) > s->max_vector_length)) { |
612 | 20425 | filter4 = 0; | |
613 |
1/2✓ Branch 0 taken 84965 times.
✗ Branch 1 not taken.
|
84965 | } else if (s->sample_variance_threshold |
614 | 84965 | && (vp6_block_variance(src+offset1, stride) | |
615 |
2/2✓ Branch 0 taken 24950 times.
✓ Branch 1 taken 60015 times.
|
84965 | < s->sample_variance_threshold)) { |
616 | 24950 | filter4 = 0; | |
617 | } | ||
618 | } | ||
619 | } | ||
620 | |||
621 |
8/8✓ Branch 0 taken 136156 times.
✓ Branch 1 taken 41387 times.
✓ Branch 2 taken 61409 times.
✓ Branch 3 taken 74747 times.
✓ Branch 4 taken 41387 times.
✓ Branch 5 taken 61409 times.
✓ Branch 6 taken 15077 times.
✓ Branch 7 taken 26310 times.
|
177543 | if ((y8 && (offset2-offset1)*s->flip<0) || (!y8 && offset1 > offset2)) { |
622 | 89824 | offset1 = offset2; | |
623 | } | ||
624 | |||
625 |
2/2✓ Branch 0 taken 60015 times.
✓ Branch 1 taken 117528 times.
|
177543 | if (filter4) { |
626 |
2/2✓ Branch 0 taken 12003 times.
✓ Branch 1 taken 48012 times.
|
60015 | if (!y8) { /* left or right combine */ |
627 | 12003 | vp6_filter_hv4(dst, src+offset1, stride, 1, | |
628 | 12003 | vp6_block_copy_filter[select][x8]); | |
629 |
2/2✓ Branch 0 taken 20666 times.
✓ Branch 1 taken 27346 times.
|
48012 | } else if (!x8) { /* above or below combine */ |
630 | 20666 | vp6_filter_hv4(dst, src+offset1, stride, stride, | |
631 | 20666 | vp6_block_copy_filter[select][y8]); | |
632 | } else { | ||
633 | 27346 | s->vp56dsp.vp6_filter_diag4(dst, src+offset1+((mv.x^mv.y)>>31), stride, | |
634 | 27346 | vp6_block_copy_filter[select][x8], | |
635 | 27346 | vp6_block_copy_filter[select][y8]); | |
636 | } | ||
637 | } else { | ||
638 |
4/4✓ Branch 0 taken 84213 times.
✓ Branch 1 taken 33315 times.
✓ Branch 2 taken 29384 times.
✓ Branch 3 taken 54829 times.
|
117528 | if (!x8 || !y8) { |
639 | 62699 | s->h264chroma.put_h264_chroma_pixels_tab[0](dst, src + offset1, stride, 8, x8, y8); | |
640 | } else { | ||
641 | 54829 | vp6_filter_diag2(s, dst, src+offset1 + ((mv.x^mv.y)>>31), stride, x8, y8); | |
642 | } | ||
643 | } | ||
644 | 177543 | } | |
645 | |||
646 | 21 | static av_cold int vp6_decode_init_context(AVCodecContext *avctx, | |
647 | VP56Context *s, int flip, int has_alpha) | ||
648 | { | ||
649 | 21 | int ret = ff_vp56_init_context(avctx, s, flip, has_alpha); | |
650 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 21 times.
|
21 | if (ret < 0) |
651 | ✗ | return ret; | |
652 | |||
653 | 21 | ff_vp6dsp_init(&s->vp56dsp); | |
654 | |||
655 | 21 | s->deblock_filtering = 0; | |
656 | 21 | s->vp56_coord_div = vp6_coord_div; | |
657 | 21 | s->parse_vector_adjustment = vp6_parse_vector_adjustment; | |
658 | 21 | s->filter = vp6_filter; | |
659 | 21 | s->default_models_init = vp6_default_models_init; | |
660 | 21 | s->parse_vector_models = vp6_parse_vector_models; | |
661 | 21 | s->parse_coeff_models = vp6_parse_coeff_models; | |
662 | 21 | s->parse_header = vp6_parse_header; | |
663 | |||
664 | 21 | return 0; | |
665 | } | ||
666 | |||
667 | 17 | static av_cold int vp6_decode_init(AVCodecContext *avctx) | |
668 | { | ||
669 | 17 | VP56Context *s = avctx->priv_data; | |
670 | int ret; | ||
671 | |||
672 | 17 | ret = vp6_decode_init_context(avctx, s, avctx->codec_id == AV_CODEC_ID_VP6, | |
673 | 17 | avctx->codec_id == AV_CODEC_ID_VP6A); | |
674 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 17 times.
|
17 | if (ret < 0) |
675 | ✗ | return ret; | |
676 | |||
677 |
2/2✓ Branch 0 taken 4 times.
✓ Branch 1 taken 13 times.
|
17 | if (s->has_alpha) { |
678 | /* Can only happen for ff_vp6a_decoder */ | ||
679 | 4 | s->alpha_context = &s[1]; | |
680 | 4 | ret = vp6_decode_init_context(avctx, s->alpha_context, | |
681 | 4 | s->flip == -1, s->has_alpha); | |
682 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 4 times.
|
4 | if (ret < 0) |
683 | ✗ | return ret; | |
684 | } | ||
685 | |||
686 | 17 | return 0; | |
687 | } | ||
688 | |||
689 | static av_cold void vp6_decode_free_context(VP56Context *s); | ||
690 | |||
691 | 17 | static av_cold int vp6_decode_free(AVCodecContext *avctx) | |
692 | { | ||
693 | 17 | VP56Context *s = avctx->priv_data; | |
694 | |||
695 | 17 | vp6_decode_free_context(s); | |
696 | |||
697 |
2/2✓ Branch 0 taken 4 times.
✓ Branch 1 taken 13 times.
|
17 | if (s->alpha_context) { |
698 | 4 | vp6_decode_free_context(s->alpha_context); | |
699 | 4 | s->alpha_context = NULL; | |
700 | } | ||
701 | |||
702 | 17 | return 0; | |
703 | } | ||
704 | |||
705 | 21 | static av_cold void vp6_decode_free_context(VP56Context *s) | |
706 | { | ||
707 | int pt, ct, cg; | ||
708 | |||
709 | 21 | ff_vp56_free_context(s); | |
710 | |||
711 |
2/2✓ Branch 0 taken 42 times.
✓ Branch 1 taken 21 times.
|
63 | for (pt=0; pt<2; pt++) { |
712 | 42 | ff_vlc_free(&s->dccv_vlc[pt]); | |
713 | 42 | ff_vlc_free(&s->runv_vlc[pt]); | |
714 |
2/2✓ Branch 0 taken 126 times.
✓ Branch 1 taken 42 times.
|
168 | for (ct=0; ct<3; ct++) |
715 |
2/2✓ Branch 0 taken 756 times.
✓ Branch 1 taken 126 times.
|
882 | for (cg=0; cg<6; cg++) |
716 | 756 | ff_vlc_free(&s->ract_vlc[pt][ct][cg]); | |
717 | } | ||
718 | 21 | } | |
719 | |||
720 | const FFCodec ff_vp6_decoder = { | ||
721 | .p.name = "vp6", | ||
722 | CODEC_LONG_NAME("On2 VP6"), | ||
723 | .p.type = AVMEDIA_TYPE_VIDEO, | ||
724 | .p.id = AV_CODEC_ID_VP6, | ||
725 | .priv_data_size = sizeof(VP56Context), | ||
726 | .init = vp6_decode_init, | ||
727 | .close = vp6_decode_free, | ||
728 | FF_CODEC_DECODE_CB(ff_vp56_decode_frame), | ||
729 | .p.capabilities = AV_CODEC_CAP_DR1, | ||
730 | .caps_internal = FF_CODEC_CAP_INIT_CLEANUP, | ||
731 | }; | ||
732 | |||
733 | /* flash version, not flipped upside-down */ | ||
734 | const FFCodec ff_vp6f_decoder = { | ||
735 | .p.name = "vp6f", | ||
736 | CODEC_LONG_NAME("On2 VP6 (Flash version)"), | ||
737 | .p.type = AVMEDIA_TYPE_VIDEO, | ||
738 | .p.id = AV_CODEC_ID_VP6F, | ||
739 | .priv_data_size = sizeof(VP56Context), | ||
740 | .init = vp6_decode_init, | ||
741 | .close = vp6_decode_free, | ||
742 | FF_CODEC_DECODE_CB(ff_vp56_decode_frame), | ||
743 | .p.capabilities = AV_CODEC_CAP_DR1, | ||
744 | .caps_internal = FF_CODEC_CAP_INIT_CLEANUP, | ||
745 | }; | ||
746 | |||
747 | /* flash version, not flipped upside-down, with alpha channel */ | ||
748 | const FFCodec ff_vp6a_decoder = { | ||
749 | .p.name = "vp6a", | ||
750 | CODEC_LONG_NAME("On2 VP6 (Flash version, with alpha channel)"), | ||
751 | .p.type = AVMEDIA_TYPE_VIDEO, | ||
752 | .p.id = AV_CODEC_ID_VP6A, | ||
753 | .priv_data_size = 2 /* Main context + alpha context */ * sizeof(VP56Context), | ||
754 | .init = vp6_decode_init, | ||
755 | .close = vp6_decode_free, | ||
756 | FF_CODEC_DECODE_CB(ff_vp56_decode_frame), | ||
757 | .p.capabilities = AV_CODEC_CAP_DR1 | AV_CODEC_CAP_SLICE_THREADS, | ||
758 | .caps_internal = FF_CODEC_CAP_INIT_CLEANUP, | ||
759 | }; | ||
760 |