From f7286bd60210d33f832fc3172b2df34251292344 Mon Sep 17 00:00:00 2001 From: Nicolas Chauvet Date: Mon, 18 Jun 2012 12:21:29 +0000 Subject: [PATCH] Backport merged patch available since March --- vlc-2.0.1-fftype.patch | 47 -------------- vlc-backport-ffmpeg54.patch | 121 ++++++++++++++++++++++++++++++++++++ vlc.spec | 7 ++- 3 files changed, 126 insertions(+), 49 deletions(-) delete mode 100644 vlc-2.0.1-fftype.patch create mode 100644 vlc-backport-ffmpeg54.patch diff --git a/vlc-2.0.1-fftype.patch b/vlc-2.0.1-fftype.patch deleted file mode 100644 index 991d01b..0000000 --- a/vlc-2.0.1-fftype.patch +++ /dev/null @@ -1,47 +0,0 @@ -diff -up vlc-2.0.1/modules/stream_out/switcher.c.orig vlc-2.0.1/modules/stream_out/switcher.c ---- vlc-2.0.1/modules/stream_out/switcher.c.orig 2012-05-01 16:31:41.036832197 +0200 -+++ vlc-2.0.1/modules/stream_out/switcher.c 2012-05-01 16:35:53.694838241 +0200 -@@ -844,7 +844,7 @@ static block_t *VideoGetBuffer( sout_str - - if ( id->i_nb_pred >= p_sys->i_gop ) - { -- id->p_frame->pict_type = FF_I_TYPE; -+ id->p_frame->pict_type = AV_PICTURE_TYPE_I; - #if 0 - id->p_frame->me_threshold = 0; - id->p_frame->mb_threshold = 0; -@@ -853,7 +853,7 @@ static block_t *VideoGetBuffer( sout_str - } - else - { -- id->p_frame->pict_type = FF_P_TYPE; -+ id->p_frame->pict_type = AV_PICTURE_TYPE_P; - #if 0 - if ( id->p_frame->mb_type != NULL ) - { -@@ -873,7 +873,7 @@ static block_t *VideoGetBuffer( sout_str - - #if 0 - if ( id->p_frame->mb_type == NULL -- && id->ff_enc_c->coded_frame->pict_type != FF_I_TYPE ) -+ && id->ff_enc_c->coded_frame->pict_type != AV_PICTURE_TYPE_I ) - { - int mb_width = (id->ff_enc_c->width + 15) / 16; - int mb_height = (id->ff_enc_c->height + 15) / 16; -@@ -926,13 +926,13 @@ static block_t *VideoGetBuffer( sout_str - - switch ( id->ff_enc_c->coded_frame->pict_type ) - { -- case FF_I_TYPE: -+ case AV_PICTURE_TYPE_I: - p_out->i_flags |= BLOCK_FLAG_TYPE_I; - break; -- case FF_P_TYPE: -+ case AV_PICTURE_TYPE_P: - p_out->i_flags |= BLOCK_FLAG_TYPE_P; - break; -- case FF_B_TYPE: -+ case AV_PICTURE_TYPE_B: - p_out->i_flags |= BLOCK_FLAG_TYPE_B; - break; - default: diff --git a/vlc-backport-ffmpeg54.patch b/vlc-backport-ffmpeg54.patch new file mode 100644 index 0000000..4a829a7 --- /dev/null +++ b/vlc-backport-ffmpeg54.patch @@ -0,0 +1,121 @@ +X-Git-Url: http://git.videolan.org/?p=vlc%2Fvlc-2.0.git;a=blobdiff_plain;f=modules%2Fstream_out%2Fswitcher.c;h=18301329e33fe413b3d8f4da18966d6205581274;hp=372eef81c9ae3b9ee5b1405bdd5b7be8254fd3f0;hb=HEAD;hpb=caf2a08a0507ab9e9ae34038854f3f218e820581 + +diff --git a/modules/stream_out/switcher.c b/modules/stream_out/switcher.c +index 372eef8..1830132 100644 +--- a/modules/stream_out/switcher.c ++++ b/modules/stream_out/switcher.c +@@ -51,12 +51,6 @@ + # include + #endif + +-#ifdef HAVE_POSTPROC_POSTPROCESS_H +-# include +-#else +-# include +-#endif +- + #include "../codec/avcodec/avcodec.h" + + #define SOUT_CFG_PREFIX "sout-switcher-" +@@ -292,7 +286,9 @@ static int Open( vlc_object_t *p_this ) + p_stream->pf_send = Send; + p_stream->p_sys = p_sys; + ++#if LIBAVCODEC_VERSION_MAJOR < 54 + avcodec_init(); ++#endif + avcodec_register_all(); + + return VLC_SUCCESS; +@@ -355,7 +351,11 @@ static sout_stream_id_t *Add( sout_stream_t *p_stream, es_format_t *p_fmt ) + return NULL; + } + ++#if LIBAVCODEC_VERSION_MAJOR < 54 + id->ff_enc_c = avcodec_alloc_context(); ++#else ++ id->ff_enc_c = avcodec_alloc_context3( id->ff_enc ); ++#endif + + /* Set CPU capabilities */ + unsigned i_cpu = vlc_CPU(); +@@ -388,7 +388,11 @@ static sout_stream_id_t *Add( sout_stream_t *p_stream, es_format_t *p_fmt ) + id->ff_enc_c->bit_rate = p_fmt->i_bitrate; + + vlc_avcodec_lock(); ++#if LIBAVCODEC_VERSION_MAJOR >= 54 ++ if( avcodec_open2( id->ff_enc_c, id->ff_enc, NULL /* options */ ) ) ++#else + if( avcodec_open( id->ff_enc_c, id->ff_enc ) ) ++#endif + { + vlc_avcodec_unlock(); + msg_Err( p_stream, "cannot open encoder" ); +@@ -748,7 +752,11 @@ static mtime_t VideoCommand( sout_stream_t *p_stream, sout_stream_id_t *id ) + return 0; + } + ++#if LIBAVCODEC_VERSION_MAJOR < 54 + id->ff_enc_c = avcodec_alloc_context(); ++#else ++ id->ff_enc_c = avcodec_alloc_context3( id->ff_enc ); ++#endif + + /* Set CPU capabilities */ + unsigned i_cpu = vlc_CPU(); +@@ -803,7 +811,11 @@ static mtime_t VideoCommand( sout_stream_t *p_stream, sout_stream_id_t *id ) + id->ff_enc_c->pix_fmt = PIX_FMT_YUV420P; + + vlc_avcodec_lock(); ++#if LIBAVCODEC_VERSION_MAJOR >= 54 ++ if( avcodec_open2( id->ff_enc_c, id->ff_enc, NULL /* options */ ) ) ++#else + if( avcodec_open( id->ff_enc_c, id->ff_enc ) ) ++#endif + { + vlc_avcodec_unlock(); + msg_Err( p_stream, "cannot open encoder" ); +@@ -844,7 +856,7 @@ static block_t *VideoGetBuffer( sout_stream_t *p_stream, sout_stream_id_t *id, + + if ( id->i_nb_pred >= p_sys->i_gop ) + { +- id->p_frame->pict_type = FF_I_TYPE; ++ id->p_frame->pict_type = AV_PICTURE_TYPE_I; + #if 0 + id->p_frame->me_threshold = 0; + id->p_frame->mb_threshold = 0; +@@ -853,7 +865,7 @@ static block_t *VideoGetBuffer( sout_stream_t *p_stream, sout_stream_id_t *id, + } + else + { +- id->p_frame->pict_type = FF_P_TYPE; ++ id->p_frame->pict_type = AV_PICTURE_TYPE_P; + #if 0 + if ( id->p_frame->mb_type != NULL ) + { +@@ -873,7 +885,7 @@ static block_t *VideoGetBuffer( sout_stream_t *p_stream, sout_stream_id_t *id, + + #if 0 + if ( id->p_frame->mb_type == NULL +- && id->ff_enc_c->coded_frame->pict_type != FF_I_TYPE ) ++ && id->ff_enc_c->coded_frame->pict_type != AV_PICTURE_TYPE_I ) + { + int mb_width = (id->ff_enc_c->width + 15) / 16; + int mb_height = (id->ff_enc_c->height + 15) / 16; +@@ -926,13 +938,13 @@ static block_t *VideoGetBuffer( sout_stream_t *p_stream, sout_stream_id_t *id, + + switch ( id->ff_enc_c->coded_frame->pict_type ) + { +- case FF_I_TYPE: ++ case AV_PICTURE_TYPE_I: + p_out->i_flags |= BLOCK_FLAG_TYPE_I; + break; +- case FF_P_TYPE: ++ case AV_PICTURE_TYPE_P: + p_out->i_flags |= BLOCK_FLAG_TYPE_P; + break; +- case FF_B_TYPE: ++ case AV_PICTURE_TYPE_B: + p_out->i_flags |= BLOCK_FLAG_TYPE_B; + break; + default: diff --git a/vlc.spec b/vlc.spec index afeaf13..e5c8780 100644 --- a/vlc.spec +++ b/vlc.spec @@ -22,12 +22,12 @@ Summary: The cross-platform open-source multimedia framework, player and server Name: vlc Version: 2.0.1 -Release: 1%{?dist} +Release: 2%{?dist} License: GPLv2+ Group: Applications/Multimedia URL: http://www.videolan.org Source0: http://download.videolan.org/pub/videolan/vlc/%{version}/vlc-%{version}%{?vlc_rc}.tar.xz -Patch0: vlc-2.0.1-fftype.patch +Patch0: vlc-backport-ffmpeg54.patch Patch5: vlc-1.1.8-bugfix.opencv22.patch BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) @@ -488,6 +488,9 @@ fi || : %changelog +* Mon Jun 18 2012 Nicolas Chauvet - 2.0.1-2 +- Backport patch for ffmpeg54 + * Wed May 02 2012 Nicolas Chauvet - 2.0.1-1 - Update to 2.0.1