FFmpeg
|
#include "config_components.h"
#include <stddef.h>
#include <string.h>
#include "libavutil/emms.h"
#include "libavutil/imgutils.h"
#include "libavutil/mem_internal.h"
#include "libavutil/thread.h"
#include "avcodec.h"
#include "codec_internal.h"
#include "decode.h"
#include "get_bits.h"
#include "hpeldsp.h"
#include "internal.h"
#include "jpegquanttables.h"
#include "mathops.h"
#include "refstruct.h"
#include "thread.h"
#include "threadframe.h"
#include "videodsp.h"
#include "vp3data.h"
#include "vp4data.h"
#include "vp3dsp.h"
#include "xiph.h"
Go to the source code of this file.
Data Structures | |
struct | Vp3Fragment |
struct | VP4Predictor |
struct | HuffEntry |
struct | HuffTable |
Used to store optimal huffman encoding results. More... | |
struct | CoeffVLCs |
struct | Vp3DecodeContext |
Macros | |
#define | VP3_MV_VLC_BITS 6 |
#define | VP4_MV_VLC_BITS 6 |
#define | SUPERBLOCK_VLC_BITS 6 |
#define | FRAGMENT_PIXELS 8 |
#define | SB_NOT_CODED 0 |
#define | SB_PARTIALLY_CODED 1 |
#define | SB_FULLY_CODED 2 |
#define | MAXIMUM_LONG_BIT_RUN 4129 |
#define | MODE_INTER_NO_MV 0 |
#define | MODE_INTRA 1 |
#define | MODE_INTER_PLUS_MV 2 |
#define | MODE_INTER_LAST_MV 3 |
#define | MODE_INTER_PRIOR_LAST 4 |
#define | MODE_USING_GOLDEN 5 |
#define | MODE_GOLDEN_MV 6 |
#define | MODE_INTER_FOURMV 7 |
#define | CODING_MODE_COUNT 8 |
#define | MODE_COPY 8 |
#define | MIN_DEQUANT_VAL 2 |
#define | TOKEN_EOB(eob_run) ((eob_run) << 2) |
#define | TOKEN_ZERO_RUN(coeff, zero_run) (((coeff) * 512) + ((zero_run) << 2) + 1) |
#define | TOKEN_COEFF(coeff) (((coeff) * 4) + 2) |
#define | BLOCK_X (2 * mb_x + (k & 1)) |
#define | BLOCK_Y (2 * mb_y + (k >> 1)) |
#define | SET_CHROMA_MODES |
#define | COMPATIBLE_FRAME(x) (compatible_frame[s->all_fragments[x].coding_method] == current_frame_type) |
#define | DC_COEFF(u) s->all_fragments[u].dc |
#define | PUL 8 |
#define | PU 4 |
#define | PUR 2 |
#define | PL 1 |
#define | TRANSPOSE(x) (((x) >> 3) | (((x) & 7) << 3)) |
Enumerations | |
enum | { VP4_DC_INTRA = 0, VP4_DC_INTER = 1, VP4_DC_GOLDEN = 2, NB_VP4_DC_TYPES, VP4_DC_UNDEFINED = NB_VP4_DC_TYPES } |
Functions | |
static int | theora_decode_header (AVCodecContext *avctx, GetBitContext *gb) |
static int | theora_decode_tables (AVCodecContext *avctx, GetBitContext *gb) |
static av_cold void | free_tables (AVCodecContext *avctx) |
static void | vp3_decode_flush (AVCodecContext *avctx) |
static av_cold int | vp3_decode_end (AVCodecContext *avctx) |
static int | init_block_mapping (Vp3DecodeContext *s) |
This function sets up all of the various blocks mappings: superblocks <-> fragments, macroblocks <-> fragments, superblocks <-> macroblocks. More... | |
static void | init_dequantizer (Vp3DecodeContext *s, int qpi) |
static void | init_loop_filter (Vp3DecodeContext *s) |
static int | unpack_superblocks (Vp3DecodeContext *s, GetBitContext *gb) |
static int | unpack_modes (Vp3DecodeContext *s, GetBitContext *gb) |
static int | vp4_get_mv (GetBitContext *gb, int axis, int last_motion) |
static int | unpack_vectors (Vp3DecodeContext *s, GetBitContext *gb) |
static int | unpack_block_qpis (Vp3DecodeContext *s, GetBitContext *gb) |
static int | get_eob_run (GetBitContext *gb, int token) |
static int | get_coeff (GetBitContext *gb, int token, int16_t *coeff) |
static int | unpack_vlcs (Vp3DecodeContext *s, GetBitContext *gb, const VLCElem *vlc_table, int coeff_index, int plane, int eob_run) |
static void | reverse_dc_prediction (Vp3DecodeContext *s, int first_fragment, int fragment_width, int fragment_height) |
static int | unpack_dct_coeffs (Vp3DecodeContext *s, GetBitContext *gb) |
static void | apply_loop_filter (Vp3DecodeContext *s, int plane, int ystart, int yend) |
static int | vp3_dequant (Vp3DecodeContext *s, const Vp3Fragment *frag, int plane, int inter, int16_t block[64]) |
Pull DCT tokens from the 64 levels to decode and dequant the coefficients for the next block in coding order. More... | |
static void | vp3_draw_horiz_band (Vp3DecodeContext *s, int y) |
called when all pixels up to row y are complete More... | |
static void | await_reference_row (Vp3DecodeContext *s, const Vp3Fragment *fragment, int motion_y, int y) |
Wait for the reference frame of the current fragment. More... | |
static void | render_slice (Vp3DecodeContext *s, int slice) |
static av_cold void | init_tables_once (void) |
static av_cold int | allocate_tables (AVCodecContext *avctx) |
Allocate tables for per-frame data in Vp3DecodeContext. More... | |
static av_cold int | init_frames (Vp3DecodeContext *s) |
static av_cold void | free_vlc_tables (FFRefStructOpaque unused, void *obj) |
static av_cold int | vp3_decode_init (AVCodecContext *avctx) |
static int | update_frames (AVCodecContext *avctx) |
Release and shuffle frames after decode finishes. More... | |
static int | vp3_decode_frame (AVCodecContext *avctx, AVFrame *frame, int *got_frame, AVPacket *avpkt) |
static int | read_huffman_tree (HuffTable *huff, GetBitContext *gb, int length, AVCodecContext *avctx) |
Variables | |
static const int | ModeAlphabet [6][CODING_MODE_COUNT] |
static const uint8_t | hilbert_offset [16][2] |
static const uint8_t | vp4_pred_block_type_map [8] |
static VLCElem | superblock_run_length_vlc [88] |
static VLCElem | fragment_run_length_vlc [56] |
static VLCElem | motion_vector_vlc [112] |
static VLCElem | mode_code_vlc [24+2108 *CONFIG_VP4_DECODER] |
const FFCodec | ff_vp3_decoder |
On2 VP3/VP4 Video Decoder
VP3 Video Decoder by Mike Melanson (mike at multimedia.cx) For more information about the VP3 coding process, visit: http://wiki.multimedia.cx/index.php?title=On2_VP3
Theora decoder by Alex Beregszaszi
Definition in file vp3.c.
#define SET_CHROMA_MODES |
#define COMPATIBLE_FRAME | ( | x | ) | (compatible_frame[s->all_fragments[x].coding_method] == current_frame_type) |
#define PUL 8 |
#define PU 4 |
#define PUR 2 |
#define PL 1 |
#define TRANSPOSE | ( | x | ) | (((x) >> 3) | (((x) & 7) << 3)) |
anonymous enum |
|
static |
Referenced by vp3_decode_frame().
|
static |
Referenced by vp3_decode_frame().
|
static |
Definition at line 335 of file vp3.c.
Referenced by allocate_tables(), and vp3_decode_end().
|
static |
Definition at line 351 of file vp3.c.
Referenced by vp3_decode_end().
|
static |
Definition at line 363 of file vp3.c.
Referenced by vp3_decode_frame().
|
static |
This function sets up all of the various blocks mappings: superblocks <-> fragments, macroblocks <-> fragments, superblocks <-> macroblocks.
Definition at line 390 of file vp3.c.
Referenced by allocate_tables().
|
static |
|
static |
|
static |
|
static |
|
static |
Definition at line 893 of file vp3.c.
Referenced by unpack_vectors().
|
static |
|
static |
|
inlinestatic |
Definition at line 1148 of file vp3.c.
Referenced by unpack_vlcs().
|
inlinestatic |
Definition at line 1156 of file vp3.c.
Referenced by unpack_vlcs().
|
static |
Definition at line 1184 of file vp3.c.
Referenced by unpack_dct_coeffs().
|
static |
Definition at line 1639 of file vp3.c.
Referenced by unpack_dct_coeffs().
|
static |
|
static |
Definition at line 1788 of file vp3.c.
Referenced by render_slice(), and vc1_decode_p_blocks().
|
inlinestatic |
Pull DCT tokens from the 64 levels to decode and dequant the coefficients for the next block in coding order.
Definition at line 1854 of file vp3.c.
Referenced by render_slice().
|
static |
called when all pixels up to row y are complete
Definition at line 1899 of file vp3.c.
Referenced by render_slice().
|
static |
Wait for the reference frame of the current fragment.
The progress value is in luma pixel rows.
Definition at line 1941 of file vp3.c.
Referenced by render_slice().
|
static |
|
static |
Definition at line 2268 of file vp3.c.
Referenced by vp3_decode_init().
|
static |
Allocate tables for per-frame data in Vp3DecodeContext.
Definition at line 2311 of file vp3.c.
Referenced by vp3_decode_init().
|
static |
Definition at line 2354 of file vp3.c.
Referenced by vp3_decode_init().
|
static |
Definition at line 2366 of file vp3.c.
Referenced by vp3_decode_init().
|
static |
Definition at line 2374 of file vp3.c.
Referenced by vp3_decode_frame().
|
static |
|
static |
|
static |
|
static |
Definition at line 100 of file vp3.c.
Referenced by unpack_modes().
|
static |
Definition at line 138 of file vp3.c.
Referenced by init_block_mapping(), and render_slice().
|
static |
|
static |
Definition at line 164 of file vp3.c.
Referenced by init_tables_once(), unpack_block_qpis(), and unpack_superblocks().
|
static |
Definition at line 165 of file vp3.c.
Referenced by init_tables_once(), and unpack_superblocks().
|
static |
Definition at line 166 of file vp3.c.
Referenced by init_tables_once(), and unpack_vectors().
|
static |
Definition at line 169 of file vp3.c.
Referenced by init_tables_once(), and unpack_modes().
const FFCodec ff_vp3_decoder |