summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFabio Berton <fabio.berton@ossystems.com.br>2019-05-15 18:22:43 +0200
committerRichard Purdie <richard.purdie@linuxfoundation.org>2019-05-16 09:16:50 +0100
commite47715708729fe3fed2c5bcafa06f5f1c84f302f (patch)
tree708f428a746a6be67482f0b0bb2640a8b40d5b3a
parent9095dc153a760a4336260419aa2298fad8d7d031 (diff)
downloadpoky-e47715708729fe3fed2c5bcafa06f5f1c84f302f.tar.gz
mesa: Convert recipe to use meson build system
- Remove all non related meson patches - Change radeon driver to r100 - Add python3-mako-native gettext-native to DEPENDS Based on https://patchwork.openembedded.org/patch/158748/ Alex: added a patch to restore glx-tls option, which addresses the musl runtime issue. (From OE-Core rev: c72b6d46d392bfbcf54154f43663a7a8ada8c567) Signed-off-by: Fabio Berton <fabio.berton@ossystems.com.br> Signed-off-by: Alexander Kanavin <alex.kanavin@gmail.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r--meta/recipes-graphics/mesa/files/0001-Simplify-wayland-scanner-lookup.patch44
-rw-r--r--meta/recipes-graphics/mesa/files/0001-meson.build-check-for-all-linux-host_os-combinations.patch51
-rw-r--r--meta/recipes-graphics/mesa/files/0001-meson.build-make-TLS-GLX-optional-again.patch44
-rw-r--r--meta/recipes-graphics/mesa/files/0002-winsys-svga-drm-Include-sys-types.h.patch35
-rw-r--r--meta/recipes-graphics/mesa/files/0003-Properly-get-LLVM-version-when-using-LLVM-Git-releas.patch45
-rw-r--r--meta/recipes-graphics/mesa/files/0004-use-PKG_CHECK_VAR-for-defining-WAYLAND_PROTOCOLS_DAT.patch38
-rw-r--r--meta/recipes-graphics/mesa/mesa.inc64
-rw-r--r--meta/recipes-graphics/mesa/mesa_19.0.3.bb8
8 files changed, 129 insertions, 200 deletions
diff --git a/meta/recipes-graphics/mesa/files/0001-Simplify-wayland-scanner-lookup.patch b/meta/recipes-graphics/mesa/files/0001-Simplify-wayland-scanner-lookup.patch
deleted file mode 100644
index d065e2285c..0000000000
--- a/meta/recipes-graphics/mesa/files/0001-Simplify-wayland-scanner-lookup.patch
+++ /dev/null
@@ -1,44 +0,0 @@
1From e53837ad7b01364f34a533b95f4817c1795789de Mon Sep 17 00:00:00 2001
2From: Fabio Berton <fabio.berton@ossystems.com.br>
3Date: Wed, 20 Feb 2019 16:17:00 -0300
4Subject: [PATCH 1/4] Simplify wayland-scanner lookup
5Organization: O.S. Systems Software LTDA.
6
7Don't use pkg-config to lookup the path of a binary that's in the path.
8
9Alternatively we'd have to prefix the path returned by pkg-config with
10PKG_CONFIG_SYSROOT_DIR.
11
12Upstream-Status: Pending
13Signed-off-by: Jussi Kukkonen <jussi.kukkonen@intel.com>
14Signed-off-by: Otavio Salvador <otavio@ossystems.com.br>
15Signed-off-by: Fabio Berton <fabio.berton@ossystems.com.br>
16---
17 configure.ac | 7 +------
18 1 file changed, 1 insertion(+), 6 deletions(-)
19
20diff --git a/configure.ac b/configure.ac
21index 1ef68fe68e6..1816a4cd475 100644
22--- a/configure.ac
23+++ b/configure.ac
24@@ -1854,16 +1854,11 @@ for plat in $platforms; do
25 fi
26 WAYLAND_PROTOCOLS_DATADIR=`$PKG_CONFIG --variable=pkgdatadir wayland-protocols`
27
28- PKG_CHECK_MODULES([WAYLAND_SCANNER], [wayland-scanner],
29- WAYLAND_SCANNER=`$PKG_CONFIG --variable=wayland_scanner wayland-scanner`,
30- WAYLAND_SCANNER='')
31 PKG_CHECK_EXISTS([wayland-scanner >= 1.15],
32 AC_SUBST(SCANNER_ARG, 'private-code'),
33 AC_SUBST(SCANNER_ARG, 'code'))
34
35- if test "x$WAYLAND_SCANNER" = x; then
36- AC_PATH_PROG([WAYLAND_SCANNER], [wayland-scanner], [:])
37- fi
38+ AC_PATH_PROG([WAYLAND_SCANNER], [wayland-scanner], [:])
39
40 if test "x$WAYLAND_SCANNER" = "x:"; then
41 AC_MSG_ERROR([wayland-scanner is needed to compile the wayland platform])
42--
432.21.0
44
diff --git a/meta/recipes-graphics/mesa/files/0001-meson.build-check-for-all-linux-host_os-combinations.patch b/meta/recipes-graphics/mesa/files/0001-meson.build-check-for-all-linux-host_os-combinations.patch
new file mode 100644
index 0000000000..61e24c6e9f
--- /dev/null
+++ b/meta/recipes-graphics/mesa/files/0001-meson.build-check-for-all-linux-host_os-combinations.patch
@@ -0,0 +1,51 @@
1From 498f230c9446fc7a1b4dc77ff6b84ee1a3b53bf4 Mon Sep 17 00:00:00 2001
2From: Fabio Berton <fabio.berton@ossystems.com.br>
3Date: Wed, 24 Apr 2019 17:01:24 -0300
4Subject: [PATCH] meson.build: check for all linux host_os combinations
5Organization: O.S. Systems Software LTDA.
6
7Make sure that we are also looking for our host_os combinations like
8linux-musl etc. when assuming support for DRM/KMS.
9
10Also delete a duplicate line.
11
12Signed-off-by: Anuj Mittal <anuj.mittal@intel.com>
13Signed-off-by: Fabio Berton <fabio.berton@ossystems.com.br>
14---
15 meson.build | 6 +++---
16 1 file changed, 3 insertions(+), 3 deletions(-)
17
18diff --git a/meson.build b/meson.build
19index 53d02e31097..c41f6b4e402 100644
20--- a/meson.build
21+++ b/meson.build
22@@ -34,6 +34,8 @@ cpp = meson.get_compiler('cpp')
23
24 null_dep = dependency('', required : false)
25
26+system_has_kms_drm = ['openbsd', 'netbsd', 'freebsd', 'dragonfly'].contains(host_machine.system()) or host_machine.system().startswith('linux')
27+
28 # Arguments for the preprocessor, put these in a separate array from the C and
29 # C++ (cpp in meson terminology) arguments since they need to be added to the
30 # default arguments for both C and C++.
31@@ -89,8 +91,6 @@ if (with_gles1 or with_gles2) and not with_opengl
32 error('building OpenGL ES without OpenGL is not supported.')
33 endif
34
35-system_has_kms_drm = ['openbsd', 'netbsd', 'freebsd', 'dragonfly', 'linux'].contains(host_machine.system())
36-
37 _drivers = get_option('dri-drivers')
38 if _drivers.contains('auto')
39 if system_has_kms_drm
40@@ -792,7 +792,7 @@ if cc.compiles('int foo(void) __attribute__((__noreturn__));',
41 endif
42
43 # TODO: this is very incomplete
44-if ['linux', 'cygwin', 'gnu'].contains(host_machine.system())
45+if ['cygwin', 'gnu'].contains(host_machine.system()) or host_machine.system().startswith('linux')
46 pre_args += '-D_GNU_SOURCE'
47 endif
48
49--
502.21.0
51
diff --git a/meta/recipes-graphics/mesa/files/0001-meson.build-make-TLS-GLX-optional-again.patch b/meta/recipes-graphics/mesa/files/0001-meson.build-make-TLS-GLX-optional-again.patch
new file mode 100644
index 0000000000..8fabafcb35
--- /dev/null
+++ b/meta/recipes-graphics/mesa/files/0001-meson.build-make-TLS-GLX-optional-again.patch
@@ -0,0 +1,44 @@
1From 48318f1a5c9042a8e1bb4456c2584362b25c4a59 Mon Sep 17 00:00:00 2001
2From: Alexander Kanavin <alex.kanavin@gmail.com>
3Date: Wed, 15 May 2019 17:21:51 +0200
4Subject: [PATCH] meson.build: make TLS GLX optional again
5
6This was optional with autotools, and needs to be disabled
7when using musl C library, for instance.
8
9Upstream-Status: Pending
10Signed-off-by: Alexander Kanavin <alex.kanavin@gmail.com>
11---
12 meson.build | 4 +++-
13 meson_options.txt | 6 ++++++
14 2 files changed, 9 insertions(+), 1 deletion(-)
15
16diff --git a/meson.build b/meson.build
17index c41f6b4..8843f3c 100644
18--- a/meson.build
19+++ b/meson.build
20@@ -336,7 +336,9 @@ if with_egl and not (with_platform_drm or with_platform_surfaceless)
21 endif
22 endif
23
24-pre_args += '-DGLX_USE_TLS'
25+if get_option('glx-tls')
26+ pre_args += '-DGLX_USE_TLS'
27+endif
28 if with_glx != 'disabled'
29 if not (with_platform_x11 and with_any_opengl)
30 error('Cannot build GLX support without X11 platform support and at least one OpenGL API')
31diff --git a/meson_options.txt b/meson_options.txt
32index ccf7065..0f1e800 100644
33--- a/meson_options.txt
34+++ b/meson_options.txt
35@@ -324,3 +324,9 @@ option(
36 value : true,
37 description : 'Enable direct rendering in GLX and EGL for DRI',
38 )
39+option(
40+ 'glx-tls',
41+ type : 'boolean',
42+ value : true,
43+ description : 'Enable TLS support in GLX',
44+)
diff --git a/meta/recipes-graphics/mesa/files/0002-winsys-svga-drm-Include-sys-types.h.patch b/meta/recipes-graphics/mesa/files/0002-winsys-svga-drm-Include-sys-types.h.patch
deleted file mode 100644
index aaeb0f11ba..0000000000
--- a/meta/recipes-graphics/mesa/files/0002-winsys-svga-drm-Include-sys-types.h.patch
+++ /dev/null
@@ -1,35 +0,0 @@
1From f212b6bed4bf265aec069c21cdc4b7c2d9cb32df Mon Sep 17 00:00:00 2001
2From: Khem Raj <raj.khem@gmail.com>
3Date: Wed, 16 Aug 2017 18:58:20 -0700
4Subject: [PATCH 2/4] winsys/svga/drm: Include sys/types.h
5Organization: O.S. Systems Software LTDA.
6
7vmw_screen.h uses dev_t which is defines in sys/types.h
8this header is required to be included for getting dev_t
9definition. This issue happens on musl C library, it is hidden
10on glibc since sys/types.h is included through another
11system headers
12
13Signed-off-by: Khem Raj <raj.khem@gmail.com>
14Upstream-Status: Backport [7dfdfbf8c37e52e7b9b09f7d1d434edad3ebc864]
15Signed-off-by: Otavio Salvador <otavio@ossystems.com.br>
16Signed-off-by: Fabio Berton <fabio.berton@ossystems.com.br>
17---
18 src/gallium/winsys/svga/drm/vmw_screen.h | 1 +
19 1 file changed, 1 insertion(+)
20
21diff --git a/src/gallium/winsys/svga/drm/vmw_screen.h b/src/gallium/winsys/svga/drm/vmw_screen.h
22index a87c087d9c5..cb34fec48e7 100644
23--- a/src/gallium/winsys/svga/drm/vmw_screen.h
24+++ b/src/gallium/winsys/svga/drm/vmw_screen.h
25@@ -41,6 +41,7 @@
26 #include "svga_winsys.h"
27 #include "pipebuffer/pb_buffer_fenced.h"
28 #include <os/os_thread.h>
29+#include <sys/types.h>
30
31 #define VMW_GMR_POOL_SIZE (16*1024*1024)
32 #define VMW_QUERY_POOL_SIZE (8192)
33--
342.21.0
35
diff --git a/meta/recipes-graphics/mesa/files/0003-Properly-get-LLVM-version-when-using-LLVM-Git-releas.patch b/meta/recipes-graphics/mesa/files/0003-Properly-get-LLVM-version-when-using-LLVM-Git-releas.patch
deleted file mode 100644
index 96edc2172b..0000000000
--- a/meta/recipes-graphics/mesa/files/0003-Properly-get-LLVM-version-when-using-LLVM-Git-releas.patch
+++ /dev/null
@@ -1,45 +0,0 @@
1From ce7b9ff6517fda089f296b2af2c1c49604872514 Mon Sep 17 00:00:00 2001
2From: Otavio Salvador <otavio@ossystems.com.br>
3Date: Tue, 5 Jun 2018 11:11:10 -0300
4Subject: [PATCH 3/4] Properly get LLVM version when using LLVM Git releases
5Organization: O.S. Systems Software LTDA.
6
7$ llvm-config-host --version
85.0.0git-9a5c333388c
9
10We need to ignore everything after 5.0.0 which is what the cut cmd is
11doing
12
13Upstream-Status: Pending
14Signed-off-by: Khem Raj <raj.khem@gmail.com>
15Signed-off-by: Otavio Salvador <otavio@ossystems.com.br>
16Signed-off-by: Fabio Berton <fabio.berton@ossystems.com.br>
17---
18 configure.ac | 4 ++--
19 1 file changed, 2 insertions(+), 2 deletions(-)
20
21diff --git a/configure.ac b/configure.ac
22index 1816a4cd475..13fed9daf59 100644
23--- a/configure.ac
24+++ b/configure.ac
25@@ -1124,7 +1124,7 @@ strip_unwanted_llvm_flags() {
26
27 llvm_set_environment_variables() {
28 if test "x$LLVM_CONFIG" != xno; then
29- LLVM_VERSION=`$LLVM_CONFIG --version | egrep -o '^[[0-9.]]+'`
30+ LLVM_VERSION=`$LLVM_CONFIG --version | cut -c1-5`
31 LLVM_CPPFLAGS=`strip_unwanted_llvm_flags "$LLVM_CONFIG --cppflags"`
32 LLVM_INCLUDEDIR=`$LLVM_CONFIG --includedir`
33 LLVM_LIBDIR=`$LLVM_CONFIG --libdir`
34@@ -2870,7 +2870,7 @@ detect_old_buggy_llvm() {
35 dnl ourselves.
36 dnl (See https://llvm.org/bugs/show_bug.cgi?id=6823)
37 dnl We can't use $LLVM_VERSION because it has 'svn' stripped out,
38- LLVM_SO_NAME=LLVM-`$LLVM_CONFIG --version`
39+ LLVM_SO_NAME=LLVM-`$LLVM_CONFIG --version | cut -c1-5`
40 AS_IF([test -f "$LLVM_LIBDIR/lib$LLVM_SO_NAME.$IMP_LIB_EXT"], [llvm_have_one_so=yes])
41
42 if test "x$llvm_have_one_so" = xyes; then
43--
442.21.0
45
diff --git a/meta/recipes-graphics/mesa/files/0004-use-PKG_CHECK_VAR-for-defining-WAYLAND_PROTOCOLS_DAT.patch b/meta/recipes-graphics/mesa/files/0004-use-PKG_CHECK_VAR-for-defining-WAYLAND_PROTOCOLS_DAT.patch
deleted file mode 100644
index 45bcd466a3..0000000000
--- a/meta/recipes-graphics/mesa/files/0004-use-PKG_CHECK_VAR-for-defining-WAYLAND_PROTOCOLS_DAT.patch
+++ /dev/null
@@ -1,38 +0,0 @@
1From 5489e1d22e18740a1924628c5c97096d48dcfbf8 Mon Sep 17 00:00:00 2001
2From: Fabio Berton <fabio.berton@ossystems.com.br>
3Date: Fri, 15 Feb 2019 10:57:06 -0200
4Subject: [PATCH 4/4] use PKG_CHECK_VAR for defining WAYLAND_PROTOCOLS_DATADIR
5Organization: O.S. Systems Software LTDA.
6
7This allows to override the wayland-protocols pkgdatadir with the
8WAYLAND_PROTOCOLS_DATADIR from environment.
9
10pkgconfig would return an absolute path in
11/usr/share/wayland-protocols
12for the pkgdatadir value, which is not suitable for cross-compiling.
13
14Upstream-Status: Pending
15
16Signed-off-by: Khem Raj <raj.khem@gmail.com>
17Signed-off-by: Otavio Salvador <otavio@ossystems.com.br>
18Signed-off-by: Fabio Berton <fabio.berton@ossystems.com.br>
19---
20 configure.ac | 2 +-
21 1 file changed, 1 insertion(+), 1 deletion(-)
22
23diff --git a/configure.ac b/configure.ac
24index 13fed9daf59..6cff8afb7cf 100644
25--- a/configure.ac
26+++ b/configure.ac
27@@ -1852,7 +1852,7 @@ for plat in $platforms; do
28 if test "x$enable_egl" = xyes; then
29 PKG_CHECK_MODULES([WAYLAND_EGL], [wayland-egl-backend >= $WAYLAND_EGL_BACKEND_REQUIRED])
30 fi
31- WAYLAND_PROTOCOLS_DATADIR=`$PKG_CONFIG --variable=pkgdatadir wayland-protocols`
32+ PKG_CHECK_VAR([WAYLAND_PROTOCOLS_DATADIR], [wayland-protocols >= $WAYLAND_PROTOCOLS_REQUIRED], pkgdatadir)
33
34 PKG_CHECK_EXISTS([wayland-scanner >= 1.15],
35 AC_SUBST(SCANNER_ARG, 'private-code'),
36--
372.21.0
38
diff --git a/meta/recipes-graphics/mesa/mesa.inc b/meta/recipes-graphics/mesa/mesa.inc
index ece74974b5..c52adbbb21 100644
--- a/meta/recipes-graphics/mesa/mesa.inc
+++ b/meta/recipes-graphics/mesa/mesa.inc
@@ -14,7 +14,7 @@ LIC_FILES_CHKSUM = "file://docs/license.html;md5=725f991a1cc322aa7a0cd3a2016621c
14 14
15PE = "2" 15PE = "2"
16 16
17DEPENDS = "expat makedepend-native flex-native bison-native libxml2-native zlib chrpath-replacement-native" 17DEPENDS = "expat makedepend-native flex-native bison-native libxml2-native zlib chrpath-replacement-native python3-mako-native gettext-native"
18EXTRANATIVEPATH += "chrpath-native" 18EXTRANATIVEPATH += "chrpath-native"
19PROVIDES = " \ 19PROVIDES = " \
20 ${@bb.utils.contains('PACKAGECONFIG', 'opengl', 'virtual/libgl', '', d)} \ 20 ${@bb.utils.contains('PACKAGECONFIG', 'opengl', 'virtual/libgl', '', d)} \
@@ -24,7 +24,7 @@ PROVIDES = " \
24 virtual/mesa \ 24 virtual/mesa \
25 " 25 "
26 26
27inherit autotools pkgconfig python3native gettext distro_features_check 27inherit meson pkgconfig python3native gettext distro_features_check
28 28
29BBCLASSEXTEND = "native nativesdk" 29BBCLASSEXTEND = "native nativesdk"
30 30
@@ -34,57 +34,59 @@ PLATFORMS ??= "${@bb.utils.filter('PACKAGECONFIG', 'x11 wayland', d)} \
34 ${@bb.utils.contains('PACKAGECONFIG', 'gbm', 'drm', '', d)} \ 34 ${@bb.utils.contains('PACKAGECONFIG', 'gbm', 'drm', '', d)} \
35 surfaceless" 35 surfaceless"
36 36
37export LLVM_CONFIG = "${STAGING_BINDIR_NATIVE}/llvm-config${MESA_LLVM_RELEASE}"
38export YOCTO_ALTERNATE_EXE_PATH = "${STAGING_LIBDIR}/llvm${MESA_LLVM_RELEASE}/llvm-config" 37export YOCTO_ALTERNATE_EXE_PATH = "${STAGING_LIBDIR}/llvm${MESA_LLVM_RELEASE}/llvm-config"
39export YOCTO_ALTERNATE_MULTILIB_NAME = "${base_libdir}" 38export YOCTO_ALTERNATE_MULTILIB_NAME = "${base_libdir}"
40EXTRA_OECONF = "--enable-shared-glapi \ 39
41 --disable-opencl \ 40EXTRA_OEMESON = " \
42 --enable-glx-read-only-text \ 41 -Dshared-glapi=true \
43 PYTHON2=python2 \ 42 -Dgallium-opencl=disabled \
44 --with-llvm-prefix=${STAGING_LIBDIR}/llvm${MESA_LLVM_RELEASE} \ 43 -Dglx-read-only-text=true \
45 --with-platforms='${PLATFORMS}' \ 44 -Dplatforms='${@",".join("${PLATFORMS}".split())}' \
46 --enable-autotools \
47" 45"
48 46
49PACKAGECONFIG_class-target ??= "${@bb.utils.filter('DISTRO_FEATURES', 'wayland vulkan', d)} \ 47PACKAGECONFIG_class-target ??= "${@bb.utils.filter('DISTRO_FEATURES', 'wayland vulkan', d)} \
50 ${@bb.utils.contains('DISTRO_FEATURES', 'opengl', 'opengl egl gles gbm dri gallium', '', d)} \ 48 ${@bb.utils.contains('DISTRO_FEATURES', 'opengl', 'opengl egl gles gbm dri gallium', '', d)} \
51 ${@bb.utils.contains('DISTRO_FEATURES', 'x11 opengl', 'x11 dri3', '', d)} \ 49 ${@bb.utils.contains('DISTRO_FEATURES', 'x11 opengl', 'x11 dri3', '', d)} \
52 ${@bb.utils.contains('DISTRO_FEATURES', 'x11 vulkan', 'dri3', '', d)} \ 50 ${@bb.utils.contains('DISTRO_FEATURES', 'x11 vulkan', 'dri3', '', d)} \
51 glx-tls \
53 " 52 "
54PACKAGECONFIG_class-native ?= "gbm dri egl opengl" 53PACKAGECONFIG_class-native ?= "gbm dri egl opengl"
55PACKAGECONFIG_class-nativesdk ?= "gbm dri egl opengl" 54PACKAGECONFIG_class-nativesdk ?= "gbm dri egl opengl"
56 55
56PACKAGECONFIG_remove_libc-musl = "glx-tls"
57
57# "gbm" requires "dri", "opengl" 58# "gbm" requires "dri", "opengl"
58PACKAGECONFIG[gbm] = "--enable-gbm,--disable-gbm" 59PACKAGECONFIG[gbm] = "-Dgbm=true,-Dgbm=false"
59 60
60X11_DEPS = "xorgproto virtual/libx11 libxext libxxf86vm libxdamage libxfixes xrandr" 61X11_DEPS = "xorgproto virtual/libx11 libxext libxxf86vm libxdamage libxfixes xrandr"
61# "x11" requires "opengl" 62# "x11" requires "opengl"
62PACKAGECONFIG[x11] = "--enable-glx-tls,--disable-glx,${X11_DEPS}" 63PACKAGECONFIG[x11] = ",-Dglx=disabled,${X11_DEPS}"
63PACKAGECONFIG[xvmc] = "--enable-xvmc,--disable-xvmc,libxvmc" 64PACKAGECONFIG[glx-tls] = "-Dglx-tls=true, -Dglx-tls=false"
65PACKAGECONFIG[xvmc] = "-Dgallium-xvmc=true,-Dgallium-xvmc=false,libxvmc"
64PACKAGECONFIG[wayland] = ",,wayland-native wayland libdrm wayland-protocols" 66PACKAGECONFIG[wayland] = ",,wayland-native wayland libdrm wayland-protocols"
65 67
66DRIDRIVERS_class-native = "swrast" 68DRIDRIVERS_class-native = "swrast"
67DRIDRIVERS_class-nativesdk = "swrast" 69DRIDRIVERS_class-nativesdk = "swrast"
68DRIDRIVERS_append_x86_class-target = ",radeon,r200,nouveau,i965,i915" 70DRIDRIVERS_append_x86_class-target = ",r100,r200,nouveau,i965,i915"
69DRIDRIVERS_append_x86-64_class-target = ",radeon,r200,nouveau,i965,i915" 71DRIDRIVERS_append_x86-64_class-target = ",r100,r200,nouveau,i965,i915"
70# "dri" requires "opengl" 72# "dri" requires "opengl"
71PACKAGECONFIG[dri] = "--enable-dri --with-dri-drivers=${DRIDRIVERS}, --disable-dri, xorgproto libdrm" 73PACKAGECONFIG[dri] = "-Ddri-drivers=${DRIDRIVERS}, -Ddri-drivers='', xorgproto libdrm"
72PACKAGECONFIG[dri3] = "--enable-dri3, --disable-dri3, xorgproto libxshmfence" 74PACKAGECONFIG[dri3] = "-Ddri3=true, -Ddri3=false, xorgproto libxshmfence"
73 75
74# Vulkan drivers need dri3 enabled 76# Vulkan drivers need dri3 enabled
75# radeon could be enabled as well but requires gallium-llvm with llvm >= 3.9 77# radeon could be enabled as well but requires gallium-llvm with llvm >= 3.9
76VULKAN_DRIVERS = "" 78VULKAN_DRIVERS = ""
77VULKAN_DRIVERS_append_x86_class-target = ",intel" 79VULKAN_DRIVERS_append_x86_class-target = ",intel"
78VULKAN_DRIVERS_append_x86-64_class-target = ",intel" 80VULKAN_DRIVERS_append_x86-64_class-target = ",intel"
79PACKAGECONFIG[vulkan] = "--with-vulkan-drivers=${VULKAN_DRIVERS}, --without-vulkan-drivers, python3-mako-native" 81PACKAGECONFIG[vulkan] = "-Dvulkan-drivers=${VULKAN_DRIVERS}, -Dvulkan-drivers='',"
80 82
81PACKAGECONFIG[opengl] = "--enable-opengl, --disable-opengl" 83PACKAGECONFIG[opengl] = "-Dopengl=true, -Dopengl=false"
82 84
83# "gles" requires "opengl" 85# "gles" requires "opengl"
84PACKAGECONFIG[gles] = "--enable-gles1 --enable-gles2, --disable-gles1 --disable-gles2" 86PACKAGECONFIG[gles] = "-Dgles1=true -Dgles2=true, -Dgles1=false -Dgles2=false"
85 87
86# "egl" requires "dri", "opengl" 88# "egl" requires "dri", "opengl"
87PACKAGECONFIG[egl] = "--enable-egl, --disable-egl" 89PACKAGECONFIG[egl] = "-Degl=true, -Degl=false"
88 90
89PACKAGECONFIG[etnaviv] = "" 91PACKAGECONFIG[etnaviv] = ""
90PACKAGECONFIG[imx] = "" 92PACKAGECONFIG[imx] = ""
@@ -104,28 +106,25 @@ GALLIUMDRIVERS_append = "${@bb.utils.contains('PACKAGECONFIG', 'gallium-llvm', '
104GALLIUMDRIVERS_append = "${@bb.utils.contains('PACKAGECONFIG', 'r600', ',r600', '', d)}" 106GALLIUMDRIVERS_append = "${@bb.utils.contains('PACKAGECONFIG', 'r600', ',r600', '', d)}"
105GALLIUMDRIVERS_append = ",virgl" 107GALLIUMDRIVERS_append = ",virgl"
106 108
107# keep --with-gallium-drivers separate, because when only one of gallium versions is enabled, other 2 were adding --without-gallium-drivers 109PACKAGECONFIG[gallium] = "-Dgallium-drivers=${GALLIUMDRIVERS}, -Dgallium-drivers=''"
108PACKAGECONFIG[gallium] = "--with-gallium-drivers=${GALLIUMDRIVERS}, --without-gallium-drivers"
109MESA_LLVM_RELEASE ?= "8.0.0" 110MESA_LLVM_RELEASE ?= "8.0.0"
110PACKAGECONFIG[gallium-llvm] = "--enable-llvm --enable-llvm-shared-libs, --disable-llvm, llvm${MESA_LLVM_RELEASE} llvm-native \ 111PACKAGECONFIG[gallium-llvm] = "-Dllvm=true -Dshared-llvm=true, -Dllvm=false, llvm${MESA_LLVM_RELEASE} llvm-native \
111 ${@'elfutils' if ${GALLIUMDRIVERS_LLVM33_ENABLED} else ''}" 112 ${@'elfutils' if ${GALLIUMDRIVERS_LLVM33_ENABLED} else ''}"
112export WANT_LLVM_RELEASE = "${MESA_LLVM_RELEASE}" 113export WANT_LLVM_RELEASE = "${MESA_LLVM_RELEASE}"
113PACKAGECONFIG[xa] = "--enable-xa, --disable-xa" 114PACKAGECONFIG[xa] = "-Dgallium-xa=true, -Dgallium-xa=false"
114 115
115OSMESA = "${@bb.utils.contains('PACKAGECONFIG', 'gallium', 'gallium-osmesa', 'osmesa', d)}" 116OSMESA = "${@bb.utils.contains('PACKAGECONFIG', 'gallium', 'gallium', 'classic', d)}"
116PACKAGECONFIG[osmesa] = "--enable-${OSMESA},--disable-${OSMESA}" 117PACKAGECONFIG[osmesa] = "-Dosmesa=${OSMESA},-Dosmesa=none"
117 118
118PACKAGECONFIG[unwind] = "--enable-libunwind,--disable-libunwind,libunwind" 119PACKAGECONFIG[unwind] = "-Dlibunwind=true,-Dlibunwind=false,libunwind"
119 120
120EXTRA_OECONF_remove_libc-musl = "--enable-glx-tls" 121# mesa tries to run cross-built gen_matypes on build machine to get struct size information
121EXTRA_OECONF_append_libc-musl = " --disable-glx-tls" 122EXTRA_OEMESON_append = " -Dasm=false"
122EXTRA_OECONF_append_libc-musl_x86 = " --disable-asm"
123 123
124# llvmpipe is slow if compiled with -fomit-frame-pointer (e.g. -O2) 124# llvmpipe is slow if compiled with -fomit-frame-pointer (e.g. -O2)
125FULL_OPTIMIZATION_append = " -fno-omit-frame-pointer" 125FULL_OPTIMIZATION_append = " -fno-omit-frame-pointer"
126 126
127CFLAGS_append_armv5 = " -DMISSING_64BIT_ATOMICS" 127CFLAGS_append_armv5 = " -DMISSING_64BIT_ATOMICS"
128EXTRA_OEMAKE += "WAYLAND_PROTOCOLS_DATADIR=${STAGING_DATADIR}/wayland-protocols"
129 128
130# Remove the mesa dependency on mesa-dev, as mesa is empty 129# Remove the mesa dependency on mesa-dev, as mesa is empty
131RDEPENDS_${PN}-dev = "" 130RDEPENDS_${PN}-dev = ""
@@ -158,7 +157,6 @@ do_install_append () {
158 # libwayland-egl has been moved to wayland 1.15+ 157 # libwayland-egl has been moved to wayland 1.15+
159 rm -f ${D}${libdir}/libwayland-egl* 158 rm -f ${D}${libdir}/libwayland-egl*
160 rm -f ${D}${libdir}/pkgconfig/wayland-egl.pc 159 rm -f ${D}${libdir}/pkgconfig/wayland-egl.pc
161 rmdir --ignore-fail-on-non-empty ${D}${libdir}/pkgconfig
162} 160}
163 161
164# For the packages that make up the OpenGL interfaces, inject variables so that 162# For the packages that make up the OpenGL interfaces, inject variables so that
diff --git a/meta/recipes-graphics/mesa/mesa_19.0.3.bb b/meta/recipes-graphics/mesa/mesa_19.0.3.bb
index 585c3ede23..36faa4a99d 100644
--- a/meta/recipes-graphics/mesa/mesa_19.0.3.bb
+++ b/meta/recipes-graphics/mesa/mesa_19.0.3.bb
@@ -1,11 +1,9 @@
1require ${BPN}.inc 1require ${BPN}.inc
2 2
3SRC_URI = "https://mesa.freedesktop.org/archive/mesa-${PV}.tar.xz \ 3SRC_URI = "https://mesa.freedesktop.org/archive/mesa-${PV}.tar.xz \
4 file://0001-Simplify-wayland-scanner-lookup.patch \ 4 file://0001-meson.build-check-for-all-linux-host_os-combinations.patch \
5 file://0002-winsys-svga-drm-Include-sys-types.h.patch \ 5 file://0001-meson.build-make-TLS-GLX-optional-again.patch \
6 file://0003-Properly-get-LLVM-version-when-using-LLVM-Git-releas.patch \ 6 "
7 file://0004-use-PKG_CHECK_VAR-for-defining-WAYLAND_PROTOCOLS_DAT.patch \
8"
9 7
10SRC_URI[md5sum] = "d03bf14e42c0e54ebae5730712ccc408" 8SRC_URI[md5sum] = "d03bf14e42c0e54ebae5730712ccc408"
11SRC_URI[sha256sum] = "f027244e38dc309a4c12db45ef79be81ab62c797a50a88d566e4edb6159fc4d5" 9SRC_URI[sha256sum] = "f027244e38dc309a4c12db45ef79be81ab62c797a50a88d566e4edb6159fc4d5"