annotate vcr1.c @ 2497:69adfbbdcdeb libavcodec

- samples from mplayer ftp in the "adv" profile seem to have profile=2, which isn't the advanced one; and indeed, using adv. profile parser fails. Using normal parser works, and that's what is done - attempt at taking care of stride for NORM2 bitplane decoding - duplication of much code from msmpeg4.c; this code isn't yet used, but goes down as far as the block layer (mainly Transform Type stuff, the remains are wild editing without checking). Unusable yet, and lacks the AC decoding (but a step further in bitstream parsing) patch by anonymous
author michael
date Fri, 04 Feb 2005 02:20:38 +0000
parents f67b63ed036d
children e25782262d7d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
1 /*
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
2 * ATI VCR1 codec
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
3 * Copyright (c) 2003 Michael Niedermayer
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
4 *
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
5 * This library is free software; you can redistribute it and/or
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
6 * modify it under the terms of the GNU Lesser General Public
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
7 * License as published by the Free Software Foundation; either
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
8 * version 2 of the License, or (at your option) any later version.
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
9 *
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
10 * This library is distributed in the hope that it will be useful,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
13 * Lesser General Public License for more details.
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
14 *
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
15 * You should have received a copy of the GNU Lesser General Public
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
16 * License along with this library; if not, write to the Free Software
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
18 */
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
19
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
20 /**
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
21 * @file vcr1.c
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
22 * ati vcr1 codec.
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
23 */
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
24
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
25 #include "avcodec.h"
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
26 #include "mpegvideo.h"
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
27
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
28 //#undef NDEBUG
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
29 //#include <assert.h>
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
30
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
31 typedef struct VCR1Context{
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
32 AVCodecContext *avctx;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
33 AVFrame picture;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
34 int delta[16];
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
35 int offset[4];
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
36 } VCR1Context;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
37
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
38 static int decode_frame(AVCodecContext *avctx,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
39 void *data, int *data_size,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
40 uint8_t *buf, int buf_size)
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
41 {
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
42 VCR1Context * const a = avctx->priv_data;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
43 AVFrame *picture = data;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
44 AVFrame * const p= (AVFrame*)&a->picture;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
45 uint8_t *bytestream= buf;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
46 int i, x, y;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
47
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
48 if(p->data[0])
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
49 avctx->release_buffer(avctx, p);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
50
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
51 p->reference= 0;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
52 if(avctx->get_buffer(avctx, p) < 0){
1598
932d306bf1dc av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents: 1419
diff changeset
53 av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
54 return -1;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
55 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
56 p->pict_type= I_TYPE;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
57 p->key_frame= 1;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
58
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
59 for(i=0; i<16; i++){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
60 a->delta[i]= *(bytestream++);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
61 bytestream++;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
62 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
63
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
64 for(y=0; y<avctx->height; y++){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
65 int offset;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
66 uint8_t *luma= &a->picture.data[0][ y*a->picture.linesize[0] ];
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
67
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
68 if((y&3) == 0){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
69 uint8_t *cb= &a->picture.data[1][ (y>>2)*a->picture.linesize[1] ];
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
70 uint8_t *cr= &a->picture.data[2][ (y>>2)*a->picture.linesize[2] ];
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
71
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
72 for(i=0; i<4; i++)
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
73 a->offset[i]= *(bytestream++);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
74
1375
michaelni
parents: 1374
diff changeset
75 offset= a->offset[0] - a->delta[ bytestream[2]&0xF ];
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
76 for(x=0; x<avctx->width; x+=4){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
77 luma[0]=( offset += a->delta[ bytestream[2]&0xF ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
78 luma[1]=( offset += a->delta[ bytestream[2]>>4 ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
79 luma[2]=( offset += a->delta[ bytestream[0]&0xF ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
80 luma[3]=( offset += a->delta[ bytestream[0]>>4 ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
81 luma += 4;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
82
1375
michaelni
parents: 1374
diff changeset
83 *(cb++) = bytestream[3];
michaelni
parents: 1374
diff changeset
84 *(cr++) = bytestream[1];
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
85
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
86 bytestream+= 4;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
87 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
88 }else{
1375
michaelni
parents: 1374
diff changeset
89 offset= a->offset[y&3] - a->delta[ bytestream[2]&0xF ];
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
90
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
91 for(x=0; x<avctx->width; x+=8){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
92 luma[0]=( offset += a->delta[ bytestream[2]&0xF ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
93 luma[1]=( offset += a->delta[ bytestream[2]>>4 ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
94 luma[2]=( offset += a->delta[ bytestream[3]&0xF ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
95 luma[3]=( offset += a->delta[ bytestream[3]>>4 ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
96 luma[4]=( offset += a->delta[ bytestream[0]&0xF ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
97 luma[5]=( offset += a->delta[ bytestream[0]>>4 ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
98 luma[6]=( offset += a->delta[ bytestream[1]&0xF ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
99 luma[7]=( offset += a->delta[ bytestream[1]>>4 ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
100 luma += 8;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
101 bytestream+= 4;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
102 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
103 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
104 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
105
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
106 *picture= *(AVFrame*)&a->picture;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
107 *data_size = sizeof(AVPicture);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
108
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
109 emms_c();
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
110
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
111 return buf_size;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
112 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
113
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
114 #if 0
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
115 static int encode_frame(AVCodecContext *avctx, unsigned char *buf, int buf_size, void *data){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
116 VCR1Context * const a = avctx->priv_data;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
117 AVFrame *pict = data;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
118 AVFrame * const p= (AVFrame*)&a->picture;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
119 int size;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
120 int mb_x, mb_y;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
121
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
122 *p = *pict;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
123 p->pict_type= I_TYPE;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
124 p->key_frame= 1;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
125
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
126 emms_c();
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
127
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
128 align_put_bits(&a->pb);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
129 while(get_bit_count(&a->pb)&31)
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
130 put_bits(&a->pb, 8, 0);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
131
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
132 size= get_bit_count(&a->pb)/32;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
133
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
134 return size*4;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
135 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
136 #endif
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
137
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
138 static void common_init(AVCodecContext *avctx){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
139 VCR1Context * const a = avctx->priv_data;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
140
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
141 avctx->coded_frame= (AVFrame*)&a->picture;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
142 a->avctx= avctx;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
143 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
144
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
145 static int decode_init(AVCodecContext *avctx){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
146
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
147 common_init(avctx);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
148
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
149 avctx->pix_fmt= PIX_FMT_YUV410P;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
150
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
151 return 0;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
152 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
153
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
154 static int encode_init(AVCodecContext *avctx){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
155
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
156 common_init(avctx);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
157
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
158 return 0;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
159 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
160
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
161 AVCodec vcr1_decoder = {
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
162 "vcr1",
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
163 CODEC_TYPE_VIDEO,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
164 CODEC_ID_VCR1,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
165 sizeof(VCR1Context),
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
166 decode_init,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
167 NULL,
1994
8d3540dddd1b cleanup & memleak fix
michael
parents: 1598
diff changeset
168 NULL,
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
169 decode_frame,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
170 CODEC_CAP_DR1,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
171 };
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
172 #if 0
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
173 #ifdef CONFIG_ENCODERS
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
174
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
175 AVCodec vcr1_encoder = {
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
176 "vcr1",
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
177 CODEC_TYPE_VIDEO,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
178 CODEC_ID_VCR1,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
179 sizeof(VCR1Context),
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
180 encode_init,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
181 encode_frame,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
182 //encode_end,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
183 };
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
184
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
185 #endif //CONFIG_ENCODERS
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
186 #endif