From: "Carlos Rafael Giani" <crg7475@mailbox.org>
To: openembedded-core@lists.openembedded.org
Subject: Re: [OE-core] [PATCH v3 05/20] gstreamer1.0-plugins-good: upgrade to version 1.18.0
Date: Mon, 19 Oct 2020 09:37:39 +0200 [thread overview]
Message-ID: <a010177b-5656-45bd-bbc2-c8de33f2b837@mailbox.org> (raw)
In-Reply-To: <20201018121002.1417335-6-quaresma.jose@gmail.com>
[-- Attachment #1: Type: text/plain, Size: 10141 bytes --]
The code in ext/qt/meson.build looks for the Qt5WaylandClient pkg-config
file. Without this module, qmlglsink will not work with Wayland. This
can be tested by checking whether or not HAVE_QT_WAYLAND has been added
to the cflags in the autogenerated ninja file.
I propose this change to fix the problem:
--- a/meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good_1.18.0.bb
+++ b/meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good_1.18.0.bb
@@ -28,6 +28,8 @@ X11DEPENDS = "virtual/libx11 libsm libxrender
libxfixes libxdamage"
X11ENABLEOPTS = "-Dximagesrc=enabled -Dximagesrc-xshm=enabled
-Dximagesrc-xfixes=enabled -Dximagesrc-xdamage=enabled"
X11DISABLEOPTS = "-Dximagesrc=disabled -Dximagesrc-xshm=disabled
-Dximagesrc-xfixes=disabled -Dximagesrc-xdamage=disabled"
+QT5WAYLANDDEPENDS = "${@bb.utils.contains("DISTRO_FEATURES", "wayland",
"qtwayland", "", d)}"
+
PACKAGECONFIG[asm] = "-Dasm=enabled,-Dasm=disabled,nasm"
PACKAGECONFIG[bz2] = "-Dbz2=enabled,-Dbz2=disabled,bzip2"
PACKAGECONFIG[cairo] = "-Dcairo=enabled,-Dcairo=disabled,cairo"
@@ -43,7 +45,7 @@ PACKAGECONFIG[libpng] =
"-Dpng=enabled,-Dpng=disabled,libpng"
PACKAGECONFIG[libv4l2] =
"-Dv4l2-libv4l2=enabled,-Dv4l2-libv4l2=disabled,v4l-utils"
PACKAGECONFIG[mpg123] = "-Dmpg123=enabled,-Dmpg123=disabled,mpg123"
PACKAGECONFIG[pulseaudio] = "-Dpulse=enabled,-Dpulse=disabled,pulseaudio"
-PACKAGECONFIG[qt5] = "-Dqt5=enabled,-Dqt5=disabled,qtbase
qtdeclarative qtbase-native"
+PACKAGECONFIG[qt5] = "-Dqt5=enabled,-Dqt5=disabled,qtbase
qtdeclarative qtbase-native ${QT5WAYLANDDEPENDS}"
PACKAGECONFIG[soup] = "-Dsoup=enabled,-Dsoup=disabled,libsoup-2.4"
PACKAGECONFIG[speex] = "-Dspeex=enabled,-Dspeex=disabled,speex"
PACKAGECONFIG[taglib] = "-Dtaglib=enabled,-Dtaglib=disabled,taglib"
On 18.10.20 14:09, Jose Quaresma wrote:
> * 0001-qmlgl-ensure-Qt-defines-GLsync-to-fix-compile-on-som.patch
> Removed since these are included in 1.18.0
>
> License-Update: removefile://common/coverage/coverage-report.pl
> Upstream dont have it any more.
>
> Signed-off-by: Jose Quaresma<quaresma.jose@gmail.com>
> ---
> ...defines-GLsync-to-fix-compile-on-som.patch | 70 -------------------
> ...t-gstqtgl.h-instead-of-gst-gl-gstglf.patch | 8 +--
> ...bb => gstreamer1.0-plugins-good_1.18.0.bb} | 14 ++--
> 3 files changed, 10 insertions(+), 82 deletions(-)
> delete mode 100644 meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good/0001-qmlgl-ensure-Qt-defines-GLsync-to-fix-compile-on-som.patch
> rename meta/recipes-multimedia/gstreamer/{gstreamer1.0-plugins-good_1.16.2.bb => gstreamer1.0-plugins-good_1.18.0.bb} (84%)
>
> diff --git a/meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good/0001-qmlgl-ensure-Qt-defines-GLsync-to-fix-compile-on-som.patch b/meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good/0001-qmlgl-ensure-Qt-defines-GLsync-to-fix-compile-on-som.patch
> deleted file mode 100644
> index 136848763b..0000000000
> --- a/meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good/0001-qmlgl-ensure-Qt-defines-GLsync-to-fix-compile-on-som.patch
> +++ /dev/null
> @@ -1,70 +0,0 @@
> -From 3e0d5577444b32579bdf5b69d720a322322ff7bc Mon Sep 17 00:00:00 2001
> -From: Milian Wolff<milian.wolff@kdab.com>
> -Date: Tue, 26 Nov 2019 15:08:20 +0100
> -Subject: [PATCH] qmlgl: ensure Qt defines GLsync to fix compile on some platforms
> -MIME-Version: 1.0
> -Content-Type: text/plain; charset=UTF-8
> -Content-Transfer-Encoding: 8bit
> -
> -By explictly including QtGui/qopengl.h we force the code path that
> -defines GLsync in the Qt-specific way. Without that, some platforms
> -failed to compile the qmlgl plugin, since neither Qt nor gstreamer
> -defined GLsync then, leading to e.g.:
> -
> -```
> -make[4]: Entering directory '/.../gst-plugins-good-1.16.1/ext/qt'
> - CXX libgstqmlgl_la-qtitem.lo
> -In file included from gstqtgl.h:32,
> - from qtitem.h:27,
> - from qtitem.cc:28:
> -/.../usr/include/gstreamer-1.0/
> -gst/gl/gstglfuncs.h:93:17: error: expected identifier before ‘*’ token
> - ret (GSTGLAPI *name) args;
> - ^
> -/.../usr/include/gstreamer-1.0/
> -gst/gl/glprototypes/sync.h:27:1: note: in expansion of macro
> -‘GST_GL_EXT_FUNCTION’
> - GST_GL_EXT_FUNCTION (GLsync, FenceSync,
> - ^~~~~~~~~~~~~~~~~~~
> -```
> -Signed-off-by: Khem Raj<raj.khem@gmail.com>
> -Upstream-Status: Backport [https://gitlab.freedesktop.org/gstreamer/gst-plugins-good/commit/3e0d5577444b32579bdf5b69d720a322322ff7bc]
> ----
> - ext/qt/gstqtgl.h | 18 +++++++++++-------
> - 1 file changed, 11 insertions(+), 7 deletions(-)
> -
> ---- a/ext/qt/gstqtgl.h
> -+++ b/ext/qt/gstqtgl.h
> -@@ -22,14 +22,7 @@
> - #include <QtGui/qtgui-config.h>
> - #endif
> -
> --/* qt uses the same trick as us to typedef GLsync on GLES2 but to a different
> -- * type which confuses the preprocessor. Instead of trying to reconcile the
> -- * two, we instead use the GLsync definition from Qt from above, and ensure
> -- * that we don't typedef GLsync in gstglfuncs.h */
> - #include <gst/gl/gstglconfig.h>
> --#undef GST_GL_HAVE_GLSYNC
> --#define GST_GL_HAVE_GLSYNC 1
> --#include <gst/gl/gstglfuncs.h>
> -
> - /* The glext.h guard was renamed in 2018, but some software which
> - * includes their own copy of the GL headers (such as qt) might have
> -@@ -46,6 +39,17 @@
> - #endif
> - #endif
> -
> -+/* pulls in GLsync, see below */
> -+#include <QtGui/qopengl.h>
> -+
> -+/* qt uses the same trick as us to typedef GLsync on GLES2 but to a different
> -+ * type which confuses the preprocessor. Instead of trying to reconcile the
> -+ * two, we instead use the GLsync definition from Qt from above, and ensure
> -+ * that we don't typedef GLsync in gstglfuncs.h */
> -+#undef GST_GL_HAVE_GLSYNC
> -+#define GST_GL_HAVE_GLSYNC 1
> -+#include <gst/gl/gstglfuncs.h>
> -+
> - #if defined(QT_OPENGL_ES_2)
> - #include <QtGui/QOpenGLContext>
> - #include <QtGui/QOpenGLFunctions>
> diff --git a/meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good/0001-qt-include-ext-qt-gstqtgl.h-instead-of-gst-gl-gstglf.patch b/meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good/0001-qt-include-ext-qt-gstqtgl.h-instead-of-gst-gl-gstglf.patch
> index 3d423154e0..788d752058 100644
> --- a/meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good/0001-qt-include-ext-qt-gstqtgl.h-instead-of-gst-gl-gstglf.patch
> +++ b/meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good/0001-qt-include-ext-qt-gstqtgl.h-instead-of-gst-gl-gstglf.patch
> @@ -1,4 +1,4 @@
> -From d08234a659bec1fd5c984fedefbeb8192af07839 Mon Sep 17 00:00:00 2001
> +From bf8b2fa0f6870589d036f0f33c140a3f85b530a0 Mon Sep 17 00:00:00 2001
> From: Khem Raj<raj.khem@gmail.com>
> Date: Tue, 31 Mar 2020 21:23:28 -0700
> Subject: [PATCH] qt: include ext/qt/gstqtgl.h instead of gst/gl/gstglfuncs.h
> @@ -26,7 +26,7 @@ Signed-off-by: Khem Raj<raj.khem@gmail.com>
> 2 files changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/ext/qt/gstqsgtexture.cc b/ext/qt/gstqsgtexture.cc
> -index 2b314e0..12b15dd 100644
> +index a05d26e..4cc9fc6 100644
> --- a/ext/qt/gstqsgtexture.cc
> +++ b/ext/qt/gstqsgtexture.cc
> @@ -27,7 +27,7 @@
> @@ -39,7 +39,7 @@ index 2b314e0..12b15dd 100644
>
> #define GST_CAT_DEFAULT gst_qsg_texture_debug
> diff --git a/ext/qt/qtwindow.cc b/ext/qt/qtwindow.cc
> -index 62d26b6..bf68ebb 100644
> +index 9360c33..0dfd3f1 100644
> --- a/ext/qt/qtwindow.cc
> +++ b/ext/qt/qtwindow.cc
> @@ -25,7 +25,7 @@
> @@ -52,5 +52,5 @@ index 62d26b6..bf68ebb 100644
> #include "gstqsgtexture.h"
> #include "gstqtglutility.h"
> --
> -2.26.0
> +2.28.0
>
> diff --git a/meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good_1.16.2.bb b/meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good_1.18.0.bb
> similarity index 84%
> rename from meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good_1.16.2.bb
> rename to meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good_1.18.0.bb
> index 17c9421394..c112f336b2 100644
> --- a/meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good_1.16.2.bb
> +++ b/meta/recipes-multimedia/gstreamer/gstreamer1.0-plugins-good_1.18.0.bb
> @@ -1,19 +1,16 @@
> require gstreamer1.0-plugins-common.inc
>
> -SRC_URI = " \
> -https://gstreamer.freedesktop.org/src/gst-plugins-good/gst-plugins-good-${PV}.tar.xz \
> -file://0001-qmlgl-ensure-Qt-defines-GLsync-to-fix-compile-on-som.patch \
> -file://0001-qt-include-ext-qt-gstqtgl.h-instead-of-gst-gl-gstglf.patch \
> - "
> +SRC_URI ="https://gstreamer.freedesktop.org/src/gst-plugins-good/gst-plugins-good-${PV}.tar.xz
> \ +
> file://0001-qt-include-ext-qt-gstqtgl.h-instead-of-gst-gl-gstglf.patch
> \ + "
>
> -SRC_URI[md5sum] = "bd025f8f14974f94b75ac69a9d1b9c93"
> -SRC_URI[sha256sum] = "40bb3bafda25c0b739c8fc36e48380fccf61c4d3f83747e97ac3f9b0171b1319"
> +SRC_URI[md5sum] = "c437bf42bf830bc0f482c7d088fb37a5"
> +SRC_URI[sha256sum] = "6329bc377a3afea5cf1ab329a91cc4a906f075781780d1edc59e8bea8c1a8bac"
>
> S = "${WORKDIR}/gst-plugins-good-${PV}"
>
> LICENSE = "GPLv2+ & LGPLv2.1+"
> LIC_FILES_CHKSUM ="file://COPYING;md5=a6f89e2100d9b6cdffcea4f398e37343 \ -
> file://common/coverage/coverage-report.pl;beginline=2;endline=17;md5=a4e1830fce078028c8f0974161272607
> \
> file://gst/replaygain/rganalysis.c;beginline=1;endline=23;md5=b60ebefd5b2f5a8e0cab6bfee391a5fe"
>
> DEPENDS += "gstreamer1.0-plugins-base libcap zlib"
> @@ -54,6 +51,7 @@ PACKAGECONFIG[wavpack] = "-Dwavpack=enabled,-Dwavpack=disabled,wavpack"
> PACKAGECONFIG[x11] = "${X11ENABLEOPTS},${X11DISABLEOPTS},${X11DEPENDS}"
>
> EXTRA_OEMESON += " \
> + -Ddoc=disabled \
> -Daalib=disabled \
> -Ddirectsound=disabled \
> -Ddv=disabled \
>
>
>
[-- Attachment #2: Type: text/html, Size: 12294 bytes --]
next prev parent reply other threads:[~2020-10-19 7:37 UTC|newest]
Thread overview: 29+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-10-18 12:09 [PATCH v3 00/20] Updates the gstreamer to version 1.18.0 Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 01/20] gstreamer1.0: upgrade " Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 02/20] gstreamer1.0: Fix reproducibility issue around libcap Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 03/20] gstreamer1.0-plugins-base: upgrade to version 1.18.0 Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 04/20] gstreamer1.0-plugins-base: add new meson option as PACKAGECONFIG Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 05/20] gstreamer1.0-plugins-good: upgrade to version 1.18.0 Jose Quaresma
2020-10-19 7:37 ` Carlos Rafael Giani [this message]
2020-10-19 10:41 ` Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 06/20] gstreamer1.0-plugins-good: disable new meson options Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 07/20] gstreamer1.0-plugins-good: add new meson option as PACKAGECONFIG Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 08/20] gstreamer1.0-plugins-bad: upgrade to version 1.18.0 Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 09/20] gstreamer1.0-plugins-bad: disable new meson options Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 10/20] gstreamer1.0-plugins-bad: add new meson options as PACKAGECONFIG Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 11/20] gstreamer1.0-plugins-ugly: upgrade to version 1.18.0 Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 12/20] gstreamer1.0-python: " Jose Quaresma
2020-10-19 7:05 ` [OE-core] " Carlos Rafael Giani
2020-10-19 10:29 ` Jose Quaresma
2020-10-19 10:37 ` [OE-core] " Carlos Rafael Giani
2020-10-18 12:09 ` [PATCH v3 13/20] gstreamer1.0-python: install append is not need any more Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 14/20] gstreamer1.0-rtsp-server: upgrade to version 1.18.0 Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 15/20] gstreamer1.0-vaapi: " Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 16/20] gst-examples: " Jose Quaresma
2020-10-18 12:09 ` [PATCH v3 17/20] gstreamer1.0-omx: " Jose Quaresma
2020-10-18 12:10 ` [PATCH v3 18/20] gstreamer1.0-libav: " Jose Quaresma
2020-10-18 12:10 ` [PATCH v3 19/20] gst-devtools: add version 1.18.0 (gst-validate -> gst-devtools) Jose Quaresma
2020-10-18 12:10 ` [PATCH v3 20/20] orc: Upgrade 0.4.31 -> 0.4.32 Jose Quaresma
2020-10-19 10:06 ` [PATCH v3 00/20] Updates the gstreamer to version 1.18.0 Jose Quaresma
2020-10-19 10:12 ` [OE-core] " Alexander Kanavin
2020-10-19 10:16 ` Jose Quaresma
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=a010177b-5656-45bd-bbc2-c8de33f2b837@mailbox.org \
--to=crg7475@mailbox.org \
--cc=openembedded-core@lists.openembedded.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox