|
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 |
1.8.17