Fixes for vp8dec including GNOME #687376
This commit is contained in:
		
							parent
							
								
									b332a6568f
								
							
						
					
					
						commit
						c109ce8fc9
					
				| @ -0,0 +1,40 @@ | |||||||
|  | From 3c216600f55351549573cf94be541fc6055db128 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Debarshi Ray <rishi@gnu.org> | ||||||
|  | Date: Thu, 1 Nov 2012 22:02:39 +0100 | ||||||
|  | Subject: [PATCH 1/2] vp8dec: Short circuit gst_vp8_dec_handle_frame if | ||||||
|  |  keyframe is missing | ||||||
|  | 
 | ||||||
|  | https://bugzilla.gnome.org/show_bug.cgi?id=687376 | ||||||
|  | ---
 | ||||||
|  |  ext/vpx/gstvp8dec.c | 7 +++++-- | ||||||
|  |  1 file changed, 5 insertions(+), 2 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/ext/vpx/gstvp8dec.c b/ext/vpx/gstvp8dec.c
 | ||||||
|  | index 9ec1771..7dcd75b 100644
 | ||||||
|  | --- a/ext/vpx/gstvp8dec.c
 | ||||||
|  | +++ b/ext/vpx/gstvp8dec.c
 | ||||||
|  | @@ -415,7 +415,7 @@ open_codec (GstVP8Dec * dec, GstVideoCodecFrame * frame)
 | ||||||
|  |    if (status != VPX_CODEC_OK || !stream_info.is_kf) { | ||||||
|  |      GST_WARNING_OBJECT (dec, "No keyframe, skipping"); | ||||||
|  |      gst_video_decoder_finish_frame (GST_VIDEO_DECODER (dec), frame); | ||||||
|  | -    return GST_FLOW_OK;
 | ||||||
|  | +    return GST_FLOW_CUSTOM_SUCCESS_1;
 | ||||||
|  |    } | ||||||
|  |   | ||||||
|  |    g_assert (dec->output_state == NULL); | ||||||
|  | @@ -483,8 +483,11 @@ gst_vp8_dec_handle_frame (GstVideoDecoder * decoder, GstVideoCodecFrame * frame)
 | ||||||
|  |   | ||||||
|  |    dec = GST_VP8_DEC (decoder); | ||||||
|  |   | ||||||
|  | -  if (!dec->decoder_inited)
 | ||||||
|  | +  if (!dec->decoder_inited) {
 | ||||||
|  |      ret = open_codec (dec, frame); | ||||||
|  | +    if (ret == GST_FLOW_CUSTOM_SUCCESS_1)
 | ||||||
|  | +      return GST_FLOW_OK;
 | ||||||
|  | +  }
 | ||||||
|  |   | ||||||
|  |    deadline = gst_video_decoder_get_max_decode_time (decoder, frame); | ||||||
|  |    if (deadline < 0) { | ||||||
|  | -- 
 | ||||||
|  | 1.7.12.1 | ||||||
|  | 
 | ||||||
| @ -0,0 +1,26 @@ | |||||||
|  | From f0640f205cca974ccbe0550e76ab37f16b7c8821 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: =?UTF-8?q?Sebastian=20Dr=C3=B6ge?= <sebastian.droege@collabora.co.uk> | ||||||
|  | Date: Fri, 2 Nov 2012 09:34:25 +0100 | ||||||
|  | Subject: [PATCH 2/2] vp8dec: Immediately return if opening the decoder failed | ||||||
|  | 
 | ||||||
|  | Instead of ignoring any errors. | ||||||
|  | ---
 | ||||||
|  |  ext/vpx/gstvp8dec.c | 2 ++ | ||||||
|  |  1 file changed, 2 insertions(+) | ||||||
|  | 
 | ||||||
|  | diff --git a/ext/vpx/gstvp8dec.c b/ext/vpx/gstvp8dec.c
 | ||||||
|  | index 7dcd75b..b5b4aa3 100644
 | ||||||
|  | --- a/ext/vpx/gstvp8dec.c
 | ||||||
|  | +++ b/ext/vpx/gstvp8dec.c
 | ||||||
|  | @@ -487,6 +487,8 @@ gst_vp8_dec_handle_frame (GstVideoDecoder * decoder, GstVideoCodecFrame * frame)
 | ||||||
|  |      ret = open_codec (dec, frame); | ||||||
|  |      if (ret == GST_FLOW_CUSTOM_SUCCESS_1) | ||||||
|  |        return GST_FLOW_OK; | ||||||
|  | +    else if (ret != GST_FLOW_OK)
 | ||||||
|  | +      return ret;
 | ||||||
|  |    } | ||||||
|  |   | ||||||
|  |    deadline = gst_video_decoder_get_max_decode_time (decoder, frame); | ||||||
|  | -- 
 | ||||||
|  | 1.7.12.1 | ||||||
|  | 
 | ||||||
| @ -9,12 +9,14 @@ | |||||||
| 
 | 
 | ||||||
| Name:           gstreamer1-plugins-good | Name:           gstreamer1-plugins-good | ||||||
| Version:        1.0.2 | Version:        1.0.2 | ||||||
| Release:        1%{?dist} | Release:        2%{?dist} | ||||||
| Summary:        GStreamer plugins with good code and licensing | Summary:        GStreamer plugins with good code and licensing | ||||||
| 
 | 
 | ||||||
| License:        LGPLv2+ | License:        LGPLv2+ | ||||||
| URL:            http://gstreamer.freedesktop.org/ | URL:            http://gstreamer.freedesktop.org/ | ||||||
| Source0:        http://gstreamer.freedesktop.org/src/gst-plugins-good/gst-plugins-good-%{version}.tar.xz | Source0:        http://gstreamer.freedesktop.org/src/gst-plugins-good/gst-plugins-good-%{version}.tar.xz | ||||||
|  | Patch0:         0001-vp8dec-Short-circuit-gst_vp8_dec_handle_frame-if-key.patch | ||||||
|  | Patch1:         0002-vp8dec-Immediately-return-if-opening-the-decoder-fai.patch | ||||||
| 
 | 
 | ||||||
| BuildRequires:  gstreamer1-devel >= %{version} | BuildRequires:  gstreamer1-devel >= %{version} | ||||||
| BuildRequires:  gstreamer1-plugins-base-devel >= %{version} | BuildRequires:  gstreamer1-plugins-base-devel >= %{version} | ||||||
| @ -83,6 +85,8 @@ to be installed. | |||||||
| 
 | 
 | ||||||
| %prep | %prep | ||||||
| %setup -q -n gst-plugins-good-%{version} | %setup -q -n gst-plugins-good-%{version} | ||||||
|  | %patch0 -p1 | ||||||
|  | %patch1 -p1 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| %build | %build | ||||||
| @ -199,6 +203,9 @@ find $RPM_BUILD_ROOT -name '*.la' -exec rm -f {} ';' | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| %changelog | %changelog | ||||||
|  | * Fri Nov  2 2012 Debarshi Ray <rishi@fedoraproject.org> - 1.0.2-2 | ||||||
|  | - Fixes for vp8dec including GNOME #687376 | ||||||
|  | 
 | ||||||
| * Thu Oct 25 2012 Brian Pepple <bpepple@fedoraproject.org> - 1.0.2-1 | * Thu Oct 25 2012 Brian Pepple <bpepple@fedoraproject.org> - 1.0.2-1 | ||||||
| - Update to 1.0.2 | - Update to 1.0.2 | ||||||
| - Drop upstream patches since they are included in latest release. | - Drop upstream patches since they are included in latest release. | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user