annotate vcr1.c @ 4850:9e471439d2e8 libavcodec

fix tiff regression test (bitexact flag was ignoredwhich caused the LAVC version to be in the file and thus breaking with the last change of that)
author michael
date Sat, 14 Apr 2007 18:58:26 +0000
parents c8c591fe26f8
children d1cf4f790f31
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 *
3947
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3036
diff changeset
5 * This file is part of FFmpeg.
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3036
diff changeset
6 *
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3036
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
3947
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3036
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
11 *
3947
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3036
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
15 * Lesser General Public License for more details.
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
16 *
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
3947
c8c591fe26f8 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 3036
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
3036
0b546eab515d Update licensing information: The FSF changed postal address.
diego
parents: 2967
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
20 */
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
21
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
22 /**
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
23 * @file vcr1.c
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
24 * ati vcr1 codec.
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
25 */
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
26
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
27 #include "avcodec.h"
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
28 #include "mpegvideo.h"
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
29
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
30 //#undef NDEBUG
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
31 //#include <assert.h>
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
32
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
33 typedef struct VCR1Context{
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
34 AVCodecContext *avctx;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
35 AVFrame picture;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
36 int delta[16];
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
37 int offset[4];
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
38 } VCR1Context;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
39
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
40 static int decode_frame(AVCodecContext *avctx,
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
41 void *data, int *data_size,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
42 uint8_t *buf, int buf_size)
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
43 {
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
44 VCR1Context * const a = avctx->priv_data;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
45 AVFrame *picture = data;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
46 AVFrame * const p= (AVFrame*)&a->picture;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
47 uint8_t *bytestream= buf;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
48 int i, x, y;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
49
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
50 if(p->data[0])
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
51 avctx->release_buffer(avctx, p);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
52
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
53 p->reference= 0;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
54 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
55 av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
56 return -1;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
57 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
58 p->pict_type= I_TYPE;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
59 p->key_frame= 1;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
60
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
61 for(i=0; i<16; i++){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
62 a->delta[i]= *(bytestream++);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
63 bytestream++;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
64 }
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
65
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
66 for(y=0; y<avctx->height; y++){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
67 int offset;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
68 uint8_t *luma= &a->picture.data[0][ y*a->picture.linesize[0] ];
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
69
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
70 if((y&3) == 0){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
71 uint8_t *cb= &a->picture.data[1][ (y>>2)*a->picture.linesize[1] ];
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
72 uint8_t *cr= &a->picture.data[2][ (y>>2)*a->picture.linesize[2] ];
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
73
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
74 for(i=0; i<4; i++)
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
75 a->offset[i]= *(bytestream++);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
76
1375
michaelni
parents: 1374
diff changeset
77 offset= a->offset[0] - a->delta[ bytestream[2]&0xF ];
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
78 for(x=0; x<avctx->width; x+=4){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
79 luma[0]=( offset += a->delta[ bytestream[2]&0xF ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
80 luma[1]=( offset += a->delta[ bytestream[2]>>4 ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
81 luma[2]=( offset += a->delta[ bytestream[0]&0xF ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
82 luma[3]=( offset += a->delta[ bytestream[0]>>4 ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
83 luma += 4;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
84
1375
michaelni
parents: 1374
diff changeset
85 *(cb++) = bytestream[3];
michaelni
parents: 1374
diff changeset
86 *(cr++) = bytestream[1];
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
87
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
88 bytestream+= 4;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
89 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
90 }else{
1375
michaelni
parents: 1374
diff changeset
91 offset= a->offset[y&3] - a->delta[ bytestream[2]&0xF ];
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
92
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
93 for(x=0; x<avctx->width; x+=8){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
94 luma[0]=( offset += a->delta[ bytestream[2]&0xF ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
95 luma[1]=( offset += a->delta[ bytestream[2]>>4 ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
96 luma[2]=( offset += a->delta[ bytestream[3]&0xF ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
97 luma[3]=( offset += a->delta[ bytestream[3]>>4 ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
98 luma[4]=( offset += a->delta[ bytestream[0]&0xF ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
99 luma[5]=( offset += a->delta[ bytestream[0]>>4 ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
100 luma[6]=( offset += a->delta[ bytestream[1]&0xF ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
101 luma[7]=( offset += a->delta[ bytestream[1]>>4 ]);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
102 luma += 8;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
103 bytestream+= 4;
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 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
107
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
108 *picture= *(AVFrame*)&a->picture;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
109 *data_size = sizeof(AVPicture);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
110
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
111 emms_c();
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
112
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
113 return buf_size;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
114 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
115
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
116 #if 0
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
117 static int encode_frame(AVCodecContext *avctx, unsigned char *buf, int buf_size, void *data){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
118 VCR1Context * const a = avctx->priv_data;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
119 AVFrame *pict = data;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
120 AVFrame * const p= (AVFrame*)&a->picture;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
121 int size;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
122 int mb_x, mb_y;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
123
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
124 *p = *pict;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
125 p->pict_type= I_TYPE;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
126 p->key_frame= 1;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
127
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
128 emms_c();
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
129
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
130 align_put_bits(&a->pb);
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
131 while(get_bit_count(&a->pb)&31)
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
132 put_bits(&a->pb, 8, 0);
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
133
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
134 size= get_bit_count(&a->pb)/32;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
135
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
136 return size*4;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
137 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
138 #endif
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
139
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
140 static void common_init(AVCodecContext *avctx){
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
141 VCR1Context * const a = avctx->priv_data;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
142
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
143 avctx->coded_frame= (AVFrame*)&a->picture;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
144 a->avctx= avctx;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
145 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
146
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
147 static int decode_init(AVCodecContext *avctx){
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
148
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
149 common_init(avctx);
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
150
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
151 avctx->pix_fmt= PIX_FMT_YUV410P;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
152
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
153 return 0;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
154 }
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
155
2522
e25782262d7d kill warnings patch by (Mns Rullgrd <mru inprovide com>)
michael
parents: 2453
diff changeset
156 #if 0
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
157 static int encode_init(AVCodecContext *avctx){
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
158
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
159 common_init(avctx);
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
160
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
161 return 0;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
162 }
2522
e25782262d7d kill warnings patch by (Mns Rullgrd <mru inprovide com>)
michael
parents: 2453
diff changeset
163 #endif
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
164
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
165 AVCodec vcr1_decoder = {
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
166 "vcr1",
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
167 CODEC_TYPE_VIDEO,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
168 CODEC_ID_VCR1,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
169 sizeof(VCR1Context),
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
170 decode_init,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
171 NULL,
1994
8d3540dddd1b cleanup & memleak fix
michael
parents: 1598
diff changeset
172 NULL,
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
173 decode_frame,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
174 CODEC_CAP_DR1,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
175 };
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
176 #if 0
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
177 #ifdef CONFIG_ENCODERS
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
178
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
179 AVCodec vcr1_encoder = {
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
180 "vcr1",
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
181 CODEC_TYPE_VIDEO,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
182 CODEC_ID_VCR1,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
183 sizeof(VCR1Context),
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
184 encode_init,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
185 encode_frame,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
186 //encode_end,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
187 };
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
188
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
189 #endif //CONFIG_ENCODERS
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
190 #endif