[Spice-devel] [PATCH spice-gtk v4 0/7] Always use Playbin to create the pipeline

Victor Toso victortoso at redhat.com
Wed Jun 28 12:42:57 UTC 2017


From: Victor Toso <me at victortoso.com>

-- v3->v4
* Not many changes, the full diff from previous version is here:
  https://paste.fedoraproject.org/paste/c6zbF4uDLpLsmCHAHkmULQ

* Included a new PATCH for debugging purposes, it can generate a .dot file and
  consequently an image file with the contents of GStreamer's video pipeline,
  see: https://people.freedesktop.org/~victortoso/imgs/spice/gstreamer/

-- Addressing Christophe's review:
* 1/7: Kept g_return_val_if_fail()
* 2/7: Improved commit log and comments.
* 3/7: Improved comments (Acked)
* 4/7: Improved commit log (Acked)
* 5/7: Moved debug chunk to separated function;
       Using g_string_truncate
       Removed #ifdef altogether with previous gstvideo_has_codec() version.
       (Acked)
* 6/7: Nothing
* 7/7: New patch

-- v2->v3:

* Apply acked in
- display-gst: check GstRegistry for decoding elements

* display-gst: include capabilities for h264
- Got the errors from h264parse related to incomplete capabilities. Not
  sure how I missed it before.  The error points out that video/x-h264
  is not enough for h264parse element and it ignores it (meaning that we
  could simple ignore capabilities for h264).
- The error is:
  h264parse gsth264parse.c:2559:gst_h264_parse_set_caps: video/x-h264
  caps without codec_data or stream-format
- But we *do* know the stream-format so I'm adding this to the
  capabilites.

* Moved 4/5 to be current 2/6 to avoid an intermediary patch that would
  cause regression if used with SPICE_GSTVIDEO_AUTO (Frediano)

* Created 1/6 to avoid creating encoder with wrong codec value (Frediano)

* Move g_sinal_connect() before g_object_set() where playbin is
  initialized on 6/6 (Frediano)

* Using a g_warn_if_fail() to be sure we will not be re-assigning the
  decoder->appsrc on 6/6 (Frediano)

-- v1-> v2:

Adressing Frediano comments in v1

* Rebased
* Removed caps="" for older version of GStreamer. No clear info on the
  issue that one had at that time. Still, video/x-h264 is the stream
  format that we receive and an error because of that should really be a
  bug in GStreamer.
* Moved v1 02/04 to be v2 01/04 in order to fix more easily the
  "cap=%s" problem in v1 01/04
* Free GstSample even while using playbin
* gst_element_ref() GstAppSrc and GstAppSink

-- v1:

Hi,

First time using git-publish [0], sorry if anything goes wrong :)

[0] https://github.com/stefanha/git-publish

The main goal for this series is to have streaming working with hardware
accelerated video decoding whenever is possible.

The best way to achieve that is to let GStreamer do most of the work. Using
Playbin [1] we can create the whole pipeline. We only need to work with
GstAppSrc and GstAppSink to set the encoded data and gather the decoded data.

[1] https://gstreamer.freedesktop.org/data/doc/gstreamer/head/gst-plugins-base-plugins/html/gst-plugins-base-plugins-playbin.html

Trying my best to not break streaming with older versions of GStreamer. Based on
a comment from ceyusa [2], since version 1.9.0 GStreamer is able to use Vaapi
elements automaticaly and for that reason I'm wrapping those changes with
GST_CHECK_VERSION(1,9,0).

[2] https://lists.freedesktop.org/archives/spice-devel/2016-October/032825.html

Cheers,
        toso

Victor Toso (7):
  display-gst: check codec type before creating decoder
  display-gst: remove SPICE_GSTVIDEO_AUTO check
  display-gst: include capabilities for h264
  display-gst: move "caps=" from struct to pipeline
  display-gst: check GstRegistry for decoding elements
  display-gst: Use Playbin for GStreamer 1.9.0 onwards
  display-gst: Debug video pipeline on stream-start message

 src/channel-display-gst.c | 207 ++++++++++++++++++++++++++++++++++++++--------
 1 file changed, 174 insertions(+), 33 deletions(-)

-- 
2.13.0



More information about the Spice-devel mailing list