Mercurial > libavcodec.hg
annotate qpeg.c @ 12379:2ea2fd28da07 libavcodec
Split h264dsp and h264pred in configure.
Many H.264 derivatives, like RV40 and VP8, use the H.264 prediction functions
but not the weight/loopfilter functions.
This should reduce the size of builds with one of these derivatives but without
H.264 decoding itself.
| author | darkshikari |
|---|---|
| date | Sat, 07 Aug 2010 23:10:25 +0000 |
| parents | 7dd2a45249a9 |
| children |
| rev | line source |
|---|---|
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
1 /* |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
2 * QPEG codec |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
3 * Copyright (c) 2004 Konstantin Shishkov |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
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 |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
8 * modify it under the terms of the GNU Lesser General Public |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
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. |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
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, |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
15 * Lesser General Public License for more details. |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
16 * |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
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:
2979
diff
changeset
|
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
20 */ |
| 2967 | 21 |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
22 /** |
|
11644
7dd2a45249a9
Remove explicit filename from Doxygen @file commands.
diego
parents:
11560
diff
changeset
|
23 * @file |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
24 * QPEG codec. |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
25 */ |
| 2967 | 26 |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
27 #include "avcodec.h" |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
28 |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
29 typedef struct QpegContext{ |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
30 AVCodecContext *avctx; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
31 AVFrame pic; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
32 uint8_t *refdata; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
33 } QpegContext; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
34 |
| 6274 | 35 static void qpeg_decode_intra(const uint8_t *src, uint8_t *dst, int size, |
| 2979 | 36 int stride, int width, int height) |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
37 { |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
38 int i; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
39 int code; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
40 int c0, c1; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
41 int run, copy; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
42 int filled = 0; |
| 2823 | 43 int rows_to_go; |
| 2967 | 44 |
| 2823 | 45 rows_to_go = height; |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
46 height--; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
47 dst = dst + height * stride; |
| 2967 | 48 |
| 2823 | 49 while((size > 0) && (rows_to_go > 0)) { |
| 2979 | 50 code = *src++; |
| 51 size--; | |
| 52 run = copy = 0; | |
| 53 if(code == 0xFC) /* end-of-picture code */ | |
| 54 break; | |
| 55 if(code >= 0xF8) { /* very long run */ | |
| 56 c0 = *src++; | |
| 57 c1 = *src++; | |
| 58 size -= 2; | |
| 59 run = ((code & 0x7) << 16) + (c0 << 8) + c1 + 2; | |
| 60 } else if (code >= 0xF0) { /* long run */ | |
| 61 c0 = *src++; | |
| 62 size--; | |
| 63 run = ((code & 0xF) << 8) + c0 + 2; | |
| 64 } else if (code >= 0xE0) { /* short run */ | |
| 65 run = (code & 0x1F) + 2; | |
| 66 } else if (code >= 0xC0) { /* very long copy */ | |
| 67 c0 = *src++; | |
| 68 c1 = *src++; | |
| 69 size -= 2; | |
| 70 copy = ((code & 0x3F) << 16) + (c0 << 8) + c1 + 1; | |
| 71 } else if (code >= 0x80) { /* long copy */ | |
| 72 c0 = *src++; | |
| 73 size--; | |
| 74 copy = ((code & 0x7F) << 8) + c0 + 1; | |
| 75 } else { /* short copy */ | |
| 76 copy = code + 1; | |
| 77 } | |
| 2967 | 78 |
| 2979 | 79 /* perform actual run or copy */ |
| 80 if(run) { | |
| 81 int p; | |
| 2967 | 82 |
| 2979 | 83 p = *src++; |
| 84 size--; | |
| 85 for(i = 0; i < run; i++) { | |
| 86 dst[filled++] = p; | |
| 87 if (filled >= width) { | |
| 88 filled = 0; | |
| 89 dst -= stride; | |
| 2823 | 90 rows_to_go--; |
| 91 if(rows_to_go <= 0) | |
| 92 break; | |
| 2979 | 93 } |
| 94 } | |
| 95 } else { | |
| 2823 | 96 size -= copy; |
| 2979 | 97 for(i = 0; i < copy; i++) { |
| 98 dst[filled++] = *src++; | |
| 99 if (filled >= width) { | |
| 100 filled = 0; | |
| 101 dst -= stride; | |
| 2823 | 102 rows_to_go--; |
| 103 if(rows_to_go <= 0) | |
| 104 break; | |
| 2979 | 105 } |
| 106 } | |
| 107 } | |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
108 } |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
109 } |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
110 |
| 7129 | 111 static const int qpeg_table_h[16] = |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
112 { 0x00, 0x20, 0x20, 0x20, 0x18, 0x10, 0x10, 0x20, 0x10, 0x08, 0x18, 0x08, 0x08, 0x18, 0x10, 0x04}; |
| 7129 | 113 static const int qpeg_table_w[16] = |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
114 { 0x00, 0x20, 0x18, 0x08, 0x18, 0x10, 0x20, 0x10, 0x08, 0x10, 0x20, 0x20, 0x08, 0x10, 0x18, 0x04}; |
| 2967 | 115 |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
116 /* Decodes delta frames */ |
| 6274 | 117 static void qpeg_decode_inter(const uint8_t *src, uint8_t *dst, int size, |
| 2979 | 118 int stride, int width, int height, |
| 6276 | 119 int delta, const uint8_t *ctable, uint8_t *refdata) |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
120 { |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
121 int i, j; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
122 int code; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
123 int filled = 0; |
| 2823 | 124 int orig_height; |
| 2967 | 125 |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
126 /* copy prev frame */ |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
127 for(i = 0; i < height; i++) |
| 2979 | 128 memcpy(refdata + (i * width), dst + (i * stride), width); |
| 2967 | 129 |
| 2823 | 130 orig_height = height; |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
131 height--; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
132 dst = dst + height * stride; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
133 |
| 2823 | 134 while((size > 0) && (height >= 0)) { |
| 2979 | 135 code = *src++; |
| 136 size--; | |
| 2967 | 137 |
| 2979 | 138 if(delta) { |
| 139 /* motion compensation */ | |
| 140 while((code & 0xF0) == 0xF0) { | |
| 141 if(delta == 1) { | |
| 142 int me_idx; | |
| 143 int me_w, me_h, me_x, me_y; | |
| 144 uint8_t *me_plane; | |
| 145 int corr, val; | |
| 2967 | 146 |
| 2979 | 147 /* get block size by index */ |
| 148 me_idx = code & 0xF; | |
| 149 me_w = qpeg_table_w[me_idx]; | |
| 150 me_h = qpeg_table_h[me_idx]; | |
| 2967 | 151 |
| 2979 | 152 /* extract motion vector */ |
| 153 corr = *src++; | |
| 154 size--; | |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
155 |
| 2979 | 156 val = corr >> 4; |
| 157 if(val > 7) | |
| 158 val -= 16; | |
| 159 me_x = val; | |
| 2967 | 160 |
| 2979 | 161 val = corr & 0xF; |
| 162 if(val > 7) | |
| 163 val -= 16; | |
| 164 me_y = val; | |
| 2967 | 165 |
| 2823 | 166 /* check motion vector */ |
| 167 if ((me_x + filled < 0) || (me_x + me_w + filled > width) || | |
| 168 (height - me_y - me_h < 0) || (height - me_y > orig_height) || | |
| 169 (filled + me_w > width) || (height - me_h < 0)) | |
| 170 av_log(NULL, AV_LOG_ERROR, "Bogus motion vector (%i,%i), block size %ix%i at %i,%i\n", | |
| 171 me_x, me_y, me_w, me_h, filled, height); | |
| 172 else { | |
| 173 /* do motion compensation */ | |
| 174 me_plane = refdata + (filled + me_x) + (height - me_y) * width; | |
| 175 for(j = 0; j < me_h; j++) { | |
| 176 for(i = 0; i < me_w; i++) | |
| 177 dst[filled + i - (j * stride)] = me_plane[i - (j * width)]; | |
| 178 } | |
| 2979 | 179 } |
| 180 } | |
| 181 code = *src++; | |
| 182 size--; | |
| 183 } | |
| 184 } | |
| 2967 | 185 |
| 2979 | 186 if(code == 0xE0) /* end-of-picture code */ |
| 187 break; | |
| 188 if(code > 0xE0) { /* run code: 0xE1..0xFF */ | |
| 189 int p; | |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
190 |
| 2979 | 191 code &= 0x1F; |
| 192 p = *src++; | |
| 193 size--; | |
| 194 for(i = 0; i <= code; i++) { | |
| 195 dst[filled++] = p; | |
| 196 if(filled >= width) { | |
| 197 filled = 0; | |
| 198 dst -= stride; | |
| 199 height--; | |
| 200 } | |
| 201 } | |
| 202 } else if(code >= 0xC0) { /* copy code: 0xC0..0xDF */ | |
| 203 code &= 0x1F; | |
| 2967 | 204 |
| 2979 | 205 for(i = 0; i <= code; i++) { |
| 206 dst[filled++] = *src++; | |
| 207 if(filled >= width) { | |
| 208 filled = 0; | |
| 209 dst -= stride; | |
| 210 height--; | |
| 211 } | |
| 212 } | |
| 213 size -= code + 1; | |
| 214 } else if(code >= 0x80) { /* skip code: 0x80..0xBF */ | |
| 215 int skip; | |
| 2967 | 216 |
| 2979 | 217 code &= 0x3F; |
| 218 /* codes 0x80 and 0x81 are actually escape codes, | |
| 219 skip value minus constant is in the next byte */ | |
| 220 if(!code) | |
| 221 skip = (*src++) + 64; | |
| 222 else if(code == 1) | |
| 223 skip = (*src++) + 320; | |
| 224 else | |
| 225 skip = code; | |
| 226 filled += skip; | |
| 227 while( filled >= width) { | |
| 228 filled -= width; | |
| 229 dst -= stride; | |
| 230 height--; | |
| 2823 | 231 if(height < 0) |
| 232 break; | |
| 2979 | 233 } |
| 234 } else { | |
| 235 /* zero code treated as one-pixel skip */ | |
| 236 if(code) | |
| 237 dst[filled++] = ctable[code & 0x7F]; | |
| 238 else | |
| 239 filled++; | |
| 240 if(filled >= width) { | |
| 241 filled = 0; | |
| 242 dst -= stride; | |
| 243 height--; | |
| 244 } | |
| 245 } | |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
246 } |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
247 } |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
248 |
| 2967 | 249 static int decode_frame(AVCodecContext *avctx, |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
250 void *data, int *data_size, |
|
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
8718
diff
changeset
|
251 AVPacket *avpkt) |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
252 { |
|
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
8718
diff
changeset
|
253 const uint8_t *buf = avpkt->data; |
|
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
8718
diff
changeset
|
254 int buf_size = avpkt->size; |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
255 QpegContext * const a = avctx->priv_data; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
256 AVFrame * const p= (AVFrame*)&a->pic; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
257 uint8_t* outdata; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
258 int delta; |
| 2967 | 259 |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
260 if(p->data[0]) |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
261 avctx->release_buffer(avctx, p); |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
262 |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
263 p->reference= 0; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
264 if(avctx->get_buffer(avctx, p) < 0){ |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
265 av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n"); |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
266 return -1; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
267 } |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
268 outdata = a->pic.data[0]; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
269 if(buf[0x85] == 0x10) { |
| 2979 | 270 qpeg_decode_intra(buf+0x86, outdata, buf_size - 0x86, a->pic.linesize[0], avctx->width, avctx->height); |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
271 } else { |
| 2979 | 272 delta = buf[0x85]; |
| 273 qpeg_decode_inter(buf+0x86, outdata, buf_size - 0x86, a->pic.linesize[0], avctx->width, avctx->height, delta, buf + 4, a->refdata); | |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
274 } |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
275 |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
276 /* make the palette available on the way out */ |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
277 memcpy(a->pic.data[1], a->avctx->palctrl->palette, AVPALETTE_SIZE); |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
278 if (a->avctx->palctrl->palette_changed) { |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
279 a->pic.palette_has_changed = 1; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
280 a->avctx->palctrl->palette_changed = 0; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
281 } |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
282 |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
283 *data_size = sizeof(AVFrame); |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
284 *(AVFrame*)data = a->pic; |
| 2967 | 285 |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
286 return buf_size; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
287 } |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
288 |
|
6517
48759bfbd073
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
6450
diff
changeset
|
289 static av_cold int decode_init(AVCodecContext *avctx){ |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
290 QpegContext * const a = avctx->priv_data; |
| 2967 | 291 |
|
9918
de14016e0b2d
Check that palctrl is available on init instead of crashing when trying to use
reimar
parents:
9553
diff
changeset
|
292 if (!avctx->palctrl) { |
|
de14016e0b2d
Check that palctrl is available on init instead of crashing when trying to use
reimar
parents:
9553
diff
changeset
|
293 av_log(avctx, AV_LOG_FATAL, "Missing required palette via palctrl\n"); |
|
de14016e0b2d
Check that palctrl is available on init instead of crashing when trying to use
reimar
parents:
9553
diff
changeset
|
294 return -1; |
|
de14016e0b2d
Check that palctrl is available on init instead of crashing when trying to use
reimar
parents:
9553
diff
changeset
|
295 } |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
296 a->avctx = avctx; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
297 avctx->pix_fmt= PIX_FMT_PAL8; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
298 a->refdata = av_malloc(avctx->width * avctx->height); |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
299 |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
300 return 0; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
301 } |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
302 |
|
6517
48759bfbd073
Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents:
6450
diff
changeset
|
303 static av_cold int decode_end(AVCodecContext *avctx){ |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
304 QpegContext * const a = avctx->priv_data; |
| 2586 | 305 AVFrame * const p= (AVFrame*)&a->pic; |
| 2967 | 306 |
| 2586 | 307 if(p->data[0]) |
| 308 avctx->release_buffer(avctx, p); | |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
309 |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
310 av_free(a->refdata); |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
311 return 0; |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
312 } |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
313 |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
314 AVCodec qpeg_decoder = { |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
315 "qpeg", |
|
11560
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
9918
diff
changeset
|
316 AVMEDIA_TYPE_VIDEO, |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
317 CODEC_ID_QPEG, |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
318 sizeof(QpegContext), |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
319 decode_init, |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
320 NULL, |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
321 decode_end, |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
322 decode_frame, |
|
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
323 CODEC_CAP_DR1, |
|
7040
e943e1409077
Make AVCodec long_names definition conditional depending on CONFIG_SMALL.
stefano
parents:
6710
diff
changeset
|
324 .long_name = NULL_IF_CONFIG_SMALL("Q-team QPEG"), |
|
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
diff
changeset
|
325 }; |
