diff --git a/configure.ac b/configure.ac index 4941da481464614ef34d90eabdfe3f3a1ff2169a..1324da5fb48df018cc43b685b0c42112fca0d05e 100644 --- a/configure.ac +++ b/configure.ac @@ -2360,7 +2360,7 @@ AC_ARG_ENABLE(avformat, ]) if test "${enable_avformat}" != "no" then - PKG_CHECK_MODULES(AVFORMAT,[libavformat > 52.30.0 libavcodec libavutil], + PKG_CHECK_MODULES(AVFORMAT,[libavformat >= 53.21.0 libavcodec libavutil], [ VLC_SAVE_FLAGS CPPFLAGS="${CPPFLAGS} ${AVFORMAT_CFLAGS}" diff --git a/modules/demux/avformat/avformat.c b/modules/demux/avformat/avformat.c index 1b4b07b592a0780497daa7f5c2934e63592d3664..12815e5f09153a5ba32f7dd21b7fd1715372cec6 100644 --- a/modules/demux/avformat/avformat.c +++ b/modules/demux/avformat/avformat.c @@ -56,9 +56,7 @@ vlc_module_begin () set_capability( "sout mux", 2 ) add_string( "sout-avformat-mux", NULL, MUX_TEXT, MUX_LONGTEXT, true ) add_obsolete_string("ffmpeg-mux") /* removed since 2.1.0 */ -#if (LIBAVFORMAT_VERSION_INT >= ((53<<16)+(2<<8)+0)) add_string( "sout-avformat-options", NULL, AV_OPTIONS_TEXT, AV_OPTIONS_LONGTEXT, true ) -#endif set_callbacks( OpenMux, CloseMux ) #endif #ifndef MERGE_FFMPEG diff --git a/modules/demux/avformat/demux.c b/modules/demux/avformat/demux.c index fa1ea75d4c14338e65040171c014faf20993cd4e..74447ed2c63ea09dc238047bde2891003f23403a 100644 --- a/modules/demux/avformat/demux.c +++ b/modules/demux/avformat/demux.c @@ -59,19 +59,13 @@ /* Version checking */ #if defined(HAVE_FFMPEG_AVFORMAT_H) || defined(HAVE_LIBAVFORMAT_AVFORMAT_H) -#if (LIBAVCODEC_VERSION_INT >= ((51<<16)+(50<<8)+0) ) -# define HAVE_AVUTIL_CODEC_ATTACHMENT 1 -#endif +# define HAVE_AVUTIL_CODEC_ATTACHMENT 1 /***************************************************************************** * demux_sys_t: demux descriptor *****************************************************************************/ struct demux_sys_t { -#if LIBAVFORMAT_VERSION_INT < ((53<<16)+(2<<8)+0) - ByteIOContext io; -#endif - int io_buffer_size; uint8_t *io_buffer; @@ -224,21 +218,11 @@ int OpenDemux( vlc_object_t *p_this ) p_sys->io_buffer_size = 32768; /* FIXME */ p_sys->io_buffer = malloc( p_sys->io_buffer_size ); -#if LIBAVFORMAT_VERSION_INT >= ((53<<16)+(2<<8)+0) p_sys->ic = avformat_alloc_context(); p_sys->ic->pb = avio_alloc_context( p_sys->io_buffer, p_sys->io_buffer_size, 0, p_demux, IORead, NULL, IOSeek ); p_sys->ic->pb->seekable = b_can_seek ? AVIO_SEEKABLE_NORMAL : 0; error = avformat_open_input(&p_sys->ic, psz_url, p_sys->fmt, NULL); -#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 free( psz_url ); if( error < 0 ) @@ -561,9 +545,7 @@ void CloseDemux( vlc_object_t *p_this ) 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 diff --git a/modules/demux/avformat/mux.c b/modules/demux/avformat/mux.c index bebe5838d5cf60f581813fc0a8ebd26d54260a98..ced7ca98ef6ecc7006635b528390817fef769eaf 100644 --- a/modules/demux/avformat/mux.c +++ b/modules/demux/avformat/mux.c @@ -39,10 +39,6 @@ #include "../../codec/avcodec/avcodec.h" #include "../../codec/avcodec/avcommon.h" -/* Support for deprecated APIs */ -#if LIBAVFORMAT_VERSION_INT < ((52<<16)+(105<<8)+0) -# define avio_flush put_flush_packet -#endif //#define AVFORMAT_DEBUG 1 @@ -55,11 +51,7 @@ static const char *const ppsz_mux_options[] = { *****************************************************************************/ struct sout_mux_sys_t { -#if LIBAVFORMAT_VERSION_INT >= ((52<<16)+(105<<8)+0) AVIOContext *io; -#else - ByteIOContext io; -#endif int io_buffer_size; uint8_t *io_buffer; @@ -100,21 +92,13 @@ int OpenMux( vlc_object_t *p_this ) psz_mux = var_GetNonEmptyString( p_mux, "sout-avformat-mux" ); if( psz_mux ) { -#if( LIBAVFORMAT_VERSION_INT >= AV_VERSION_INT( 52, 45, 0 ) ) file_oformat = av_guess_format( psz_mux, NULL, NULL ); -#else - file_oformat = guess_format( psz_mux, NULL, NULL ); -#endif free( psz_mux ); } else { file_oformat = -#if( LIBAVFORMAT_VERSION_INT >= AV_VERSION_INT( 52, 45, 0 ) ) av_guess_format( NULL, p_mux->p_access->psz_path, NULL); -#else - guess_format( NULL, p_mux->p_access->psz_path, NULL); -#endif } if (!file_oformat) { @@ -141,33 +125,11 @@ int OpenMux( vlc_object_t *p_this ) p_sys->io_buffer_size = 32768; /* FIXME */ p_sys->io_buffer = malloc( p_sys->io_buffer_size ); -#if (LIBAVFORMAT_VERSION_INT >= ((52<<16)+(105<<8)+0)) p_sys->io = avio_alloc_context( -#else - init_put_byte( &p_sys->io, -#endif p_sys->io_buffer, p_sys->io_buffer_size, 1, p_mux, NULL, IOWrite, IOSeek ); - -#if (LIBAVFORMAT_VERSION_INT < ((52<<16)+(105<<8)+0)) - AVFormatParameters params, *ap = ¶ms; - memset( ap, 0, sizeof(*ap) ); - if( av_set_parameters( p_sys->oc, ap ) < 0 ) - { - msg_Err( p_mux, "invalid encoding parameters" ); - av_free( p_sys->oc ); - free( p_sys->io_buffer ); - free( p_sys ); - return VLC_EGENERIC; - } -#endif - -#if (LIBAVFORMAT_VERSION_INT >= ((52<<16)+(105<<8)+0)) p_sys->oc->pb = p_sys->io; -#else - p_sys->oc->pb = &p_sys->io; -#endif p_sys->oc->nb_streams = 0; p_sys->b_write_header = true; @@ -190,21 +152,7 @@ void CloseMux( vlc_object_t *p_this ) msg_Err( p_mux, "could not write trailer" ); } -#if( LIBAVFORMAT_VERSION_INT >= AV_VERSION_INT( 52, 96, 0 ) ) avformat_free_context(p_sys->oc); -#else - for( unsigned i = 0 ; i < p_sys->oc->nb_streams; i++ ) - { - av_free( p_sys->oc->streams[i]->codec->extradata ); - av_free( p_sys->oc->streams[i]->codec ); -#if( LIBAVFORMAT_VERSION_INT >= AV_VERSION_INT( 52, 81, 0 ) ) - av_free( p_sys->oc->streams[i]->info ); -#endif - av_free( p_sys->oc->streams[i] ); - } - av_free( p_sys->oc->streams ); - av_free( p_sys->oc ); -#endif free( p_sys->io_buffer ); free( p_sys ); @@ -238,11 +186,7 @@ static int AddStream( sout_mux_t *p_mux, sout_input_t *p_input ) return VLC_EGENERIC; } -#if (LIBAVFORMAT_VERSION_INT >= ((53<<16)+(10<<8)+0)) stream = avformat_new_stream( p_sys->oc, NULL); -#else - stream = av_new_stream( p_sys->oc, p_sys->oc->nb_streams); -#endif if( !stream ) { free( p_input->p_sys ); @@ -277,10 +221,7 @@ static int AddStream( sout_mux_t *p_mux, sout_input_t *p_input ) &codec->sample_aspect_ratio.den, p_input->p_fmt->video.i_sar_num, p_input->p_fmt->video.i_sar_den, 1 << 30 /* something big */ ); -#if LIBAVFORMAT_VERSION_INT >= ((52<<16)+(21<<8)+0) stream->sample_aspect_ratio.num = codec->sample_aspect_ratio.num; - stream->sample_aspect_ratio.den = codec->sample_aspect_ratio.den; -#endif codec->time_base.den = p_input->p_fmt->video.i_frame_rate; codec->time_base.num = p_input->p_fmt->video.i_frame_rate_base; break; @@ -288,21 +229,12 @@ static int AddStream( sout_mux_t *p_mux, sout_input_t *p_input ) } codec->bit_rate = p_input->p_fmt->i_bitrate; -#if LIBAVFORMAT_VERSION_INT >= ((51<<16)+(8<<8)+0) codec->codec_tag = av_codec_get_tag( p_sys->oc->oformat->codec_tag, i_codec_id ); if( !codec->codec_tag && i_codec_id == CODEC_ID_MP2 ) { i_codec_id = CODEC_ID_MP3; codec->codec_tag = av_codec_get_tag( p_sys->oc->oformat->codec_tag, i_codec_id ); } -#else -# warning "WARNING!!!!!!!" -# warning "Using libavformat muxing with versions older than 51.8.0 (r7593) might produce broken files." - /* This is a hack */ - if( i_codec_id == CODEC_ID_MP2 ) - i_codec_id = CODEC_ID_MP3; - codec->codec_tag = p_input->p_fmt->i_original_fourcc ?: p_input->p_fmt->i_codec; -#endif codec->codec_id = i_codec_id; if( p_input->p_fmt->i_extra ) @@ -385,7 +317,6 @@ static int Mux( sout_mux_t *p_mux ) int error; msg_Dbg( p_mux, "writing header" ); -#if (LIBAVFORMAT_VERSION_INT >= ((53<<16)+(2<<8)+0)) char *psz_opts = var_GetNonEmptyString( p_mux, "sout-avformat-options" ); AVDictionary *options = NULL; if (psz_opts && *psz_opts) @@ -397,9 +328,6 @@ static int Mux( sout_mux_t *p_mux ) msg_Err( p_mux, "Unknown option \"%s\"", t->key ); } av_dict_free(&options); -#else - error = av_write_header( p_sys->oc ); -#endif if( error < 0 ) { errno = AVUNERROR(error); @@ -409,11 +337,7 @@ static int Mux( sout_mux_t *p_mux ) return VLC_EGENERIC; } -#if LIBAVFORMAT_VERSION_INT >= ((52<<16)+(0<<8)+0) avio_flush( p_sys->oc->pb ); -#else - avio_flush( &p_sys->oc->pb ); -#endif p_sys->b_write_header = false; }