annotate ptx.c @ 7855:9a135b6a1dc7 libavcodec

Correct order of parsing for pulse scalefactor band and offset to match the specification. Patch by Alex Converse (alex converse gmail com)
author superdump
date Sat, 13 Sep 2008 18:47:43 +0000
parents e943e1409077
children 2acf0ae7b041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
4884
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
1 /*
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
2 * V.Flash PTX (.ptx) image decoder
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
3 * Copyright (c) 2007 Ivo van Poorten
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
4 *
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
5 * This file is part of FFmpeg.
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
6 *
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
11 *
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
15 * Lesser General Public License for more details.
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
16 *
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
20 */
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
21
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
22 #include "avcodec.h"
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
23
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
24 typedef struct PTXContext {
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
25 AVFrame picture;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
26 } PTXContext;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
27
6517
48759bfbd073 Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents: 6246
diff changeset
28 static av_cold int ptx_init(AVCodecContext *avctx) {
4884
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
29 PTXContext *s = avctx->priv_data;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
30
6070
4acd7b248bb8 remove useless casts
ivo
parents: 5520
diff changeset
31 avcodec_get_frame_defaults(&s->picture);
4acd7b248bb8 remove useless casts
ivo
parents: 5520
diff changeset
32 avctx->coded_frame= &s->picture;
4884
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
33
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
34 return 0;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
35 }
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
36
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
37 static int ptx_decode_frame(AVCodecContext *avctx, void *data, int *data_size,
6246
michael
parents: 6075
diff changeset
38 const uint8_t *buf, int buf_size) {
4884
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
39 PTXContext * const s = avctx->priv_data;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
40 AVFrame *picture = data;
6075
4d43f2e3aaa5 remove useless cast
ivo
parents: 6071
diff changeset
41 AVFrame * const p = &s->picture;
4884
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
42 unsigned int offset, w, h, y, stride, bytes_per_pixel;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
43 uint8_t *ptr;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
44
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
45 offset = AV_RL16(buf);
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
46 w = AV_RL16(buf+8);
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
47 h = AV_RL16(buf+10);
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
48 bytes_per_pixel = AV_RL16(buf+12) >> 3;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
49
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
50 if (bytes_per_pixel != 2) {
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
51 av_log(avctx, AV_LOG_ERROR, "image format is not rgb15, please report on ffmpeg-users mailing list\n");
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
52 return -1;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
53 }
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
54
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
55 avctx->pix_fmt = PIX_FMT_RGB555;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
56
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
57 if (offset != 0x2c)
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
58 av_log(avctx, AV_LOG_WARNING, "offset != 0x2c, untested due to lack of sample files\n");
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
59
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
60 buf += offset;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
61
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
62 if (p->data[0])
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
63 avctx->release_buffer(avctx, p);
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
64
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
65 if (avcodec_check_dimensions(avctx, w, h))
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
66 return -1;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
67 if (w != avctx->width || h != avctx->height)
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
68 avcodec_set_dimensions(avctx, w, h);
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
69 if (avctx->get_buffer(avctx, p) < 0) {
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
70 av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
71 return -1;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
72 }
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
73
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
74 p->pict_type = FF_I_TYPE;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
75
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
76 ptr = p->data[0];
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
77 stride = p->linesize[0];
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
78
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
79 for (y=0; y<h; y++) {
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
80 #ifdef WORDS_BIGENDIAN
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
81 unsigned int x;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
82 for (x=0; x<w*bytes_per_pixel; x+=bytes_per_pixel)
5520
c16a59ef6a86 * renaming (ST|LD)(16|32|64) -> AV_(R|W)N(16|32|64)
romansh
parents: 5215
diff changeset
83 AV_WN16(ptr+x, AV_RL16(buf+x));
4884
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
84 #else
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
85 memcpy(ptr, buf, w*bytes_per_pixel);
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
86 #endif
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
87 ptr += stride;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
88 buf += w*bytes_per_pixel;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
89 }
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
90
6070
4acd7b248bb8 remove useless casts
ivo
parents: 5520
diff changeset
91 *picture = s->picture;
4884
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
92 *data_size = sizeof(AVPicture);
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
93
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
94 return offset + w*h*bytes_per_pixel;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
95 }
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
96
6517
48759bfbd073 Apply 'cold' attribute to init/uninit functions in libavcodec
zuxy
parents: 6246
diff changeset
97 static av_cold int ptx_end(AVCodecContext *avctx) {
4884
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
98 PTXContext *s = avctx->priv_data;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
99
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
100 if(s->picture.data[0])
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
101 avctx->release_buffer(avctx, &s->picture);
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
102
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
103 return 0;
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
104 }
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
105
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
106 AVCodec ptx_decoder = {
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
107 "ptx",
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
108 CODEC_TYPE_VIDEO,
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
109 CODEC_ID_PTX,
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
110 sizeof(PTXContext),
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
111 ptx_init,
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
112 NULL,
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
113 ptx_end,
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
114 ptx_decode_frame,
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
115 0,
6722
6eeb19edcee3 Add long names to some AVCodec declarations.
diego
parents: 6517
diff changeset
116 NULL,
7040
e943e1409077 Make AVCodec long_names definition conditional depending on CONFIG_SMALL.
stefano
parents: 6722
diff changeset
117 .long_name = NULL_IF_CONFIG_SMALL("V.Flash PTX image"),
4884
b23051d2a676 add V.Flash PTX decoder
ivo
parents:
diff changeset
118 };