Mercurial > mplayer.hg
annotate libmpdemux/demux_lavf.c @ 24790:319ba65a7110
Add ASF/MXF decryption support to Changelog
author | reimar |
---|---|
date | Sat, 20 Oct 2007 14:27:19 +0000 |
parents | fbf46414bb48 |
children | d5f716b49cb4 |
rev | line source |
---|---|
12164 | 1 /* |
2 Copyright (C) 2004 Michael Niedermayer <michaelni@gmx.at> | |
3 | |
4 This program is free software; you can redistribute it and/or modify | |
5 it under the terms of the GNU General Public License as published by | |
6 the Free Software Foundation; either version 2 of the License, or | |
7 (at your option) any later version. | |
8 | |
9 This program is distributed in the hope that it will be useful, | |
10 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
12 GNU General Public License for more details. | |
13 | |
14 You should have received a copy of the GNU General Public License | |
15 along with this program; if not, write to the Free Software | |
17367
401b440a6d76
Update licensing information: The FSF changed postal address.
diego
parents:
17354
diff
changeset
|
16 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
12164 | 17 */ |
18 | |
19 // #include <stdio.h> | |
20 #include <stdlib.h> | |
21 // #include <unistd.h> | |
19611 | 22 #include <limits.h> |
12164 | 23 |
24 #include "config.h" | |
25 #include "mp_msg.h" | |
23010
74efb0fa8a0b
with -identify show audio and video id; patch by Andrew Savchenko (Bircoph list ru)
nicodvb
parents:
22990
diff
changeset
|
26 #include "help_mp.h" |
12164 | 27 |
22605
4d81dbdf46b9
Add explicit location for headers from the stream/ directory.
diego
parents:
22440
diff
changeset
|
28 #include "stream/stream.h" |
12164 | 29 #include "demuxer.h" |
30 #include "stheader.h" | |
19598 | 31 #include "m_option.h" |
23758 | 32 #include "libvo/sub.h" |
12164 | 33 |
17354 | 34 #ifdef USE_LIBAVFORMAT_SO |
35 #include <ffmpeg/avformat.h> | |
21995
f615c862f862
Remove ff_gcd prototype and include avutil.h instead where it is defined.
reimar
parents:
21966
diff
changeset
|
36 #include <ffmpeg/avutil.h> |
19598 | 37 #include <ffmpeg/opt.h> |
17354 | 38 #else |
12164 | 39 #include "avformat.h" |
21995
f615c862f862
Remove ff_gcd prototype and include avutil.h instead where it is defined.
reimar
parents:
21966
diff
changeset
|
40 #include "avutil.h" |
12164 | 41 #include "avi.h" |
19598 | 42 #include "opt.h" |
17354 | 43 #endif |
21822
fc4ce8a91a2e
Include "internal" libavformat/riff.h also when dynamic libavformat is used
reimar
parents:
21779
diff
changeset
|
44 #include "riff.h" |
12164 | 45 |
46 #define PROBE_BUF_SIZE 2048 | |
47 | |
18775 | 48 extern char *audio_lang; |
19598 | 49 static unsigned int opt_probesize = 0; |
24635 | 50 static unsigned int opt_analyzeduration = 0; |
22150
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
51 static char *opt_format; |
24757 | 52 static char *opt_cryptokey; |
19598 | 53 |
54 m_option_t lavfdopts_conf[] = { | |
55 {"probesize", &(opt_probesize), CONF_TYPE_INT, CONF_RANGE, 32, INT_MAX, NULL}, | |
22150
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
56 {"format", &(opt_format), CONF_TYPE_STRING, 0, 0, 0, NULL}, |
24635 | 57 {"analyzeduration", &(opt_analyzeduration), CONF_TYPE_INT, CONF_RANGE, 0, INT_MAX, NULL}, |
24757 | 58 {"cryptokey", &(opt_cryptokey), CONF_TYPE_STRING, 0, 0, 0, NULL}, |
19598 | 59 {NULL, NULL, 0, 0, 0, 0, NULL} |
60 }; | |
61 | |
18775 | 62 |
12164 | 63 typedef struct lavf_priv_t{ |
64 AVInputFormat *avif; | |
65 AVFormatContext *avfc; | |
66 ByteIOContext pb; | |
67 int audio_streams; | |
68 int video_streams; | |
23758 | 69 int sub_streams; |
12168 | 70 int64_t last_pts; |
18762 | 71 int astreams[MAX_A_STREAMS]; |
21100
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
72 int vstreams[MAX_V_STREAMS]; |
23758 | 73 int sstreams[MAX_S_STREAMS]; |
12164 | 74 }lavf_priv_t; |
75 | |
17977
f70772d02eaa
Convert printfs in aviprint.c to mp_msg and give the information printing
diego
parents:
17932
diff
changeset
|
76 extern void print_wave_header(WAVEFORMATEX *h, int verbose_level); |
f70772d02eaa
Convert printfs in aviprint.c to mp_msg and give the information printing
diego
parents:
17932
diff
changeset
|
77 extern void print_video_header(BITMAPINFOHEADER *h, int verbose_level); |
12164 | 78 |
21966
d9494ca70ca7
Simplify by using av_codec_get_id and include riff.h only in demux_lavf.c
reimar
parents:
21962
diff
changeset
|
79 static const AVCodecTag mp_wav_tags[] = { |
20944
20910582789d
cosmetics: Restore alphabetical order, align both tables.
diego
parents:
20942
diff
changeset
|
80 { CODEC_ID_ADPCM_4XM, MKTAG('4', 'X', 'M', 'A')}, |
20910582789d
cosmetics: Restore alphabetical order, align both tables.
diego
parents:
20942
diff
changeset
|
81 { CODEC_ID_ADPCM_EA, MKTAG('A', 'D', 'E', 'A')}, |
20910582789d
cosmetics: Restore alphabetical order, align both tables.
diego
parents:
20942
diff
changeset
|
82 { CODEC_ID_ADPCM_IMA_WS, MKTAG('A', 'I', 'W', 'S')}, |
22916 | 83 { CODEC_ID_ADPCM_THP, MKTAG('T', 'H', 'P', 'A')}, |
21779 | 84 { CODEC_ID_AMR_NB, MKTAG('n', 'b', 0, 0)}, |
24518
8b525df8357a
Add support for cook audio (though most .rm files don't work with lavf
reimar
parents:
24355
diff
changeset
|
85 { CODEC_ID_COOK, MKTAG('c', 'o', 'o', 'k')}, |
20944
20910582789d
cosmetics: Restore alphabetical order, align both tables.
diego
parents:
20942
diff
changeset
|
86 { CODEC_ID_DSICINAUDIO, MKTAG('D', 'C', 'I', 'A')}, |
20910582789d
cosmetics: Restore alphabetical order, align both tables.
diego
parents:
20942
diff
changeset
|
87 { CODEC_ID_INTERPLAY_DPCM, MKTAG('I', 'N', 'P', 'A')}, |
21763
43c8f1aa82bb
add support for musepack native decoder from ffmpeg (require -demuxer lavf)
aurel
parents:
21568
diff
changeset
|
88 { CODEC_ID_MUSEPACK7, MKTAG('M', 'P', 'C', ' ')}, |
24764
fbf46414bb48
add nellymoser codec to mplayer with internal fourcc NELL
compn
parents:
24757
diff
changeset
|
89 { CODEC_ID_NELLYMOSER, MKTAG('N', 'E', 'L', 'L')}, |
20944
20910582789d
cosmetics: Restore alphabetical order, align both tables.
diego
parents:
20942
diff
changeset
|
90 { CODEC_ID_PCM_S24BE, MKTAG('i', 'n', '2', '4')}, |
22058
b149aa896f8d
Support 16bit bigendian PCM audio from libavformat
reimar
parents:
21995
diff
changeset
|
91 { CODEC_ID_PCM_S16BE, MKTAG('t', 'w', 'o', 's')}, |
20944
20910582789d
cosmetics: Restore alphabetical order, align both tables.
diego
parents:
20942
diff
changeset
|
92 { CODEC_ID_PCM_S8, MKTAG('t', 'w', 'o', 's')}, |
20910582789d
cosmetics: Restore alphabetical order, align both tables.
diego
parents:
20942
diff
changeset
|
93 { CODEC_ID_ROQ_DPCM, MKTAG('R', 'o', 'Q', 'A')}, |
20910582789d
cosmetics: Restore alphabetical order, align both tables.
diego
parents:
20942
diff
changeset
|
94 { CODEC_ID_SHORTEN, MKTAG('s', 'h', 'r', 'n')}, |
20910582789d
cosmetics: Restore alphabetical order, align both tables.
diego
parents:
20942
diff
changeset
|
95 { CODEC_ID_TTA, MKTAG('T', 'T', 'A', '1')}, |
20910582789d
cosmetics: Restore alphabetical order, align both tables.
diego
parents:
20942
diff
changeset
|
96 { CODEC_ID_WAVPACK, MKTAG('W', 'V', 'P', 'K')}, |
21362 | 97 { CODEC_ID_WESTWOOD_SND1, MKTAG('S', 'N', 'D', '1')}, |
20990 | 98 { CODEC_ID_XAN_DPCM, MKTAG('A', 'x', 'a', 'n')}, |
20733
404fb439acba
Add our own CODEC_ID -> fourcc translation tables so we do not need
reimar
parents:
20070
diff
changeset
|
99 { 0, 0 }, |
404fb439acba
Add our own CODEC_ID -> fourcc translation tables so we do not need
reimar
parents:
20070
diff
changeset
|
100 }; |
404fb439acba
Add our own CODEC_ID -> fourcc translation tables so we do not need
reimar
parents:
20070
diff
changeset
|
101 |
21966
d9494ca70ca7
Simplify by using av_codec_get_id and include riff.h only in demux_lavf.c
reimar
parents:
21962
diff
changeset
|
102 const struct AVCodecTag *mp_wav_taglists[] = {codec_wav_tags, mp_wav_tags, 0}; |
d9494ca70ca7
Simplify by using av_codec_get_id and include riff.h only in demux_lavf.c
reimar
parents:
21962
diff
changeset
|
103 |
d9494ca70ca7
Simplify by using av_codec_get_id and include riff.h only in demux_lavf.c
reimar
parents:
21962
diff
changeset
|
104 static const AVCodecTag mp_bmp_tags[] = { |
24653 | 105 { CODEC_ID_AMV, MKTAG('A', 'M', 'V', 'V')}, |
23088 | 106 { CODEC_ID_BETHSOFTVID, MKTAG('B', 'E', 'T', 'H')}, |
22918 | 107 { CODEC_ID_C93, MKTAG('C', '9', '3', 'V')}, |
20940 | 108 { CODEC_ID_DSICINVIDEO, MKTAG('D', 'C', 'I', 'V')}, |
22690 | 109 { CODEC_ID_DXA, MKTAG('D', 'X', 'A', '1')}, |
20963 | 110 { CODEC_ID_FLIC, MKTAG('F', 'L', 'I', 'C')}, |
20980
70ca50bcc4a8
support for some more fringe formats, still buggy ..
diego
parents:
20963
diff
changeset
|
111 { CODEC_ID_IDCIN, MKTAG('I', 'D', 'C', 'I')}, |
70ca50bcc4a8
support for some more fringe formats, still buggy ..
diego
parents:
20963
diff
changeset
|
112 { CODEC_ID_INTERPLAY_VIDEO, MKTAG('I', 'N', 'P', 'V')}, |
20942
2093d87ed14b
support for RoQ video and audio through libavformat
diego
parents:
20941
diff
changeset
|
113 { CODEC_ID_ROQ, MKTAG('R', 'o', 'Q', 'V')}, |
22876 | 114 { CODEC_ID_THP, MKTAG('T', 'H', 'P', 'V')}, |
20933 | 115 { CODEC_ID_TIERTEXSEQVIDEO, MKTAG('T', 'S', 'E', 'Q')}, |
23274
f3e72ce8a9fd
add txd codec, works with http://samples.mplayerhq.hu/game-formats/txd/fronten2.txd .
compn
parents:
23088
diff
changeset
|
116 { CODEC_ID_TXD, MKTAG('T', 'X', 'D', 'V')}, |
20935
4a8c67e44c7f
cosmetics: alphabetical order and prettyprinting for the CodecTag table
diego
parents:
20934
diff
changeset
|
117 { CODEC_ID_VMDVIDEO, MKTAG('V', 'M', 'D', 'V')}, |
20980
70ca50bcc4a8
support for some more fringe formats, still buggy ..
diego
parents:
20963
diff
changeset
|
118 { CODEC_ID_WS_VQA, MKTAG('V', 'Q', 'A', 'V')}, |
20935
4a8c67e44c7f
cosmetics: alphabetical order and prettyprinting for the CodecTag table
diego
parents:
20934
diff
changeset
|
119 { CODEC_ID_XAN_WC3, MKTAG('W', 'C', '3', 'V')}, |
24355 | 120 { CODEC_ID_NUV, MKTAG('N', 'U', 'V', '1')}, |
20733
404fb439acba
Add our own CODEC_ID -> fourcc translation tables so we do not need
reimar
parents:
20070
diff
changeset
|
121 { 0, 0 }, |
404fb439acba
Add our own CODEC_ID -> fourcc translation tables so we do not need
reimar
parents:
20070
diff
changeset
|
122 }; |
404fb439acba
Add our own CODEC_ID -> fourcc translation tables so we do not need
reimar
parents:
20070
diff
changeset
|
123 |
21966
d9494ca70ca7
Simplify by using av_codec_get_id and include riff.h only in demux_lavf.c
reimar
parents:
21962
diff
changeset
|
124 const struct AVCodecTag *mp_bmp_taglists[] = {codec_bmp_tags, mp_bmp_tags, 0}; |
d9494ca70ca7
Simplify by using av_codec_get_id and include riff.h only in demux_lavf.c
reimar
parents:
21962
diff
changeset
|
125 |
12164 | 126 static int mp_open(URLContext *h, const char *filename, int flags){ |
127 return 0; | |
128 } | |
129 | |
130 static int mp_read(URLContext *h, unsigned char *buf, int size){ | |
131 stream_t *stream = (stream_t*)h->priv_data; | |
12165
6ae21c78ed8d
libavformat really doesnt like it that the streams get stuck if the end is reached
michael
parents:
12164
diff
changeset
|
132 int ret; |
6ae21c78ed8d
libavformat really doesnt like it that the streams get stuck if the end is reached
michael
parents:
12164
diff
changeset
|
133 |
12164 | 134 if(stream_eof(stream)) //needed? |
135 return -1; | |
12165
6ae21c78ed8d
libavformat really doesnt like it that the streams get stuck if the end is reached
michael
parents:
12164
diff
changeset
|
136 ret=stream_read(stream, buf, size); |
12166 | 137 |
12165
6ae21c78ed8d
libavformat really doesnt like it that the streams get stuck if the end is reached
michael
parents:
12164
diff
changeset
|
138 mp_msg(MSGT_HEADER,MSGL_DBG2,"%d=mp_read(%p, %p, %d), eof:%d\n", ret, h, buf, size, stream->eof); |
6ae21c78ed8d
libavformat really doesnt like it that the streams get stuck if the end is reached
michael
parents:
12164
diff
changeset
|
139 return ret; |
12164 | 140 } |
141 | |
142 static int mp_write(URLContext *h, unsigned char *buf, int size){ | |
143 return -1; | |
144 } | |
145 | |
146 static offset_t mp_seek(URLContext *h, offset_t pos, int whence){ | |
147 stream_t *stream = (stream_t*)h->priv_data; | |
12165
6ae21c78ed8d
libavformat really doesnt like it that the streams get stuck if the end is reached
michael
parents:
12164
diff
changeset
|
148 |
6ae21c78ed8d
libavformat really doesnt like it that the streams get stuck if the end is reached
michael
parents:
12164
diff
changeset
|
149 mp_msg(MSGT_HEADER,MSGL_DBG2,"mp_seek(%p, %d, %d)\n", h, (int)pos, whence); |
12164 | 150 if(whence == SEEK_CUR) |
151 pos +=stream_tell(stream); | |
24085
71d17c28f545
We can support SEEK_END seeks only when stream->end_pos is known
reimar
parents:
24084
diff
changeset
|
152 else if(whence == SEEK_END && stream->end_pos > 0) |
12164 | 153 pos += stream->end_pos; |
22440
ee6b8e74d727
when seeking consider stream->start_pos instead of 0 as initial position; patch by Zuxy Meng approved by Michael
nicodvb
parents:
22266
diff
changeset
|
154 else if(whence == SEEK_SET) |
ee6b8e74d727
when seeking consider stream->start_pos instead of 0 as initial position; patch by Zuxy Meng approved by Michael
nicodvb
parents:
22266
diff
changeset
|
155 pos += stream->start_pos; |
24084 | 156 else if(whence == AVSEEK_SIZE && stream->end_pos > 0) |
157 return stream->end_pos - stream->start_pos; | |
22440
ee6b8e74d727
when seeking consider stream->start_pos instead of 0 as initial position; patch by Zuxy Meng approved by Michael
nicodvb
parents:
22266
diff
changeset
|
158 else |
12164 | 159 return -1; |
160 | |
24082 | 161 if(pos<0) |
162 return -1; | |
12167 | 163 if(pos<stream->end_pos && stream->eof) |
12166 | 164 stream_reset(stream); |
12164 | 165 if(stream_seek(stream, pos)==0) |
166 return -1; | |
12166 | 167 |
22440
ee6b8e74d727
when seeking consider stream->start_pos instead of 0 as initial position; patch by Zuxy Meng approved by Michael
nicodvb
parents:
22266
diff
changeset
|
168 return pos - stream->start_pos; |
12164 | 169 } |
170 | |
171 static int mp_close(URLContext *h){ | |
172 return 0; | |
173 } | |
174 | |
175 static URLProtocol mp_protocol = { | |
176 "mp", | |
177 mp_open, | |
178 mp_read, | |
179 mp_write, | |
180 mp_seek, | |
181 mp_close, | |
182 }; | |
183 | |
22150
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
184 static void list_formats(void) { |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
185 AVInputFormat *fmt; |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
186 mp_msg(MSGT_DEMUX, MSGL_INFO, "Available lavf input formats:\n"); |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
187 for (fmt = first_iformat; fmt; fmt = fmt->next) |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
188 mp_msg(MSGT_DEMUX, MSGL_INFO, "%15s : %s\n", fmt->name, fmt->long_name); |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
189 } |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
190 |
16175 | 191 static int lavf_check_file(demuxer_t *demuxer){ |
12164 | 192 AVProbeData avpd; |
193 uint8_t buf[PROBE_BUF_SIZE]; | |
194 lavf_priv_t *priv; | |
195 | |
196 if(!demuxer->priv) | |
197 demuxer->priv=calloc(sizeof(lavf_priv_t),1); | |
198 priv= demuxer->priv; | |
199 | |
200 av_register_all(); | |
201 | |
15819 | 202 if(stream_read(demuxer->stream, buf, PROBE_BUF_SIZE)!=PROBE_BUF_SIZE) |
203 return 0; | |
12164 | 204 avpd.filename= demuxer->stream->url; |
205 avpd.buf= buf; | |
206 avpd.buf_size= PROBE_BUF_SIZE; | |
207 | |
22150
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
208 if (opt_format) { |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
209 if (strcmp(opt_format, "help") == 0) { |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
210 list_formats(); |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
211 return 0; |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
212 } |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
213 priv->avif= av_find_input_format(opt_format); |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
214 if (!priv->avif) { |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
215 mp_msg(MSGT_DEMUX,MSGL_FATAL,"Unknown lavf format %s\n", opt_format); |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
216 return 0; |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
217 } |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
218 mp_msg(MSGT_DEMUX,MSGL_INFO,"Forced lavf %s demuxer\n", priv->avif->long_name); |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
219 return DEMUXER_TYPE_LAVF; |
6d50b08a8bcd
Support selecting a specific lavf demuxer and listing available ones via -lavfdopts
reimar
parents:
22058
diff
changeset
|
220 } |
12164 | 221 priv->avif= av_probe_input_format(&avpd, 1); |
222 if(!priv->avif){ | |
223 mp_msg(MSGT_HEADER,MSGL_V,"LAVF_check: no clue about this gibberish!\n"); | |
224 return 0; | |
225 }else | |
226 mp_msg(MSGT_HEADER,MSGL_V,"LAVF_check: %s\n", priv->avif->long_name); | |
227 | |
16175 | 228 return DEMUXER_TYPE_LAVF; |
12164 | 229 } |
22971
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
230 |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
231 static const char *preferred_list[] = { |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
232 "dxa", |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
233 "wv", |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
234 "nuv", |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
235 "nut", |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
236 "gxf", |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
237 "mxf", |
22972
46593cc4aeba
Use lavf_preferred mechanism to replace more extension-based detection hacks
reimar
parents:
22971
diff
changeset
|
238 "flv", |
46593cc4aeba
Use lavf_preferred mechanism to replace more extension-based detection hacks
reimar
parents:
22971
diff
changeset
|
239 "swf", |
22971
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
240 NULL |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
241 }; |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
242 |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
243 static int lavf_check_preferred_file(demuxer_t *demuxer){ |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
244 if (lavf_check_file(demuxer)) { |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
245 char **p = preferred_list; |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
246 lavf_priv_t *priv = demuxer->priv; |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
247 while (*p) { |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
248 if (strcmp(*p, priv->avif->name) == 0) |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
249 return DEMUXER_TYPE_LAVF_PREFERRED; |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
250 p++; |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
251 } |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
252 } |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
253 return 0; |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
254 } |
12164 | 255 |
24757 | 256 static uint8_t char2int(char c) { |
257 if (c >= '0' && c <= '9') return c - '0'; | |
258 if (c >= 'a' && c <= 'f') return c - 'a' + 10; | |
259 if (c >= 'A' && c <= 'F') return c - 'A' + 10; | |
260 return 0; | |
261 } | |
262 | |
263 static void parse_cryptokey(AVFormatContext *avfc, const char *str) { | |
264 int len = strlen(str) / 2; | |
265 uint8_t *key = av_mallocz(len); | |
266 int i; | |
267 avfc->keylen = len; | |
268 avfc->key = key; | |
269 for (i = 0; i < len; i++, str += 2) | |
270 *key++ = (char2int(str[0]) << 4) | char2int(str[1]); | |
271 } | |
272 | |
16175 | 273 static demuxer_t* demux_open_lavf(demuxer_t *demuxer){ |
12164 | 274 AVFormatContext *avfc; |
275 AVFormatParameters ap; | |
24633 | 276 const AVOption *opt; |
12164 | 277 lavf_priv_t *priv= demuxer->priv; |
15011 | 278 int i,g; |
12164 | 279 char mp_filename[256]="mp:"; |
280 | |
281 memset(&ap, 0, sizeof(AVFormatParameters)); | |
282 | |
283 stream_seek(demuxer->stream, 0); | |
284 | |
285 register_protocol(&mp_protocol); | |
286 | |
19598 | 287 avfc = av_alloc_format_context(); |
21548 | 288 |
24757 | 289 if (opt_cryptokey) |
290 parse_cryptokey(avfc, opt_cryptokey); | |
21548 | 291 if (correct_pts) |
292 avfc->flags |= AVFMT_FLAG_GENPTS; | |
21568 | 293 if (index_mode == 0) |
294 avfc->flags |= AVFMT_FLAG_IGNIDX; | |
21548 | 295 |
19598 | 296 ap.prealloced_context = 1; |
297 if(opt_probesize) { | |
24634 | 298 opt = av_set_int(avfc, "probesize", opt_probesize); |
299 if(!opt) mp_msg(MSGT_HEADER,MSGL_ERR, "demux_lavf, couldn't set option probesize to %u\n", opt_probesize); | |
19598 | 300 } |
24635 | 301 if(opt_analyzeduration) { |
302 opt = av_set_int(avfc, "analyzeduration", opt_analyzeduration * AV_TIME_BASE); | |
303 if(!opt) mp_msg(MSGT_HEADER,MSGL_ERR, "demux_lavf, couldn't set option analyzeduration to %u\n", opt_analyzeduration); | |
304 } | |
19598 | 305 |
12463 | 306 if(demuxer->stream->url) |
307 strncpy(mp_filename + 3, demuxer->stream->url, sizeof(mp_filename)-3); | |
308 else | |
309 strncpy(mp_filename + 3, "foobar.dummy", sizeof(mp_filename)-3); | |
12164 | 310 |
311 url_fopen(&priv->pb, mp_filename, URL_RDONLY); | |
312 | |
313 ((URLContext*)(priv->pb.opaque))->priv_data= demuxer->stream; | |
314 | |
315 if(av_open_input_stream(&avfc, &priv->pb, mp_filename, priv->avif, &ap)<0){ | |
316 mp_msg(MSGT_HEADER,MSGL_ERR,"LAVF_header: av_open_input_stream() failed\n"); | |
16175 | 317 return NULL; |
12164 | 318 } |
319 | |
320 priv->avfc= avfc; | |
321 | |
322 if(av_find_stream_info(avfc) < 0){ | |
323 mp_msg(MSGT_HEADER,MSGL_ERR,"LAVF_header: av_find_stream_info() failed\n"); | |
16175 | 324 return NULL; |
12164 | 325 } |
326 | |
12167 | 327 if(avfc->title [0]) demux_info_add(demuxer, "name" , avfc->title ); |
328 if(avfc->author [0]) demux_info_add(demuxer, "author" , avfc->author ); | |
329 if(avfc->copyright[0]) demux_info_add(demuxer, "copyright", avfc->copyright); | |
330 if(avfc->comment [0]) demux_info_add(demuxer, "comments" , avfc->comment ); | |
331 if(avfc->album [0]) demux_info_add(demuxer, "album" , avfc->album ); | |
332 // if(avfc->year ) demux_info_add(demuxer, "year" , avfc->year ); | |
333 // if(avfc->track ) demux_info_add(demuxer, "track" , avfc->track ); | |
334 if(avfc->genre [0]) demux_info_add(demuxer, "genre" , avfc->genre ); | |
12164 | 335 |
336 for(i=0; i<avfc->nb_streams; i++){ | |
337 AVStream *st= avfc->streams[i]; | |
16000 | 338 AVCodecContext *codec= st->codec; |
19073
8b52dad54b1d
Remove #if LIBAVCODEC_BUILD >= XXX and #if LIBAVFORMAT_BUILD >= XXX jungle.
diego
parents:
19062
diff
changeset
|
339 |
12164 | 340 switch(codec->codec_type){ |
341 case CODEC_TYPE_AUDIO:{ | |
342 WAVEFORMATEX *wf= calloc(sizeof(WAVEFORMATEX) + codec->extradata_size, 1); | |
18985 | 343 sh_audio_t* sh_audio; |
18762 | 344 if(priv->audio_streams >= MAX_A_STREAMS) |
345 break; | |
18985 | 346 sh_audio=new_sh_audio(demuxer, i); |
23010
74efb0fa8a0b
with -identify show audio and video id; patch by Andrew Savchenko (Bircoph list ru)
nicodvb
parents:
22990
diff
changeset
|
347 mp_msg(MSGT_DEMUX, MSGL_INFO, MSGTR_AudioID, "lavf", i); |
18762 | 348 if(!sh_audio) |
349 break; | |
350 priv->astreams[priv->audio_streams] = i; | |
12164 | 351 priv->audio_streams++; |
22990
a76748e71a18
Ignore mp4a audio tag, it is meaningless since we get it for all mp4 files
reimar
parents:
22972
diff
changeset
|
352 // mp4a tag is used for all mp4 files no matter what they actually contain |
a76748e71a18
Ignore mp4a audio tag, it is meaningless since we get it for all mp4 files
reimar
parents:
22972
diff
changeset
|
353 if(codec->codec_tag == MKTAG('m', 'p', '4', 'a')) |
a76748e71a18
Ignore mp4a audio tag, it is meaningless since we get it for all mp4 files
reimar
parents:
22972
diff
changeset
|
354 codec->codec_tag= 0; |
24674
f6cf2c01315d
Format 0x01 cannot be used with "AMV IMA ADPCM", because it belongs to normal PCM.
voroshil
parents:
24653
diff
changeset
|
355 if(codec->codec_id == CODEC_ID_ADPCM_IMA_AMV) |
f6cf2c01315d
Format 0x01 cannot be used with "AMV IMA ADPCM", because it belongs to normal PCM.
voroshil
parents:
24653
diff
changeset
|
356 codec->codec_tag= MKTAG('A','M','V','A'); |
12164 | 357 if(!codec->codec_tag) |
21966
d9494ca70ca7
Simplify by using av_codec_get_id and include riff.h only in demux_lavf.c
reimar
parents:
21962
diff
changeset
|
358 codec->codec_tag= av_codec_get_tag(mp_wav_taglists, codec->codec_id); |
12164 | 359 wf->wFormatTag= codec->codec_tag; |
360 wf->nChannels= codec->channels; | |
361 wf->nSamplesPerSec= codec->sample_rate; | |
362 wf->nAvgBytesPerSec= codec->bit_rate/8; | |
22266 | 363 wf->nBlockAlign= codec->block_align ? codec->block_align : 1; |
12164 | 364 wf->wBitsPerSample= codec->bits_per_sample; |
365 wf->cbSize= codec->extradata_size; | |
366 if(codec->extradata_size){ | |
367 memcpy( | |
368 wf + 1, | |
369 codec->extradata, | |
370 codec->extradata_size); | |
371 } | |
372 sh_audio->wf= wf; | |
15011 | 373 sh_audio->audio.dwSampleSize= codec->block_align; |
374 if(codec->frame_size && codec->sample_rate){ | |
375 sh_audio->audio.dwScale=codec->frame_size; | |
376 sh_audio->audio.dwRate= codec->sample_rate; | |
377 }else{ | |
378 sh_audio->audio.dwScale= codec->block_align ? codec->block_align*8 : 8; | |
379 sh_audio->audio.dwRate = codec->bit_rate; | |
380 } | |
381 g= ff_gcd(sh_audio->audio.dwScale, sh_audio->audio.dwRate); | |
382 sh_audio->audio.dwScale /= g; | |
383 sh_audio->audio.dwRate /= g; | |
384 // printf("sca:%d rat:%d fs:%d sr:%d ba:%d\n", sh_audio->audio.dwScale, sh_audio->audio.dwRate, codec->frame_size, codec->sample_rate, codec->block_align); | |
12164 | 385 sh_audio->ds= demuxer->audio; |
386 sh_audio->format= codec->codec_tag; | |
387 sh_audio->channels= codec->channels; | |
388 sh_audio->samplerate= codec->sample_rate; | |
15007 | 389 sh_audio->i_bps= codec->bit_rate/8; |
16134
a1fd1a7eeb35
lavf demuxer with raw PCM fix (and a related hang)
reimar
parents:
16000
diff
changeset
|
390 switch (codec->codec_id) { |
a1fd1a7eeb35
lavf demuxer with raw PCM fix (and a related hang)
reimar
parents:
16000
diff
changeset
|
391 case CODEC_ID_PCM_S8: |
a1fd1a7eeb35
lavf demuxer with raw PCM fix (and a related hang)
reimar
parents:
16000
diff
changeset
|
392 case CODEC_ID_PCM_U8: |
a1fd1a7eeb35
lavf demuxer with raw PCM fix (and a related hang)
reimar
parents:
16000
diff
changeset
|
393 sh_audio->samplesize = 1; |
16135 | 394 break; |
16134
a1fd1a7eeb35
lavf demuxer with raw PCM fix (and a related hang)
reimar
parents:
16000
diff
changeset
|
395 case CODEC_ID_PCM_S16LE: |
a1fd1a7eeb35
lavf demuxer with raw PCM fix (and a related hang)
reimar
parents:
16000
diff
changeset
|
396 case CODEC_ID_PCM_S16BE: |
a1fd1a7eeb35
lavf demuxer with raw PCM fix (and a related hang)
reimar
parents:
16000
diff
changeset
|
397 case CODEC_ID_PCM_U16LE: |
a1fd1a7eeb35
lavf demuxer with raw PCM fix (and a related hang)
reimar
parents:
16000
diff
changeset
|
398 case CODEC_ID_PCM_U16BE: |
a1fd1a7eeb35
lavf demuxer with raw PCM fix (and a related hang)
reimar
parents:
16000
diff
changeset
|
399 sh_audio->samplesize = 2; |
16135 | 400 break; |
401 case CODEC_ID_PCM_ALAW: | |
402 sh_audio->format = 0x6; | |
403 break; | |
404 case CODEC_ID_PCM_MULAW: | |
405 sh_audio->format = 0x7; | |
406 break; | |
16134
a1fd1a7eeb35
lavf demuxer with raw PCM fix (and a related hang)
reimar
parents:
16000
diff
changeset
|
407 } |
17977
f70772d02eaa
Convert printfs in aviprint.c to mp_msg and give the information printing
diego
parents:
17932
diff
changeset
|
408 if( mp_msg_test(MSGT_HEADER,MSGL_V) ) print_wave_header(sh_audio->wf, MSGL_V); |
18775 | 409 if((audio_lang && st->language[0] && !strncmp(audio_lang, st->language, 3)) |
410 || (demuxer->audio->id == i || demuxer->audio->id == -1) | |
411 ) { | |
412 demuxer->audio->id = i; | |
413 demuxer->audio->sh= demuxer->a_streams[i]; | |
414 } | |
415 else | |
15004 | 416 st->discard= AVDISCARD_ALL; |
12164 | 417 break;} |
418 case CODEC_TYPE_VIDEO:{ | |
21100
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
419 sh_video_t* sh_video; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
420 BITMAPINFOHEADER *bih; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
421 if(priv->video_streams >= MAX_V_STREAMS) |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
422 break; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
423 sh_video=new_sh_video(demuxer, i); |
23010
74efb0fa8a0b
with -identify show audio and video id; patch by Andrew Savchenko (Bircoph list ru)
nicodvb
parents:
22990
diff
changeset
|
424 mp_msg(MSGT_DEMUX, MSGL_INFO, MSGTR_VideoID, "lavf", i); |
21100
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
425 if(!sh_video) break; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
426 priv->vstreams[priv->video_streams] = i; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
427 priv->video_streams++; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
428 bih=calloc(sizeof(BITMAPINFOHEADER) + codec->extradata_size,1); |
12164 | 429 |
430 if(!codec->codec_tag) | |
21966
d9494ca70ca7
Simplify by using av_codec_get_id and include riff.h only in demux_lavf.c
reimar
parents:
21962
diff
changeset
|
431 codec->codec_tag= av_codec_get_tag(mp_bmp_taglists, codec->codec_id); |
12164 | 432 bih->biSize= sizeof(BITMAPINFOHEADER) + codec->extradata_size; |
433 bih->biWidth= codec->width; | |
434 bih->biHeight= codec->height; | |
435 bih->biBitCount= codec->bits_per_sample; | |
436 bih->biSizeImage = bih->biWidth * bih->biHeight * bih->biBitCount/8; | |
437 bih->biCompression= codec->codec_tag; | |
438 sh_video->bih= bih; | |
439 sh_video->disp_w= codec->width; | |
440 sh_video->disp_h= codec->height; | |
16718
044260623695
makes demux_lavf (-demuxer 35) use the framerate specified in the container
gpoirier
parents:
16346
diff
changeset
|
441 if (st->time_base.den) { /* if container has time_base, use that */ |
044260623695
makes demux_lavf (-demuxer 35) use the framerate specified in the container
gpoirier
parents:
16346
diff
changeset
|
442 sh_video->video.dwRate= st->time_base.den; |
044260623695
makes demux_lavf (-demuxer 35) use the framerate specified in the container
gpoirier
parents:
16346
diff
changeset
|
443 sh_video->video.dwScale= st->time_base.num; |
044260623695
makes demux_lavf (-demuxer 35) use the framerate specified in the container
gpoirier
parents:
16346
diff
changeset
|
444 } else { |
15308 | 445 sh_video->video.dwRate= codec->time_base.den; |
446 sh_video->video.dwScale= codec->time_base.num; | |
16718
044260623695
makes demux_lavf (-demuxer 35) use the framerate specified in the container
gpoirier
parents:
16346
diff
changeset
|
447 } |
17556 | 448 sh_video->fps=av_q2d(st->r_frame_rate); |
449 sh_video->frametime=1/av_q2d(st->r_frame_rate); | |
12164 | 450 sh_video->format = bih->biCompression; |
12167 | 451 sh_video->aspect= codec->width * codec->sample_aspect_ratio.num |
452 / (float)(codec->height * codec->sample_aspect_ratio.den); | |
15007 | 453 sh_video->i_bps= codec->bit_rate/8; |
12167 | 454 mp_msg(MSGT_DEMUX,MSGL_DBG2,"aspect= %d*%d/(%d*%d)\n", |
455 codec->width, codec->sample_aspect_ratio.num, | |
456 codec->height, codec->sample_aspect_ratio.den); | |
457 | |
12164 | 458 sh_video->ds= demuxer->video; |
459 if(codec->extradata_size) | |
460 memcpy(sh_video->bih + 1, codec->extradata, codec->extradata_size); | |
17977
f70772d02eaa
Convert printfs in aviprint.c to mp_msg and give the information printing
diego
parents:
17932
diff
changeset
|
461 if( mp_msg_test(MSGT_HEADER,MSGL_V) ) print_video_header(sh_video->bih, MSGL_V); |
12164 | 462 /* short biPlanes; |
463 int biXPelsPerMeter; | |
464 int biYPelsPerMeter; | |
465 int biClrUsed; | |
466 int biClrImportant;*/ | |
15004 | 467 if(demuxer->video->id != i && demuxer->video->id != -1) |
468 st->discard= AVDISCARD_ALL; | |
469 else{ | |
470 demuxer->video->id = i; | |
471 demuxer->video->sh= demuxer->v_streams[i]; | |
472 } | |
12164 | 473 break;} |
23758 | 474 case CODEC_TYPE_SUBTITLE:{ |
475 sh_sub_t* sh_sub; | |
476 if(priv->sub_streams >= MAX_S_STREAMS) | |
477 break; | |
478 /* only support text subtitles for now */ | |
479 if(codec->codec_id != CODEC_ID_TEXT) | |
480 break; | |
481 sh_sub = new_sh_sub_sid(demuxer, i, priv->sub_streams); | |
482 mp_msg(MSGT_DEMUX, MSGL_INFO, MSGTR_SubtitleID, "lavf", priv->sub_streams); | |
483 if(!sh_sub) break; | |
484 priv->sstreams[priv->sub_streams] = i; | |
485 sh_sub->type = 't'; | |
486 demuxer->sub->sh = demuxer->s_streams[priv->sub_streams++]; | |
487 break;} | |
15004 | 488 default: |
489 st->discard= AVDISCARD_ALL; | |
12164 | 490 } |
491 } | |
492 | |
493 mp_msg(MSGT_HEADER,MSGL_V,"LAVF: %d audio and %d video streams found\n",priv->audio_streams,priv->video_streams); | |
13749 | 494 mp_msg(MSGT_HEADER,MSGL_V,"LAVF: build %d\n", LIBAVFORMAT_BUILD); |
12164 | 495 if(!priv->audio_streams) demuxer->audio->id=-2; // nosound |
496 // else if(best_audio > 0 && demuxer->audio->id == -1) demuxer->audio->id=best_audio; | |
497 if(!priv->video_streams){ | |
498 if(!priv->audio_streams){ | |
499 mp_msg(MSGT_HEADER,MSGL_ERR,"LAVF: no audio or video headers found - broken file?\n"); | |
16175 | 500 return NULL; |
12164 | 501 } |
502 demuxer->video->id=-2; // audio-only | |
503 } //else if (best_video > 0 && demuxer->video->id == -1) demuxer->video->id = best_video; | |
504 | |
16175 | 505 return demuxer; |
12164 | 506 } |
507 | |
16175 | 508 static int demux_lavf_fill_buffer(demuxer_t *demux, demux_stream_t *dsds){ |
12164 | 509 lavf_priv_t *priv= demux->priv; |
510 AVPacket pkt; | |
511 demux_packet_t *dp; | |
512 demux_stream_t *ds; | |
513 int id; | |
514 mp_msg(MSGT_DEMUX,MSGL_DBG2,"demux_lavf_fill_buffer()\n"); | |
515 | |
516 demux->filepos=stream_tell(demux->stream); | |
517 | |
518 if(av_read_frame(priv->avfc, &pkt) < 0) | |
519 return 0; | |
520 | |
521 id= pkt.stream_index; | |
522 | |
523 if(id==demux->audio->id){ | |
524 // audio | |
525 ds=demux->audio; | |
526 if(!ds->sh){ | |
527 ds->sh=demux->a_streams[id]; | |
528 mp_msg(MSGT_DEMUX,MSGL_V,"Auto-selected LAVF audio ID = %d\n",ds->id); | |
529 } | |
530 } else if(id==demux->video->id){ | |
531 // video | |
532 ds=demux->video; | |
533 if(!ds->sh){ | |
534 ds->sh=demux->v_streams[id]; | |
535 mp_msg(MSGT_DEMUX,MSGL_V,"Auto-selected LAVF video ID = %d\n",ds->id); | |
536 } | |
23758 | 537 } else if(id==demux->sub->id){ |
538 // subtitle | |
539 ds=demux->sub; | |
540 sub_utf8=1; | |
14611 | 541 } else { |
542 av_free_packet(&pkt); | |
543 return 1; | |
544 } | |
12164 | 545 |
546 if(0/*pkt.destruct == av_destruct_packet*/){ | |
547 //ok kids, dont try this at home :) | |
19062
83c3afeab35d
drops casts from void * on malloc/calloc from libmpdemux code
reynaldo
parents:
18985
diff
changeset
|
548 dp=malloc(sizeof(demux_packet_t)); |
12164 | 549 dp->len=pkt.size; |
550 dp->next=NULL; | |
551 dp->refcount=1; | |
552 dp->master=NULL; | |
553 dp->buffer=pkt.data; | |
554 pkt.destruct= NULL; | |
555 }else{ | |
556 dp=new_demux_packet(pkt.size); | |
557 memcpy(dp->buffer, pkt.data, pkt.size); | |
558 av_free_packet(&pkt); | |
559 } | |
560 | |
13747 | 561 if(pkt.pts != AV_NOPTS_VALUE){ |
15308 | 562 dp->pts=pkt.pts * av_q2d(priv->avfc->streams[id]->time_base); |
563 priv->last_pts= dp->pts * AV_TIME_BASE; | |
23758 | 564 if(pkt.duration) |
565 dp->endpts = dp->pts + pkt.duration * av_q2d(priv->avfc->streams[id]->time_base); | |
13747 | 566 } |
12164 | 567 dp->pos=demux->filepos; |
568 dp->flags= !!(pkt.flags&PKT_FLAG_KEY); | |
569 // append packet to DS stream: | |
570 ds_add_packet(ds,dp); | |
571 return 1; | |
572 } | |
573 | |
17636 | 574 static void demux_seek_lavf(demuxer_t *demuxer, float rel_seek_secs, float audio_delay, int flags){ |
12168 | 575 lavf_priv_t *priv = demuxer->priv; |
20070 | 576 int avsflags = 0; |
17636 | 577 mp_msg(MSGT_DEMUX,MSGL_DBG2,"demux_seek_lavf(%p, %f, %f, %d)\n", demuxer, rel_seek_secs, audio_delay, flags); |
19073
8b52dad54b1d
Remove #if LIBAVCODEC_BUILD >= XXX and #if LIBAVFORMAT_BUILD >= XXX jungle.
diego
parents:
19062
diff
changeset
|
578 |
20070 | 579 if (flags & 1) // absolute seek |
580 priv->last_pts = priv->avfc->start_time; | |
581 if (flags & 2) { // percent seek | |
582 if (priv->avfc->duration == 0 || priv->avfc->duration == AV_NOPTS_VALUE) | |
583 return; | |
584 priv->last_pts += rel_seek_secs * priv->avfc->duration; | |
585 } else { | |
586 priv->last_pts += rel_seek_secs * AV_TIME_BASE; | |
587 if (rel_seek_secs < 0) avsflags = AVSEEK_FLAG_BACKWARD; | |
588 } | |
589 av_seek_frame(priv->avfc, -1, priv->last_pts, avsflags); | |
12164 | 590 } |
591 | |
16175 | 592 static int demux_lavf_control(demuxer_t *demuxer, int cmd, void *arg) |
12164 | 593 { |
594 lavf_priv_t *priv = demuxer->priv; | |
595 | |
596 switch (cmd) { | |
12168 | 597 case DEMUXER_CTRL_GET_TIME_LENGTH: |
19207
c636a4e9565a
Do not treat AV_NOPTS_VALUE as a valid duration value.
reimar
parents:
19160
diff
changeset
|
598 if (priv->avfc->duration == 0 || priv->avfc->duration == AV_NOPTS_VALUE) |
12164 | 599 return DEMUXER_CTRL_DONTKNOW; |
600 | |
16346
6ff303d2876b
Make -identify's 'ID_LENGTH=' print a float and not an integer.. The
ods15
parents:
16175
diff
changeset
|
601 *((double *)arg) = (double)priv->avfc->duration / AV_TIME_BASE; |
12164 | 602 return DEMUXER_CTRL_OK; |
603 | |
604 case DEMUXER_CTRL_GET_PERCENT_POS: | |
19207
c636a4e9565a
Do not treat AV_NOPTS_VALUE as a valid duration value.
reimar
parents:
19160
diff
changeset
|
605 if (priv->avfc->duration == 0 || priv->avfc->duration == AV_NOPTS_VALUE) |
12164 | 606 return DEMUXER_CTRL_DONTKNOW; |
607 | |
19160
ccb42ce33c23
Take start time into consideration when calculation percentage position
reimar
parents:
19073
diff
changeset
|
608 *((int *)arg) = (int)((priv->last_pts - priv->avfc->start_time)*100 / priv->avfc->duration); |
12168 | 609 return DEMUXER_CTRL_OK; |
18762 | 610 case DEMUXER_CTRL_SWITCH_AUDIO: |
21100
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
611 case DEMUXER_CTRL_SWITCH_VIDEO: |
18762 | 612 { |
613 int id = *((int*)arg); | |
614 int newid = -2; | |
615 int i, curridx = -2; | |
21100
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
616 int nstreams, *pstreams; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
617 demux_stream_t *ds; |
18762 | 618 |
21100
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
619 if(cmd == DEMUXER_CTRL_SWITCH_VIDEO) |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
620 { |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
621 ds = demuxer->video; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
622 nstreams = priv->video_streams; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
623 pstreams = priv->vstreams; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
624 } |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
625 else |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
626 { |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
627 ds = demuxer->audio; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
628 nstreams = priv->audio_streams; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
629 pstreams = priv->astreams; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
630 } |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
631 if(ds->id == -2) |
18762 | 632 return DEMUXER_CTRL_NOTIMPL; |
21100
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
633 for(i = 0; i < nstreams; i++) |
18762 | 634 { |
21100
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
635 if(pstreams[i] == ds->id) //current stream id |
18762 | 636 { |
637 curridx = i; | |
638 break; | |
639 } | |
640 } | |
641 | |
642 if(id < 0) | |
643 { | |
21100
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
644 i = (curridx + 1) % nstreams; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
645 newid = pstreams[i]; |
18762 | 646 } |
647 else | |
648 { | |
21100
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
649 for(i = 0; i < nstreams; i++) |
18762 | 650 { |
21100
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
651 if(pstreams[i] == id) |
18762 | 652 { |
653 newid = id; | |
654 break; | |
655 } | |
656 } | |
657 } | |
658 if(newid == -2 || i == curridx) | |
659 return DEMUXER_CTRL_NOTIMPL; | |
660 else | |
661 { | |
21100
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
662 ds_free_packs(ds); |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
663 priv->avfc->streams[ds->id]->discard = AVDISCARD_ALL; |
6bc989360c8b
check we aren't short of sh_videos before allocating another one
nicodvb
parents:
20990
diff
changeset
|
664 *((int*)arg) = ds->id = newid; |
18762 | 665 priv->avfc->streams[newid]->discard = AVDISCARD_NONE; |
666 return DEMUXER_CTRL_OK; | |
667 } | |
668 } | |
12164 | 669 default: |
670 return DEMUXER_CTRL_NOTIMPL; | |
671 } | |
672 } | |
673 | |
23758 | 674 /** \brief Get the language code for a subtitle track. |
675 | |
676 Retrieves the language code for a subtitle track. | |
677 | |
678 \param demuxer The demuxer to work on | |
679 \param track_num The subtitle track number to get the language from | |
680 */ | |
681 char *demux_lavf_sub_lang(demuxer_t *demuxer, int track_num) | |
682 { | |
683 lavf_priv_t *priv = demuxer->priv; | |
684 return priv->avfc->streams[priv->sstreams[track_num]]->language; | |
685 } | |
686 | |
16175 | 687 static void demux_close_lavf(demuxer_t *demuxer) |
12164 | 688 { |
689 lavf_priv_t* priv = demuxer->priv; | |
690 if (priv){ | |
12304
434242b0706c
fix possible segfault on lavf demuxer patch by (adland <adland123 at yahoo dot com>)
michael
parents:
12168
diff
changeset
|
691 if(priv->avfc) |
434242b0706c
fix possible segfault on lavf demuxer patch by (adland <adland123 at yahoo dot com>)
michael
parents:
12168
diff
changeset
|
692 { |
24757 | 693 av_freep(&priv->avfc->key); |
12304
434242b0706c
fix possible segfault on lavf demuxer patch by (adland <adland123 at yahoo dot com>)
michael
parents:
12168
diff
changeset
|
694 av_close_input_file(priv->avfc); priv->avfc= NULL; |
434242b0706c
fix possible segfault on lavf demuxer patch by (adland <adland123 at yahoo dot com>)
michael
parents:
12168
diff
changeset
|
695 } |
12164 | 696 free(priv); demuxer->priv= NULL; |
697 } | |
698 } | |
699 | |
16175 | 700 |
701 demuxer_desc_t demuxer_desc_lavf = { | |
702 "libavformat demuxer", | |
703 "lavf", | |
704 "libavformat", | |
705 "Michael Niedermayer", | |
706 "supports many formats, requires libavformat", | |
707 DEMUXER_TYPE_LAVF, | |
708 0, // Check after other demuxer | |
709 lavf_check_file, | |
710 demux_lavf_fill_buffer, | |
711 demux_open_lavf, | |
712 demux_close_lavf, | |
713 demux_seek_lavf, | |
714 demux_lavf_control | |
715 }; | |
716 | |
22971
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
717 demuxer_desc_t demuxer_desc_lavf_preferred = { |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
718 "libavformat preferred demuxer", |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
719 "lavfpref", |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
720 "libavformat", |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
721 "Michael Niedermayer", |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
722 "supports many formats, requires libavformat", |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
723 DEMUXER_TYPE_LAVF_PREFERRED, |
24354
ae226b882283
Mark lavfpref demuxer as safe, so it that it is actually used for e.g.
reimar
parents:
24085
diff
changeset
|
724 1, |
22971
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
725 lavf_check_preferred_file, |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
726 demux_lavf_fill_buffer, |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
727 demux_open_lavf, |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
728 demux_close_lavf, |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
729 demux_seek_lavf, |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
730 demux_lavf_control |
a1b2fbb000fc
Add lavf_preferred demuxer for lavf formats we want to be probed
reimar
parents:
22918
diff
changeset
|
731 }; |