2013-05-08 14:13:32 +00:00
|
|
|
/*
|
|
|
|
* DASH demux plugin for GStreamer
|
|
|
|
*
|
|
|
|
* gstdashdemux.h
|
|
|
|
*
|
|
|
|
* Copyright (C) 2012 Orange
|
|
|
|
* Authors:
|
|
|
|
* David Corvoysier <david.corvoysier@orange.com>
|
|
|
|
* Hamid Zakari <hamid.zakari@gmail.com>
|
|
|
|
*
|
2013-01-25 15:45:18 +00:00
|
|
|
* Copyright (C) 2013 Smart TV Alliance
|
|
|
|
* Author: Thiago Sousa Santos <thiago.sousa.santos@collabora.com>, Collabora Ltd.
|
|
|
|
*
|
2013-05-08 14:13:32 +00:00
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Library General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Library General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
2012-09-28 10:55:27 +00:00
|
|
|
* License along with this library (COPYING); if not, write to the
|
2013-05-08 14:13:32 +00:00
|
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
* Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __GST_DASH_DEMUX_H__
|
|
|
|
#define __GST_DASH_DEMUX_H__
|
|
|
|
|
|
|
|
#include <gst/gst.h>
|
|
|
|
#include <gst/base/gstadapter.h>
|
2013-01-28 21:52:04 +00:00
|
|
|
#include <gst/base/gstdataqueue.h>
|
2013-05-08 14:13:32 +00:00
|
|
|
#include "gstmpdparser.h"
|
2013-02-05 20:38:06 +00:00
|
|
|
#include "gstdownloadrate.h"
|
2013-02-05 03:45:06 +00:00
|
|
|
#include <gst/uridownloader/gsturidownloader.h>
|
2013-05-08 14:13:32 +00:00
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
#define GST_TYPE_DASH_DEMUX \
|
|
|
|
(gst_dash_demux_get_type())
|
|
|
|
#define GST_DASH_DEMUX(obj) \
|
|
|
|
(G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_DASH_DEMUX,GstDashDemux))
|
|
|
|
#define GST_DASH_DEMUX_CLASS(klass) \
|
|
|
|
(G_TYPE_CHECK_CLASS_CAST((klass),GST_TYPE_DASH_DEMUX,GstDashDemuxClass))
|
|
|
|
#define GST_IS_DASH_DEMUX(obj) \
|
|
|
|
(G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_DASH_DEMUX))
|
|
|
|
#define GST_IS_DASH_DEMUX_CLASS(klass) \
|
|
|
|
(G_TYPE_CHECK_CLASS_TYPE((klass),GST_TYPE_DASH_DEMUX))
|
2013-01-28 13:46:27 +00:00
|
|
|
|
|
|
|
typedef struct _GstDashDemuxStream GstDashDemuxStream;
|
2013-05-08 14:13:32 +00:00
|
|
|
typedef struct _GstDashDemux GstDashDemux;
|
|
|
|
typedef struct _GstDashDemuxClass GstDashDemuxClass;
|
2013-01-28 13:46:27 +00:00
|
|
|
|
|
|
|
struct _GstDashDemuxStream
|
|
|
|
{
|
|
|
|
GstPad *pad;
|
|
|
|
|
|
|
|
gint index;
|
|
|
|
|
|
|
|
GstCaps *input_caps;
|
2013-01-28 15:28:29 +00:00
|
|
|
|
2013-01-29 18:58:50 +00:00
|
|
|
/*
|
|
|
|
* Need to store the status for the download and
|
|
|
|
* stream tasks separately as they are working at
|
|
|
|
* different points of the stream timeline.
|
|
|
|
* The download task is ahead of the stream.
|
|
|
|
*
|
|
|
|
* The download_end_of_period is set when a stream
|
|
|
|
* has already downloaded all fragments for the current
|
|
|
|
* period.
|
|
|
|
*
|
|
|
|
* The stream_end_of_period is set when a stream
|
|
|
|
* has pushed all fragments for the current period
|
|
|
|
*/
|
|
|
|
gboolean download_end_of_period;
|
|
|
|
gboolean stream_end_of_period;
|
|
|
|
|
|
|
|
gboolean stream_eos;
|
2013-01-30 20:27:47 +00:00
|
|
|
gboolean need_header;
|
2013-02-01 03:37:33 +00:00
|
|
|
|
2013-02-01 05:10:15 +00:00
|
|
|
/* tracks if a stream has enqueued data
|
|
|
|
* after a pad switch.
|
|
|
|
* This is required to prevent pads being
|
|
|
|
* added to the demuxer and having no data
|
|
|
|
* pushed to it before another pad switch
|
|
|
|
* as this might make downstream elements
|
|
|
|
* unhappy and error out if they get
|
|
|
|
* an EOS without receiving any input
|
|
|
|
*/
|
|
|
|
gboolean has_data_queued;
|
|
|
|
|
2013-01-28 21:52:04 +00:00
|
|
|
GstDataQueue *queue;
|
2013-02-05 17:22:51 +00:00
|
|
|
|
2013-02-05 20:38:06 +00:00
|
|
|
GstDownloadRate dnl_rate;
|
2013-01-28 13:46:27 +00:00
|
|
|
};
|
|
|
|
|
2013-05-08 14:13:32 +00:00
|
|
|
/**
|
|
|
|
* GstDashDemux:
|
|
|
|
*
|
|
|
|
* Opaque #GstDashDemux data structure.
|
|
|
|
*/
|
|
|
|
struct _GstDashDemux
|
|
|
|
{
|
|
|
|
GstElement parent;
|
|
|
|
GstPad *sinkpad;
|
2013-01-28 13:46:27 +00:00
|
|
|
|
2013-07-23 08:04:42 +00:00
|
|
|
gboolean have_group_id;
|
|
|
|
guint group_id;
|
|
|
|
|
2013-01-28 13:46:27 +00:00
|
|
|
GSList *streams;
|
2013-02-13 04:13:23 +00:00
|
|
|
GSList *next_periods;
|
2013-04-18 10:41:09 +00:00
|
|
|
GMutex streams_lock;
|
2013-05-08 14:13:32 +00:00
|
|
|
|
2013-02-01 03:37:33 +00:00
|
|
|
GstSegment segment;
|
2013-02-12 20:50:51 +00:00
|
|
|
gboolean need_segment;
|
2013-03-08 14:04:48 +00:00
|
|
|
GstClockTime timestamp_offset;
|
2013-02-01 03:37:33 +00:00
|
|
|
|
2012-10-15 09:40:55 +00:00
|
|
|
GstBuffer *manifest;
|
2013-05-08 14:13:32 +00:00
|
|
|
GstUriDownloader *downloader;
|
|
|
|
GstMpdClient *client; /* MPD client */
|
2012-10-24 09:49:51 +00:00
|
|
|
gboolean end_of_period;
|
2012-10-15 09:40:55 +00:00
|
|
|
gboolean end_of_manifest;
|
2013-05-08 14:13:32 +00:00
|
|
|
|
|
|
|
/* Properties */
|
2012-10-16 11:43:39 +00:00
|
|
|
GstClockTime max_buffering_time; /* Maximum buffering time accumulated during playback */
|
|
|
|
gfloat bandwidth_usage; /* Percentage of the available bandwidth to use */
|
|
|
|
guint64 max_bitrate; /* max of bitrate supported by target decoder */
|
2013-05-08 14:13:32 +00:00
|
|
|
|
|
|
|
/* Streaming task */
|
|
|
|
GstTask *stream_task;
|
2013-04-18 10:41:09 +00:00
|
|
|
GRecMutex stream_task_lock;
|
2013-05-08 14:13:32 +00:00
|
|
|
|
|
|
|
/* Download task */
|
|
|
|
GstTask *download_task;
|
2013-04-18 10:41:09 +00:00
|
|
|
GRecMutex download_task_lock;
|
2013-07-09 02:24:28 +00:00
|
|
|
GMutex download_mutex;
|
|
|
|
GCond download_cond;
|
2013-05-08 14:13:32 +00:00
|
|
|
gboolean cancelled;
|
|
|
|
|
2012-12-17 14:12:58 +00:00
|
|
|
/* Manifest update */
|
|
|
|
GstClockTime last_manifest_update;
|
2013-05-08 14:13:32 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct _GstDashDemuxClass
|
|
|
|
{
|
|
|
|
GstElementClass parent_class;
|
|
|
|
};
|
|
|
|
|
|
|
|
GType gst_dash_demux_get_type (void);
|
|
|
|
|
|
|
|
G_END_DECLS
|
|
|
|
#endif /* __GST_DASH_DEMUX_H__ */
|
|
|
|
|