FFmpeg
Main Page
Related Pages
Modules
Namespaces
Data Structures
Files
Examples
File List
Globals
All
Data Structures
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Macros
Groups
Pages
libavcodec
vp8.h
Go to the documentation of this file.
1
/*
2
* VP8 compatible video decoder
3
*
4
* Copyright (C) 2010 David Conrad
5
* Copyright (C) 2010 Ronald S. Bultje
6
* Copyright (C) 2010 Jason Garrett-Glaser
7
* Copyright (C) 2012 Daniel Kang
8
*
9
* This file is part of FFmpeg.
10
*
11
* FFmpeg is free software; you can redistribute it and/or
12
* modify it under the terms of the GNU Lesser General Public
13
* License as published by the Free Software Foundation; either
14
* version 2.1 of the License, or (at your option) any later version.
15
*
16
* FFmpeg is distributed in the hope that it will be useful,
17
* but WITHOUT ANY WARRANTY; without even the implied warranty of
18
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19
* Lesser General Public License for more details.
20
*
21
* You should have received a copy of the GNU Lesser General Public
22
* License along with FFmpeg; if not, write to the Free Software
23
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
24
*/
25
26
#ifndef AVCODEC_VP8_H
27
#define AVCODEC_VP8_H
28
29
#include "
libavutil/buffer.h
"
30
31
#include "
vp56.h
"
32
#include "
vp8dsp.h
"
33
#include "
h264pred.h
"
34
#include "
thread.h
"
35
#if HAVE_PTHREADS
36
#include <pthread.h>
37
#elif HAVE_OS2THREADS
38
#include "
compat/os2threads.h
"
39
#elif HAVE_W32THREADS
40
#include "
compat/w32pthreads.h
"
41
#endif
42
43
#define VP8_MAX_QUANT 127
44
45
enum
dct_token
{
46
DCT_0
,
47
DCT_1
,
48
DCT_2
,
49
DCT_3
,
50
DCT_4
,
51
DCT_CAT1
,
52
DCT_CAT2
,
53
DCT_CAT3
,
54
DCT_CAT4
,
55
DCT_CAT5
,
56
DCT_CAT6
,
57
DCT_EOB
,
58
59
NUM_DCT_TOKENS
60
};
61
62
// used to signal 4x4 intra pred in luma MBs
63
#define MODE_I4x4 4
64
65
enum
inter_mvmode
{
66
VP8_MVMODE_ZERO
=
MODE_I4x4
+ 1,
67
VP8_MVMODE_MV
,
68
VP8_MVMODE_SPLIT
69
};
70
71
enum
inter_splitmvmode
{
72
VP8_SPLITMVMODE_16x8
= 0,
///< 2 16x8 blocks (vertical)
73
VP8_SPLITMVMODE_8x16
,
///< 2 8x16 blocks (horizontal)
74
VP8_SPLITMVMODE_8x8
,
///< 2x2 blocks of 8x8px each
75
VP8_SPLITMVMODE_4x4
,
///< 4x4 blocks of 4x4px each
76
VP8_SPLITMVMODE_NONE
,
///< (only used in prediction) no split MVs
77
};
78
79
typedef
struct
VP8FilterStrength
{
80
uint8_t
filter_level
;
81
uint8_t
inner_limit
;
82
uint8_t
inner_filter
;
83
}
VP8FilterStrength
;
84
85
typedef
struct
VP8Macroblock
{
86
uint8_t
skip
;
87
// todo: make it possible to check for at least (i4x4 or split_mv)
88
// in one op. are others needed?
89
uint8_t
mode
;
90
uint8_t
ref_frame
;
91
uint8_t
partitioning
;
92
uint8_t
chroma_pred_mode
;
93
uint8_t
segment
;
94
uint8_t
intra4x4_pred_mode_mb
[16];
95
uint8_t
intra4x4_pred_mode_top
[4];
96
VP56mv
mv
;
97
VP56mv
bmv
[16];
98
}
VP8Macroblock
;
99
100
typedef
struct
VP8ThreadData
{
101
DECLARE_ALIGNED
(16, int16_t,
block
)[6][4][16];
102
DECLARE_ALIGNED
(16, int16_t,
block_dc
)[16];
103
/**
104
* This is the index plus one of the last non-zero coeff
105
* for each of the blocks in the current macroblock.
106
* So, 0 -> no coeffs
107
* 1 -> dc-only (special transform)
108
* 2+-> full transform
109
*/
110
DECLARE_ALIGNED
(16,
uint8_t
,
non_zero_count_cache
)[6][4];
111
/**
112
* For coeff decode, we need to know whether the above block had non-zero
113
* coefficients. This means for each macroblock, we need data for 4 luma
114
* blocks, 2 u blocks, 2 v blocks, and the luma dc block, for a total of 9
115
* per macroblock. We keep the last row in top_nnz.
116
*/
117
DECLARE_ALIGNED
(8,
uint8_t
,
left_nnz
)[9];
118
int
thread_nr
;
119
#if HAVE_THREADS
120
pthread_mutex_t
lock;
121
pthread_cond_t
cond;
122
#endif
123
int
thread_mb_pos
;
// (mb_y << 16) | (mb_x & 0xFFFF)
124
int
wait_mb_pos
;
// What the current thread is waiting on.
125
126
#define EDGE_EMU_LINESIZE 32
127
DECLARE_ALIGNED
(16,
uint8_t
,
edge_emu_buffer
)[21 *
EDGE_EMU_LINESIZE
];
128
VP8FilterStrength
*
filter_strength
;
129
}
VP8ThreadData
;
130
131
typedef
struct
VP8Frame
{
132
ThreadFrame
tf
;
133
AVBufferRef
*
seg_map
;
134
}
VP8Frame
;
135
136
#define MAX_THREADS 8
137
typedef
struct
VP8Context
{
138
VP8ThreadData
*
thread_data
;
139
AVCodecContext
*
avctx
;
140
VP8Frame
*
framep
[4];
141
VP8Frame
*
next_framep
[4];
142
VP8Frame
*
curframe
;
143
VP8Frame
*
prev_frame
;
144
145
uint16_t
mb_width
;
/* number of horizontal MB */
146
uint16_t
mb_height
;
/* number of vertical MB */
147
int
linesize
;
148
int
uvlinesize
;
149
150
uint8_t
keyframe
;
151
uint8_t
deblock_filter
;
152
uint8_t
mbskip_enabled
;
153
uint8_t
profile
;
154
VP56mv
mv_min
;
155
VP56mv
mv_max
;
156
157
int8_t
sign_bias
[4];
///< one state [0, 1] per ref frame type
158
int
ref_count
[3];
159
160
/**
161
* Base parameters for segmentation, i.e. per-macroblock parameters.
162
* These must be kept unchanged even if segmentation is not used for
163
* a frame, since the values persist between interframes.
164
*/
165
struct
{
166
uint8_t
enabled
;
167
uint8_t
absolute_vals
;
168
uint8_t
update_map
;
169
int8_t
base_quant
[4];
170
int8_t
filter_level
[4];
///< base loop filter level
171
}
segmentation
;
172
173
struct
{
174
uint8_t
simple
;
175
uint8_t
level
;
176
uint8_t
sharpness
;
177
}
filter
;
178
179
VP8Macroblock
*
macroblocks
;
180
181
uint8_t
*
intra4x4_pred_mode_top
;
182
uint8_t
intra4x4_pred_mode_left
[4];
183
184
/**
185
* Macroblocks can have one of 4 different quants in a frame when
186
* segmentation is enabled.
187
* If segmentation is disabled, only the first segment's values are used.
188
*/
189
struct
{
190
// [0] - DC qmul [1] - AC qmul
191
int16_t
luma_qmul
[2];
192
int16_t
luma_dc_qmul
[2];
///< luma dc-only block quant
193
int16_t
chroma_qmul
[2];
194
}
qmat
[4];
195
196
struct
{
197
uint8_t
enabled
;
///< whether each mb can have a different strength based on mode/ref
198
199
/**
200
* filter strength adjustment for the following macroblock modes:
201
* [0-3] - i16x16 (always zero)
202
* [4] - i4x4
203
* [5] - zero mv
204
* [6] - inter modes except for zero or split mv
205
* [7] - split mv
206
* i16x16 modes never have any adjustment
207
*/
208
int8_t
mode
[
VP8_MVMODE_SPLIT
+1];
209
210
/**
211
* filter strength adjustment for macroblocks that reference:
212
* [0] - intra / VP56_FRAME_CURRENT
213
* [1] - VP56_FRAME_PREVIOUS
214
* [2] - VP56_FRAME_GOLDEN
215
* [3] - altref / VP56_FRAME_GOLDEN2
216
*/
217
int8_t
ref
[4];
218
}
lf_delta
;
219
220
uint8_t
(*
top_border
)[16+8+8];
221
uint8_t
(*
top_nnz
)[9];
222
223
VP56RangeCoder
c
;
///< header context, includes mb modes and motion vectors
224
225
/**
226
* These are all of the updatable probabilities for binary decisions.
227
* They are only implictly reset on keyframes, making it quite likely
228
* for an interframe to desync if a prior frame's header was corrupt
229
* or missing outright!
230
*/
231
struct
{
232
uint8_t
segmentid
[3];
233
uint8_t
mbskip
;
234
uint8_t
intra
;
235
uint8_t
last
;
236
uint8_t
golden
;
237
uint8_t
pred16x16
[4];
238
uint8_t
pred8x8c
[3];
239
uint8_t
token
[4][16][3][
NUM_DCT_TOKENS
-1];
240
uint8_t
mvc
[2][19];
241
}
prob
[2];
242
243
VP8Macroblock
*
macroblocks_base
;
244
int
invisible
;
245
int
update_last
;
///< update VP56_FRAME_PREVIOUS with the current one
246
int
update_golden
;
///< VP56_FRAME_NONE if not updated, or which frame to copy if so
247
int
update_altref
;
248
249
/**
250
* If this flag is not set, all the probability updates
251
* are discarded after this frame is decoded.
252
*/
253
int
update_probabilities
;
254
255
/**
256
* All coefficients are contained in separate arith coding contexts.
257
* There can be 1, 2, 4, or 8 of these after the header context.
258
*/
259
int
num_coeff_partitions
;
260
VP56RangeCoder
coeff_partition
[8];
261
VideoDSPContext
vdsp
;
262
VP8DSPContext
vp8dsp
;
263
H264PredContext
hpc
;
264
vp8_mc_func
put_pixels_tab
[3][3][3];
265
VP8Frame
frames
[5];
266
267
int
num_jobs
;
268
/**
269
* This describes the macroblock memory layout.
270
* 0 -> Only width+height*2+1 macroblocks allocated (frame/single thread).
271
* 1 -> Macroblocks for entire frame alloced (sliced thread).
272
*/
273
int
mb_layout
;
274
}
VP8Context
;
275
276
int
ff_vp8_decode_init
(
AVCodecContext
*avctx);
277
278
int
ff_vp8_decode_frame
(
AVCodecContext
*avctx,
void
*
data
,
int
*got_frame,
279
AVPacket
*avpkt);
280
281
int
ff_vp8_decode_free
(
AVCodecContext
*avctx);
282
283
#endif
/* AVCODEC_VP8_H */
Generated on Sun Mar 23 2014 23:49:51 for FFmpeg by
1.8.2