Signed-off-by: Ramprasad N <[email protected]>
---
 ...aylandsink-Add-drm-support-in-waylandsink.patch | 697 +++++++++++++++++++++
 .../gstreamer1.0-plugins-bad_1.14.4.bbappend       |   8 +-
 2 files changed, 701 insertions(+), 4 deletions(-)
 create mode 100644 
meta-arago-extras/recipes-multimedia/gstreamer/gstreamer1.0-plugins-bad/0004-waylandsink-Add-drm-support-in-waylandsink.patch

diff --git 
a/meta-arago-extras/recipes-multimedia/gstreamer/gstreamer1.0-plugins-bad/0004-waylandsink-Add-drm-support-in-waylandsink.patch
 
b/meta-arago-extras/recipes-multimedia/gstreamer/gstreamer1.0-plugins-bad/0004-waylandsink-Add-drm-support-in-waylandsink.patch
new file mode 100644
index 0000000..b8ef08f
--- /dev/null
+++ 
b/meta-arago-extras/recipes-multimedia/gstreamer/gstreamer1.0-plugins-bad/0004-waylandsink-Add-drm-support-in-waylandsink.patch
@@ -0,0 +1,697 @@
+From 7e5f42a25a8b30655df304acc83a485b9fc7090e Mon Sep 17 00:00:00 2001
+From: Ramprasad N <[email protected]>
+Date: Wed, 26 Dec 2018 15:47:28 +0530
+Subject: [PATCH 4/4] waylandsink: Add drm support in waylandsink
+
+Waylandsink works out of shm memory. We have a DRM
+based memory allocator in place. Adding wl_drm support
+enables us to use DRM buffers without copy
+
+Following features are also added
+1) YUY2 and BGRA input format support
+2) Crop support
+3) Window resolution configuration support
+4) A property use-drm to command DRM buffer allocation
+   when propose_allocation is called
+
+Signed-off-by: Ramprasad N <[email protected]>
+---
+ ext/wayland/Makefile.am      |  11 +++-
+ ext/wayland/gstwaylandsink.c |  82 +++++++++++++++++++++++++++--
+ ext/wayland/gstwaylandsink.h |   2 +
+ ext/wayland/wldisplay.c      |  56 ++++++++++++++++++++
+ ext/wayland/wldisplay.h      |   9 ++++
+ ext/wayland/wldrm.c          | 121 +++++++++++++++++++++++++++++++++++++++++++
+ ext/wayland/wldrm.h          |  21 ++++++++
+ ext/wayland/wlwindow.c       |  63 +++++++++++++++++++---
+ 8 files changed, 354 insertions(+), 11 deletions(-)
+ create mode 100644 ext/wayland/wldrm.c
+ create mode 100644 ext/wayland/wldrm.h
+
+diff --git a/ext/wayland/Makefile.am b/ext/wayland/Makefile.am
+index 387f84f..ebc9968 100644
+--- a/ext/wayland/Makefile.am
++++ b/ext/wayland/Makefile.am
+@@ -4,12 +4,15 @@ BUILT_SOURCES = \
+       viewporter-protocol.c \
+       viewporter-client-protocol.h \
+       linux-dmabuf-unstable-v1-protocol.c \
+-      linux-dmabuf-unstable-v1-client-protocol.h
++      linux-dmabuf-unstable-v1-client-protocol.h \
++      wayland-drm-protocol.c \
++      wayland-drm-client-protocol.h
+ 
+ libgstwaylandsink_la_SOURCES =  \
+       gstwaylandsink.c \
+       wlshmallocator.c \
+       wlbuffer.c \
++      wldrm.c \
+       wldisplay.c \
+       wlwindow.c \
+       wlvideoformat.c \
+@@ -17,24 +20,28 @@ libgstwaylandsink_la_SOURCES =  \
+ 
+ nodist_libgstwaylandsink_la_SOURCES = \
+       viewporter-protocol.c \
+-      linux-dmabuf-unstable-v1-protocol.c
++      linux-dmabuf-unstable-v1-protocol.c \
++      wayland-drm-protocol.c
+ 
+ libgstwaylandsink_la_CFLAGS = \
+       $(GST_PLUGINS_BAD_CFLAGS) \
+       $(GST_PLUGINS_BASE_CFLAGS) \
+       $(GST_CFLAGS) \
++      $(DRM_CFLAGS) \
+       $(WAYLAND_CFLAGS)
+ libgstwaylandsink_la_LIBADD = \
+       
$(top_builddir)/gst-libs/gst/wayland/libgstwayland-$(GST_API_VERSION).la \
+       $(GST_PLUGINS_BASE_LIBS) \
+       -lgstvideo-$(GST_API_VERSION) \
+       -lgstallocators-$(GST_API_VERSION) \
++      $(top_builddir)/gst-libs/gst/drm/libgstdrm-$(GST_API_VERSION).la \
+       $(WAYLAND_LIBS)
+ libgstwaylandsink_la_LDFLAGS = $(GST_PLUGIN_LDFLAGS)
+ 
+ noinst_HEADERS = \
+       gstwaylandsink.h \
+       wlshmallocator.h \
++      wldrm.h \
+       wlbuffer.h \
+       wldisplay.h \
+       wlwindow.h \
+diff --git a/ext/wayland/gstwaylandsink.c b/ext/wayland/gstwaylandsink.c
+index ff08194..f0aeea0 100644
+--- a/ext/wayland/gstwaylandsink.c
++++ b/ext/wayland/gstwaylandsink.c
+@@ -46,6 +46,7 @@
+ #include "wlbuffer.h"
+ #include "wlshmallocator.h"
+ #include "wllinuxdmabuf.h"
++#include "wldrm.h"
+ 
+ #include <gst/wayland/wayland.h>
+ #include <gst/video/videooverlay.h>
+@@ -61,7 +62,9 @@ enum
+ enum
+ {
+   PROP_0,
+-  PROP_DISPLAY
++  PROP_DISPLAY,
++  PROP_ALLOCATION,
++  PROP_SCALE
+ };
+ 
+ GST_DEBUG_CATEGORY (gstwayland_debug);
+@@ -202,6 +205,18 @@ gst_wayland_sink_class_init (GstWaylandSinkClass * klass)
+       g_param_spec_string ("display", "Wayland Display name", "Wayland "
+           "display name to connect to, if not supplied via the GstContext",
+           NULL, G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
++
++  g_object_class_install_property (gobject_class, PROP_ALLOCATION,
++      g_param_spec_boolean ("use-drm", "Wayland Allocation name", "Wayland "
++          "Use DRM based memory for allocation",
++          FALSE, G_PARAM_WRITABLE));
++
++  g_object_class_install_property (gobject_class, PROP_SCALE,
++      g_param_spec_string ("window-resolution", "window resolution on 
display",
++          "resolution of video widthxheight ",
++          "NULL",
++          G_PARAM_WRITABLE | G_PARAM_STATIC_STRINGS));
++
+ }
+ 
+ static void
+@@ -209,6 +224,7 @@ gst_wayland_sink_init (GstWaylandSink * sink)
+ {
+   g_mutex_init (&sink->display_lock);
+   g_mutex_init (&sink->render_lock);
++  sink->scale_width = sink->scale_height = 0;
+ }
+ 
+ static void
+@@ -234,6 +250,7 @@ gst_wayland_sink_set_property (GObject * object,
+     guint prop_id, const GValue * value, GParamSpec * pspec)
+ {
+   GstWaylandSink *sink = GST_WAYLAND_SINK (object);
++  gchar *string = NULL, *end;
+ 
+   switch (prop_id) {
+     case PROP_DISPLAY:
+@@ -241,6 +258,23 @@ gst_wayland_sink_set_property (GObject * object,
+       sink->display_name = g_value_dup_string (value);
+       GST_OBJECT_UNLOCK (sink);
+       break;
++    case PROP_ALLOCATION:
++      GST_OBJECT_LOCK (sink);
++      sink->use_drm = g_value_get_boolean (value);
++      GST_OBJECT_UNLOCK (sink);
++      break;
++    case PROP_SCALE:
++      GST_OBJECT_LOCK (sink);
++      string = g_value_dup_string (value);
++      sink->scale_width = g_ascii_strtoull (string, &end, 10);
++      if (*end != 'x')
++         sink->scale_width = 0 ;
++
++      sink->scale_height = g_ascii_strtoull (end+1, &end, 10);
++      if(string)
++          g_free(string);
++      GST_OBJECT_UNLOCK (sink);
++      break;
+     default:
+       G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
+       break;
+@@ -325,6 +359,9 @@ gst_wayland_sink_find_display (GstWaylandSink * sink)
+         /* if the application didn't set a display, let's create it ourselves 
*/
+         GST_OBJECT_LOCK (sink);
+         sink->display = gst_wl_display_new (sink->display_name, &error);
++      sink->display->use_drm = sink->use_drm;
++        sink->display->scale_width = sink->scale_width;
++        sink->display->scale_height = sink->scale_height;
+         GST_OBJECT_UNLOCK (sink);
+ 
+         if (error) {
+@@ -501,7 +538,11 @@ gst_wayland_create_pool (GstWaylandSink * sink, GstCaps * 
caps)
+   structure = gst_buffer_pool_get_config (pool);
+   gst_buffer_pool_config_set_params (structure, caps, size, 2, 0);
+ 
+-  alloc = gst_wl_shm_allocator_get ();
++  if(sink->display->use_drm)
++      alloc = gst_drm_allocator_get ();
++  else
++      alloc = gst_wl_shm_allocator_get ();
++
+   gst_buffer_pool_config_set_allocator (structure, alloc, NULL);
+   if (!gst_buffer_pool_set_config (pool, structure)) {
+     g_object_unref (pool);
+@@ -512,16 +553,34 @@ gst_wayland_create_pool (GstWaylandSink * sink, GstCaps 
* caps)
+   return pool;
+ }
+ 
++static void
++wait_authentication (GstWaylandSink * sink)
++{
++  GST_DEBUG_OBJECT (sink, "Before wait aunthenticated value is %d : \n", 
sink->display->authenticated );
++  while (!sink->display->authenticated) {
++    GST_DEBUG_OBJECT (sink, "waiting for authentication");
++    wl_display_roundtrip (sink->display->display);
++  }
++  GST_DEBUG_OBJECT (sink, "After wait aunthenticated value is %d : \n", 
sink->display->authenticated );
++}
++
+ static gboolean
+ gst_wayland_sink_set_caps (GstBaseSink * bsink, GstCaps * caps)
+ {
+   GstWaylandSink *sink;
+   gboolean use_dmabuf;
++  gboolean use_drm = 0;
+   GstVideoFormat format;
++  GstStructure *s;
+ 
+   sink = GST_WAYLAND_SINK (bsink);
+ 
+   GST_DEBUG_OBJECT (sink, "set caps %" GST_PTR_FORMAT, caps);
++  wait_authentication (sink);
++
++  while (!sink->display->authenticated) {
++    GST_DEBUG_OBJECT (sink, "not authenticated yet");
++  }
+ 
+   /* extract info from caps */
+   if (!gst_video_info_from_caps (&sink->video_info, caps))
+@@ -530,6 +589,12 @@ gst_wayland_sink_set_caps (GstBaseSink * bsink, GstCaps * 
caps)
+   format = GST_VIDEO_INFO_FORMAT (&sink->video_info);
+   sink->video_info_changed = TRUE;
+ 
++  s = gst_caps_get_structure (caps, 0);
++  gst_structure_get_boolean (s, "drm_mem", &use_drm);
++
++  if(use_drm)
++     sink->display->use_drm = TRUE;
++
+   /* create a new pool for the new caps */
+   if (sink->pool)
+     gst_object_unref (sink->pool);
+@@ -582,7 +647,11 @@ gst_wayland_sink_propose_allocation (GstBaseSink * bsink, 
GstQuery * query)
+   if (pool)
+     g_object_unref (pool);
+ 
+-  alloc = gst_wl_shm_allocator_get ();
++  if(sink->display->use_drm)
++      alloc = gst_drm_allocator_get ();
++  else
++      alloc = gst_wl_shm_allocator_get ();
++
+   gst_query_add_allocation_param (query, alloc, NULL);
+   gst_query_add_allocation_meta (query, GST_VIDEO_META_API_TYPE, NULL);
+   g_object_unref (alloc);
+@@ -649,6 +718,9 @@ gst_wayland_sink_show_frame (GstVideoSink * vsink, 
GstBuffer * buffer)
+ 
+   GST_LOG_OBJECT (sink, "render buffer %p", buffer);
+ 
++  if (sink->display) {
++     sink->display->crop = gst_buffer_get_video_crop_meta (buffer);
++  }
+   if (G_UNLIKELY (!sink->window)) {
+     /* ask for window handle. Unlock render_lock while doing that because
+      * set_window_handle & friends will lock it in this context */
+@@ -712,6 +784,10 @@ gst_wayland_sink_show_frame (GstVideoSink * vsink, 
GstBuffer * buffer)
+       wbuf = gst_wl_linux_dmabuf_construct_wl_buffer (buffer, sink->display,
+           &sink->video_info);
+   }
++  if (gst_is_drm_memory (mem)) {
++     wbuf = gst_wl_drm_memory_construct_wl_buffer (mem, sink->display,
++         &sink->video_info);
++  }
+ 
+   if (!wbuf && gst_wl_display_check_format_for_shm (sink->display, format)) {
+     if (gst_buffer_n_memory (buffer) == 1 && gst_is_fd_memory (mem))
+diff --git a/ext/wayland/gstwaylandsink.h b/ext/wayland/gstwaylandsink.h
+index 2704d00..a7123fb 100644
+--- a/ext/wayland/gstwaylandsink.h
++++ b/ext/wayland/gstwaylandsink.h
+@@ -63,6 +63,8 @@ struct _GstWaylandSink
+ 
+   gchar *display_name;
+ 
++  gboolean use_drm;
++  gint scale_width, scale_height;
+   gboolean redraw_pending;
+   GMutex render_lock;
+   GstBuffer *last_buffer;
+diff --git a/ext/wayland/wldisplay.c b/ext/wayland/wldisplay.c
+index 39782bc..ac6637f 100644
+--- a/ext/wayland/wldisplay.c
++++ b/ext/wayland/wldisplay.c
+@@ -26,6 +26,10 @@
+ #include "wlbuffer.h"
+ #include "wlvideoformat.h"
+ 
++#include "wayland-drm-client-protocol.h"
++#include <fcntl.h>
++#include <xf86drm.h>
++#include <xf86drmMode.h>
+ #include <errno.h>
+ 
+ GST_DEBUG_CATEGORY_EXTERN (gstwayland_debug);
+@@ -46,9 +50,12 @@ static void
+ gst_wl_display_init (GstWlDisplay * self)
+ {
+   self->shm_formats = g_array_new (FALSE, FALSE, sizeof (uint32_t));
++  self->drm_formats = g_array_new (FALSE, FALSE, sizeof (uint32_t));
+   self->dmabuf_formats = g_array_new (FALSE, FALSE, sizeof (uint32_t));
+   self->wl_fd_poll = gst_poll_new (TRUE);
+   self->buffers = g_hash_table_new (g_direct_hash, g_direct_equal);
++  self->fd = -1;
++  self->use_drm = FALSE;
+   g_mutex_init (&self->buffers_mutex);
+ }
+ 
+@@ -73,11 +80,15 @@ gst_wl_display_finalize (GObject * gobject)
+   g_hash_table_remove_all (self->buffers);
+ 
+   g_array_unref (self->shm_formats);
++  g_array_unref (self->drm_formats);
+   g_array_unref (self->dmabuf_formats);
+   gst_poll_free (self->wl_fd_poll);
+   g_hash_table_unref (self->buffers);
+   g_mutex_clear (&self->buffers_mutex);
+ 
++  if(self->fd != -1)
++      close(self->fd);
++
+   if (self->viewporter)
+     wp_viewporter_destroy (self->viewporter);
+ 
+@@ -87,6 +98,9 @@ gst_wl_display_finalize (GObject * gobject)
+   if (self->dmabuf)
+     zwp_linux_dmabuf_v1_destroy (self->dmabuf);
+ 
++  if (self->drm)
++    wl_drm_destroy (self->drm);
++
+   if (self->shell)
+     wl_shell_destroy (self->shell);
+ 
+@@ -210,8 +224,46 @@ gst_wl_display_check_format_for_dmabuf (GstWlDisplay * 
display,
+ 
+   return FALSE;
+ }
++/* For wl_drm_listener */
+ 
+ static void
++drm_handle_device (void *data, struct wl_drm *drm, const char *device)
++{
++  GstWlDisplay *d = data;
++  drm_magic_t magic;
++  d->fd = open (device, O_RDWR | O_CLOEXEC);
++  if (d->fd == -1) {
++    GST_ERROR ("could not open %s: %m", device);
++    return;
++  }
++  drmGetMagic (d->fd, &magic);
++  wl_drm_authenticate (d->drm, magic);
++}
++
++static void
++drm_handle_format (void *data, struct wl_drm *drm, uint32_t format)
++{
++  GstWlDisplay *self = data;
++  g_array_append_val (self->drm_formats, format);
++  GST_DEBUG ("got format: %" GST_FOURCC_FORMAT, GST_FOURCC_ARGS (format));
++}
++
++static void
++drm_handle_authenticated (void *data, struct wl_drm *drm)
++{
++  GstWlDisplay *d = data;
++  GST_DEBUG ("authenticated");
++  d->authenticated = 1;
++  GST_DEBUG ("drm_handle_authenticated: d->authenticated: 
%d\n",d->authenticated);
++}
++
++static const struct wl_drm_listener drm_listener = {
++  drm_handle_device,
++  drm_handle_format,
++  drm_handle_authenticated
++};
++ 
++static void
+ registry_handle_global (void *data, struct wl_registry *registry,
+     uint32_t id, const char *interface, uint32_t version)
+ {
+@@ -228,6 +280,9 @@ registry_handle_global (void *data, struct wl_registry 
*registry,
+   } else if (g_strcmp0 (interface, "wl_shm") == 0) {
+     self->shm = wl_registry_bind (registry, id, &wl_shm_interface, 1);
+     wl_shm_add_listener (self->shm, &shm_listener, self);
++  } else if (g_strcmp0 (interface, "wl_drm") == 0) {
++    self->drm = wl_registry_bind (registry, id, &wl_drm_interface, 1);
++    wl_drm_add_listener (self->drm, &drm_listener, self);
+   } else if (g_strcmp0 (interface, "wp_viewporter") == 0) {
+     self->viewporter =
+         wl_registry_bind (registry, id, &wp_viewporter_interface, 1);
+@@ -338,6 +393,7 @@ gst_wl_display_new_existing (struct wl_display * display,
+   VERIFY_INTERFACE_EXISTS (subcompositor, "wl_subcompositor");
+   VERIFY_INTERFACE_EXISTS (shell, "wl_shell");
+   VERIFY_INTERFACE_EXISTS (shm, "wl_shm");
++  VERIFY_INTERFACE_EXISTS (drm, "wl_drm");
+ 
+ #undef VERIFY_INTERFACE_EXISTS
+ 
+diff --git a/ext/wayland/wldisplay.h b/ext/wayland/wldisplay.h
+index 7c89212..1d3a49e 100644
+--- a/ext/wayland/wldisplay.h
++++ b/ext/wayland/wldisplay.h
+@@ -53,10 +53,12 @@ struct _GstWlDisplay
+   struct wl_subcompositor *subcompositor;
+   struct wl_shell *shell;
+   struct wl_shm *shm;
++  struct wl_drm *drm;
+   struct wp_viewporter *viewporter;
+   struct zwp_linux_dmabuf_v1 *dmabuf;
+   GArray *shm_formats;
+   GArray *dmabuf_formats;
++  GArray *drm_formats;
+ 
+   /* private */
+   gboolean own_display;
+@@ -66,6 +68,13 @@ struct _GstWlDisplay
+   GMutex buffers_mutex;
+   GHashTable *buffers;
+   gboolean shutting_down;
++
++  int fd;
++  int authenticated;
++  gboolean use_drm;
++  gint scale_width, scale_height;
++  GstVideoCropMeta *crop;
++
+ };
+ 
+ struct _GstWlDisplayClass
+diff --git a/ext/wayland/wldrm.c b/ext/wayland/wldrm.c
+new file mode 100644
+index 0000000..92f8e74
+--- /dev/null
++++ b/ext/wayland/wldrm.c
+@@ -0,0 +1,121 @@
++#include "wldisplay.h"
++#include <gst/drm/gstdrmallocator.h>
++#include "wayland-drm-client-protocol.h"
++#include <wayland-client.h>
++
++GST_DEBUG_CATEGORY_EXTERN (gstwayland_debug);
++#define GST_CAT_DEFAULT gstwayland_debug
++
++
++struct wl_buffer *
++gst_wl_drm_memory_construct_wl_buffer (GstMemory * mem, GstWlDisplay * 
display,
++    const GstVideoInfo * info)
++{
++  gint video_width = GST_VIDEO_INFO_WIDTH (info);
++  gint video_height = GST_VIDEO_INFO_HEIGHT (info);
++  GstVideoFormat format = GST_VIDEO_INFO_FORMAT (info);
++  int fd = -1;
++  struct wl_buffer *buffer;
++  uint32_t fourcc;
++  uint32_t bpp;
++  uint32_t name;
++  int singlePlane = 0;
++  int ret;
++  struct drm_prime_handle req1;
++  struct drm_gem_flink req2;
++  /* note: wayland and mesa use the terminology:
++   *    stride - rowstride in bytes
++   *    pitch  - rowstride in pixels
++   */
++  uint32_t strides[3] = {
++    GST_ROUND_UP_4 (video_width), 0, 0,
++  };
++  uint32_t offsets[3] = {
++    0, strides[0] * video_height, 0
++  };
++
++  if (format == GST_VIDEO_FORMAT_NV12)
++  {
++    /* NV12 */
++    fourcc = GST_MAKE_FOURCC ('N', 'V', '1', '2');
++    strides[1] = GST_ROUND_UP_4 (video_width);
++  }
++  else if(format == GST_VIDEO_FORMAT_I420)
++  {
++    /* YUV420 */
++    fourcc = GST_MAKE_FOURCC ('Y', 'U', '1', '2');
++    strides[0] = GST_VIDEO_INFO_PLANE_STRIDE (info, 0);
++    strides[1] = GST_VIDEO_INFO_PLANE_STRIDE (info, 1);
++    strides[2] = GST_VIDEO_INFO_PLANE_STRIDE (info, 2);
++    offsets[0] = GST_VIDEO_INFO_PLANE_OFFSET (info, 0);
++    offsets[1] = GST_VIDEO_INFO_PLANE_OFFSET (info, 1);
++    offsets[2] = GST_VIDEO_INFO_PLANE_OFFSET (info, 2);
++
++  }
++  else if(format == GST_VIDEO_FORMAT_BGRA)
++  {
++    singlePlane = 1;
++    bpp = 4;
++    fourcc = GST_MAKE_FOURCC ('A', 'R', '2', '4');
++  }
++  else if(format == GST_VIDEO_FORMAT_YUY2)
++  {
++    singlePlane = 1;
++    bpp = 2;
++    fourcc = GST_MAKE_FOURCC ('Y', 'U', 'Y', 'V');
++  }
++  else
++  {
++
++    GST_DEBUG ("Unsupported video format: %d", format);
++    /*
++     * There are two xRGB frames with width and height = 1 required in the 
begining of a video stream.
++     * If we consider them as errot, then it will case libwayland-clent.so 
crashes
++     * due to invalid error handling.
++     * Consider them as NV12 until we can figure out a better solution
++     */
++    fourcc = GST_MAKE_FOURCC ('N', 'V', '1', '2');
++    strides[1] = GST_ROUND_UP_4 (video_width);
++  }
++
++  fd = gst_fd_memory_get_fd (mem);
++
++  if (fd < 0 ) {
++    GST_DEBUG ("Invalid fd");
++    return NULL;
++  }
++  req1.fd = fd,
++
++  ret = drmIoctl(display->fd, DRM_IOCTL_PRIME_FD_TO_HANDLE, &req1);
++  if (ret) {
++    GST_DEBUG ("could not get handle, DRM_IOCTL_PRIME_FD_TO_HANDLE returned 
%d", ret);
++    return NULL;
++  }
++
++  req2.handle = req1.handle,
++
++  ret = drmIoctl(display->fd, DRM_IOCTL_GEM_FLINK, &req2);
++  if (ret) {
++    GST_DEBUG ("could not get name, DRM_IOCTL_GEM_FLINK returned %d", ret);
++    return NULL;
++  }
++
++  name = req2.name;
++  GST_LOG ("width = %d , height = %d , fourcc = %d ",  video_width, 
video_height, fourcc );
++
++  if(!singlePlane)
++     buffer = wl_drm_create_planar_buffer (display->drm, name,
++          video_width, video_height, fourcc,
++          offsets[0], strides[0],
++          offsets[1], strides[1],
++          offsets[2], strides[2]);
++  else
++     buffer = wl_drm_create_buffer(display->drm, name, video_width, 
video_height,
++                      video_width * bpp, fourcc);
++
++  GST_DEBUG ("create planar buffer: %p (name=%d)",
++      buffer, name);
++
++  return buffer;
++}
++
+diff --git a/ext/wayland/wldrm.h b/ext/wayland/wldrm.h
+new file mode 100644
+index 0000000..c6b4ae1
+--- /dev/null
++++ b/ext/wayland/wldrm.h
+@@ -0,0 +1,21 @@
++/*
++ 
*******************************************************************************
++ *
++ * Copyright (C) 2017 Texas Instruments Incorporated - http://www.ti.com/
++ * ALL RIGHTS RESERVED
++ *
++ 
*******************************************************************************
++ */
++#ifndef __GST_WL_DRM_H__
++#define __GST_WL_DRM_H__
++
++#include <gst/drm/gstdrmallocator.h>
++#include "wayland-drm-client-protocol.h"
++#include <wayland-client.h>
++
++struct wl_buffer *
++gst_wl_drm_memory_construct_wl_buffer (GstMemory * mem, GstWlDisplay * 
display,
++    const GstVideoInfo * info);
++
++
++#endif /* __GST_WL_DRM_H__ */
+diff --git a/ext/wayland/wlwindow.c b/ext/wayland/wlwindow.c
+index c64c77a..e066ef2 100644
+--- a/ext/wayland/wlwindow.c
++++ b/ext/wayland/wlwindow.c
+@@ -137,6 +137,16 @@ gst_wl_window_new_internal (GstWlDisplay * display, 
GMutex * render_lock)
+     window->video_viewport = wp_viewporter_get_viewport (display->viewporter,
+         window->video_surface);
+   }
++  if (display->crop) {
++    GST_DEBUG ("Setting source crop : %d %d %d %d",display->crop->x, 
display->crop->y,
++                    display->crop->width, display->crop->height);
++    wp_viewport_set_source (window->video_viewport,
++                                        wl_fixed_from_int(display->crop->x),
++                                        wl_fixed_from_int(display->crop->y),
++                                        
wl_fixed_from_int(display->crop->width),
++                                        
wl_fixed_from_int(display->crop->height));
++
++  }
+ 
+   /* do not accept input */
+   region = wl_compositor_create_region (display->compositor);
+@@ -228,6 +238,8 @@ gst_wl_window_resize_video_surface (GstWlWindow * window, 
gboolean commit)
+   GstVideoRectangle src = { 0, };
+   GstVideoRectangle dst = { 0, };
+   GstVideoRectangle res;
++  gint scale_width = window->display->scale_width;
++  gint scale_height = window->display->scale_height;
+ 
+   /* center the video_subsurface inside area_subsurface */
+   src.w = window->video_width;
+@@ -237,10 +249,31 @@ gst_wl_window_resize_video_surface (GstWlWindow * 
window, gboolean commit)
+ 
+   if (window->video_viewport) {
+     gst_video_sink_center_rect (src, dst, &res, TRUE);
+-    wp_viewport_set_destination (window->video_viewport, res.w, res.h);
+-  } else {
++ 
++    if(scale_width > 0 && scale_height > 0)
++    {
++          res.x = 0;
++          res.y = 0;
++          res.w = scale_width;
++          res.h = scale_height;
++          if (window->display->crop) {
++                  window->display->crop->width = scale_width;
++                  window->display->crop->height = scale_height;
++          }
++    }
++
++    if (window->display->crop) {
++          wp_viewport_set_destination (window->area_viewport, 
window->display->crop->width,  window->display->crop->height);
++          wp_viewport_set_destination (window->video_viewport, 
window->display->crop->width,  window->display->crop->height);
++    } else 
++    {
++          wp_viewport_set_destination (window->video_viewport, res.w, res.h);
++    }
++  }
++   else {
+     gst_video_sink_center_rect (src, dst, &res, FALSE);
+   }
++  
+ 
+   wl_subsurface_set_position (window->video_subsurface, res.x, res.y);
+ 
+@@ -355,13 +388,23 @@ gst_wl_window_update_borders (GstWlWindow * window)
+   /* draw the area_subsurface */
+   gst_video_info_set_format (&info, format, width, height);
+ 
+-  alloc = gst_wl_shm_allocator_get ();
++  if(!window->display->use_drm)
++      alloc = gst_wl_shm_allocator_get ();
++  else
++      alloc = gst_drm_allocator_get ();
+ 
+   buf = gst_buffer_new_allocate (alloc, info.size, NULL);
+   gst_buffer_memset (buf, 0, 0, info.size);
+-  wlbuf =
+-      gst_wl_shm_memory_construct_wl_buffer (gst_buffer_peek_memory (buf, 0),
+-      window->display, &info);
++
++  if(!window->display->use_drm)
++      wlbuf =
++          gst_wl_shm_memory_construct_wl_buffer (gst_buffer_peek_memory (buf, 
0),
++          window->display, &info);
++  else
++      wlbuf =
++          gst_wl_drm_memory_construct_wl_buffer (gst_buffer_peek_memory (buf, 
0),
++          window->display, &info);
++
+   gwlbuf = gst_buffer_add_wl_buffer (buf, wlbuf, window->display);
+   gst_wl_buffer_attach (gwlbuf, window->area_surface);
+ 
+@@ -375,8 +418,16 @@ void
+ gst_wl_window_set_render_rectangle (GstWlWindow * window, gint x, gint y,
+     gint w, gint h)
+ {
++  gint scale_width = window->display->scale_width;
++  gint scale_height = window->display->scale_height;
++
+   g_return_if_fail (window != NULL);
+ 
++  if(scale_width > 0 && scale_height > 0) {
++    w = scale_width;
++    h = scale_height;
++   }
++
+   window->render_rectangle.x = x;
+   window->render_rectangle.y = y;
+   window->render_rectangle.w = w;
+-- 
+1.9.1
+
diff --git 
a/meta-arago-extras/recipes-multimedia/gstreamer/gstreamer1.0-plugins-bad_1.14.4.bbappend
 
b/meta-arago-extras/recipes-multimedia/gstreamer/gstreamer1.0-plugins-bad_1.14.4.bbappend
index aa6d5fb..517a560 100644
--- 
a/meta-arago-extras/recipes-multimedia/gstreamer/gstreamer1.0-plugins-bad_1.14.4.bbappend
+++ 
b/meta-arago-extras/recipes-multimedia/gstreamer/gstreamer1.0-plugins-bad_1.14.4.bbappend
@@ -25,34 +25,34 @@ DEPENDS_append_k3 = " \
     libdrm \
 "
 
-#    file://0004-waylandsink-Add-drm-support-in-waylandsink.patch
 #    file://0005-waylandsink-Add-input-device-support.patch
 SRC_URI_append_ti43x = " \
     file://0001-gstdrmallocator-Add-DRM-allocator-support.patch \
     file://0002-parsers-bug-fixes-on-parsers.patch \
     file://0003-kmssink-Add-omapdrm-and-tidss-in-the-list-of-drivers.patch \
+    file://0004-waylandsink-Add-drm-support-in-waylandsink.patch \
 "
 
 SRC_URI_append_ti33x = " \
     file://0001-waylandsink-Add-mouse-drag-and-drop-support.patch \
 "
 
-#    file://0004-waylandsink-Add-drm-support-in-waylandsink.patch
 #    file://0005-waylandsink-Add-input-device-support.patch
 SRC_URI_append_omap-a15 = " \
     file://0001-gstdrmallocator-Add-DRM-allocator-support.patch \
     file://0002-parsers-bug-fixes-on-parsers.patch \
     file://0003-kmssink-Add-omapdrm-and-tidss-in-the-list-of-drivers.patch \
+    file://0004-waylandsink-Add-drm-support-in-waylandsink.patch \
 "
 
-#    file://0004-waylandsink-Add-drm-support-in-waylandsink.patch
 #    file://0005-waylandsink-Add-input-device-support.patch
 SRC_URI_append_k3 = " \
     file://0001-gstdrmallocator-Add-DRM-allocator-support.patch \
     file://0002-parsers-bug-fixes-on-parsers.patch \
     file://0003-kmssink-Add-omapdrm-and-tidss-in-the-list-of-drivers.patch \
+    file://0004-waylandsink-Add-drm-support-in-waylandsink.patch \
 "
 
 PACKAGE_ARCH = "${MACHINE_ARCH}"
 
-PR = "r9"
+PR = "r10"
-- 
1.9.1

_______________________________________________
meta-arago mailing list
[email protected]
http://arago-project.org/cgi-bin/mailman/listinfo/meta-arago

Reply via email to