Mercurial > libavformat.hg
annotate raw.c @ 2210:dbcfc6a4c016 libavformat
remove empty write trailer functions
patch by Vitor: [vitor1001 gmail com]
| author | benoit |
|---|---|
| date | Wed, 27 Jun 2007 06:54:47 +0000 |
| parents | 3804e39efbfd |
| children | fbaec5e545d2 |
| rev | line source |
|---|---|
| 885 | 1 /* |
|
1415
3b00fb8ef8e4
replace coder/decoder file description in libavformat by muxer/demuxer
aurel
parents:
1399
diff
changeset
|
2 * RAW muxer and demuxer |
| 0 | 3 * Copyright (c) 2001 Fabrice Bellard. |
|
868
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
4 * Copyright (c) 2005 Alex Beregszaszi |
| 0 | 5 * |
|
1358
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1245
diff
changeset
|
6 * This file is part of FFmpeg. |
|
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1245
diff
changeset
|
7 * |
|
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1245
diff
changeset
|
8 * FFmpeg is free software; you can redistribute it and/or |
| 0 | 9 * modify it under the terms of the GNU Lesser General Public |
| 10 * License as published by the Free Software Foundation; either | |
|
1358
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1245
diff
changeset
|
11 * version 2.1 of the License, or (at your option) any later version. |
| 0 | 12 * |
|
1358
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1245
diff
changeset
|
13 * FFmpeg is distributed in the hope that it will be useful, |
| 0 | 14 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
| 16 * Lesser General Public License for more details. | |
| 17 * | |
| 18 * You should have received a copy of the GNU Lesser General Public | |
|
1358
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1245
diff
changeset
|
19 * License along with FFmpeg; if not, write to the Free Software |
|
896
edbe5c3717f9
Update licensing information: The FSF changed postal address.
diego
parents:
887
diff
changeset
|
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
| 0 | 21 */ |
| 22 #include "avformat.h" | |
| 2075 | 23 #include "ac3_parser.h" |
| 0 | 24 |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
25 #ifdef CONFIG_MUXERS |
| 0 | 26 /* simple formats */ |
| 64 | 27 static int raw_write_header(struct AVFormatContext *s) |
| 0 | 28 { |
| 29 return 0; | |
| 30 } | |
| 31 | |
|
1078
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
32 static int flac_write_header(struct AVFormatContext *s) |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
33 { |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
34 static const uint8_t header[8] = { |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
35 0x66, 0x4C, 0x61, 0x43, 0x80, 0x00, 0x00, 0x22 |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
36 }; |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
37 uint8_t *streaminfo = s->streams[0]->codec->extradata; |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
38 int len = s->streams[0]->codec->extradata_size; |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
39 if(streaminfo != NULL && len > 0) { |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
40 put_buffer(&s->pb, header, 8); |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
41 put_buffer(&s->pb, streaminfo, len); |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
42 } |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
43 return 0; |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
44 } |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
45 |
| 2076 | 46 |
| 47 static int roq_write_header(struct AVFormatContext *s) | |
| 48 { | |
| 49 static const uint8_t header[] = { | |
| 50 0x84, 0x10, 0xFF, 0xFF, 0xFF, 0xFF, 0x1E, 0x00 | |
| 51 }; | |
| 52 | |
| 53 put_buffer(&s->pb, header, 8); | |
| 54 put_flush_packet(&s->pb); | |
| 55 | |
| 56 return 0; | |
| 57 } | |
| 58 | |
| 468 | 59 static int raw_write_packet(struct AVFormatContext *s, AVPacket *pkt) |
| 0 | 60 { |
| 468 | 61 put_buffer(&s->pb, pkt->data, pkt->size); |
| 0 | 62 put_flush_packet(&s->pb); |
| 63 return 0; | |
| 64 } | |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
65 #endif //CONFIG_MUXERS |
| 0 | 66 |
| 67 /* raw input */ | |
| 65 | 68 static int raw_read_header(AVFormatContext *s, AVFormatParameters *ap) |
| 0 | 69 { |
| 70 AVStream *st; | |
| 71 int id; | |
| 72 | |
| 73 st = av_new_stream(s, 0); | |
| 74 if (!st) | |
| 75 return AVERROR_NOMEM; | |
| 1003 | 76 |
| 0 | 77 id = s->iformat->value; |
| 78 if (id == CODEC_ID_RAWVIDEO) { | |
|
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
79 st->codec->codec_type = CODEC_TYPE_VIDEO; |
| 0 | 80 } else { |
|
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
81 st->codec->codec_type = CODEC_TYPE_AUDIO; |
| 0 | 82 } |
|
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
83 st->codec->codec_id = id; |
| 0 | 84 |
|
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
85 switch(st->codec->codec_type) { |
| 0 | 86 case CODEC_TYPE_AUDIO: |
|
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
87 st->codec->sample_rate = ap->sample_rate; |
|
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
88 st->codec->channels = ap->channels; |
|
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
89 av_set_pts_info(st, 64, 1, st->codec->sample_rate); |
| 0 | 90 break; |
| 91 case CODEC_TYPE_VIDEO: | |
| 743 | 92 av_set_pts_info(st, 64, ap->time_base.num, ap->time_base.den); |
|
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
93 st->codec->width = ap->width; |
|
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
94 st->codec->height = ap->height; |
|
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
95 st->codec->pix_fmt = ap->pix_fmt; |
|
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
96 if(st->codec->pix_fmt == PIX_FMT_NONE) |
|
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
97 st->codec->pix_fmt= PIX_FMT_YUV420P; |
| 0 | 98 break; |
| 99 default: | |
| 100 return -1; | |
| 101 } | |
| 102 return 0; | |
| 103 } | |
| 104 | |
| 105 #define RAW_PACKET_SIZE 1024 | |
| 106 | |
| 64 | 107 static int raw_read_packet(AVFormatContext *s, AVPacket *pkt) |
| 0 | 108 { |
| 109 int ret, size; | |
| 28 | 110 // AVStream *st = s->streams[0]; |
| 885 | 111 |
| 0 | 112 size= RAW_PACKET_SIZE; |
| 113 | |
| 775 | 114 ret= av_get_packet(&s->pb, pkt, size); |
| 0 | 115 |
| 116 pkt->stream_index = 0; | |
| 117 if (ret <= 0) { | |
| 482 | 118 return AVERROR_IO; |
| 0 | 119 } |
| 120 /* note: we need to modify the packet size here to handle the last | |
| 121 packet */ | |
| 122 pkt->size = ret; | |
| 123 return ret; | |
| 124 } | |
| 125 | |
|
389
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
126 static int raw_read_partial_packet(AVFormatContext *s, AVPacket *pkt) |
|
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
127 { |
|
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
128 int ret, size; |
|
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
129 |
|
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
130 size = RAW_PACKET_SIZE; |
|
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
131 |
|
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
132 if (av_new_packet(pkt, size) < 0) |
| 482 | 133 return AVERROR_IO; |
| 885 | 134 |
| 775 | 135 pkt->pos= url_ftell(&s->pb); |
|
389
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
136 pkt->stream_index = 0; |
|
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
137 ret = get_partial_buffer(&s->pb, pkt->data, size); |
|
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
138 if (ret <= 0) { |
|
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
139 av_free_packet(pkt); |
| 482 | 140 return AVERROR_IO; |
|
389
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
141 } |
|
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
142 pkt->size = ret; |
|
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
143 return ret; |
|
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
144 } |
|
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
145 |
|
868
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
146 // http://www.artificis.hu/files/texts/ingenient.txt |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
147 static int ingenient_read_packet(AVFormatContext *s, AVPacket *pkt) |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
148 { |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
149 int ret, size, w, h, unk1, unk2; |
| 885 | 150 |
|
868
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
151 if (get_le32(&s->pb) != MKTAG('M', 'J', 'P', 'G')) |
| 887 | 152 return AVERROR_IO; // FIXME |
|
868
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
153 |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
154 size = get_le32(&s->pb); |
| 885 | 155 |
|
868
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
156 w = get_le16(&s->pb); |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
157 h = get_le16(&s->pb); |
| 885 | 158 |
|
868
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
159 url_fskip(&s->pb, 8); // zero + size (padded?) |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
160 url_fskip(&s->pb, 2); |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
161 unk1 = get_le16(&s->pb); |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
162 unk2 = get_le16(&s->pb); |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
163 url_fskip(&s->pb, 22); // ascii timestamp |
| 885 | 164 |
|
868
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
165 av_log(NULL, AV_LOG_DEBUG, "Ingenient packet: size=%d, width=%d, height=%d, unk1=%d unk2=%d\n", |
| 887 | 166 size, w, h, unk1, unk2); |
|
868
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
167 |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
168 if (av_new_packet(pkt, size) < 0) |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
169 return AVERROR_IO; |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
170 |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
171 pkt->pos = url_ftell(&s->pb); |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
172 pkt->stream_index = 0; |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
173 ret = get_buffer(&s->pb, pkt->data, size); |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
174 if (ret <= 0) { |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
175 av_free_packet(pkt); |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
176 return AVERROR_IO; |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
177 } |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
178 pkt->size = ret; |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
179 return ret; |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
180 } |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
181 |
| 64 | 182 static int raw_read_close(AVFormatContext *s) |
| 0 | 183 { |
| 184 return 0; | |
| 185 } | |
| 186 | |
| 885 | 187 int pcm_read_seek(AVFormatContext *s, |
| 558 | 188 int stream_index, int64_t timestamp, int flags) |
| 306 | 189 { |
| 190 AVStream *st; | |
| 191 int block_align, byte_rate; | |
| 192 int64_t pos; | |
| 193 | |
| 194 st = s->streams[0]; | |
|
1399
5a3003271ad8
simplify pcm read seek, use av_get_bits_per_sample
bcoudurier
parents:
1358
diff
changeset
|
195 |
|
5a3003271ad8
simplify pcm read seek, use av_get_bits_per_sample
bcoudurier
parents:
1358
diff
changeset
|
196 block_align = st->codec->block_align ? st->codec->block_align : |
|
5a3003271ad8
simplify pcm read seek, use av_get_bits_per_sample
bcoudurier
parents:
1358
diff
changeset
|
197 (av_get_bits_per_sample(st->codec->codec_id) * st->codec->channels) >> 3; |
|
5a3003271ad8
simplify pcm read seek, use av_get_bits_per_sample
bcoudurier
parents:
1358
diff
changeset
|
198 byte_rate = st->codec->bit_rate ? st->codec->bit_rate >> 3 : |
|
5a3003271ad8
simplify pcm read seek, use av_get_bits_per_sample
bcoudurier
parents:
1358
diff
changeset
|
199 block_align * st->codec->sample_rate; |
| 885 | 200 |
| 306 | 201 if (block_align <= 0 || byte_rate <= 0) |
| 202 return -1; | |
| 203 | |
| 204 /* compute the position by aligning it to block_align */ | |
| 885 | 205 pos = av_rescale_rnd(timestamp * byte_rate, |
| 206 st->time_base.num, | |
| 558 | 207 st->time_base.den * (int64_t)block_align, |
| 208 (flags & AVSEEK_FLAG_BACKWARD) ? AV_ROUND_DOWN : AV_ROUND_UP); | |
| 209 pos *= block_align; | |
| 306 | 210 |
| 211 /* recompute exact position */ | |
| 464 | 212 st->cur_dts = av_rescale(pos, st->time_base.den, byte_rate * (int64_t)st->time_base.num); |
| 306 | 213 url_fseek(&s->pb, pos + s->data_offset, SEEK_SET); |
| 214 return 0; | |
| 215 } | |
| 216 | |
| 63 | 217 /* ac3 read */ |
| 218 static int ac3_read_header(AVFormatContext *s, | |
| 219 AVFormatParameters *ap) | |
| 220 { | |
| 221 AVStream *st; | |
| 222 | |
| 223 st = av_new_stream(s, 0); | |
| 224 if (!st) | |
| 225 return AVERROR_NOMEM; | |
| 226 | |
|
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
227 st->codec->codec_type = CODEC_TYPE_AUDIO; |
|
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
228 st->codec->codec_id = CODEC_ID_AC3; |
| 2023 | 229 st->need_parsing = AVSTREAM_PARSE_FULL; |
| 63 | 230 /* the parameters will be extracted from the compressed bitstream */ |
| 231 return 0; | |
| 232 } | |
| 233 | |
|
686
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
234 static int shorten_read_header(AVFormatContext *s, |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
235 AVFormatParameters *ap) |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
236 { |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
237 AVStream *st; |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
238 |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
239 st = av_new_stream(s, 0); |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
240 if (!st) |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
241 return AVERROR_NOMEM; |
|
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
242 st->codec->codec_type = CODEC_TYPE_AUDIO; |
|
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
243 st->codec->codec_id = CODEC_ID_SHORTEN; |
| 2023 | 244 st->need_parsing = AVSTREAM_PARSE_FULL; |
|
686
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
245 /* the parameters will be extracted from the compressed bitstream */ |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
246 return 0; |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
247 } |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
248 |
|
1070
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
249 /* flac read */ |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
250 static int flac_read_header(AVFormatContext *s, |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
251 AVFormatParameters *ap) |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
252 { |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
253 AVStream *st; |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
254 |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
255 st = av_new_stream(s, 0); |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
256 if (!st) |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
257 return AVERROR_NOMEM; |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
258 st->codec->codec_type = CODEC_TYPE_AUDIO; |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
259 st->codec->codec_id = CODEC_ID_FLAC; |
| 2023 | 260 st->need_parsing = AVSTREAM_PARSE_FULL; |
|
1070
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
261 /* the parameters will be extracted from the compressed bitstream */ |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
262 return 0; |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
263 } |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
264 |
|
496
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
265 /* dts read */ |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
266 static int dts_read_header(AVFormatContext *s, |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
267 AVFormatParameters *ap) |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
268 { |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
269 AVStream *st; |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
270 |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
271 st = av_new_stream(s, 0); |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
272 if (!st) |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
273 return AVERROR_NOMEM; |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
274 |
|
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
275 st->codec->codec_type = CODEC_TYPE_AUDIO; |
|
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
276 st->codec->codec_id = CODEC_ID_DTS; |
| 2023 | 277 st->need_parsing = AVSTREAM_PARSE_FULL; |
|
496
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
278 /* the parameters will be extracted from the compressed bitstream */ |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
279 return 0; |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
280 } |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
281 |
| 931 | 282 /* aac read */ |
| 283 static int aac_read_header(AVFormatContext *s, | |
| 284 AVFormatParameters *ap) | |
| 285 { | |
| 286 AVStream *st; | |
| 287 | |
| 288 st = av_new_stream(s, 0); | |
| 289 if (!st) | |
| 290 return AVERROR_NOMEM; | |
| 291 | |
| 292 st->codec->codec_type = CODEC_TYPE_AUDIO; | |
| 293 st->codec->codec_id = CODEC_ID_AAC; | |
| 2023 | 294 st->need_parsing = AVSTREAM_PARSE_FULL; |
| 931 | 295 /* the parameters will be extracted from the compressed bitstream */ |
| 296 return 0; | |
| 297 } | |
| 298 | |
| 0 | 299 /* mpeg1/h263 input */ |
| 300 static int video_read_header(AVFormatContext *s, | |
| 301 AVFormatParameters *ap) | |
| 302 { | |
| 303 AVStream *st; | |
| 304 | |
| 305 st = av_new_stream(s, 0); | |
| 306 if (!st) | |
| 307 return AVERROR_NOMEM; | |
| 308 | |
|
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
309 st->codec->codec_type = CODEC_TYPE_VIDEO; |
|
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
310 st->codec->codec_id = s->iformat->value; |
| 2023 | 311 st->need_parsing = AVSTREAM_PARSE_FULL; |
| 306 | 312 |
| 0 | 313 /* for mjpeg, specify frame rate */ |
| 2164 | 314 /* for mpeg4 specify it too (most mpeg4 streams do not have the fixed_vop_rate set ...)*/ |
| 1003 | 315 if (ap->time_base.num) { |
| 745 | 316 av_set_pts_info(st, 64, ap->time_base.num, ap->time_base.den); |
| 885 | 317 } else if ( st->codec->codec_id == CODEC_ID_MJPEG || |
|
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
318 st->codec->codec_id == CODEC_ID_MPEG4 || |
|
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
319 st->codec->codec_id == CODEC_ID_H264) { |
| 745 | 320 av_set_pts_info(st, 64, 1, 25); |
| 0 | 321 } |
| 745 | 322 |
| 0 | 323 return 0; |
| 324 } | |
| 325 | |
| 887 | 326 #define SEQ_START_CODE 0x000001b3 |
| 327 #define GOP_START_CODE 0x000001b8 | |
| 328 #define PICTURE_START_CODE 0x00000100 | |
| 924 | 329 #define SLICE_START_CODE 0x00000101 |
| 330 #define PACK_START_CODE 0x000001ba | |
|
985
7f8b1a1ac020
can't have PES headers in MPEG video elementary streams so fail probe
mru
parents:
939
diff
changeset
|
331 #define VIDEO_ID 0x000001e0 |
|
7f8b1a1ac020
can't have PES headers in MPEG video elementary streams so fail probe
mru
parents:
939
diff
changeset
|
332 #define AUDIO_ID 0x000001c0 |
| 0 | 333 |
| 334 static int mpegvideo_probe(AVProbeData *p) | |
| 335 { | |
| 924 | 336 uint32_t code= -1; |
|
985
7f8b1a1ac020
can't have PES headers in MPEG video elementary streams so fail probe
mru
parents:
939
diff
changeset
|
337 int pic=0, seq=0, slice=0, pspack=0, pes=0; |
| 924 | 338 int i; |
| 49 | 339 |
| 924 | 340 for(i=0; i<p->buf_size; i++){ |
| 341 code = (code<<8) + p->buf[i]; | |
| 342 if ((code & 0xffffff00) == 0x100) { | |
| 343 switch(code){ | |
| 344 case SEQ_START_CODE: seq++; break; | |
| 345 case PICTURE_START_CODE: pic++; break; | |
| 346 case SLICE_START_CODE: slice++; break; | |
| 347 case PACK_START_CODE: pspack++; break; | |
| 348 } | |
| 1965 | 349 if ((code & 0x1f0) == VIDEO_ID) pes++; |
| 350 else if((code & 0x1e0) == AUDIO_ID) pes++; | |
| 924 | 351 } |
| 0 | 352 } |
|
985
7f8b1a1ac020
can't have PES headers in MPEG video elementary streams so fail probe
mru
parents:
939
diff
changeset
|
353 if(seq && seq*9<=pic*10 && pic*9<=slice*10 && !pspack && !pes) |
| 924 | 354 return AVPROBE_SCORE_MAX/2+1; // +1 for .mpg |
| 0 | 355 return 0; |
| 356 } | |
| 357 | |
|
1463
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
358 #define VISUAL_OBJECT_START_CODE 0x000001b5 |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
359 #define VOP_START_CODE 0x000001b6 |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
360 |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
361 static int mpeg4video_probe(AVProbeData *probe_packet) |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
362 { |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
363 uint32_t temp_buffer= -1; |
|
2071
228e5fd9a357
improve mpeg4-es detection by rejecting streams with reserved startcodes (fixes 11-i_need_your_love-daw.mp3 detected as mpeg4)
michael
parents:
2038
diff
changeset
|
364 int VO=0, VOL=0, VOP = 0, VISO = 0, res=0; |
|
1463
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
365 int i; |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
366 |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
367 for(i=0; i<probe_packet->buf_size; i++){ |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
368 temp_buffer = (temp_buffer<<8) + probe_packet->buf[i]; |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
369 if ((temp_buffer & 0xffffff00) == 0x100) { |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
370 switch(temp_buffer){ |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
371 case VOP_START_CODE: VOP++; break; |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
372 case VISUAL_OBJECT_START_CODE: VISO++; break; |
|
2071
228e5fd9a357
improve mpeg4-es detection by rejecting streams with reserved startcodes (fixes 11-i_need_your_love-daw.mp3 detected as mpeg4)
michael
parents:
2038
diff
changeset
|
373 case 0x100 ... 0x11F: VO++; break; |
|
228e5fd9a357
improve mpeg4-es detection by rejecting streams with reserved startcodes (fixes 11-i_need_your_love-daw.mp3 detected as mpeg4)
michael
parents:
2038
diff
changeset
|
374 case 0x120 ... 0x12F: VOL++; break; |
|
228e5fd9a357
improve mpeg4-es detection by rejecting streams with reserved startcodes (fixes 11-i_need_your_love-daw.mp3 detected as mpeg4)
michael
parents:
2038
diff
changeset
|
375 case 0x130 ... 0x1AF: |
|
228e5fd9a357
improve mpeg4-es detection by rejecting streams with reserved startcodes (fixes 11-i_need_your_love-daw.mp3 detected as mpeg4)
michael
parents:
2038
diff
changeset
|
376 case 0x1B7 ... 0x1B9: |
|
228e5fd9a357
improve mpeg4-es detection by rejecting streams with reserved startcodes (fixes 11-i_need_your_love-daw.mp3 detected as mpeg4)
michael
parents:
2038
diff
changeset
|
377 case 0x1C4 ... 0x1FF: res++; break; |
|
1463
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
378 } |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
379 } |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
380 } |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
381 |
|
2071
228e5fd9a357
improve mpeg4-es detection by rejecting streams with reserved startcodes (fixes 11-i_need_your_love-daw.mp3 detected as mpeg4)
michael
parents:
2038
diff
changeset
|
382 if ( VOP >= VISO && VOP >= VOL && VO >= VOL && VOL > 0 && res==0) |
|
1463
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
383 return AVPROBE_SCORE_MAX/2; |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
384 return 0; |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
385 } |
|
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
386 |
|
135
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
387 static int h263_probe(AVProbeData *p) |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
388 { |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
389 int code; |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
390 const uint8_t *d; |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
391 |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
392 d = p->buf; |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
393 code = (d[0] << 14) | (d[1] << 6) | (d[2] >> 2); |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
394 if (code == 0x20) { |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
395 return 50; |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
396 } |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
397 return 0; |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
398 } |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
399 |
|
473
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
400 static int h261_probe(AVProbeData *p) |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
401 { |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
402 int code; |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
403 const uint8_t *d; |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
404 |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
405 d = p->buf; |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
406 code = (d[0] << 12) | (d[1] << 4) | (d[2] >> 4); |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
407 if (code == 0x10) { |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
408 return 50; |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
409 } |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
410 return 0; |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
411 } |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
412 |
| 1768 | 413 static int ac3_probe(AVProbeData *p) |
| 414 { | |
| 1931 | 415 int max_frames, first_frames, frames; |
| 416 uint8_t *buf, *buf2, *end; | |
| 417 AC3HeaderInfo hdr; | |
| 1768 | 418 |
| 1931 | 419 if(p->buf_size < 7) |
| 1768 | 420 return 0; |
| 421 | |
| 1931 | 422 max_frames = 0; |
| 423 buf = p->buf; | |
| 424 end = buf + FFMIN(4096, p->buf_size - 7); | |
| 425 | |
| 426 for(; buf < end; buf++) { | |
| 427 buf2 = buf; | |
| 428 | |
| 429 for(frames = 0; buf2 < end; frames++) { | |
| 430 if(ff_ac3_parse_header(buf2, &hdr) < 0) | |
| 431 break; | |
| 432 buf2 += hdr.frame_size; | |
| 433 } | |
| 434 max_frames = FFMAX(max_frames, frames); | |
| 435 if(buf == p->buf) | |
| 436 first_frames = frames; | |
| 1768 | 437 } |
| 1931 | 438 if (first_frames>=3) return AVPROBE_SCORE_MAX * 3 / 4; |
| 439 else if(max_frames>=3) return AVPROBE_SCORE_MAX / 2; | |
| 440 else if(max_frames>=1) return 1; | |
| 441 else return 0; | |
| 1768 | 442 } |
| 443 | |
| 1167 | 444 AVInputFormat shorten_demuxer = { |
|
686
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
445 "shn", |
|
868
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
446 "raw shorten", |
|
686
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
447 0, |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
448 NULL, |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
449 shorten_read_header, |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
450 raw_read_partial_packet, |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
451 raw_read_close, |
| 1756 | 452 .flags= AVFMT_GENERIC_INDEX, |
|
686
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
453 .extensions = "shn", |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
454 }; |
|
e2687b784c3a
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
637
diff
changeset
|
455 |
| 1167 | 456 AVInputFormat flac_demuxer = { |
|
1070
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
457 "flac", |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
458 "raw flac", |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
459 0, |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
460 NULL, |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
461 flac_read_header, |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
462 raw_read_partial_packet, |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
463 raw_read_close, |
| 1756 | 464 .flags= AVFMT_GENERIC_INDEX, |
|
1070
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
465 .extensions = "flac", |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
466 }; |
|
26d75e74c7b7
Add support for raw flac decoding based on the .flac suffix of input files.
banan
parents:
1003
diff
changeset
|
467 |
|
1078
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
468 #ifdef CONFIG_MUXERS |
| 1167 | 469 AVOutputFormat flac_muxer = { |
|
1078
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
470 "flac", |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
471 "raw flac", |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
472 "audio/x-flac", |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
473 "flac", |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
474 0, |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
475 CODEC_ID_FLAC, |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
476 0, |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
477 flac_write_header, |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
478 raw_write_packet, |
|
1245
e59b75051ded
dont be too picky about timestampsbeing wrong if the destination container is without timestamps and raw of the raw video / raw audio sort
michael
parents:
1169
diff
changeset
|
479 .flags= AVFMT_NOTIMESTAMPS, |
|
1078
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
480 }; |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
481 #endif //CONFIG_MUXERS |
|
0bc9422cc0ad
Raw flac muxer, patch by Justin Ruggles (jruggle earthlink net). Can be
banan
parents:
1070
diff
changeset
|
482 |
|
2022
4f62a7d9381a
Make the declaration of AVInputFormat ac3_demuxer conditional
diego
parents:
2021
diff
changeset
|
483 #ifdef CONFIG_AC3_DEMUXER |
| 1167 | 484 AVInputFormat ac3_demuxer = { |
| 0 | 485 "ac3", |
| 486 "raw ac3", | |
| 487 0, | |
| 1768 | 488 ac3_probe, |
| 63 | 489 ac3_read_header, |
|
389
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
490 raw_read_partial_packet, |
| 0 | 491 raw_read_close, |
| 1756 | 492 .flags= AVFMT_GENERIC_INDEX, |
| 0 | 493 .extensions = "ac3", |
| 494 }; | |
|
2022
4f62a7d9381a
Make the declaration of AVInputFormat ac3_demuxer conditional
diego
parents:
2021
diff
changeset
|
495 #endif |
| 0 | 496 |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
497 #ifdef CONFIG_MUXERS |
| 1167 | 498 AVOutputFormat ac3_muxer = { |
| 0 | 499 "ac3", |
| 500 "raw ac3", | |
| 885 | 501 "audio/x-ac3", |
| 0 | 502 "ac3", |
| 503 0, | |
| 504 CODEC_ID_AC3, | |
| 505 0, | |
| 506 raw_write_header, | |
| 507 raw_write_packet, | |
|
1245
e59b75051ded
dont be too picky about timestampsbeing wrong if the destination container is without timestamps and raw of the raw video / raw audio sort
michael
parents:
1169
diff
changeset
|
508 .flags= AVFMT_NOTIMESTAMPS, |
| 0 | 509 }; |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
510 #endif //CONFIG_MUXERS |
| 0 | 511 |
| 1167 | 512 AVInputFormat dts_demuxer = { |
|
496
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
513 "dts", |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
514 "raw dts", |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
515 0, |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
516 NULL, |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
517 dts_read_header, |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
518 raw_read_partial_packet, |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
519 raw_read_close, |
| 1756 | 520 .flags= AVFMT_GENERIC_INDEX, |
|
496
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
521 .extensions = "dts", |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
522 }; |
|
112057e05179
libdts support by (Benjamin Zores <ben at geexbox dot org>)
michael
parents:
483
diff
changeset
|
523 |
| 1167 | 524 AVInputFormat aac_demuxer = { |
| 931 | 525 "aac", |
| 526 "ADTS AAC", | |
| 527 0, | |
| 528 NULL, | |
| 529 aac_read_header, | |
| 530 raw_read_partial_packet, | |
| 531 raw_read_close, | |
| 1756 | 532 .flags= AVFMT_GENERIC_INDEX, |
| 931 | 533 .extensions = "aac", |
| 534 }; | |
| 535 | |
| 2076 | 536 #ifdef CONFIG_ROQ_MUXER |
| 537 AVOutputFormat roq_muxer = | |
| 538 { | |
| 539 "RoQ", | |
| 540 "Id RoQ format", | |
| 541 NULL, | |
| 542 "roq", | |
| 543 0, | |
| 544 CODEC_ID_ROQ_DPCM, | |
| 545 CODEC_ID_ROQ, | |
| 546 roq_write_header, | |
| 547 raw_write_packet, | |
| 548 }; | |
| 549 #endif //CONFIG_ROQ_MUXER | |
| 550 | |
| 1167 | 551 AVInputFormat h261_demuxer = { |
|
473
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
552 "h261", |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
553 "raw h261", |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
554 0, |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
555 h261_probe, |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
556 video_read_header, |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
557 raw_read_partial_packet, |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
558 raw_read_close, |
| 1756 | 559 .flags= AVFMT_GENERIC_INDEX, |
|
473
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
560 .extensions = "h261", |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
561 .value = CODEC_ID_H261, |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
562 }; |
|
e0a66a870b7f
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
468
diff
changeset
|
563 |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
564 #ifdef CONFIG_MUXERS |
| 1167 | 565 AVOutputFormat h261_muxer = { |
|
576
f701ba509d0c
H.261 encoder by (Maarten Daniels <maarten dot daniels at luc dot ac dot be>)
michael
parents:
567
diff
changeset
|
566 "h261", |
|
f701ba509d0c
H.261 encoder by (Maarten Daniels <maarten dot daniels at luc dot ac dot be>)
michael
parents:
567
diff
changeset
|
567 "raw h261", |
|
f701ba509d0c
H.261 encoder by (Maarten Daniels <maarten dot daniels at luc dot ac dot be>)
michael
parents:
567
diff
changeset
|
568 "video/x-h261", |
|
f701ba509d0c
H.261 encoder by (Maarten Daniels <maarten dot daniels at luc dot ac dot be>)
michael
parents:
567
diff
changeset
|
569 "h261", |
|
f701ba509d0c
H.261 encoder by (Maarten Daniels <maarten dot daniels at luc dot ac dot be>)
michael
parents:
567
diff
changeset
|
570 0, |
|
f701ba509d0c
H.261 encoder by (Maarten Daniels <maarten dot daniels at luc dot ac dot be>)
michael
parents:
567
diff
changeset
|
571 0, |
|
f701ba509d0c
H.261 encoder by (Maarten Daniels <maarten dot daniels at luc dot ac dot be>)
michael
parents:
567
diff
changeset
|
572 CODEC_ID_H261, |
|
f701ba509d0c
H.261 encoder by (Maarten Daniels <maarten dot daniels at luc dot ac dot be>)
michael
parents:
567
diff
changeset
|
573 raw_write_header, |
|
f701ba509d0c
H.261 encoder by (Maarten Daniels <maarten dot daniels at luc dot ac dot be>)
michael
parents:
567
diff
changeset
|
574 raw_write_packet, |
|
1245
e59b75051ded
dont be too picky about timestampsbeing wrong if the destination container is without timestamps and raw of the raw video / raw audio sort
michael
parents:
1169
diff
changeset
|
575 .flags= AVFMT_NOTIMESTAMPS, |
|
576
f701ba509d0c
H.261 encoder by (Maarten Daniels <maarten dot daniels at luc dot ac dot be>)
michael
parents:
567
diff
changeset
|
576 }; |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
577 #endif //CONFIG_MUXERS |
|
576
f701ba509d0c
H.261 encoder by (Maarten Daniels <maarten dot daniels at luc dot ac dot be>)
michael
parents:
567
diff
changeset
|
578 |
| 1167 | 579 AVInputFormat h263_demuxer = { |
|
135
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
580 "h263", |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
581 "raw h263", |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
582 0, |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
583 h263_probe, |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
584 video_read_header, |
|
389
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
585 raw_read_partial_packet, |
|
135
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
586 raw_read_close, |
| 1756 | 587 .flags= AVFMT_GENERIC_INDEX, |
|
135
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
588 // .extensions = "h263", //FIXME remove after writing mpeg4_probe |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
589 .value = CODEC_ID_H263, |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
590 }; |
|
56590088f801
truncated h263 decoding support / H263-ES "demuxer"
michaelni
parents:
128
diff
changeset
|
591 |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
592 #ifdef CONFIG_MUXERS |
| 1167 | 593 AVOutputFormat h263_muxer = { |
| 0 | 594 "h263", |
| 595 "raw h263", | |
| 596 "video/x-h263", | |
| 597 "h263", | |
| 598 0, | |
| 599 0, | |
| 600 CODEC_ID_H263, | |
| 601 raw_write_header, | |
| 602 raw_write_packet, | |
|
1245
e59b75051ded
dont be too picky about timestampsbeing wrong if the destination container is without timestamps and raw of the raw video / raw audio sort
michael
parents:
1169
diff
changeset
|
603 .flags= AVFMT_NOTIMESTAMPS, |
| 0 | 604 }; |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
605 #endif //CONFIG_MUXERS |
| 0 | 606 |
| 1167 | 607 AVInputFormat m4v_demuxer = { |
| 0 | 608 "m4v", |
| 609 "raw MPEG4 video format", | |
| 610 0, | |
|
1463
acf4dbb1a7e6
mpeg4probe patch by (Thijs Vermeir ; thijs vermeir barco com)
michael
parents:
1415
diff
changeset
|
611 mpeg4video_probe, /** probing for mpeg4 data */ |
| 0 | 612 video_read_header, |
|
389
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
613 raw_read_partial_packet, |
| 0 | 614 raw_read_close, |
| 1756 | 615 .flags= AVFMT_GENERIC_INDEX, |
| 0 | 616 .extensions = "m4v", //FIXME remove after writing mpeg4_probe |
| 617 .value = CODEC_ID_MPEG4, | |
| 618 }; | |
| 619 | |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
620 #ifdef CONFIG_MUXERS |
| 1167 | 621 AVOutputFormat m4v_muxer = { |
| 0 | 622 "m4v", |
| 623 "raw MPEG4 video format", | |
| 624 NULL, | |
| 625 "m4v", | |
| 626 0, | |
| 627 CODEC_ID_NONE, | |
| 628 CODEC_ID_MPEG4, | |
| 629 raw_write_header, | |
| 630 raw_write_packet, | |
|
1245
e59b75051ded
dont be too picky about timestampsbeing wrong if the destination container is without timestamps and raw of the raw video / raw audio sort
michael
parents:
1169
diff
changeset
|
631 .flags= AVFMT_NOTIMESTAMPS, |
| 0 | 632 }; |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
633 #endif //CONFIG_MUXERS |
| 0 | 634 |
| 1167 | 635 AVInputFormat h264_demuxer = { |
| 100 | 636 "h264", |
| 637 "raw H264 video format", | |
| 638 0, | |
| 639 NULL /*mpegvideo_probe*/, | |
| 640 video_read_header, | |
|
389
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
641 raw_read_partial_packet, |
| 100 | 642 raw_read_close, |
| 1756 | 643 .flags= AVFMT_GENERIC_INDEX, |
| 808 | 644 .extensions = "h26l,h264,264", //FIXME remove after writing mpeg4_probe |
| 100 | 645 .value = CODEC_ID_H264, |
| 646 }; | |
| 647 | |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
648 #ifdef CONFIG_MUXERS |
| 1167 | 649 AVOutputFormat h264_muxer = { |
| 100 | 650 "h264", |
| 651 "raw H264 video format", | |
| 652 NULL, | |
| 653 "h264", | |
| 654 0, | |
| 655 CODEC_ID_NONE, | |
| 656 CODEC_ID_H264, | |
| 657 raw_write_header, | |
| 658 raw_write_packet, | |
|
1245
e59b75051ded
dont be too picky about timestampsbeing wrong if the destination container is without timestamps and raw of the raw video / raw audio sort
michael
parents:
1169
diff
changeset
|
659 .flags= AVFMT_NOTIMESTAMPS, |
| 100 | 660 }; |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
661 #endif //CONFIG_MUXERS |
| 100 | 662 |
| 1167 | 663 AVInputFormat mpegvideo_demuxer = { |
| 0 | 664 "mpegvideo", |
| 665 "MPEG video", | |
| 666 0, | |
| 667 mpegvideo_probe, | |
| 668 video_read_header, | |
|
389
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
669 raw_read_partial_packet, |
| 0 | 670 raw_read_close, |
| 1756 | 671 .flags= AVFMT_GENERIC_INDEX, |
| 0 | 672 .value = CODEC_ID_MPEG1VIDEO, |
| 673 }; | |
| 674 | |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
675 #ifdef CONFIG_MUXERS |
| 1167 | 676 AVOutputFormat mpeg1video_muxer = { |
| 0 | 677 "mpeg1video", |
| 678 "MPEG video", | |
| 679 "video/x-mpeg", | |
| 814 | 680 "mpg,mpeg,m1v", |
| 0 | 681 0, |
| 682 0, | |
| 683 CODEC_ID_MPEG1VIDEO, | |
| 684 raw_write_header, | |
| 685 raw_write_packet, | |
|
1245
e59b75051ded
dont be too picky about timestampsbeing wrong if the destination container is without timestamps and raw of the raw video / raw audio sort
michael
parents:
1169
diff
changeset
|
686 .flags= AVFMT_NOTIMESTAMPS, |
| 0 | 687 }; |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
688 #endif //CONFIG_MUXERS |
| 0 | 689 |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
690 #ifdef CONFIG_MUXERS |
| 1167 | 691 AVOutputFormat mpeg2video_muxer = { |
|
637
76e36d97a27a
Patch for creating m2v files by (Fabrizio Gennari <fabrizio.ge tiscali it)
michael
parents:
576
diff
changeset
|
692 "mpeg2video", |
|
76e36d97a27a
Patch for creating m2v files by (Fabrizio Gennari <fabrizio.ge tiscali it)
michael
parents:
576
diff
changeset
|
693 "MPEG2 video", |
|
76e36d97a27a
Patch for creating m2v files by (Fabrizio Gennari <fabrizio.ge tiscali it)
michael
parents:
576
diff
changeset
|
694 NULL, |
|
76e36d97a27a
Patch for creating m2v files by (Fabrizio Gennari <fabrizio.ge tiscali it)
michael
parents:
576
diff
changeset
|
695 "m2v", |
|
76e36d97a27a
Patch for creating m2v files by (Fabrizio Gennari <fabrizio.ge tiscali it)
michael
parents:
576
diff
changeset
|
696 0, |
|
76e36d97a27a
Patch for creating m2v files by (Fabrizio Gennari <fabrizio.ge tiscali it)
michael
parents:
576
diff
changeset
|
697 0, |
|
76e36d97a27a
Patch for creating m2v files by (Fabrizio Gennari <fabrizio.ge tiscali it)
michael
parents:
576
diff
changeset
|
698 CODEC_ID_MPEG2VIDEO, |
|
76e36d97a27a
Patch for creating m2v files by (Fabrizio Gennari <fabrizio.ge tiscali it)
michael
parents:
576
diff
changeset
|
699 raw_write_header, |
|
76e36d97a27a
Patch for creating m2v files by (Fabrizio Gennari <fabrizio.ge tiscali it)
michael
parents:
576
diff
changeset
|
700 raw_write_packet, |
|
1245
e59b75051ded
dont be too picky about timestampsbeing wrong if the destination container is without timestamps and raw of the raw video / raw audio sort
michael
parents:
1169
diff
changeset
|
701 .flags= AVFMT_NOTIMESTAMPS, |
|
637
76e36d97a27a
Patch for creating m2v files by (Fabrizio Gennari <fabrizio.ge tiscali it)
michael
parents:
576
diff
changeset
|
702 }; |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
703 #endif //CONFIG_MUXERS |
|
637
76e36d97a27a
Patch for creating m2v files by (Fabrizio Gennari <fabrizio.ge tiscali it)
michael
parents:
576
diff
changeset
|
704 |
| 1167 | 705 AVInputFormat mjpeg_demuxer = { |
| 0 | 706 "mjpeg", |
| 707 "MJPEG video", | |
| 708 0, | |
| 709 NULL, | |
| 710 video_read_header, | |
|
389
e14fcd57ad2f
decode latency patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
michael
parents:
306
diff
changeset
|
711 raw_read_partial_packet, |
| 0 | 712 raw_read_close, |
| 1756 | 713 .flags= AVFMT_GENERIC_INDEX, |
| 0 | 714 .extensions = "mjpg,mjpeg", |
| 715 .value = CODEC_ID_MJPEG, | |
| 716 }; | |
| 717 | |
| 1167 | 718 AVInputFormat ingenient_demuxer = { |
|
868
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
719 "ingenient", |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
720 "Ingenient MJPEG", |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
721 0, |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
722 NULL, |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
723 video_read_header, |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
724 ingenient_read_packet, |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
725 raw_read_close, |
| 1756 | 726 .flags= AVFMT_GENERIC_INDEX, |
|
868
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
727 .extensions = "cgi", // FIXME |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
728 .value = CODEC_ID_MJPEG, |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
729 }; |
|
c6b1dde68f3a
Ingenient MJPEG support, more at http://www.artificis.hu/files/texts/ingenient.txt
alex
parents:
858
diff
changeset
|
730 |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
731 #ifdef CONFIG_MUXERS |
| 1167 | 732 AVOutputFormat mjpeg_muxer = { |
| 0 | 733 "mjpeg", |
| 734 "MJPEG video", | |
| 735 "video/x-mjpeg", | |
| 736 "mjpg,mjpeg", | |
| 737 0, | |
| 738 0, | |
| 739 CODEC_ID_MJPEG, | |
| 740 raw_write_header, | |
| 741 raw_write_packet, | |
|
1245
e59b75051ded
dont be too picky about timestampsbeing wrong if the destination container is without timestamps and raw of the raw video / raw audio sort
michael
parents:
1169
diff
changeset
|
742 .flags= AVFMT_NOTIMESTAMPS, |
| 0 | 743 }; |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
744 #endif //CONFIG_MUXERS |
| 0 | 745 |
| 1773 | 746 AVInputFormat vc1_demuxer = { |
| 747 "vc1", | |
| 748 "raw vc1", | |
| 749 0, | |
| 750 NULL /* vc1_probe */, | |
| 751 video_read_header, | |
| 752 raw_read_partial_packet, | |
| 753 raw_read_close, | |
| 754 .extensions = "vc1", | |
| 755 .value = CODEC_ID_VC1, | |
| 756 }; | |
| 757 | |
| 0 | 758 /* pcm formats */ |
|
277
a313e1080322
disable encoders where appropriate (patch courtesy of BERO
melanson
parents:
241
diff
changeset
|
759 |
| 306 | 760 #define PCMINPUTDEF(name, long_name, ext, codec) \ |
| 1167 | 761 AVInputFormat pcm_ ## name ## _demuxer = {\ |
|
277
a313e1080322
disable encoders where appropriate (patch courtesy of BERO
melanson
parents:
241
diff
changeset
|
762 #name,\ |
|
a313e1080322
disable encoders where appropriate (patch courtesy of BERO
melanson
parents:
241
diff
changeset
|
763 long_name,\ |
|
a313e1080322
disable encoders where appropriate (patch courtesy of BERO
melanson
parents:
241
diff
changeset
|
764 0,\ |
|
a313e1080322
disable encoders where appropriate (patch courtesy of BERO
melanson
parents:
241
diff
changeset
|
765 NULL,\ |
|
a313e1080322
disable encoders where appropriate (patch courtesy of BERO
melanson
parents:
241
diff
changeset
|
766 raw_read_header,\ |
|
a313e1080322
disable encoders where appropriate (patch courtesy of BERO
melanson
parents:
241
diff
changeset
|
767 raw_read_packet,\ |
|
a313e1080322
disable encoders where appropriate (patch courtesy of BERO
melanson
parents:
241
diff
changeset
|
768 raw_read_close,\ |
| 306 | 769 pcm_read_seek,\ |
| 1756 | 770 .flags= AVFMT_GENERIC_INDEX,\ |
|
277
a313e1080322
disable encoders where appropriate (patch courtesy of BERO
melanson
parents:
241
diff
changeset
|
771 .extensions = ext,\ |
|
a313e1080322
disable encoders where appropriate (patch courtesy of BERO
melanson
parents:
241
diff
changeset
|
772 .value = codec,\ |
|
a313e1080322
disable encoders where appropriate (patch courtesy of BERO
melanson
parents:
241
diff
changeset
|
773 }; |
|
a313e1080322
disable encoders where appropriate (patch courtesy of BERO
melanson
parents:
241
diff
changeset
|
774 |
|
1121
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
775 #define PCMOUTPUTDEF(name, long_name, ext, codec) \ |
| 1167 | 776 AVOutputFormat pcm_ ## name ## _muxer = {\ |
| 0 | 777 #name,\ |
| 778 long_name,\ | |
| 779 NULL,\ | |
| 780 ext,\ | |
| 781 0,\ | |
| 782 codec,\ | |
| 783 0,\ | |
| 784 raw_write_header,\ | |
| 785 raw_write_packet,\ | |
|
1245
e59b75051ded
dont be too picky about timestampsbeing wrong if the destination container is without timestamps and raw of the raw video / raw audio sort
michael
parents:
1169
diff
changeset
|
786 .flags= AVFMT_NOTIMESTAMPS,\ |
| 0 | 787 }; |
|
1121
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
788 |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
789 |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
790 #if !defined(CONFIG_MUXERS) && defined(CONFIG_DEMUXERS) |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
791 #define PCMDEF(name, long_name, ext, codec) \ |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
792 PCMINPUTDEF(name, long_name, ext, codec) |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
793 #elif defined(CONFIG_MUXERS) && !defined(CONFIG_DEMUXERS) |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
794 #define PCMDEF(name, long_name, ext, codec) \ |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
795 PCMOUTPUTDEF(name, long_name, ext, codec) |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
796 #elif defined(CONFIG_MUXERS) && defined(CONFIG_DEMUXERS) |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
797 #define PCMDEF(name, long_name, ext, codec) \ |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
798 PCMINPUTDEF(name, long_name, ext, codec)\ |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
799 PCMOUTPUTDEF(name, long_name, ext, codec) |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
800 #else |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
801 #define PCMDEF(name, long_name, ext, codec) |
|
787a70a8b867
Fix compilation with all combinations of --disable-(de)muxers.
diego
parents:
1078
diff
changeset
|
802 #endif |
| 0 | 803 |
| 804 #ifdef WORDS_BIGENDIAN | |
| 805 #define BE_DEF(s) s | |
| 806 #define LE_DEF(s) NULL | |
| 807 #else | |
| 808 #define BE_DEF(s) NULL | |
| 809 #define LE_DEF(s) s | |
| 810 #endif | |
| 811 | |
| 812 | |
| 885 | 813 PCMDEF(s16le, "pcm signed 16 bit little endian format", |
| 0 | 814 LE_DEF("sw"), CODEC_ID_PCM_S16LE) |
| 815 | |
| 885 | 816 PCMDEF(s16be, "pcm signed 16 bit big endian format", |
| 0 | 817 BE_DEF("sw"), CODEC_ID_PCM_S16BE) |
| 818 | |
| 885 | 819 PCMDEF(u16le, "pcm unsigned 16 bit little endian format", |
| 0 | 820 LE_DEF("uw"), CODEC_ID_PCM_U16LE) |
| 821 | |
| 885 | 822 PCMDEF(u16be, "pcm unsigned 16 bit big endian format", |
| 0 | 823 BE_DEF("uw"), CODEC_ID_PCM_U16BE) |
| 824 | |
| 885 | 825 PCMDEF(s8, "pcm signed 8 bit format", |
| 0 | 826 "sb", CODEC_ID_PCM_S8) |
| 827 | |
| 885 | 828 PCMDEF(u8, "pcm unsigned 8 bit format", |
| 0 | 829 "ub", CODEC_ID_PCM_U8) |
| 830 | |
| 885 | 831 PCMDEF(mulaw, "pcm mu law format", |
| 0 | 832 "ul", CODEC_ID_PCM_MULAW) |
| 833 | |
| 885 | 834 PCMDEF(alaw, "pcm A law format", |
| 0 | 835 "al", CODEC_ID_PCM_ALAW) |
| 836 | |
| 64 | 837 static int rawvideo_read_packet(AVFormatContext *s, AVPacket *pkt) |
| 0 | 838 { |
| 839 int packet_size, ret, width, height; | |
| 840 AVStream *st = s->streams[0]; | |
| 841 | |
|
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
842 width = st->codec->width; |
|
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
843 height = st->codec->height; |
| 0 | 844 |
|
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
814
diff
changeset
|
845 packet_size = avpicture_get_size(st->codec->pix_fmt, width, height); |
| 128 | 846 if (packet_size < 0) |
| 537 | 847 return -1; |
| 0 | 848 |
| 775 | 849 ret= av_get_packet(&s->pb, pkt, packet_size); |
| 0 | 850 |
| 851 pkt->stream_index = 0; | |
| 775 | 852 if (ret != packet_size) { |
| 482 | 853 return AVERROR_IO; |
| 0 | 854 } else { |
| 855 return 0; | |
| 856 } | |
| 857 } | |
| 858 | |
| 1167 | 859 AVInputFormat rawvideo_demuxer = { |
| 0 | 860 "rawvideo", |
| 861 "raw video format", | |
| 862 0, | |
| 863 NULL, | |
| 864 raw_read_header, | |
| 865 rawvideo_read_packet, | |
| 866 raw_read_close, | |
| 1756 | 867 .flags= AVFMT_GENERIC_INDEX, |
| 2099 | 868 .extensions = "yuv,cif,qcif,rgb", |
| 0 | 869 .value = CODEC_ID_RAWVIDEO, |
| 870 }; | |
| 871 | |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
872 #ifdef CONFIG_MUXERS |
| 1167 | 873 AVOutputFormat rawvideo_muxer = { |
| 0 | 874 "rawvideo", |
| 875 "raw video format", | |
| 876 NULL, | |
| 2038 | 877 "yuv,rgb", |
| 0 | 878 0, |
| 879 CODEC_ID_NONE, | |
| 880 CODEC_ID_RAWVIDEO, | |
| 881 raw_write_header, | |
| 882 raw_write_packet, | |
|
1245
e59b75051ded
dont be too picky about timestampsbeing wrong if the destination container is without timestamps and raw of the raw video / raw audio sort
michael
parents:
1169
diff
changeset
|
883 .flags= AVFMT_NOTIMESTAMPS, |
| 0 | 884 }; |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
885 #endif //CONFIG_MUXERS |
| 0 | 886 |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
887 #ifdef CONFIG_MUXERS |
| 468 | 888 static int null_write_packet(struct AVFormatContext *s, AVPacket *pkt) |
| 0 | 889 { |
| 890 return 0; | |
| 891 } | |
| 892 | |
| 1167 | 893 AVOutputFormat null_muxer = { |
| 0 | 894 "null", |
| 895 "null video format", | |
| 896 NULL, | |
| 897 NULL, | |
| 898 0, | |
| 899 #ifdef WORDS_BIGENDIAN | |
| 900 CODEC_ID_PCM_S16BE, | |
| 901 #else | |
| 902 CODEC_ID_PCM_S16LE, | |
| 903 #endif | |
| 904 CODEC_ID_RAWVIDEO, | |
| 905 raw_write_header, | |
| 906 null_write_packet, | |
|
1245
e59b75051ded
dont be too picky about timestampsbeing wrong if the destination container is without timestamps and raw of the raw video / raw audio sort
michael
parents:
1169
diff
changeset
|
907 .flags = AVFMT_NOFILE | AVFMT_RAWPICTURE | AVFMT_NOTIMESTAMPS, |
| 0 | 908 }; |
|
858
66cc656ea404
Replace CONFIG_ENCODERS/CONFIG_DECODERS with CONFIG_MUXERS/CONFIG_DEMUXERS
diego
parents:
820
diff
changeset
|
909 #endif //CONFIG_MUXERS |
