openh264dec: The codec can only do baseline so simplify the code a bit

and declare this also on the srcpad caps.

With baseline profile there are no B-frames or frame reordering.
This commit is contained in:
Sebastian Dröge 2014-10-03 17:22:23 +03:00
parent bc8e1465dc
commit 518d84c148

View file

@ -86,7 +86,7 @@ GST_STATIC_PAD_TEMPLATE ("sink",
GST_PAD_SINK, GST_PAD_SINK,
GST_PAD_ALWAYS, GST_PAD_ALWAYS,
GST_STATIC_CAPS GST_STATIC_CAPS
("video/x-h264, stream-format=(string)byte-stream, alignment=(string)au")); ("video/x-h264, stream-format=(string)byte-stream, alignment=(string)au,profile=(string){constrained-baseline,baseline}"));
static GstStaticPadTemplate gst_openh264dec_src_template = static GstStaticPadTemplate gst_openh264dec_src_template =
GST_STATIC_PAD_TEMPLATE ("src", GST_STATIC_PAD_TEMPLATE ("src",
@ -252,32 +252,6 @@ gst_openh264dec_reset (GstVideoDecoder * decoder, gboolean hard)
return TRUE; return TRUE;
} }
static GstVideoCodecFrame *
get_oldest_pts_frame (GstVideoDecoder * decoder)
{
GList *frames, *l;
GstVideoCodecFrame *oldest = NULL;
frames = gst_video_decoder_get_frames (decoder);
for (l = frames; l; l = l->next) {
GstVideoCodecFrame *tmp = (GstVideoCodecFrame *) l->data;
if (tmp->pts != GST_CLOCK_TIME_NONE &&
(oldest == NULL || oldest->pts > tmp->pts))
oldest = tmp;
}
if (oldest)
gst_video_codec_frame_ref (oldest);
else
oldest = gst_video_decoder_get_oldest_frame (decoder);
g_list_foreach (frames, (GFunc) gst_video_codec_frame_unref, NULL);
g_list_free (frames);
return oldest;
}
static GstFlowReturn static GstFlowReturn
gst_openh264dec_handle_frame (GstVideoDecoder * decoder, gst_openh264dec_handle_frame (GstVideoDecoder * decoder,
GstVideoCodecFrame * frame) GstVideoCodecFrame * frame)
@ -338,8 +312,9 @@ gst_openh264dec_handle_frame (GstVideoDecoder * decoder,
/* FIXME: openh264 has no way for us to get a connection /* FIXME: openh264 has no way for us to get a connection
* between the input and output frames, we just have to * between the input and output frames, we just have to
* guess based on the input */ * guess based on the input. Fortunately openh264 can
frame = get_oldest_pts_frame (decoder); * only do baseline profile. */
frame = gst_video_decoder_get_oldest_frame (decoder);
if (!frame) { if (!frame) {
/* Can only happen in finish() */ /* Can only happen in finish() */
return GST_FLOW_EOS; return GST_FLOW_EOS;