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