FFmpeg
vp9dec.h
Go to the documentation of this file.
1 /*
2  * VP9 compatible video decoder
3  *
4  * Copyright (C) 2013 Ronald S. Bultje <rsbultje gmail com>
5  * Copyright (C) 2013 Clément Bœsch <u pkh me>
6  *
7  * This file is part of FFmpeg.
8  *
9  * FFmpeg is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU Lesser General Public
11  * License as published by the Free Software Foundation; either
12  * version 2.1 of the License, or (at your option) any later version.
13  *
14  * FFmpeg is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17  * Lesser General Public License for more details.
18  *
19  * You should have received a copy of the GNU Lesser General Public
20  * License along with FFmpeg; if not, write to the Free Software
21  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22  */
23 
24 #ifndef AVCODEC_VP9DEC_H
25 #define AVCODEC_VP9DEC_H
26 
27 #include <stddef.h>
28 #include <stdint.h>
29 #include <stdatomic.h>
30 
31 #include "libavutil/buffer.h"
32 #include "libavutil/thread.h"
33 #include "libavutil/internal.h"
34 
35 #include "vp9.h"
36 #include "vp9dsp.h"
37 #include "vp9shared.h"
38 
39 enum MVJoint {
44 };
45 
46 typedef struct ProbContext {
47  uint8_t y_mode[4][9];
48  uint8_t uv_mode[10][9];
49  uint8_t filter[4][2];
55  uint8_t tx32p[2][3];
56  uint8_t tx16p[2][2];
60  struct {
66  uint8_t fp[3];
69  } mv_comp[2];
70  uint8_t partition[4][4][3];
71 } ProbContext;
72 
73 typedef struct VP9Filter {
74  uint8_t level[8 * 8];
75  uint8_t /* bit=col */ mask[2 /* 0=y, 1=uv */][2 /* 0=col, 1=row */]
76  [8 /* rows */][4 /* 0=16, 1=8, 2=4, 3=inner4 */];
77 } VP9Filter;
78 
79 typedef struct VP9Block {
82  VP56mv mv[4 /* b_idx */][2 /* ref */];
83  enum BlockSize bs;
84  enum TxfmMode tx, uvtx;
85  enum BlockLevel bl;
87 } VP9Block;
88 
89 typedef struct VP9TileData VP9TileData;
90 
91 typedef struct VP9Context {
94 
100 
101 #if HAVE_THREADS
102  pthread_mutex_t progress_mutex;
103  pthread_cond_t progress_cond;
104  atomic_int *entries;
105 #endif
106 
110  // sb_cols/rows, rows/cols and last_fmt are used for allocating all internal
111  // arrays, and are thus per-thread. w/h and gf_fmt are synced between threads
112  // and are therefore per-stream. pix_fmt represents the value in the header
113  // of the currently processed frame.
114  int w, h;
115  enum AVPixelFormat pix_fmt, last_fmt, gf_fmt;
116  unsigned sb_cols, sb_rows, rows, cols;
118 
119  struct {
122  } filter_lut;
123  struct {
125  uint8_t coef[4][2][2][6][6][3];
126  } prob_ctx[4];
127  struct {
128  ProbContext p;
129  uint8_t coef[4][2][2][6][6][11];
130  } prob;
131 
132  // contextual (above) cache
135  // FIXME maybe merge some of the below in a flags field?
146 
147  // whole-frame cache
150 
151  // block reconstruction intermediates
153  uint16_t mvscale[3][2];
155 } VP9Context;
156 
157 struct VP9TileData {
158  //VP9Context should be const, but because of the threading API(generates
159  //a lot of warnings) it's not.
163  int row, row7, col, col7;
165  ptrdiff_t y_stride, uv_stride;
167  unsigned tile_col_start;
168 
169  struct {
170  unsigned y_mode[4][10];
171  unsigned uv_mode[10][10];
172  unsigned filter[4][3];
173  unsigned mv_mode[7][4];
174  unsigned intra[4][2];
175  unsigned comp[5][2];
176  unsigned single_ref[5][2][2];
177  unsigned comp_ref[5][2];
178  unsigned tx32p[2][4];
179  unsigned tx16p[2][3];
180  unsigned tx8p[2][2];
181  unsigned skip[3][2];
182  unsigned mv_joint[4];
183  struct {
184  unsigned sign[2];
185  unsigned classes[11];
186  unsigned class0[2];
187  unsigned bits[10][2];
188  unsigned class0_fp[2][4];
189  unsigned fp[4];
190  unsigned class0_hp[2];
191  unsigned hp[2];
192  } mv_comp[2];
193  unsigned partition[4][4][4];
194  unsigned coef[4][2][2][6][6][3];
195  unsigned eob[4][2][2][6][6][2];
196  } counts;
197 
198  // whole-frame cache
200 
201  // contextual (left) cache
214  // block reconstruction intermediates
215  DECLARE_ALIGNED(32, uint8_t, tmp_y)[64 * 64 * 2];
216  DECLARE_ALIGNED(32, uint8_t, tmp_uv)[2][64 * 64 * 2];
217  struct { int x, y; } min_mv, max_mv;
218  int16_t *block_base, *block, *uvblock_base[2], *uvblock[2];
220 };
221 
222 void ff_vp9_fill_mv(VP9TileData *td, VP56mv *mv, int mode, int sb);
223 
225 
226 void ff_vp9_decode_block(VP9TileData *td, int row, int col,
227  VP9Filter *lflvl, ptrdiff_t yoff, ptrdiff_t uvoff,
228  enum BlockLevel bl, enum BlockPartition bp);
229 
230 void ff_vp9_loopfilter_sb(AVCodecContext *avctx, VP9Filter *lflvl,
231  int row, int col, ptrdiff_t yoff, ptrdiff_t uvoff);
232 
234  ptrdiff_t y_off, ptrdiff_t uv_off);
236  ptrdiff_t y_off, ptrdiff_t uv_off);
239 
240 #endif /* AVCODEC_VP9DEC_H */
VP9TileData::left_y_nnz_ctx
uint8_t left_y_nnz_ctx[16]
Definition: vp9dec.h:202
ff_vp9_inter_recon_8bpp
void ff_vp9_inter_recon_8bpp(VP9TileData *td)
Definition: vp9recon.c:636
pthread_mutex_t
_fmutex pthread_mutex_t
Definition: os2threads.h:49
td
#define td
Definition: regdef.h:70
AVPixelFormat
AVPixelFormat
Pixel format.
Definition: pixfmt.h:64
ProbContext::class0_fp
uint8_t class0_fp[2][3]
Definition: vp9dec.h:65
VP9Context::mblim_lut
uint8_t mblim_lut[64]
Definition: vp9dec.h:121
VP9Context::dsp
VP9DSPContext dsp
Definition: vp9dec.h:95
VP9TileData::single_ref
unsigned single_ref[5][2][2]
Definition: vp9dec.h:176
VP9Block::ref
uint8_t ref[2]
Definition: vp9dec.h:80
VP9TileData::uvblock_base
int16_t * uvblock_base[2]
Definition: vp9dec.h:218
VP9Block::mv
VP56mv mv[4][2]
Definition: vp9dec.h:82
VP9Context::above_mode_ctx
uint8_t * above_mode_ctx
Definition: vp9dec.h:134
VP9Block::skip
uint8_t skip
Definition: vp9dec.h:80
VP9TileData::partition
unsigned partition[4][4][4]
Definition: vp9dec.h:193
thread.h
VP9Context::last_keyframe
uint8_t last_keyframe
Definition: vp9dec.h:109
ProbContext::classes
uint8_t classes[10]
Definition: vp9dec.h:62
VP9Context::filter_lut
struct VP9Context::@189 filter_lut
ff_vp9_adapt_probs
void ff_vp9_adapt_probs(VP9Context *s)
Definition: vp9prob.c:46
mv
static const int8_t mv[256][2]
Definition: 4xm.c:77
VP9TileData::min_mv
struct VP9TileData::@193 min_mv
VP9TileData::left_skip_ctx
uint8_t left_skip_ctx[8]
Definition: vp9dec.h:207
VP9TileData::c_b
VP56RangeCoder * c_b
Definition: vp9dec.h:161
VP9TileData::row
int row
Definition: vp9dec.h:163
VP9TileData::counts
struct VP9TileData::@192 counts
BlockPartition
BlockPartition
Definition: vp9shared.h:34
VP9Context::vdsp
VideoDSPContext vdsp
Definition: vp9dec.h:96
MVJoint
MVJoint
Definition: vp9dec.h:39
VP9DSPContext
Definition: vp9dsp.h:39
VP9TileData::x
int x
Definition: vp9dec.h:217
atomic_int
intptr_t atomic_int
Definition: stdatomic.h:55
VP9TileData::block
int16_t * block
Definition: vp9dec.h:218
ProbContext::hp
uint8_t hp
Definition: vp9dec.h:68
ProbContext::tx32p
uint8_t tx32p[2][3]
Definition: vp9dec.h:55
VP9Context::above_txfm_ctx
uint8_t * above_txfm_ctx
Definition: vp9dec.h:139
VP9TileData::left_segpred_ctx
uint8_t left_segpred_ctx[8]
Definition: vp9dec.h:209
ProbContext::comp
uint8_t comp[5]
Definition: vp9dec.h:52
VP9Block::bl
enum BlockLevel bl
Definition: vp9dec.h:85
VP9TileData::left_comp_ctx
uint8_t left_comp_ctx[8]
Definition: vp9dec.h:211
VP9Filter
Definition: vp9dec.h:73
MV_JOINT_HV
@ MV_JOINT_HV
Definition: vp9dec.h:43
VP9Context::above_skip_ctx
uint8_t * above_skip_ctx
Definition: vp9dec.h:138
VP9TileData::b
VP9Block * b
Definition: vp9dec.h:166
VP9Block::filter
enum FilterMode filter
Definition: vp9dec.h:81
VP9Context::cols
unsigned cols
Definition: vp9dec.h:116
VP9Context::gf_fmt
enum AVPixelFormat pix_fmt last_fmt gf_fmt
Definition: vp9dec.h:115
VP9TileData::skip
unsigned skip[3][2]
Definition: vp9dec.h:181
VP9Block
Definition: vp9dec.h:79
VP9Context::above_uv_nnz_ctx
uint8_t * above_uv_nnz_ctx[2]
Definition: vp9dec.h:137
VP9TileData::max_mv
struct VP9TileData::@193 max_mv
VP9Context::ss_v
uint8_t ss_v
Definition: vp9dec.h:107
ProbContext::sign
uint8_t sign
Definition: vp9dec.h:61
VP9Context::coef
uint8_t coef[4][2][2][6][6][3]
Definition: vp9dec.h:125
VP9TileData::tmp_uv
uint8_t tmp_uv[2][64 *64 *2]
Definition: vp9dec.h:216
FilterMode
FilterMode
Definition: vp9.h:64
GetBitContext
Definition: get_bits.h:61
VP9TileData::left_filter_ctx
uint8_t left_filter_ctx[8]
Definition: vp9dec.h:213
VP9Context::above_filter_ctx
uint8_t * above_filter_ctx
Definition: vp9dec.h:144
VP9Context::last_bpp
uint8_t last_bpp
Definition: vp9dec.h:108
VP9TileData::mv_comp
struct VP9TileData::@192::@194 mv_comp[2]
VP9Context::prob
struct VP9Context::@191 prob
VP9TileData::class0_hp
unsigned class0_hp[2]
Definition: vp9dec.h:190
VP9TileData::fp
unsigned fp[4]
Definition: vp9dec.h:189
ProbContext::y_mode
uint8_t y_mode[4][9]
Definition: vp9dec.h:47
VP9Context::p
ProbContext p
Definition: vp9dec.h:124
VP9Context::lim_lut
uint8_t lim_lut[64]
Definition: vp9dec.h:120
VP9TileData::col
int col
Definition: vp9dec.h:163
VP9Block::intra
uint8_t intra
Definition: vp9dec.h:80
vp9shared.h
VP9Context::sb_cols
unsigned sb_cols
Definition: vp9dec.h:116
VP9TileData::left_txfm_ctx
uint8_t left_txfm_ctx[8]
Definition: vp9dec.h:208
VP9TileData::comp_ref
unsigned comp_ref[5][2]
Definition: vp9dec.h:177
VP9TileData::c
VP56RangeCoder * c
Definition: vp9dec.h:162
s
#define s(width, name)
Definition: cbs_vp9.c:257
VP9SharedContext
Definition: vp9shared.h:159
VP9TileData::hp
unsigned hp[2]
Definition: vp9dec.h:191
VP9TileData::mv_joint
unsigned mv_joint[4]
Definition: vp9dec.h:182
ff_vp9_decode_block
void ff_vp9_decode_block(VP9TileData *td, int row, int col, VP9Filter *lflvl, ptrdiff_t yoff, ptrdiff_t uvoff, enum BlockLevel bl, enum BlockPartition bp)
Definition: vp9block.c:1263
VP9Context::s
VP9SharedContext s
Definition: vp9dec.h:92
VP9TileData::intra
unsigned intra[4][2]
Definition: vp9dec.h:174
VP9TileData::filter
unsigned filter[4][3]
Definition: vp9dec.h:172
pix_fmt
static enum AVPixelFormat pix_fmt
Definition: demuxing_decoding.c:40
VP56mv
Definition: vp56.h:66
VP9Context::c
VP56RangeCoder c
Definition: vp9dec.h:98
VP9Context::bytesperpixel
uint8_t bytesperpixel
Definition: vp9dec.h:108
VP9TileData::y
int y
Definition: vp9dec.h:217
VP9Block::bs
enum BlockSize bs
Definition: vp9dec.h:83
VP9TileData::class0_fp
unsigned class0_fp[2][4]
Definition: vp9dec.h:188
VP9Context::mvstep
uint8_t mvstep[3][2]
Definition: vp9dec.h:154
VP9Context
Definition: vp9dec.h:91
VP9TileData::uv_stride
ptrdiff_t uv_stride
Definition: vp9dec.h:165
VP9Context::above_segpred_ctx
uint8_t * above_segpred_ctx
Definition: vp9dec.h:140
VP9Context::block_alloc_using_2pass
int block_alloc_using_2pass
Definition: vp9dec.h:152
VP9Context::prob_ctx
struct VP9Context::@190 prob_ctx[4]
VP9TileData::classes
unsigned classes[11]
Definition: vp9dec.h:185
VP9Context::rows
unsigned rows
Definition: vp9dec.h:116
MV_JOINT_V
@ MV_JOINT_V
Definition: vp9dec.h:42
VP9TileData::eob
unsigned eob[4][2][2][6][6][2]
Definition: vp9dec.h:195
ff_vp9_intra_recon_16bpp
void ff_vp9_intra_recon_16bpp(VP9TileData *td, ptrdiff_t y_off, ptrdiff_t uv_off)
Definition: vp9recon.c:293
VP9Context::h
int h
Definition: vp9dec.h:114
vp9dsp.h
ProbContext::bits
uint8_t bits[10]
Definition: vp9dec.h:64
TxfmMode
TxfmMode
Definition: vp9.h:27
vp9.h
ff_vp9_fill_mv
void ff_vp9_fill_mv(VP9TileData *td, VP56mv *mv, int mode, int sb)
Definition: vp9mvs.c:291
VP9Context::next_refs
ThreadFrame next_refs[8]
Definition: vp9dec.h:117
ProbContext::skip
uint8_t skip[3]
Definition: vp9dec.h:58
ProbContext::mv_mode
uint8_t mv_mode[7][3]
Definition: vp9dec.h:50
VP9TileData::edge_emu_buffer
uint8_t edge_emu_buffer[135 *144 *2]
Definition: vp9dec.h:199
VP9TileData::eob_base
uint8_t * eob_base
Definition: vp9dec.h:219
VP9Context::above_y_nnz_ctx
uint8_t * above_y_nnz_ctx
Definition: vp9dec.h:136
VP9Context::above_mv_ctx
VP56mv(* above_mv_ctx)[2]
Definition: vp9dec.h:145
VP9Block::seg_id
uint8_t seg_id
Definition: vp9dec.h:80
VP9TileData::b_base
VP9Block * b_base
Definition: vp9dec.h:166
ProbContext::comp_ref
uint8_t comp_ref[5]
Definition: vp9dec.h:54
buffer.h
VP9TileData::left_intra_ctx
uint8_t left_intra_ctx[8]
Definition: vp9dec.h:210
VP9Block::bp
enum BlockPartition bp
Definition: vp9dec.h:86
VP9TileData::uv_mode
unsigned uv_mode[10][10]
Definition: vp9dec.h:171
VP9TileData::block_base
int16_t * block_base
Definition: vp9dec.h:218
ProbContext
Definition: vp9dec.h:46
VP9TileData::left_uv_nnz_ctx
uint8_t left_uv_nnz_ctx[2][16]
Definition: vp9dec.h:205
ProbContext::fp
uint8_t fp[3]
Definition: vp9dec.h:66
DECLARE_ALIGNED
#define DECLARE_ALIGNED(n, t, v)
Definition: mem.h:112
VP9TileData::class0
unsigned class0[2]
Definition: vp9dec.h:186
VP9TileData::tmp_y
uint8_t tmp_y[64 *64 *2]
Definition: vp9dec.h:215
VP9TileData::mv_mode
unsigned mv_mode[7][4]
Definition: vp9dec.h:173
VP9Block::uvmode
uint8_t uvmode
Definition: vp9dec.h:80
VP9TileData::y_mode
unsigned y_mode[4][10]
Definition: vp9dec.h:170
internal.h
VP9TileData::uveob
uint8_t * uveob[2]
Definition: vp9dec.h:219
uint8_t
uint8_t
Definition: audio_convert.c:194
BlockSize
BlockSize
Definition: vp9shared.h:77
VP9TileData::left_mode_ctx
uint8_t left_mode_ctx[16]
Definition: vp9dec.h:203
VP9Context::pass
int pass
Definition: vp9dec.h:99
VP9Context::w
int w
Definition: vp9dec.h:114
VP9TileData::bits
unsigned bits[10][2]
Definition: vp9dec.h:187
pthread_cond_t
Definition: os2threads.h:54
VP9TileData::coef
unsigned coef[4][2][2][6][6][3]
Definition: vp9dec.h:194
ProbContext::class0_hp
uint8_t class0_hp
Definition: vp9dec.h:67
ProbContext::single_ref
uint8_t single_ref[5][2]
Definition: vp9dec.h:53
VP9TileData::comp
unsigned comp[5][2]
Definition: vp9dec.h:175
ProbContext::tx16p
uint8_t tx16p[2][2]
Definition: vp9dec.h:56
VP9Context::sb_rows
unsigned sb_rows
Definition: vp9dec.h:116
VP9Context::above_intra_ctx
uint8_t * above_intra_ctx
Definition: vp9dec.h:141
VP9TileData
Definition: vp9dec.h:157
VP9TileData::uveob_base
uint8_t * uveob_base[2]
Definition: vp9dec.h:219
VP56RangeCoder
Definition: vp56.h:85
AVCodecContext
main external API structure.
Definition: avcodec.h:1565
ThreadFrame
Definition: thread.h:34
VP9Filter::mask
uint8_t mask[2][2][8][4]
Definition: vp9dec.h:76
VP9Context::bpp_index
uint8_t bpp_index
Definition: vp9dec.h:108
ProbContext::partition
uint8_t partition[4][4][3]
Definition: vp9dec.h:70
ProbContext::mv_joint
uint8_t mv_joint[3]
Definition: vp9dec.h:59
mode
mode
Definition: ebur128.h:83
VP9Context::active_tile_cols
int active_tile_cols
Definition: vp9dec.h:99
VP9Context::mvscale
uint16_t mvscale[3][2]
Definition: vp9dec.h:153
BlockLevel
BlockLevel
Definition: vp9shared.h:70
VP9TileData::dst
uint8_t * dst[3]
Definition: vp9dec.h:164
ProbContext::filter
uint8_t filter[4][2]
Definition: vp9dec.h:49
VideoDSPContext
Definition: videodsp.h:41
VP9TileData::sign
unsigned sign[2]
Definition: vp9dec.h:184
ProbContext::tx8p
uint8_t tx8p[2]
Definition: vp9dec.h:57
VP9Context::td
VP9TileData * td
Definition: vp9dec.h:93
ProbContext::class0
uint8_t class0
Definition: vp9dec.h:63
MV_JOINT_ZERO
@ MV_JOINT_ZERO
Definition: vp9dec.h:40
VP9TileData::s
VP9Context * s
Definition: vp9dec.h:160
VP9Context::gb
GetBitContext gb
Definition: vp9dec.h:97
MV_JOINT_H
@ MV_JOINT_H
Definition: vp9dec.h:41
ProbContext::uv_mode
uint8_t uv_mode[10][9]
Definition: vp9dec.h:48
VP9Block::comp
uint8_t comp
Definition: vp9dec.h:80
VP9TileData::row7
int row7
Definition: vp9dec.h:163
VP9Context::above_ref_ctx
uint8_t * above_ref_ctx
Definition: vp9dec.h:143
ProbContext::mv_comp
struct ProbContext::@188 mv_comp[2]
ff_vp9_loopfilter_sb
void ff_vp9_loopfilter_sb(AVCodecContext *avctx, VP9Filter *lflvl, int row, int col, ptrdiff_t yoff, ptrdiff_t uvoff)
Definition: vp9lpf.c:178
VP9TileData::col7
int col7
Definition: vp9dec.h:163
VP9Context::above_comp_ctx
uint8_t * above_comp_ctx
Definition: vp9dec.h:142
ff_vp9_intra_recon_8bpp
void ff_vp9_intra_recon_8bpp(VP9TileData *td, ptrdiff_t y_off, ptrdiff_t uv_off)
Definition: vp9recon.c:288
VP9TileData::y_stride
ptrdiff_t y_stride
Definition: vp9dec.h:165
VP9Context::ss_h
uint8_t ss_h
Definition: vp9dec.h:107
VP9TileData::tx16p
unsigned tx16p[2][3]
Definition: vp9dec.h:179
VP9Context::lflvl
VP9Filter * lflvl
Definition: vp9dec.h:149
VP9TileData::left_ref_ctx
uint8_t left_ref_ctx[8]
Definition: vp9dec.h:212
VP9TileData::tile_col_start
unsigned tile_col_start
Definition: vp9dec.h:167
VP9Context::above_partition_ctx
uint8_t * above_partition_ctx
Definition: vp9dec.h:133
VP9TileData::left_mv_ctx
VP56mv left_mv_ctx[16][2]
Definition: vp9dec.h:204
VP9Filter::level
uint8_t level[8 *8]
Definition: vp9dec.h:74
ProbContext::intra
uint8_t intra[4]
Definition: vp9dec.h:51
VP9TileData::uvblock
int16_t * uvblock[2]
Definition: vp9dec.h:218
VP9TileData::tx8p
unsigned tx8p[2][2]
Definition: vp9dec.h:180
VP9Block::uvtx
enum TxfmMode tx uvtx
Definition: vp9dec.h:84
VP9Context::intra_pred_data
uint8_t * intra_pred_data[3]
Definition: vp9dec.h:148
VP9TileData::left_partition_ctx
uint8_t left_partition_ctx[8]
Definition: vp9dec.h:206
VP9TileData::tx32p
unsigned tx32p[2][4]
Definition: vp9dec.h:178
ff_vp9_inter_recon_16bpp
void ff_vp9_inter_recon_16bpp(VP9TileData *td)
Definition: vp9recon.c:641