[vlc-devel] [PATCH 09/15] avformat demux: use new IO API
KO Myung-Hun
komh78 at gmail.com
Fri Mar 2 16:03:06 CET 2012
From: Rafaël Carré <funman at videolan.org>
- Use AVIOContext instead of ByteIOContext
- Use avformat_open_input instead of av_open_input_stream
- Use avio_alloc_context instead of init_put_byte, allocate context on the heap
- Use AVIOContext.seekable
print avformat_open_input errors
avformat_open_input is the most recent and is documented as available since
libavformat 53.2.0 (other changes happened in 52.105)
avformat_open_input was introduced in 52.94 in FFmpeg
(cherry picked from commit 4c3037ac45b92853d5d85f7bedebdb4b281da0c6)
Signed-off-by: KO Myung-Hun <komh at chollian.net>
---
modules/demux/avformat/demux.c | 50 ++++++++++++++++++++++++----------------
1 files changed, 30 insertions(+), 20 deletions(-)
diff --git a/modules/demux/avformat/demux.c b/modules/demux/avformat/demux.c
index 357f46c..6fa109b 100644
--- a/modules/demux/avformat/demux.c
+++ b/modules/demux/avformat/demux.c
@@ -67,7 +67,10 @@
*****************************************************************************/
struct demux_sys_t
{
+#if LIBAVFORMAT_VERSION_INT < ((53<<16)+(2<<8)+0)
ByteIOContext io;
+#endif
+
int io_buffer_size;
uint8_t *io_buffer;
@@ -132,6 +135,7 @@ int OpenDemux( vlc_object_t *p_this )
msg_Warn( p_demux, "cannot peek" );
return VLC_EGENERIC;
}
+ stream_Control( p_demux->s, STREAM_CAN_SEEK, &b_can_seek );
vlc_avcodec_lock();
av_register_all(); /* Can be called several times */
@@ -220,35 +224,36 @@ int OpenDemux( vlc_object_t *p_this )
/* Create I/O wrapper */
p_sys->io_buffer_size = 32768; /* FIXME */
p_sys->io_buffer = malloc( p_sys->io_buffer_size );
- init_put_byte( &p_sys->io, p_sys->io_buffer, p_sys->io_buffer_size,
- 0, p_demux, IORead, NULL, IOSeek );
- stream_Control( p_demux->s, STREAM_CAN_SEEK, &b_can_seek );
- if( !b_can_seek )
- {
- /* Tell avformat that input is stream, so it doesn't get stuck
- when trying av_find_stream_info() trying to seek all the wrong places
- init_put_byte defaults io.is_streamed=0, so thats why we set them after it
- */
- p_sys->io.is_streamed = 1;
-#if defined(AVIO_SEEKABLE_NORMAL)
- p_sys->io.seekable = 0;
-#endif
+#if LIBAVFORMAT_VERSION_INT >= ((53<<16)+(2<<8)+0)
+ AVIOContext *io = avio_alloc_context( p_sys->io_buffer,
+ p_sys->io_buffer_size, 0, p_demux, IORead, NULL, IOSeek );
+ io->seekable = b_can_seek ? AVIO_SEEKABLE_NORMAL : 0;
+ error = avformat_open_input(&p_sys->ic, psz_url, p_sys->fmt, NULL);
+ if (error == 0)
+ {
+ p_sys->ic->flags |= AVFMT_FLAG_CUSTOM_IO;
+ p_sys->ic->pb = io;
}
+#else
+ init_put_byte( &p_sys->io, p_sys->io_buffer, p_sys->io_buffer_size, 0,
+ p_demux, IORead, NULL, IOSeek );
+ p_sys->io.is_streamed = !b_can_seek;
+# if defined(AVIO_SEEKABLE_NORMAL)
+ p_sys->io.seekable = !!b_can_seek;
+# endif
+ error = av_open_input_stream(&p_sys->ic, &p_sys->io, psz_url, p_sys->fmt, NULL);
+#endif
-
- /* Open it */
- if( av_open_input_stream( &p_sys->ic, &p_sys->io, psz_url,
- p_sys->fmt, NULL ) )
+ free( psz_url );
+ if( error < 0 )
{
- msg_Err( p_demux, "av_open_input_stream failed" );
+ errno = AVUNERROR(error);
+ msg_Err( p_demux, "Could not open %s: %m", psz_url );
p_sys->ic = NULL;
- free( psz_url );
CloseDemux( p_this );
return VLC_EGENERIC;
}
- free( psz_url );
- psz_url = NULL;
vlc_avcodec_lock(); /* avformat calls avcodec behind our back!!! */
#if LIBAVFORMAT_VERSION_INT >= ((53<<16)+(26<<8)+0)
@@ -537,11 +542,16 @@ void CloseDemux( vlc_object_t *p_this )
free( p_sys->tk_pcr );
if( p_sys->ic )
+ {
+#if LIBAVFORMAT_VERSION_INT >= ((53<<16)+(2<<8)+0)
+ av_free( p_sys->ic->pb );
+#endif
#if LIBAVFORMAT_VERSION_INT >= ((53<<16)+(26<<8)+0)
avformat_close_input( &p_sys->ic );
#else
av_close_input_stream( p_sys->ic );
#endif
+ }
for( int i = 0; i < p_sys->i_attachments; i++ )
free( p_sys->attachments[i] );
--
1.7.3.2
More information about the vlc-devel
mailing list