Request for feedback: New DASH plugin implementation (dashdemux)

classic Classic list List threaded Threaded
2 messages Options
Reply | Threaded
Open this post in threaded view
|

Request for feedback: New DASH plugin implementation (dashdemux)

david.corvoysier
Hi,

Dashbin now has a kid brother !

After a first implementation of DASH in gstreamer brought to the
attention of the community in May (see
https://bugzilla.gnome.org/show_bug.cgi?id=675625), we would like people
interested to evaluate dashdemux, a brand new implementation that tries
to address most of the concerns raised by the previous one.

This new plugin is the result of a joint effort from ST MicroElectronics
and Orange, and tries to take advantage of a few generic classes
introduced by the existing HLS Demux from gst-plugins-good.

The code is available here:
https://github.com/Orange-OpenSource/gstdashdemux, and is licensed under
LGPL V2.1.

When evaluating the plugin, please keep in mind that despite our
efforts, it is still a prototype that would require some work to reach
production grade:
- the seek is unreliable (sorry !),
- there may be a memory leak, as under certain circumstances, the memory
increases a lot (but it's still hard to figure out which part is
responsible, as decodebin for instance doesn't prune drained chains
before the end of the pipeline),
- if multiple audio languages are available, they are all downloaded
(otherwise we cannot change the audio dynamically),
- a few other things need to be fixed in the code (look for FIXME),
- it is not compatible with gstreamer 1.x ...

Based on your feedback, we are ready to discuss of a plan to include
dashdemux to the existing suite of gstreamer plugins (probably sitting
next to HLS demux inside a 'fragmented' plugin is the best option).

Regards

David Corvoysier
_______________________________________________
gstreamer-devel mailing list
[hidden email]
http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel
Reply | Threaded
Open this post in threaded view
|

Re: Request for feedback: New DASH plugin implementation (dashdemux)

Edward Hervey
Administrator
Hi,

On Mon, 2012-10-22 at 17:44 +0200, David Corvoysier wrote:

> Hi,
>
> Dashbin now has a kid brother !
>
> After a first implementation of DASH in gstreamer brought to the
> attention of the community in May (see
> https://bugzilla.gnome.org/show_bug.cgi?id=675625), we would like people
> interested to evaluate dashdemux, a brand new implementation that tries
> to address most of the concerns raised by the previous one.
>
> This new plugin is the result of a joint effort from ST MicroElectronics
> and Orange, and tries to take advantage of a few generic classes
> introduced by the existing HLS Demux from gst-plugins-good.
>
> The code is available here:
> https://github.com/Orange-OpenSource/gstdashdemux, and is licensed under
> LGPL V2.1.
>
> When evaluating the plugin, please keep in mind that despite our
> efforts, it is still a prototype that would require some work to reach
> production grade:
> - the seek is unreliable (sorry !),
> - there may be a memory leak, as under certain circumstances, the memory
> increases a lot (but it's still hard to figure out which part is
> responsible, as decodebin for instance doesn't prune drained chains
> before the end of the pipeline),
> - if multiple audio languages are available, they are all downloaded
> (otherwise we cannot change the audio dynamically),
> - a few other things need to be fixed in the code (look for FIXME),
> - it is not compatible with gstreamer 1.x ...
>
> Based on your feedback, we are ready to discuss of a plan to include
> dashdemux to the existing suite of gstreamer plugins (probably sitting
> next to HLS demux inside a 'fragmented' plugin is the best option).

I'll let someone more familiar with HLS and DASH comment about the
implementation itself, but a few first comments:
* All the bugs/patches you mentioned in the README are pushed upstream
in both 0.10 and master. The problem is that ... there's no guarantee
there will be a future 0.10 release.
* The various source files you are re-using are already ported to 1.0
(along with hlsdemux itself).
* Most of the development effort is concentrated on 1.0 these days, and
in combination with the above-mentioned release issue, I fear you might
not get much help by sticking to 0.10 :(
* For the plugin to make it into -bad (and not -good as you mentionned),
it would be a good move to make your repository based on -bad (and not a
standalone repository as is the case right now).
* Quite a bit of your code isn't related to gstreamer API but more to
protocol handling (which is agnostic to the 0.10/1.0 changes).

Considering all the above, I'd therefore recommend you do the following:
* Re-use the current master (1.0) code of gstfragmented and related
source files
* For that, clone gst-plugins-bad and adapt your commits/code on top.
Since hlsdemux is already ported, and you inspired yourself from that
code, you can see how it is now handling the gstreamer parts in 1.0.
* Open a bug report on the gstreamer bug tracker pointing to that
repository so we can track/comment/assist on the progress

Nice work !

  Edward

>
> Regards
>
> David Corvoysier
> _______________________________________________
> gstreamer-devel mailing list
> [hidden email]
> http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel


_______________________________________________
gstreamer-devel mailing list
[hidden email]
http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel