The current design, where - proper init is called for the first per-thread context - first thread's private data is copied into private data for all the other threads - a "fixup" function is called for all the other threads to e.g. allocate dynamically allocated data is very fragile and hard to follow, so it is abandoned. Instead, the same init function is used to init each per-thread context. Where necessary, AVCodecInternal.is_copy can be used to differentiate between the first thread and the other ones (e.g. for decoding the extradata just once).
		
			
				
	
	
		
			142 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			142 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * RV30/40 decoder common data declarations
 | |
|  * Copyright (c) 2007 Mike Melanson, Konstantin Shishkov
 | |
|  *
 | |
|  * This file is part of FFmpeg.
 | |
|  *
 | |
|  * FFmpeg is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU Lesser General Public
 | |
|  * License as published by the Free Software Foundation; either
 | |
|  * version 2.1 of the License, or (at your option) any later version.
 | |
|  *
 | |
|  * FFmpeg is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|  * Lesser General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public
 | |
|  * License along with FFmpeg; if not, write to the Free Software
 | |
|  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * @file
 | |
|  * RV30 and RV40 decoder common data declarations
 | |
|  */
 | |
| 
 | |
| #ifndef AVCODEC_RV34_H
 | |
| #define AVCODEC_RV34_H
 | |
| 
 | |
| #include "avcodec.h"
 | |
| #include "mpegvideo.h"
 | |
| 
 | |
| #include "h264pred.h"
 | |
| #include "rv34dsp.h"
 | |
| 
 | |
| #define MB_TYPE_SEPARATE_DC 0x01000000
 | |
| #define IS_SEPARATE_DC(a)   ((a) & MB_TYPE_SEPARATE_DC)
 | |
| 
 | |
| /**
 | |
|  * RV30 and RV40 Macroblock types
 | |
|  */
 | |
| enum RV40BlockTypes{
 | |
|     RV34_MB_TYPE_INTRA,      ///< Intra macroblock
 | |
|     RV34_MB_TYPE_INTRA16x16, ///< Intra macroblock with DCs in a separate 4x4 block
 | |
|     RV34_MB_P_16x16,         ///< P-frame macroblock, one motion frame
 | |
|     RV34_MB_P_8x8,           ///< P-frame macroblock, 8x8 motion compensation partitions
 | |
|     RV34_MB_B_FORWARD,       ///< B-frame macroblock, forward prediction
 | |
|     RV34_MB_B_BACKWARD,      ///< B-frame macroblock, backward prediction
 | |
|     RV34_MB_SKIP,            ///< Skipped block
 | |
|     RV34_MB_B_DIRECT,        ///< Bidirectionally predicted B-frame macroblock, no motion vectors
 | |
|     RV34_MB_P_16x8,          ///< P-frame macroblock, 16x8 motion compensation partitions
 | |
|     RV34_MB_P_8x16,          ///< P-frame macroblock, 8x16 motion compensation partitions
 | |
|     RV34_MB_B_BIDIR,         ///< Bidirectionally predicted B-frame macroblock, two motion vectors
 | |
|     RV34_MB_P_MIX16x16,      ///< P-frame macroblock with DCs in a separate 4x4 block, one motion vector
 | |
|     RV34_MB_TYPES
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * VLC tables used by the decoder
 | |
|  *
 | |
|  * Intra frame VLC sets do not contain some of those tables.
 | |
|  */
 | |
| typedef struct RV34VLC{
 | |
|     VLC cbppattern[2];     ///< VLCs used for pattern of coded block patterns decoding
 | |
|     VLC cbp[2][4];         ///< VLCs used for coded block patterns decoding
 | |
|     VLC first_pattern[4];  ///< VLCs used for decoding coefficients in the first subblock
 | |
|     VLC second_pattern[2]; ///< VLCs used for decoding coefficients in the subblocks 2 and 3
 | |
|     VLC third_pattern[2];  ///< VLCs used for decoding coefficients in the last subblock
 | |
|     VLC coefficient;       ///< VLCs used for decoding big coefficients
 | |
| }RV34VLC;
 | |
| 
 | |
| /** essential slice information */
 | |
| typedef struct SliceInfo{
 | |
|     int type;              ///< slice type (intra, inter)
 | |
|     int quant;             ///< quantizer used for this slice
 | |
|     int vlc_set;           ///< VLCs used for this slice
 | |
|     int start, end;        ///< start and end macroblocks of the slice
 | |
|     int width;             ///< coded width
 | |
|     int height;            ///< coded height
 | |
|     int pts;               ///< frame timestamp
 | |
| }SliceInfo;
 | |
| 
 | |
| /** decoder context */
 | |
| typedef struct RV34DecContext{
 | |
|     MpegEncContext s;
 | |
|     RV34DSPContext rdsp;
 | |
|     int8_t *intra_types_hist;///< old block types, used for prediction
 | |
|     int8_t *intra_types;     ///< block types
 | |
|     int    intra_types_stride;///< block types array stride
 | |
|     const uint8_t *luma_dc_quant_i;///< luma subblock DC quantizer for intraframes
 | |
|     const uint8_t *luma_dc_quant_p;///< luma subblock DC quantizer for interframes
 | |
| 
 | |
|     RV34VLC *cur_vlcs;       ///< VLC set used for current frame decoding
 | |
|     H264PredContext h;       ///< functions for 4x4 and 16x16 intra block prediction
 | |
|     SliceInfo si;            ///< current slice information
 | |
| 
 | |
|     int *mb_type;            ///< internal macroblock types
 | |
|     int block_type;          ///< current block type
 | |
|     int luma_vlc;            ///< which VLC set will be used for decoding of luma blocks
 | |
|     int chroma_vlc;          ///< which VLC set will be used for decoding of chroma blocks
 | |
|     int is16;                ///< current block has additional 16x16 specific features or not
 | |
|     int dmv[4][2];           ///< differential motion vectors for the current macroblock
 | |
| 
 | |
|     int rv30;                ///< indicates which RV variant is currently decoded
 | |
|     int max_rpr;
 | |
| 
 | |
|     int cur_pts, last_pts, next_pts;
 | |
|     int scaled_weight;
 | |
|     int weight1, weight2;    ///< B-frame distance fractions (0.14) used in motion compensation
 | |
|     int mv_weight1, mv_weight2;
 | |
| 
 | |
|     int orig_width, orig_height;
 | |
| 
 | |
|     uint16_t *cbp_luma;      ///< CBP values for luma subblocks
 | |
|     uint8_t  *cbp_chroma;    ///< CBP values for chroma subblocks
 | |
|     uint16_t *deblock_coefs; ///< deblock coefficients for each macroblock
 | |
| 
 | |
|     /** 8x8 block available flags (for MV prediction) */
 | |
|     DECLARE_ALIGNED(8, uint32_t, avail_cache)[3*4];
 | |
| 
 | |
|     /** temporary blocks for RV4 weighted MC */
 | |
|     uint8_t *tmp_b_block_y[2];
 | |
|     uint8_t *tmp_b_block_uv[4];
 | |
|     uint8_t *tmp_b_block_base;
 | |
| 
 | |
|     int (*parse_slice_header)(struct RV34DecContext *r, GetBitContext *gb, SliceInfo *si);
 | |
|     int (*decode_mb_info)(struct RV34DecContext *r);
 | |
|     int (*decode_intra_types)(struct RV34DecContext *r, GetBitContext *gb, int8_t *dst);
 | |
|     void (*loop_filter)(struct RV34DecContext *r, int row);
 | |
| }RV34DecContext;
 | |
| 
 | |
| /**
 | |
|  * common decoding functions
 | |
|  */
 | |
| int ff_rv34_get_start_offset(GetBitContext *gb, int blocks);
 | |
| int ff_rv34_decode_init(AVCodecContext *avctx);
 | |
| int ff_rv34_decode_frame(AVCodecContext *avctx, void *data, int *got_frame, AVPacket *avpkt);
 | |
| int ff_rv34_decode_end(AVCodecContext *avctx);
 | |
| int ff_rv34_decode_update_thread_context(AVCodecContext *dst, const AVCodecContext *src);
 | |
| 
 | |
| #endif /* AVCODEC_RV34_H */
 |