2 * RAW Ingenient MJPEG demuxer
3 * Copyright (c) 2005 Alex Beregszaszi
5 * This file is part of Libav.
7 * Libav is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
12 * Libav is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with Libav; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
25 // http://www.artificis.hu/files/texts/ingenient.txt
26 static int ingenient_read_packet(AVFormatContext
*s
, AVPacket
*pkt
)
28 int ret
, size
, w
, h
, unk1
, unk2
;
30 if (avio_rl32(s
->pb
) != MKTAG('M', 'J', 'P', 'G'))
31 return AVERROR(EIO
); // FIXME
33 size
= avio_rl32(s
->pb
);
38 avio_skip(s
->pb
, 8); // zero + size (padded?)
40 unk1
= avio_rl16(s
->pb
);
41 unk2
= avio_rl16(s
->pb
);
42 avio_skip(s
->pb
, 22); // ASCII timestamp
44 av_log(s
, AV_LOG_DEBUG
, "Ingenient packet: size=%d, width=%d, height=%d, unk1=%d unk2=%d\n",
45 size
, w
, h
, unk1
, unk2
);
47 if (av_new_packet(pkt
, size
) < 0)
48 return AVERROR(ENOMEM
);
50 pkt
->pos
= avio_tell(s
->pb
);
51 pkt
->stream_index
= 0;
52 ret
= avio_read(s
->pb
, pkt
->data
, size
);
61 FF_RAWVIDEO_DEMUXER_CLASS(ingenient
)
63 AVInputFormat ff_ingenient_demuxer
= {
65 .long_name
= NULL_IF_CONFIG_SMALL("raw Ingenient MJPEG"),
66 .priv_data_size
= sizeof(FFRawVideoDemuxerContext
),
67 .read_header
= ff_raw_video_read_header
,
68 .read_packet
= ingenient_read_packet
,
69 .flags
= AVFMT_GENERIC_INDEX
,
70 .extensions
= "cgi", // FIXME
71 .raw_codec_id
= AV_CODEC_ID_MJPEG
,
72 .priv_class
= &ingenient_demuxer_class
,