1 /*
2 * RV30 decoder
3 * Copyright (c) 2007 Konstantin Shishkov
4 *
5 * This file is part of FFmpeg.
6 *
7 * FFmpeg is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
11 *
12 * FFmpeg is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
16 *
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with FFmpeg; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 */
21
22 /**
23 * @file
24 * RV30 decoder
25 */
26
31
34
35
37 {
39 int mb_bits;
41 int mb_size;
42 int rpr;
43
46 return -1;
50 return -1;
55 if(rpr){
59 }
60
63 "Insufficient extradata - need at least %d bytes, got %d\n",
66 }
67
70 } else {
73 }
76 mb_size = ((w + 15) >> 4) * ((
h + 15) >> 4);
80 return 0;
81 }
82
83 /**
84 * Decode 4x4 intra types array.
85 */
87 {
88 int i, j, k;
89
91 for(j = 0; j < 4; j+= 2){
95 return -1;
96 }
97 for(k = 0; k < 2; k++){
101 if(dst[-1] == 9){
103 return -1;
104 }
105 }
106 }
107 }
108 return 0;
109 }
110
111 /**
112 * Decode macroblock information.
113 */
115 {
121
122 if (code > 11) {
124 return -1;
125 }
126 if(code > 5){
128 code -= 6;
129 }
131 return rv30_p_types[code];
132 else
133 return rv30_b_types[code];
134 }
135
137 const int stride,
const int lim)
138 {
141
142 for(i = 0; i < 4; i++){
143 diff = ((src[-2*step] - src[1*step]) - (src[-1*step] - src[0*step])*4) >> 3;
144 diff = av_clip(diff, -lim, lim);
145 src[-1*step] = cm[src[-1*step] +
diff];
146 src[ 0*step] = cm[src[ 0*step] -
diff];
148 }
149 }
150
152 {
154 int mb_pos, mb_x;
155 int i, j, k;
157 int loc_lim, cur_lim, left_lim = 0, top_lim = 0;
158
160 for(mb_x = 0; mb_x < s->
mb_width; mb_x++, mb_pos++){
166 }
167
168 /* all vertical edges are filtered first
169 * and horizontal edges are filtered on the next iteration
170 */
172 for(mb_x = 0; mb_x < s->
mb_width; mb_x++, mb_pos++){
174 if(mb_x)
176 for(j = 0; j < 16; j += 4){
178 for(i = !mb_x; i < 4; i++, Y += 4){
179 int ij = i + j;
180 loc_lim = 0;
182 loc_lim = cur_lim;
183 else if(!i && r->
deblock_coefs[mb_pos - 1] & (1 << (ij + 3)))
184 loc_lim = left_lim;
186 loc_lim = cur_lim;
187 if(loc_lim)
189 }
190 }
191 for(k = 0; k < 2; k++){
192 int cur_cbp, left_cbp = 0;
193 cur_cbp = (r->
cbp_chroma[mb_pos] >> (k*4)) & 0xF;
194 if(mb_x)
195 left_cbp = (r->
cbp_chroma[mb_pos - 1] >> (k*4)) & 0xF;
196 for(j = 0; j < 8; j += 4){
198 for(i = !mb_x; i < 2; i++, C += 4){
199 int ij = i + (j >> 1);
200 loc_lim = 0;
201 if (cur_cbp & (1 << ij))
202 loc_lim = cur_lim;
203 else if(!i && left_cbp & (1 << (ij + 1)))
204 loc_lim = left_lim;
205 else if( i && cur_cbp & (1 << (ij - 1)))
206 loc_lim = cur_lim;
207 if(loc_lim)
209 }
210 }
211 }
212 }
214 for(mb_x = 0; mb_x < s->
mb_width; mb_x++, mb_pos++){
216 if(row)
218 for(j = 4*!row; j < 16; j += 4){
220 for(i = 0; i < 4; i++, Y += 4){
221 int ij = i + j;
222 loc_lim = 0;
224 loc_lim = cur_lim;
226 loc_lim = top_lim;
228 loc_lim = cur_lim;
229 if(loc_lim)
231 }
232 }
233 for(k = 0; k < 2; k++){
234 int cur_cbp, top_cbp = 0;
235 cur_cbp = (r->
cbp_chroma[mb_pos] >> (k*4)) & 0xF;
236 if(row)
238 for(j = 4*!row; j < 8; j += 4){
240 for(i = 0; i < 2; i++, C += 4){
241 int ij = i + (j >> 1);
242 loc_lim = 0;
244 loc_lim = cur_lim;
245 else if(!j && top_cbp & (1 << (ij + 2)))
246 loc_lim = top_lim;
247 else if( j && cur_cbp & (1 << (ij - 2)))
248 loc_lim = cur_lim;
249 if(loc_lim)
251 }
252 }
253 }
254 }
255 }
256
257 /**
258 * Initialize decoder.
259 */
261 {
263 int ret;
264
267
271 }
274 return ret;
275
280 }
281
288 return 0;
289 }
290
306 },
309 };
static const uint8_t rv30_luma_dc_quant[32]
DC quantizer mapping for RV30.
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
int(* decode_intra_types)(struct RV34DecContext *r, GetBitContext *gb, int8_t *dst)
static void flush(AVCodecContext *avctx)
void(* loop_filter)(struct RV34DecContext *r, int row)
int coded_width
Bitstream width / height, may be different from width/height e.g.
#define IS_SEPARATE_DC(a)
static unsigned int get_bits(GetBitContext *s, int n)
Read 1-25 bits.
#define AV_LOG_WARNING
Something somehow does not look correct.
B-frame macroblock, forward prediction.
static av_cold int init(AVCodecContext *avctx)
static const uint8_t rv30_loop_filt_lim[32]
Loop filter limits are taken from this table.
Bidirectionally predicted B-frame macroblock, no motion vectors.
static av_cold int rv30_decode_init(AVCodecContext *avctx)
Initialize decoder.
RV30 and RV40 decoder common data declarations.
const uint8_t * luma_dc_quant_p
luma subblock DC quantizer for interframes
static void decode(AVCodecContext *dec_ctx, AVPacket *pkt, AVFrame *frame, FILE *outfile)
static int rv30_decode_intra_types(RV34DecContext *r, GetBitContext *gb, int8_t *dst)
Decode 4x4 intra types array.
#define AV_CODEC_CAP_DELAY
Encoder or decoder requires flushing with NULL input at the end in order to give the complete and cor...
uint8_t * extradata
some codecs need / can use extradata like Huffman tables.
uint16_t * deblock_coefs
deblock coefficients for each macroblock
static int rv30_decode_mb_info(RV34DecContext *r)
Decode macroblock information.
int quant
quantizer used for this slice
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
int(* parse_slice_header)(struct RV34DecContext *r, GetBitContext *gb, SliceInfo *si)
static const uint8_t rv30_itype_from_context[900]
This table is used for retrieving the current intra type based on its neighbors and adjustment provid...
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
const char * name
Name of the codec implementation.
#define AV_CODEC_CAP_FRAME_THREADS
Codec supports frame-level multithreading.
void ff_mpeg_flush(AVCodecContext *avctx)
#define ONLY_IF_THREADS_ENABLED(x)
Define a function with only the non-default version specified.
Intra macroblock with DCs in a separate 4x4 block.
Picture * current_picture_ptr
pointer to the current picture
static const uint8_t rv30_itype_code[9 *9 *2]
This table is used for storing the differences between the predicted and the real intra type...
int ff_rv34_decode_init_thread_copy(AVCodecContext *avctx)
essential slice information
Libavcodec external API header.
static void rv30_loop_filter(RV34DecContext *r, int row)
ptrdiff_t linesize
line size, in bytes, may be different from width
main external API structure.
int height
picture size. must be a multiple of 16
static void rv30_weak_loop_filter(uint8_t *src, const int step, const int stride, const int lim)
P-frame macroblock, 8x8 motion compensation partitions.
static unsigned int get_bits1(GetBitContext *s)
static void skip_bits1(GetBitContext *s)
av_cold int ff_rv34_decode_init(AVCodecContext *avctx)
Initialize decoder.
ptrdiff_t uvlinesize
line size, for chroma in bytes, may be different from width
int ff_rv34_decode_frame(AVCodecContext *avctx, void *data, int *got_picture_ptr, AVPacket *avpkt)
int intra_types_stride
block types array stride
int pict_type
AV_PICTURE_TYPE_I, AV_PICTURE_TYPE_P, AV_PICTURE_TYPE_B, ...
static enum AVPixelFormat pix_fmts[]
P-frame macroblock, one motion frame.
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
av_cold int ff_rv34_decode_end(AVCodecContext *avctx)
struct AVCodecContext * avctx
int(* decode_mb_info)(struct RV34DecContext *r)
GLint GLenum GLboolean GLsizei stride
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples)
int mb_stride
mb_width+1 used for some arrays to allow simple addressing of left & top MBs without sig11 ...
B-frame macroblock, backward prediction.
int ff_rv34_decode_update_thread_context(AVCodecContext *dst, const AVCodecContext *src)
int ff_rv34_get_start_offset(GetBitContext *gb, int mb_size)
Decode starting slice position.
static av_always_inline int diff(const uint32_t a, const uint32_t b)
static int rv30_parse_slice_header(RV34DecContext *r, GetBitContext *gb, SliceInfo *si)
const uint8_t * luma_dc_quant_i
luma subblock DC quantizer for intraframes
uint32_t * mb_type
types and macros are defined in mpegutils.h
int type
slice type (intra, inter)
static unsigned get_interleaved_ue_golomb(GetBitContext *gb)
miscellaneous RV30 tables
int rv30
indicates which RV variant is currently decoded
AVPixelFormat
Pixel format.
#define AV_CODEC_CAP_DR1
Codec uses get_buffer() for allocating buffers and supports custom allocators.
uint8_t * cbp_chroma
CBP values for chroma subblocks.