annotate vcr1.c @ 3797:0596dbc4f858 libavcodec

marking AVPaletteControl as deprecated due to thread saftey amongth other issues (it doesnt work if theres any delay between demuxer and decoder)
author michael
date Sat, 30 Sep 2006 18:16:38 +0000
parents 0b546eab515d
children c8c591fe26f8
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
3036
0b546eab515d Update licensing information: The FSF changed postal address.
diego
parents: 2967
diff changeset
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
18 */
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
19
1374
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 */
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
24
1374
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
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
38 static int decode_frame(AVCodecContext *avctx,
1374
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 }
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
63
1374
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;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
82
1375
michaelni
parents: 1374
diff changeset
83 *(cb++) = bytestream[3];
michaelni
parents: 1374
diff changeset
84 *(cr++) = bytestream[1];
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
85
1374
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();
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
110
1374
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();
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
127
1374
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);
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
131
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
132 size= get_bit_count(&a->pb)/32;
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
133
1374
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){
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
146
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
147 common_init(avctx);
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
148
1374
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
2522
e25782262d7d kill warnings patch by (Mns Rullgrd <mru inprovide com>)
michael
parents: 2453
diff changeset
154 #if 0
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
155 static int encode_init(AVCodecContext *avctx){
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
156
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
157 common_init(avctx);
2967
ef2149182f1c COSMETICS: Remove all trailing whitespace.
diego
parents: 2522
diff changeset
158
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
159 return 0;
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
160 }
2522
e25782262d7d kill warnings patch by (Mns Rullgrd <mru inprovide com>)
michael
parents: 2453
diff changeset
161 #endif
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
162
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
163 AVCodec vcr1_decoder = {
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
164 "vcr1",
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
165 CODEC_TYPE_VIDEO,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
166 CODEC_ID_VCR1,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
167 sizeof(VCR1Context),
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
168 decode_init,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
169 NULL,
1994
8d3540dddd1b cleanup & memleak fix
michael
parents: 1598
diff changeset
170 NULL,
1374
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
171 decode_frame,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
172 CODEC_CAP_DR1,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
173 };
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
174 #if 0
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
175 #ifdef CONFIG_ENCODERS
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
176
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
177 AVCodec vcr1_encoder = {
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
178 "vcr1",
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
179 CODEC_TYPE_VIDEO,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
180 CODEC_ID_VCR1,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
181 sizeof(VCR1Context),
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
182 encode_init,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
183 encode_frame,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
184 //encode_end,
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
185 };
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
186
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
187 #endif //CONFIG_ENCODERS
f9b088451fb3 ATI VCR1 decoder
michaelni
parents:
diff changeset
188 #endif