annotate rl2.c @ 12530:63edd10ad4bc libavcodec tip

Try to fix crashes introduced by r25218 r25218 made assumptions about the existence of past reference frames that weren't necessarily true.
author darkshikari
date Tue, 28 Sep 2010 09:06:22 +0000
parents 9cfc564bc3e6
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6523
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
1 /*
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
2 * RL2 Video Decoder
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
3 * Copyright (C) 2008 Sascha Sommer (saschasommer@freenet.de)
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
4 *
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
5 * This file is part of FFmpeg.
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
6 *
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
11 *
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
15 * Lesser General Public License for more details.
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
16 *
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
20 */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
21
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
22 /**
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
23 * RL2 Video Decoder
11644
7dd2a45249a9 Remove explicit filename from Doxygen @file commands.
diego
parents: 11560
diff changeset
24 * @file
6523
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
25 * @author Sascha Sommer (saschasommer@freenet.de)
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
26 * For more information about the RL2 format, visit:
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
27 * http://wiki.multimedia.cx/index.php?title=RL2
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
28 */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
29
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
30 #include <stdio.h>
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
31 #include <stdlib.h>
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
32 #include <string.h>
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
33
8573
2acf0ae7b041 Fix build: Add intreadwrite.h and bswap.h #includes where necessary.
diego
parents: 7040
diff changeset
34 #include "libavutil/intreadwrite.h"
6523
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
35 #include "avcodec.h"
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
36
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
37
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
38 #define EXTRADATA1_SIZE (6 + 256 * 3) ///< video base, clr count, palette
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
39
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
40 typedef struct Rl2Context {
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
41 AVCodecContext *avctx;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
42 AVFrame frame;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
43
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
44 unsigned short video_base; ///< initial drawing offset
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
45 unsigned int clr_count; ///< number of used colors (currently unused)
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
46 unsigned char* back_frame; ///< background frame
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
47 unsigned int palette[AVPALETTE_COUNT];
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
48 } Rl2Context;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
49
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
50 /**
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
51 * Run Length Decode a single 320x200 frame
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
52 * @param s rl2 context
12056
25e9cb2b9477 Fix misspelled parameter names in Doxygen documentation.
diego
parents: 11644
diff changeset
53 * @param in input buffer
6523
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
54 * @param size input buffer size
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
55 * @param out ouput buffer
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
56 * @param stride stride of the output buffer
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
57 * @param video_base offset of the rle data inside the frame
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
58 */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
59 static void rl2_rle_decode(Rl2Context *s,const unsigned char* in,int size,
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
60 unsigned char* out,int stride,int video_base){
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
61 int base_x = video_base % s->avctx->width;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
62 int base_y = video_base / s->avctx->width;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
63 int stride_adj = stride - s->avctx->width;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
64 int i;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
65 const unsigned char* back_frame = s->back_frame;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
66 const unsigned char* in_end = in + size;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
67 const unsigned char* out_end = out + stride * s->avctx->height;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
68 unsigned char* line_end = out + s->avctx->width;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
69
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
70 /** copy start of the background frame */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
71 for(i=0;i<=base_y;i++){
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
72 if(s->back_frame)
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
73 memcpy(out,back_frame,s->avctx->width);
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
74 out += stride;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
75 back_frame += s->avctx->width;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
76 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
77 back_frame += base_x - s->avctx->width;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
78 line_end = out - stride_adj;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
79 out += base_x - stride;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
80
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
81 /** decode the variable part of the frame */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
82 while(in < in_end){
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
83 unsigned char val = *in++;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
84 int len = 1;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
85 if(val >= 0x80){
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
86 if(in >= in_end)
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
87 break;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
88 len = *in++;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
89 if(!len)
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
90 break;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
91 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
92
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
93 if(len >= out_end - out)
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
94 break;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
95
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
96 if(s->back_frame)
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
97 val |= 0x80;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
98 else
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
99 val &= ~0x80;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
100
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
101 while(len--){
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
102 *out++ = (val == 0x80)? *back_frame:val;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
103 back_frame++;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
104 if(out == line_end){
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
105 out += stride_adj;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
106 line_end += stride;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
107 if(len >= out_end - out)
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
108 break;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
109 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
110 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
111 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
112
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
113 /** copy the rest from the background frame */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
114 if(s->back_frame){
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
115 while(out < out_end){
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
116 memcpy(out, back_frame, line_end - out);
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
117 back_frame += line_end - out;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
118 out = line_end + stride_adj;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
119 line_end += stride;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
120 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
121 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
122 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
123
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
124
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
125 /**
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
126 * Initialize the decoder
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
127 * @param avctx decoder context
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
128 * @return 0 success, -1 on error
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
129 */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
130 static av_cold int rl2_decode_init(AVCodecContext *avctx)
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
131 {
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
132 Rl2Context *s = avctx->priv_data;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
133 int back_size;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
134 int i;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
135 s->avctx = avctx;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
136 avctx->pix_fmt = PIX_FMT_PAL8;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
137
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
138 /** parse extra data */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
139 if(!avctx->extradata || avctx->extradata_size < EXTRADATA1_SIZE){
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
140 av_log(avctx, AV_LOG_ERROR, "invalid extradata size\n");
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
141 return -1;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
142 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
143
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
144 /** get frame_offset */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
145 s->video_base = AV_RL16(&avctx->extradata[0]);
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
146 s->clr_count = AV_RL32(&avctx->extradata[2]);
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
147
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
148 if(s->video_base >= avctx->width * avctx->height){
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
149 av_log(avctx, AV_LOG_ERROR, "invalid video_base\n");
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
150 return -1;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
151 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
152
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
153 /** initialize palette */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
154 for(i=0;i<AVPALETTE_COUNT;i++)
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
155 s->palette[i] = AV_RB24(&avctx->extradata[6 + i * 3]);
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
156
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
157 /** decode background frame if present */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
158 back_size = avctx->extradata_size - EXTRADATA1_SIZE;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
159
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
160 if(back_size > 0){
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
161 unsigned char* back_frame = av_mallocz(avctx->width*avctx->height);
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
162 if(!back_frame)
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
163 return -1;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
164 rl2_rle_decode(s,avctx->extradata + EXTRADATA1_SIZE,back_size,
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
165 back_frame,avctx->width,0);
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
166 s->back_frame = back_frame;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
167 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
168 return 0;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
169 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
170
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
171
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
172 static int rl2_decode_frame(AVCodecContext *avctx,
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
173 void *data, int *data_size,
9355
54bc8a2727b0 Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents: 8718
diff changeset
174 AVPacket *avpkt)
6523
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
175 {
9355
54bc8a2727b0 Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents: 8718
diff changeset
176 const uint8_t *buf = avpkt->data;
54bc8a2727b0 Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents: 8718
diff changeset
177 int buf_size = avpkt->size;
6523
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
178 Rl2Context *s = avctx->priv_data;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
179
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
180 if(s->frame.data[0])
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
181 avctx->release_buffer(avctx, &s->frame);
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
182
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
183 /** get buffer */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
184 s->frame.reference= 0;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
185 if(avctx->get_buffer(avctx, &s->frame)) {
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
186 av_log(s->avctx, AV_LOG_ERROR, "get_buffer() failed\n");
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
187 return -1;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
188 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
189
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
190 /** run length decode */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
191 rl2_rle_decode(s,buf,buf_size,s->frame.data[0],s->frame.linesize[0],s->video_base);
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
192
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
193 /** make the palette available on the way out */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
194 memcpy(s->frame.data[1], s->palette, AVPALETTE_SIZE);
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
195
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
196 *data_size = sizeof(AVFrame);
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
197 *(AVFrame*)data = s->frame;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
198
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
199 /** report that the buffer was completely consumed */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
200 return buf_size;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
201 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
202
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
203
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
204 /**
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
205 * Uninit decoder
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
206 * @param avctx decoder context
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
207 * @return 0 success, -1 on error
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
208 */
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
209 static av_cold int rl2_decode_end(AVCodecContext *avctx)
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
210 {
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
211 Rl2Context *s = avctx->priv_data;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
212
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
213 if(s->frame.data[0])
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
214 avctx->release_buffer(avctx, &s->frame);
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
215
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
216 av_free(s->back_frame);
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
217
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
218 return 0;
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
219 }
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
220
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
221
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
222 AVCodec rl2_decoder = {
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
223 "rl2",
11560
8a4984c5cacc Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents: 9981
diff changeset
224 AVMEDIA_TYPE_VIDEO,
6523
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
225 CODEC_ID_RL2,
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
226 sizeof(Rl2Context),
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
227 rl2_decode_init,
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
228 NULL,
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
229 rl2_decode_end,
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
230 rl2_decode_frame,
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
231 CODEC_CAP_DR1,
7040
e943e1409077 Make AVCodec long_names definition conditional depending on CONFIG_SMALL.
stefano
parents: 6712
diff changeset
232 .long_name = NULL_IF_CONFIG_SMALL("RL2 video"),
6523
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
233 };
ae19192241c4 rl2 decoder
faust3
parents:
diff changeset
234