annotate utils.c @ 625:bb6a69f9d409 libavcodec

slow but accurate integer dct from IJG (should be ok with the LGPL as the old DCT is the fast integer DCT from IJG) per context DCT selection
author michaelni
date Thu, 29 Aug 2002 23:55:32 +0000
parents d6955d0d7d27
children b3869ffff47a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1 /*
986e461dc072 Initial revision
glantau
parents:
diff changeset
2 * utils for libavcodec
429
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
3 * Copyright (c) 2001 Fabrice Bellard.
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
4 *
429
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
5 * This library is free software; you can redistribute it and/or
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
6 * modify it under the terms of the GNU Lesser General Public
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
7 * License as published by the Free Software Foundation; either
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
8 * version 2 of the License, or (at your option) any later version.
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
9 *
429
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
10 * This library is distributed in the hope that it will be useful,
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
429
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
13 * Lesser General Public License for more details.
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
14 *
429
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
15 * You should have received a copy of the GNU Lesser General Public
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
16 * License along with this library; if not, write to the Free Software
718a22dc121f license/copyright change
glantau
parents: 400
diff changeset
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
18 */
394
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
19 #include "avcodec.h"
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
20 #include "dsputil.h"
341
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
21 #include "mpegvideo.h"
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
22
394
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
23 void *av_mallocz(int size)
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
24 {
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
25 void *ptr;
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
26 ptr = av_malloc(size);
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
27 if (!ptr)
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
28 return NULL;
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
29 memset(ptr, 0, size);
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
30 return ptr;
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
31 }
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
32
400
b0aed401a756 better av_freep()
glantau
parents: 394
diff changeset
33 /* cannot call it directly because of 'void **' casting is not automatic */
b0aed401a756 better av_freep()
glantau
parents: 394
diff changeset
34 void __av_freep(void **ptr)
b0aed401a756 better av_freep()
glantau
parents: 394
diff changeset
35 {
b0aed401a756 better av_freep()
glantau
parents: 394
diff changeset
36 av_free(*ptr);
b0aed401a756 better av_freep()
glantau
parents: 394
diff changeset
37 *ptr = NULL;
b0aed401a756 better av_freep()
glantau
parents: 394
diff changeset
38 }
b0aed401a756 better av_freep()
glantau
parents: 394
diff changeset
39
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
40 /* encoder management */
986e461dc072 Initial revision
glantau
parents:
diff changeset
41 AVCodec *first_avcodec;
986e461dc072 Initial revision
glantau
parents:
diff changeset
42
986e461dc072 Initial revision
glantau
parents:
diff changeset
43 void register_avcodec(AVCodec *format)
986e461dc072 Initial revision
glantau
parents:
diff changeset
44 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
45 AVCodec **p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
46 p = &first_avcodec;
986e461dc072 Initial revision
glantau
parents:
diff changeset
47 while (*p != NULL) p = &(*p)->next;
986e461dc072 Initial revision
glantau
parents:
diff changeset
48 *p = format;
986e461dc072 Initial revision
glantau
parents:
diff changeset
49 format->next = NULL;
986e461dc072 Initial revision
glantau
parents:
diff changeset
50 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
51
986e461dc072 Initial revision
glantau
parents:
diff changeset
52 int avcodec_open(AVCodecContext *avctx, AVCodec *codec)
986e461dc072 Initial revision
glantau
parents:
diff changeset
53 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
54 int ret;
986e461dc072 Initial revision
glantau
parents:
diff changeset
55
986e461dc072 Initial revision
glantau
parents:
diff changeset
56 avctx->codec = codec;
986e461dc072 Initial revision
glantau
parents:
diff changeset
57 avctx->frame_number = 0;
374
02147e22f8c8 * Don't allocate 0 bytes of memory. It upsets electricFence!
philipjsg
parents: 362
diff changeset
58 if (codec->priv_data_size > 0) {
02147e22f8c8 * Don't allocate 0 bytes of memory. It upsets electricFence!
philipjsg
parents: 362
diff changeset
59 avctx->priv_data = av_mallocz(codec->priv_data_size);
02147e22f8c8 * Don't allocate 0 bytes of memory. It upsets electricFence!
philipjsg
parents: 362
diff changeset
60 if (!avctx->priv_data)
02147e22f8c8 * Don't allocate 0 bytes of memory. It upsets electricFence!
philipjsg
parents: 362
diff changeset
61 return -ENOMEM;
02147e22f8c8 * Don't allocate 0 bytes of memory. It upsets electricFence!
philipjsg
parents: 362
diff changeset
62 } else {
02147e22f8c8 * Don't allocate 0 bytes of memory. It upsets electricFence!
philipjsg
parents: 362
diff changeset
63 avctx->priv_data = NULL;
02147e22f8c8 * Don't allocate 0 bytes of memory. It upsets electricFence!
philipjsg
parents: 362
diff changeset
64 }
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
65 ret = avctx->codec->init(avctx);
986e461dc072 Initial revision
glantau
parents:
diff changeset
66 if (ret < 0) {
394
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
67 av_freep(&avctx->priv_data);
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
68 return ret;
986e461dc072 Initial revision
glantau
parents:
diff changeset
69 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
70 return 0;
986e461dc072 Initial revision
glantau
parents:
diff changeset
71 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
72
986e461dc072 Initial revision
glantau
parents:
diff changeset
73 int avcodec_encode_audio(AVCodecContext *avctx, UINT8 *buf, int buf_size,
986e461dc072 Initial revision
glantau
parents:
diff changeset
74 const short *samples)
986e461dc072 Initial revision
glantau
parents:
diff changeset
75 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
76 int ret;
986e461dc072 Initial revision
glantau
parents:
diff changeset
77
986e461dc072 Initial revision
glantau
parents:
diff changeset
78 ret = avctx->codec->encode(avctx, buf, buf_size, (void *)samples);
986e461dc072 Initial revision
glantau
parents:
diff changeset
79 avctx->frame_number++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
80 return ret;
986e461dc072 Initial revision
glantau
parents:
diff changeset
81 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
82
986e461dc072 Initial revision
glantau
parents:
diff changeset
83 int avcodec_encode_video(AVCodecContext *avctx, UINT8 *buf, int buf_size,
986e461dc072 Initial revision
glantau
parents:
diff changeset
84 const AVPicture *pict)
986e461dc072 Initial revision
glantau
parents:
diff changeset
85 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
86 int ret;
986e461dc072 Initial revision
glantau
parents:
diff changeset
87
986e461dc072 Initial revision
glantau
parents:
diff changeset
88 ret = avctx->codec->encode(avctx, buf, buf_size, (void *)pict);
986e461dc072 Initial revision
glantau
parents:
diff changeset
89 avctx->frame_number++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
90 return ret;
986e461dc072 Initial revision
glantau
parents:
diff changeset
91 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
92
986e461dc072 Initial revision
glantau
parents:
diff changeset
93 /* decode a frame. return -1 if error, otherwise return the number of
986e461dc072 Initial revision
glantau
parents:
diff changeset
94 bytes used. If no frame could be decompressed, *got_picture_ptr is
986e461dc072 Initial revision
glantau
parents:
diff changeset
95 zero. Otherwise, it is non zero */
986e461dc072 Initial revision
glantau
parents:
diff changeset
96 int avcodec_decode_video(AVCodecContext *avctx, AVPicture *picture,
986e461dc072 Initial revision
glantau
parents:
diff changeset
97 int *got_picture_ptr,
986e461dc072 Initial revision
glantau
parents:
diff changeset
98 UINT8 *buf, int buf_size)
986e461dc072 Initial revision
glantau
parents:
diff changeset
99 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
100 int ret;
986e461dc072 Initial revision
glantau
parents:
diff changeset
101
986e461dc072 Initial revision
glantau
parents:
diff changeset
102 ret = avctx->codec->decode(avctx, picture, got_picture_ptr,
986e461dc072 Initial revision
glantau
parents:
diff changeset
103 buf, buf_size);
267
e10840e4f773 - Bug fix MPEG-2 decoder to handle "repeat_first_field" (Telecine)
pulento
parents: 260
diff changeset
104 if (*got_picture_ptr)
e10840e4f773 - Bug fix MPEG-2 decoder to handle "repeat_first_field" (Telecine)
pulento
parents: 260
diff changeset
105 avctx->frame_number++;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
106 return ret;
986e461dc072 Initial revision
glantau
parents:
diff changeset
107 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
108
986e461dc072 Initial revision
glantau
parents:
diff changeset
109 /* decode an audio frame. return -1 if error, otherwise return the
986e461dc072 Initial revision
glantau
parents:
diff changeset
110 *number of bytes used. If no frame could be decompressed,
986e461dc072 Initial revision
glantau
parents:
diff changeset
111 *frame_size_ptr is zero. Otherwise, it is the decompressed frame
986e461dc072 Initial revision
glantau
parents:
diff changeset
112 *size in BYTES. */
986e461dc072 Initial revision
glantau
parents:
diff changeset
113 int avcodec_decode_audio(AVCodecContext *avctx, INT16 *samples,
986e461dc072 Initial revision
glantau
parents:
diff changeset
114 int *frame_size_ptr,
986e461dc072 Initial revision
glantau
parents:
diff changeset
115 UINT8 *buf, int buf_size)
986e461dc072 Initial revision
glantau
parents:
diff changeset
116 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
117 int ret;
986e461dc072 Initial revision
glantau
parents:
diff changeset
118
986e461dc072 Initial revision
glantau
parents:
diff changeset
119 ret = avctx->codec->decode(avctx, samples, frame_size_ptr,
986e461dc072 Initial revision
glantau
parents:
diff changeset
120 buf, buf_size);
986e461dc072 Initial revision
glantau
parents:
diff changeset
121 avctx->frame_number++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
122 return ret;
986e461dc072 Initial revision
glantau
parents:
diff changeset
123 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
124
986e461dc072 Initial revision
glantau
parents:
diff changeset
125 int avcodec_close(AVCodecContext *avctx)
986e461dc072 Initial revision
glantau
parents:
diff changeset
126 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
127 if (avctx->codec->close)
986e461dc072 Initial revision
glantau
parents:
diff changeset
128 avctx->codec->close(avctx);
394
e2cb8a4ee0c5 proper memory handling functions
glantau
parents: 379
diff changeset
129 av_freep(&avctx->priv_data);
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
130 avctx->codec = NULL;
986e461dc072 Initial revision
glantau
parents:
diff changeset
131 return 0;
986e461dc072 Initial revision
glantau
parents:
diff changeset
132 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
133
986e461dc072 Initial revision
glantau
parents:
diff changeset
134 AVCodec *avcodec_find_encoder(enum CodecID id)
986e461dc072 Initial revision
glantau
parents:
diff changeset
135 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
136 AVCodec *p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
137 p = first_avcodec;
986e461dc072 Initial revision
glantau
parents:
diff changeset
138 while (p) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
139 if (p->encode != NULL && p->id == id)
986e461dc072 Initial revision
glantau
parents:
diff changeset
140 return p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
141 p = p->next;
986e461dc072 Initial revision
glantau
parents:
diff changeset
142 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
143 return NULL;
986e461dc072 Initial revision
glantau
parents:
diff changeset
144 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
145
177
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
146 AVCodec *avcodec_find_encoder_by_name(const char *name)
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
147 {
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
148 AVCodec *p;
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
149 p = first_avcodec;
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
150 while (p) {
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
151 if (p->encode != NULL && strcmp(name,p->name) == 0)
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
152 return p;
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
153 p = p->next;
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
154 }
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
155 return NULL;
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
156 }
53da914d6f46 avcodec_find_encoder_by_name() patch by Alex
arpi_esp
parents: 94
diff changeset
157
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
158 AVCodec *avcodec_find_decoder(enum CodecID id)
986e461dc072 Initial revision
glantau
parents:
diff changeset
159 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
160 AVCodec *p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
161 p = first_avcodec;
986e461dc072 Initial revision
glantau
parents:
diff changeset
162 while (p) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
163 if (p->decode != NULL && p->id == id)
986e461dc072 Initial revision
glantau
parents:
diff changeset
164 return p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
165 p = p->next;
986e461dc072 Initial revision
glantau
parents:
diff changeset
166 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
167 return NULL;
986e461dc072 Initial revision
glantau
parents:
diff changeset
168 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
169
986e461dc072 Initial revision
glantau
parents:
diff changeset
170 AVCodec *avcodec_find_decoder_by_name(const char *name)
986e461dc072 Initial revision
glantau
parents:
diff changeset
171 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
172 AVCodec *p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
173 p = first_avcodec;
986e461dc072 Initial revision
glantau
parents:
diff changeset
174 while (p) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
175 if (p->decode != NULL && strcmp(name,p->name) == 0)
986e461dc072 Initial revision
glantau
parents:
diff changeset
176 return p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
177 p = p->next;
986e461dc072 Initial revision
glantau
parents:
diff changeset
178 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
179 return NULL;
986e461dc072 Initial revision
glantau
parents:
diff changeset
180 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
181
986e461dc072 Initial revision
glantau
parents:
diff changeset
182 AVCodec *avcodec_find(enum CodecID id)
986e461dc072 Initial revision
glantau
parents:
diff changeset
183 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
184 AVCodec *p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
185 p = first_avcodec;
986e461dc072 Initial revision
glantau
parents:
diff changeset
186 while (p) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
187 if (p->id == id)
986e461dc072 Initial revision
glantau
parents:
diff changeset
188 return p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
189 p = p->next;
986e461dc072 Initial revision
glantau
parents:
diff changeset
190 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
191 return NULL;
986e461dc072 Initial revision
glantau
parents:
diff changeset
192 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
193
55
6064342168f4 picture utils
glantau
parents: 24
diff changeset
194 const char *pix_fmt_str[] = {
315
40d8092e2ff0 * using pixtype as enum - by Philip Gladstone
kabi
parents: 311
diff changeset
195 "??",
55
6064342168f4 picture utils
glantau
parents: 24
diff changeset
196 "yuv420p",
6064342168f4 picture utils
glantau
parents: 24
diff changeset
197 "yuv422",
6064342168f4 picture utils
glantau
parents: 24
diff changeset
198 "rgb24",
6064342168f4 picture utils
glantau
parents: 24
diff changeset
199 "bgr24",
6064342168f4 picture utils
glantau
parents: 24
diff changeset
200 "yuv422p",
6064342168f4 picture utils
glantau
parents: 24
diff changeset
201 "yuv444p",
583
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
202 "rgba32",
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
203 "bgra32",
521
9c66b5183ab3 new codec: Sorenson v1
nickols_k
parents: 495
diff changeset
204 "yuv410p"
55
6064342168f4 picture utils
glantau
parents: 24
diff changeset
205 };
6064342168f4 picture utils
glantau
parents: 24
diff changeset
206
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
207 void avcodec_string(char *buf, int buf_size, AVCodecContext *enc, int encode)
986e461dc072 Initial revision
glantau
parents:
diff changeset
208 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
209 const char *codec_name;
986e461dc072 Initial revision
glantau
parents:
diff changeset
210 AVCodec *p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
211 char buf1[32];
337
8899c3b35b57 * using some small char buffer - needed for sprintf
kabi
parents: 322
diff changeset
212 char channels_str[100];
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
213 int bitrate;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
214
986e461dc072 Initial revision
glantau
parents:
diff changeset
215 if (encode)
986e461dc072 Initial revision
glantau
parents:
diff changeset
216 p = avcodec_find_encoder(enc->codec_id);
986e461dc072 Initial revision
glantau
parents:
diff changeset
217 else
986e461dc072 Initial revision
glantau
parents:
diff changeset
218 p = avcodec_find_decoder(enc->codec_id);
986e461dc072 Initial revision
glantau
parents:
diff changeset
219
986e461dc072 Initial revision
glantau
parents:
diff changeset
220 if (p) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
221 codec_name = p->name;
986e461dc072 Initial revision
glantau
parents:
diff changeset
222 } else if (enc->codec_name[0] != '\0') {
986e461dc072 Initial revision
glantau
parents:
diff changeset
223 codec_name = enc->codec_name;
986e461dc072 Initial revision
glantau
parents:
diff changeset
224 } else {
986e461dc072 Initial revision
glantau
parents:
diff changeset
225 /* output avi tags */
986e461dc072 Initial revision
glantau
parents:
diff changeset
226 if (enc->codec_type == CODEC_TYPE_VIDEO) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
227 snprintf(buf1, sizeof(buf1), "%c%c%c%c",
986e461dc072 Initial revision
glantau
parents:
diff changeset
228 enc->codec_tag & 0xff,
986e461dc072 Initial revision
glantau
parents:
diff changeset
229 (enc->codec_tag >> 8) & 0xff,
986e461dc072 Initial revision
glantau
parents:
diff changeset
230 (enc->codec_tag >> 16) & 0xff,
986e461dc072 Initial revision
glantau
parents:
diff changeset
231 (enc->codec_tag >> 24) & 0xff);
986e461dc072 Initial revision
glantau
parents:
diff changeset
232 } else {
986e461dc072 Initial revision
glantau
parents:
diff changeset
233 snprintf(buf1, sizeof(buf1), "0x%04x", enc->codec_tag);
986e461dc072 Initial revision
glantau
parents:
diff changeset
234 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
235 codec_name = buf1;
986e461dc072 Initial revision
glantau
parents:
diff changeset
236 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
237
986e461dc072 Initial revision
glantau
parents:
diff changeset
238 switch(enc->codec_type) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
239 case CODEC_TYPE_VIDEO:
986e461dc072 Initial revision
glantau
parents:
diff changeset
240 snprintf(buf, buf_size,
986e461dc072 Initial revision
glantau
parents:
diff changeset
241 "Video: %s%s",
986e461dc072 Initial revision
glantau
parents:
diff changeset
242 codec_name, enc->flags & CODEC_FLAG_HQ ? " (hq)" : "");
55
6064342168f4 picture utils
glantau
parents: 24
diff changeset
243 if (enc->codec_id == CODEC_ID_RAWVIDEO) {
6064342168f4 picture utils
glantau
parents: 24
diff changeset
244 snprintf(buf + strlen(buf), buf_size - strlen(buf),
6064342168f4 picture utils
glantau
parents: 24
diff changeset
245 ", %s",
6064342168f4 picture utils
glantau
parents: 24
diff changeset
246 pix_fmt_str[enc->pix_fmt]);
6064342168f4 picture utils
glantau
parents: 24
diff changeset
247 }
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
248 if (enc->width) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
249 snprintf(buf + strlen(buf), buf_size - strlen(buf),
986e461dc072 Initial revision
glantau
parents:
diff changeset
250 ", %dx%d, %0.2f fps",
986e461dc072 Initial revision
glantau
parents:
diff changeset
251 enc->width, enc->height,
986e461dc072 Initial revision
glantau
parents:
diff changeset
252 (float)enc->frame_rate / FRAME_RATE_BASE);
986e461dc072 Initial revision
glantau
parents:
diff changeset
253 }
315
40d8092e2ff0 * using pixtype as enum - by Philip Gladstone
kabi
parents: 311
diff changeset
254 snprintf(buf + strlen(buf), buf_size - strlen(buf),
40d8092e2ff0 * using pixtype as enum - by Philip Gladstone
kabi
parents: 311
diff changeset
255 ", q=%d-%d", enc->qmin, enc->qmax);
40d8092e2ff0 * using pixtype as enum - by Philip Gladstone
kabi
parents: 311
diff changeset
256
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
257 bitrate = enc->bit_rate;
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
258 break;
986e461dc072 Initial revision
glantau
parents:
diff changeset
259 case CODEC_TYPE_AUDIO:
986e461dc072 Initial revision
glantau
parents:
diff changeset
260 snprintf(buf, buf_size,
986e461dc072 Initial revision
glantau
parents:
diff changeset
261 "Audio: %s",
986e461dc072 Initial revision
glantau
parents:
diff changeset
262 codec_name);
318
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
263 switch (enc->channels) {
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
264 case 1:
337
8899c3b35b57 * using some small char buffer - needed for sprintf
kabi
parents: 322
diff changeset
265 strcpy(channels_str, "mono");
318
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
266 break;
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
267 case 2:
337
8899c3b35b57 * using some small char buffer - needed for sprintf
kabi
parents: 322
diff changeset
268 strcpy(channels_str, "stereo");
318
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
269 break;
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
270 case 6:
337
8899c3b35b57 * using some small char buffer - needed for sprintf
kabi
parents: 322
diff changeset
271 strcpy(channels_str, "5:1");
318
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
272 break;
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
273 default:
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
274 sprintf(channels_str, "%d channels", enc->channels);
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
275 break;
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
276 }
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
277 if (enc->sample_rate) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
278 snprintf(buf + strlen(buf), buf_size - strlen(buf),
986e461dc072 Initial revision
glantau
parents:
diff changeset
279 ", %d Hz, %s",
986e461dc072 Initial revision
glantau
parents:
diff changeset
280 enc->sample_rate,
318
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
281 channels_str);
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
282 }
318
21697f35a9ca - Fixed AC3 decoding for 5:1 AC3 streams. Now when calling av_audio_decode for
pulento
parents: 315
diff changeset
283
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
284 /* for PCM codecs, compute bitrate directly */
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
285 switch(enc->codec_id) {
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
286 case CODEC_ID_PCM_S16LE:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
287 case CODEC_ID_PCM_S16BE:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
288 case CODEC_ID_PCM_U16LE:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
289 case CODEC_ID_PCM_U16BE:
94
7e263a256a6f fixed pcm bitrate
glantau
parents: 92
diff changeset
290 bitrate = enc->sample_rate * enc->channels * 16;
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
291 break;
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
292 case CODEC_ID_PCM_S8:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
293 case CODEC_ID_PCM_U8:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
294 case CODEC_ID_PCM_ALAW:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
295 case CODEC_ID_PCM_MULAW:
94
7e263a256a6f fixed pcm bitrate
glantau
parents: 92
diff changeset
296 bitrate = enc->sample_rate * enc->channels * 8;
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
297 break;
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
298 default:
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
299 bitrate = enc->bit_rate;
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
300 break;
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
301 }
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
302 break;
986e461dc072 Initial revision
glantau
parents:
diff changeset
303 default:
583
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
304 av_abort();
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
305 }
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
306 if (bitrate != 0) {
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
307 snprintf(buf + strlen(buf), buf_size - strlen(buf),
92
1d3eb6cdc6b5 added pcm codecs
glantau
parents: 91
diff changeset
308 ", %d kb/s", bitrate / 1000);
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
309 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
310 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
311
55
6064342168f4 picture utils
glantau
parents: 24
diff changeset
312 /* Picture field are filled with 'ptr' addresses */
6064342168f4 picture utils
glantau
parents: 24
diff changeset
313 void avpicture_fill(AVPicture *picture, UINT8 *ptr,
6064342168f4 picture utils
glantau
parents: 24
diff changeset
314 int pix_fmt, int width, int height)
6064342168f4 picture utils
glantau
parents: 24
diff changeset
315 {
6064342168f4 picture utils
glantau
parents: 24
diff changeset
316 int size;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
317
6064342168f4 picture utils
glantau
parents: 24
diff changeset
318 size = width * height;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
319 switch(pix_fmt) {
6064342168f4 picture utils
glantau
parents: 24
diff changeset
320 case PIX_FMT_YUV420P:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
321 picture->data[0] = ptr;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
322 picture->data[1] = picture->data[0] + size;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
323 picture->data[2] = picture->data[1] + size / 4;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
324 picture->linesize[0] = width;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
325 picture->linesize[1] = width / 2;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
326 picture->linesize[2] = width / 2;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
327 break;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
328 case PIX_FMT_YUV422P:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
329 picture->data[0] = ptr;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
330 picture->data[1] = picture->data[0] + size;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
331 picture->data[2] = picture->data[1] + size / 2;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
332 picture->linesize[0] = width;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
333 picture->linesize[1] = width / 2;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
334 picture->linesize[2] = width / 2;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
335 break;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
336 case PIX_FMT_YUV444P:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
337 picture->data[0] = ptr;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
338 picture->data[1] = picture->data[0] + size;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
339 picture->data[2] = picture->data[1] + size;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
340 picture->linesize[0] = width;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
341 picture->linesize[1] = width;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
342 picture->linesize[2] = width;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
343 break;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
344 case PIX_FMT_RGB24:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
345 case PIX_FMT_BGR24:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
346 picture->data[0] = ptr;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
347 picture->data[1] = NULL;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
348 picture->data[2] = NULL;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
349 picture->linesize[0] = width * 3;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
350 break;
583
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
351 case PIX_FMT_RGBA32:
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
352 case PIX_FMT_BGRA32:
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
353 picture->data[0] = ptr;
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
354 picture->data[1] = NULL;
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
355 picture->data[2] = NULL;
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
356 picture->linesize[0] = width * 4;
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
357 break;
55
6064342168f4 picture utils
glantau
parents: 24
diff changeset
358 case PIX_FMT_YUV422:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
359 picture->data[0] = ptr;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
360 picture->data[1] = NULL;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
361 picture->data[2] = NULL;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
362 picture->linesize[0] = width * 2;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
363 break;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
364 default:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
365 picture->data[0] = NULL;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
366 picture->data[1] = NULL;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
367 picture->data[2] = NULL;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
368 break;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
369 }
6064342168f4 picture utils
glantau
parents: 24
diff changeset
370 }
6064342168f4 picture utils
glantau
parents: 24
diff changeset
371
6064342168f4 picture utils
glantau
parents: 24
diff changeset
372 int avpicture_get_size(int pix_fmt, int width, int height)
6064342168f4 picture utils
glantau
parents: 24
diff changeset
373 {
6064342168f4 picture utils
glantau
parents: 24
diff changeset
374 int size;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
375
6064342168f4 picture utils
glantau
parents: 24
diff changeset
376 size = width * height;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
377 switch(pix_fmt) {
6064342168f4 picture utils
glantau
parents: 24
diff changeset
378 case PIX_FMT_YUV420P:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
379 size = (size * 3) / 2;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
380 break;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
381 case PIX_FMT_YUV422P:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
382 size = (size * 2);
6064342168f4 picture utils
glantau
parents: 24
diff changeset
383 break;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
384 case PIX_FMT_YUV444P:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
385 size = (size * 3);
6064342168f4 picture utils
glantau
parents: 24
diff changeset
386 break;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
387 case PIX_FMT_RGB24:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
388 case PIX_FMT_BGR24:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
389 size = (size * 3);
6064342168f4 picture utils
glantau
parents: 24
diff changeset
390 break;
583
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
391 case PIX_FMT_RGBA32:
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
392 case PIX_FMT_BGRA32:
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
393 size = (size * 4);
d6955d0d7d27 Add conversions to and from RGBA32 and BGRA32.
philipjsg
parents: 521
diff changeset
394 break;
55
6064342168f4 picture utils
glantau
parents: 24
diff changeset
395 case PIX_FMT_YUV422:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
396 size = (size * 2);
6064342168f4 picture utils
glantau
parents: 24
diff changeset
397 break;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
398 default:
6064342168f4 picture utils
glantau
parents: 24
diff changeset
399 size = -1;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
400 break;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
401 }
6064342168f4 picture utils
glantau
parents: 24
diff changeset
402 return size;
6064342168f4 picture utils
glantau
parents: 24
diff changeset
403 }
6064342168f4 picture utils
glantau
parents: 24
diff changeset
404
362
1ee4ba4ca783 version info
nickols_k
parents: 341
diff changeset
405 unsigned avcodec_version( void )
1ee4ba4ca783 version info
nickols_k
parents: 341
diff changeset
406 {
1ee4ba4ca783 version info
nickols_k
parents: 341
diff changeset
407 return LIBAVCODEC_VERSION_INT;
1ee4ba4ca783 version info
nickols_k
parents: 341
diff changeset
408 }
55
6064342168f4 picture utils
glantau
parents: 24
diff changeset
409
379
47c878305986 build info for ABI
nickols_k
parents: 374
diff changeset
410 unsigned avcodec_build( void )
47c878305986 build info for ABI
nickols_k
parents: 374
diff changeset
411 {
47c878305986 build info for ABI
nickols_k
parents: 374
diff changeset
412 return LIBAVCODEC_BUILD;
47c878305986 build info for ABI
nickols_k
parents: 374
diff changeset
413 }
47c878305986 build info for ABI
nickols_k
parents: 374
diff changeset
414
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
415 /* must be called before any other functions */
986e461dc072 Initial revision
glantau
parents:
diff changeset
416 void avcodec_init(void)
986e461dc072 Initial revision
glantau
parents:
diff changeset
417 {
303
9a931fd8d06c multiple init bugfix (patch by Alex Beregszaszi <alex@naxine.org>)
michaelni
parents: 267
diff changeset
418 static int inited = 0;
9a931fd8d06c multiple init bugfix (patch by Alex Beregszaszi <alex@naxine.org>)
michaelni
parents: 267
diff changeset
419
9a931fd8d06c multiple init bugfix (patch by Alex Beregszaszi <alex@naxine.org>)
michaelni
parents: 267
diff changeset
420 if (inited != 0)
9a931fd8d06c multiple init bugfix (patch by Alex Beregszaszi <alex@naxine.org>)
michaelni
parents: 267
diff changeset
421 return;
9a931fd8d06c multiple init bugfix (patch by Alex Beregszaszi <alex@naxine.org>)
michaelni
parents: 267
diff changeset
422 inited = 1;
9a931fd8d06c multiple init bugfix (patch by Alex Beregszaszi <alex@naxine.org>)
michaelni
parents: 267
diff changeset
423
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
424 dsputil_init();
986e461dc072 Initial revision
glantau
parents:
diff changeset
425 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
426
341
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
427 /* this should be called after seeking and before trying to decode the next frame */
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
428 void avcodec_flush_buffers(AVCodecContext *avctx)
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
429 {
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
430 MpegEncContext *s = avctx->priv_data;
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
431 s->num_available_buffers=0;
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
432 }
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
433
bf26081c373c avcodec_flush_buffers()
michaelni
parents: 337
diff changeset
434
440
000aeeac27a2 * started to cleanup name clashes for onetime compilation
kabi
parents: 429
diff changeset
435 static int raw_encode_init(AVCodecContext *s)
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
436 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
437 return 0;
986e461dc072 Initial revision
glantau
parents:
diff changeset
438 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
439
440
000aeeac27a2 * started to cleanup name clashes for onetime compilation
kabi
parents: 429
diff changeset
440 static int raw_decode_frame(AVCodecContext *avctx,
000aeeac27a2 * started to cleanup name clashes for onetime compilation
kabi
parents: 429
diff changeset
441 void *data, int *data_size,
000aeeac27a2 * started to cleanup name clashes for onetime compilation
kabi
parents: 429
diff changeset
442 UINT8 *buf, int buf_size)
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
443 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
444 return -1;
986e461dc072 Initial revision
glantau
parents:
diff changeset
445 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
446
440
000aeeac27a2 * started to cleanup name clashes for onetime compilation
kabi
parents: 429
diff changeset
447 static int raw_encode_frame(AVCodecContext *avctx,
000aeeac27a2 * started to cleanup name clashes for onetime compilation
kabi
parents: 429
diff changeset
448 unsigned char *frame, int buf_size, void *data)
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
449 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
450 return -1;
986e461dc072 Initial revision
glantau
parents:
diff changeset
451 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
452
986e461dc072 Initial revision
glantau
parents:
diff changeset
453 AVCodec rawvideo_codec = {
986e461dc072 Initial revision
glantau
parents:
diff changeset
454 "rawvideo",
986e461dc072 Initial revision
glantau
parents:
diff changeset
455 CODEC_TYPE_VIDEO,
986e461dc072 Initial revision
glantau
parents:
diff changeset
456 CODEC_ID_RAWVIDEO,
986e461dc072 Initial revision
glantau
parents:
diff changeset
457 0,
440
000aeeac27a2 * started to cleanup name clashes for onetime compilation
kabi
parents: 429
diff changeset
458 raw_encode_init,
000aeeac27a2 * started to cleanup name clashes for onetime compilation
kabi
parents: 429
diff changeset
459 raw_encode_frame,
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
460 NULL,
440
000aeeac27a2 * started to cleanup name clashes for onetime compilation
kabi
parents: 429
diff changeset
461 raw_decode_frame,
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
462 };