diff options
Diffstat (limited to 'meta/recipes-graphics/mesa/mesa.inc')
-rw-r--r-- | meta/recipes-graphics/mesa/mesa.inc | 302 |
1 files changed, 181 insertions, 121 deletions
diff --git a/meta/recipes-graphics/mesa/mesa.inc b/meta/recipes-graphics/mesa/mesa.inc index 9f8ec112cf..1c9fa66c72 100644 --- a/meta/recipes-graphics/mesa/mesa.inc +++ b/meta/recipes-graphics/mesa/mesa.inc | |||
@@ -10,35 +10,39 @@ HOMEPAGE = "http://mesa3d.org" | |||
10 | BUGTRACKER = "https://bugs.freedesktop.org" | 10 | BUGTRACKER = "https://bugs.freedesktop.org" |
11 | SECTION = "x11" | 11 | SECTION = "x11" |
12 | LICENSE = "MIT" | 12 | LICENSE = "MIT" |
13 | LIC_FILES_CHKSUM = "file://docs/license.rst;md5=9aa1bc48c9826ad9fdb16661f6930496" | 13 | LIC_FILES_CHKSUM = "file://docs/license.rst;md5=63779ec98d78d823a9dc533a0735ef10" |
14 | 14 | ||
15 | PE = "2" | 15 | PE = "2" |
16 | 16 | ||
17 | SRC_URI = "https://mesa.freedesktop.org/archive/mesa-${PV}.tar.xz \ | 17 | SRC_URI = "https://mesa.freedesktop.org/archive/mesa-${PV}.tar.xz \ |
18 | file://0001-meson.build-check-for-all-linux-host_os-combinations.patch \ | 18 | file://0001-meson.build-check-for-all-linux-host_os-combinations.patch \ |
19 | file://0002-meson.build-make-TLS-ELF-optional.patch \ | ||
20 | file://0001-meson-misdetects-64bit-atomics-on-mips-clang.patch \ | 19 | file://0001-meson-misdetects-64bit-atomics-on-mips-clang.patch \ |
21 | file://0001-futex.h-Define-__NR_futex-if-it-does-not-exist.patch \ | 20 | file://0001-drisw-fix-build-without-dri3.patch \ |
22 | file://0001-anv-fix-a-build-race-between-generating-a-header-and.patch \ | 21 | file://0002-glxext-don-t-try-zink-if-not-enabled-in-mesa.patch \ |
23 | " | 22 | file://0001-Revert-meson-do-not-pull-in-clc-for-clover.patch \ |
23 | " | ||
24 | 24 | ||
25 | SRC_URI[sha256sum] = "dc21a987ec1ff45b278fe4b1419b1719f1968debbb80221480e44180849b4084" | 25 | SRC_URI[sha256sum] = "77aec9a2a37b7d3596ea1640b3cc53d0b5d9b3b52abed89de07e3717e91bfdbe" |
26 | 26 | ||
27 | UPSTREAM_CHECK_GITTAGREGEX = "mesa-(?P<pver>\d+(\.\d+)+)" | 27 | UPSTREAM_CHECK_GITTAGREGEX = "mesa-(?P<pver>\d+(\.\d+)+)" |
28 | 28 | ||
29 | #because we cannot rely on the fact that all apps will use pkgconfig, | 29 | #because we cannot rely on the fact that all apps will use pkgconfig, |
30 | #make eglplatform.h independent of MESA_EGL_NO_X11_HEADER | 30 | #make eglplatform.h independent of MESA_EGL_NO_X11_HEADER |
31 | do_install_append() { | 31 | do_install:append() { |
32 | if ${@bb.utils.contains('PACKAGECONFIG', 'egl', 'true', 'false', d)}; then | 32 | # sed can't find EGL/eglplatform.h as it doesn't get installed when glvnd enabled. |
33 | sed -i -e 's/^#elif defined(__unix__) && defined(EGL_NO_X11)$/#elif defined(__unix__) \&\& defined(EGL_NO_X11) || ${@bb.utils.contains('PACKAGECONFIG', 'x11', '0', '1', d)}/' ${D}${includedir}/EGL/eglplatform.h | 33 | # So, check if EGL/eglplatform.h exists before running sed. |
34 | fi | 34 | if ${@bb.utils.contains('PACKAGECONFIG', 'egl', 'true', 'false', d)} && [ -f ${D}${includedir}/EGL/eglplatform.h ]; then |
35 | sed -i -e 's/^#elif defined(__unix__) && defined(EGL_NO_X11)$/#elif defined(__unix__) \&\& defined(EGL_NO_X11) || ${@bb.utils.contains('PACKAGECONFIG', 'x11', '0', '1', d)}/' ${D}${includedir}/EGL/eglplatform.h | ||
36 | fi | ||
35 | } | 37 | } |
36 | 38 | ||
37 | DEPENDS = "expat makedepend-native flex-native bison-native libxml2-native zlib chrpath-replacement-native python3-mako-native gettext-native" | 39 | DEPENDS = "expat makedepend-native flex-native bison-native libxml2-native zlib chrpath-replacement-native python3-mako-native gettext-native" |
40 | DEPENDS:append:class-target = " ${@bb.utils.contains('PACKAGECONFIG', 'opencl', 'mesa-native', '', d)}" | ||
38 | EXTRANATIVEPATH += "chrpath-native" | 41 | EXTRANATIVEPATH += "chrpath-native" |
39 | PROVIDES = " \ | 42 | PROVIDES = " \ |
40 | ${@bb.utils.contains('PACKAGECONFIG', 'opengl', 'virtual/libgl', '', d)} \ | 43 | ${@bb.utils.contains('PACKAGECONFIG', 'opengl', 'virtual/libgl', '', d)} \ |
41 | ${@bb.utils.contains('PACKAGECONFIG', 'gles', 'virtual/libgles1 virtual/libgles2', '', d)} \ | 44 | ${@bb.utils.contains('PACKAGECONFIG', 'glvnd', 'virtual/libglx', '', d)} \ |
45 | ${@bb.utils.contains('PACKAGECONFIG', 'gles', 'virtual/libgles1 virtual/libgles2 virtual/libgles3', '', d)} \ | ||
42 | ${@bb.utils.contains('PACKAGECONFIG', 'egl', 'virtual/egl', '', d)} \ | 46 | ${@bb.utils.contains('PACKAGECONFIG', 'egl', 'virtual/egl', '', d)} \ |
43 | ${@bb.utils.contains('PACKAGECONFIG', 'gbm', 'virtual/libgbm', '', d)} \ | 47 | ${@bb.utils.contains('PACKAGECONFIG', 'gbm', 'virtual/libgbm', '', d)} \ |
44 | virtual/mesa \ | 48 | virtual/mesa \ |
@@ -48,17 +52,10 @@ inherit meson pkgconfig python3native gettext features_check | |||
48 | 52 | ||
49 | BBCLASSEXTEND = "native nativesdk" | 53 | BBCLASSEXTEND = "native nativesdk" |
50 | 54 | ||
51 | ANY_OF_DISTRO_FEATURES_class-target = "opengl vulkan" | 55 | ANY_OF_DISTRO_FEATURES = "opengl vulkan" |
52 | 56 | ||
53 | PLATFORMS ??= "${@bb.utils.filter('PACKAGECONFIG', 'x11 wayland', d)}" | 57 | PLATFORMS ??= "${@bb.utils.filter('PACKAGECONFIG', 'x11 wayland', d)}" |
54 | 58 | ||
55 | export YOCTO_ALTERNATE_EXE_PATH = "${STAGING_LIBDIR}/llvm${MESA_LLVM_RELEASE}/llvm-config" | ||
56 | export YOCTO_ALTERNATE_MULTILIB_NAME = "${base_libdir}" | ||
57 | export LLVM_CONFIG = "${STAGING_BINDIR_NATIVE}/llvm-config${MESA_LLVM_RELEASE}" | ||
58 | export WANT_LLVM_RELEASE = "${MESA_LLVM_RELEASE}" | ||
59 | |||
60 | MESA_LLVM_RELEASE ?= "${LLVMVERSION}" | ||
61 | |||
62 | # set the MESA_BUILD_TYPE to either 'release' (default) or 'debug' | 59 | # set the MESA_BUILD_TYPE to either 'release' (default) or 'debug' |
63 | # by default the upstream mesa sources build a debug release | 60 | # by default the upstream mesa sources build a debug release |
64 | # here we assume the user will want a release build by default | 61 | # here we assume the user will want a release build by default |
@@ -74,145 +71,199 @@ MESON_BUILDTYPE = "${@check_buildtype(d)}" | |||
74 | 71 | ||
75 | EXTRA_OEMESON = " \ | 72 | EXTRA_OEMESON = " \ |
76 | -Dshared-glapi=enabled \ | 73 | -Dshared-glapi=enabled \ |
77 | -Dgallium-opencl=disabled \ | ||
78 | -Dglx-read-only-text=true \ | 74 | -Dglx-read-only-text=true \ |
79 | -Dplatforms='${@",".join("${PLATFORMS}".split())}' \ | 75 | -Dplatforms='${@",".join("${PLATFORMS}".split())}' \ |
80 | " | 76 | " |
81 | 77 | ||
78 | EXTRA_OEMESON:append:class-target = " ${@bb.utils.contains('PACKAGECONFIG', 'opencl', '-Dintel-clc=system', '', d)}" | ||
79 | EXTRA_OEMESON:append:class-native = " ${@bb.utils.contains('PACKAGECONFIG', 'opencl', '-Dintel-clc=enabled', '', d)}" | ||
80 | |||
82 | def strip_comma(s): | 81 | def strip_comma(s): |
83 | return s.strip(',') | 82 | return s.strip(',') |
84 | 83 | ||
85 | PACKAGECONFIG_class-target ??= "${@bb.utils.filter('DISTRO_FEATURES', 'wayland vulkan', d)} \ | 84 | PACKAGECONFIG = " \ |
86 | ${@bb.utils.contains('DISTRO_FEATURES', 'opengl', 'opengl egl gles gbm dri gallium virgl', '', d)} \ | 85 | gallium \ |
87 | ${@bb.utils.contains('DISTRO_FEATURES', 'x11 opengl', 'x11 dri3', '', d)} \ | 86 | video-codecs \ |
88 | ${@bb.utils.contains('DISTRO_FEATURES', 'x11 vulkan', 'dri3', '', d)} \ | 87 | ${@bb.utils.filter('DISTRO_FEATURES', 'x11 vulkan wayland', d)} \ |
89 | elf-tls \ | 88 | ${@bb.utils.contains('DISTRO_FEATURES', 'opengl', 'opengl egl gles gbm virgl', '', d)} \ |
90 | " | 89 | ${@bb.utils.contains('DISTRO_FEATURES', 'x11 opengl', 'dri3', '', d)} \ |
91 | PACKAGECONFIG_class-native ?= "gbm dri egl opengl elf-tls x11" | 90 | ${@bb.utils.contains('DISTRO_FEATURES', 'x11 vulkan', 'dri3', '', d)} \ |
92 | PACKAGECONFIG_class-nativesdk ?= "gbm dri egl opengl elf-tls x11" | 91 | ${@bb.utils.contains('DISTRO_FEATURES', 'vulkan', 'zink', '', d)} \ |
92 | " | ||
93 | 93 | ||
94 | PACKAGECONFIG_remove_libc-musl = "elf-tls" | 94 | PACKAGECONFIG:append:class-native = "gallium-llvm r600" |
95 | 95 | ||
96 | # "gbm" requires "dri", "opengl" | 96 | # "gbm" requires "opengl" |
97 | PACKAGECONFIG[gbm] = "-Dgbm=enabled,-Dgbm=disabled" | 97 | PACKAGECONFIG[gbm] = "-Dgbm=enabled,-Dgbm=disabled" |
98 | 98 | ||
99 | X11_DEPS = "xorgproto virtual/libx11 libxext libxxf86vm libxdamage libxfixes xrandr" | 99 | X11_DEPS = "xorgproto virtual/libx11 libxext libxxf86vm libxdamage libxfixes xrandr" |
100 | # "x11" requires "opengl" | 100 | # "x11" requires "opengl" |
101 | PACKAGECONFIG[x11] = ",-Dglx=disabled,${X11_DEPS}" | 101 | PACKAGECONFIG[x11] = ",-Dglx=disabled,${X11_DEPS}" |
102 | PACKAGECONFIG[elf-tls] = "-Delf-tls=true, -Delf-tls=false" | ||
103 | PACKAGECONFIG[xvmc] = "-Dgallium-xvmc=enabled,-Dgallium-xvmc=disabled,libxvmc" | ||
104 | PACKAGECONFIG[wayland] = ",,wayland-native wayland libdrm wayland-protocols" | 102 | PACKAGECONFIG[wayland] = ",,wayland-native wayland libdrm wayland-protocols" |
105 | 103 | ||
106 | DRIDRIVERS_class-native = "swrast" | ||
107 | DRIDRIVERS_class-nativesdk = "swrast" | ||
108 | DRIDRIVERS_append_x86_class-target = ",r100,r200,nouveau,i965,i915" | ||
109 | DRIDRIVERS_append_x86-64_class-target = ",r100,r200,nouveau,i965,i915" | ||
110 | # "dri" requires "opengl" | ||
111 | PACKAGECONFIG[dri] = "-Ddri-drivers=${@strip_comma('${DRIDRIVERS}')}, -Ddri-drivers='', xorgproto libdrm" | ||
112 | PACKAGECONFIG[dri3] = "-Ddri3=enabled, -Ddri3=disabled, xorgproto libxshmfence" | 104 | PACKAGECONFIG[dri3] = "-Ddri3=enabled, -Ddri3=disabled, xorgproto libxshmfence" |
113 | 105 | ||
114 | # Vulkan drivers need dri3 enabled | 106 | # Vulkan drivers need dri3 enabled |
115 | # amd could be enabled as well but requires gallium-llvm with llvm >= 3.9 | 107 | # amd could be enabled as well but requires gallium-llvm with llvm >= 3.9 |
116 | VULKAN_DRIVERS = "" | 108 | VULKAN_DRIVERS = "" |
117 | VULKAN_DRIVERS_append_x86_class-target = ",intel" | 109 | VULKAN_DRIVERS:append:x86 = ",intel,amd" |
118 | VULKAN_DRIVERS_append_x86-64_class-target = ",intel" | 110 | VULKAN_DRIVERS:append:x86-64 = ",intel,amd" |
119 | VULKAN_DRIVERS_append ="${@bb.utils.contains('PACKAGECONFIG', 'freedreno', ',freedreno', '', d)}" | 111 | # i686 is a 32 bit override for mesa-native |
120 | PACKAGECONFIG[vulkan] = "-Dvulkan-drivers=${@strip_comma('${VULKAN_DRIVERS}')}, -Dvulkan-drivers=''," | 112 | VULKAN_DRIVERS:append:i686 = ",intel,amd" |
113 | VULKAN_DRIVERS:append ="${@bb.utils.contains('PACKAGECONFIG', 'freedreno', ',freedreno', '', d)}" | ||
114 | VULKAN_DRIVERS:append ="${@bb.utils.contains('PACKAGECONFIG', 'broadcom', ',broadcom', '', d)}" | ||
115 | VULKAN_DRIVERS:append ="${@bb.utils.contains('PACKAGECONFIG', 'gallium-llvm', ',swrast', '', d)}" | ||
116 | VULKAN_DRIVERS:append ="${@bb.utils.contains('PACKAGECONFIG', 'imagination', ',imagination-experimental', '', d)}" | ||
117 | PACKAGECONFIG[vulkan] = "-Dvulkan-drivers=${@strip_comma('${VULKAN_DRIVERS}')}, -Dvulkan-drivers='',glslang-native vulkan-loader vulkan-headers" | ||
118 | |||
119 | # mesa development and testing tools support, per driver | ||
120 | TOOLS = "" | ||
121 | TOOLS_DEPS = "" | ||
122 | TOOLS:append = "${@bb.utils.contains('PACKAGECONFIG', 'etnaviv', ',etnaviv', '', d)}" | ||
123 | TOOLS:append = "${@bb.utils.contains('PACKAGECONFIG', 'freedreno', ',freedreno', '', d)}" | ||
124 | TOOLS:append = "${@bb.utils.contains('PACKAGECONFIG', 'lima', ',lima', '', d)}" | ||
125 | TOOLS:append = "${@bb.utils.contains('PACKAGECONFIG', 'panfrost', ',panfrost', '', d)}" | ||
126 | TOOLS:append = "${@bb.utils.contains('PACKAGECONFIG', 'imagination', ',imagination', '', d)}" | ||
127 | |||
128 | # dependencies for tools. | ||
129 | TOOLS_DEPS:append = "${@bb.utils.contains('PACKAGECONFIG', 'freedreno', ' ncurses libxml2 ', '', d)}" | ||
130 | |||
131 | # the fdperf tool requires libconfig (a part of meta-oe) so it needs special | ||
132 | # treatment in addition to the usual 'freedreno tools'. | ||
133 | PACKAGECONFIG[freedreno-fdperf] = ",,libconfig" | ||
134 | |||
135 | PACKAGECONFIG[tools] = "-Dtools=${@strip_comma('${TOOLS}')}, -Dtools='', ${TOOLS_DEPS}" | ||
121 | 136 | ||
122 | PACKAGECONFIG[opengl] = "-Dopengl=true, -Dopengl=false" | 137 | PACKAGECONFIG[opengl] = "-Dopengl=true, -Dopengl=false" |
138 | PACKAGECONFIG[glvnd] = "-Dglvnd=true, -Dglvnd=false, libglvnd" | ||
123 | 139 | ||
124 | # "gles" requires "opengl" | 140 | # "gles" requires "opengl" |
125 | PACKAGECONFIG[gles] = "-Dgles1=enabled -Dgles2=enabled, -Dgles1=disabled -Dgles2=disabled" | 141 | PACKAGECONFIG[gles] = "-Dgles1=enabled -Dgles2=enabled, -Dgles1=disabled -Dgles2=disabled" |
126 | 142 | ||
127 | # "egl" requires "dri", "opengl" | 143 | # "egl" requires "opengl" |
128 | PACKAGECONFIG[egl] = "-Degl=enabled, -Degl=disabled" | 144 | PACKAGECONFIG[egl] = "-Degl=enabled, -Degl=disabled" |
129 | 145 | ||
146 | # "opencl" requires libclc from meta-clang and spirv-tools from OE-Core | ||
147 | OPENCL_NATIVE = "${@bb.utils.contains('PACKAGECONFIG', 'freedreno', '-Dopencl-native=true', '', d)}" | ||
148 | PACKAGECONFIG[opencl] = "-Dgallium-opencl=icd -Dopencl-spirv=true ${OPENCL_NATIVE},-Dgallium-opencl=disabled -Dopencl-spirv=false,libclc spirv-tools python3-ply-native" | ||
149 | |||
150 | PACKAGECONFIG[broadcom] = "" | ||
130 | PACKAGECONFIG[etnaviv] = "" | 151 | PACKAGECONFIG[etnaviv] = "" |
131 | PACKAGECONFIG[freedreno] = "" | 152 | PACKAGECONFIG[freedreno] = "" |
132 | PACKAGECONFIG[kmsro] = "" | 153 | PACKAGECONFIG[kmsro] = "" |
133 | PACKAGECONFIG[vc4] = "" | 154 | PACKAGECONFIG[vc4] = "" |
134 | PACKAGECONFIG[v3d] = "" | 155 | PACKAGECONFIG[v3d] = "" |
156 | PACKAGECONFIG[zink] = "" | ||
135 | 157 | ||
136 | GALLIUMDRIVERS = "swrast" | 158 | GALLIUMDRIVERS = "swrast" |
137 | # gallium swrast was found to crash Xorg on startup in x32 qemu | 159 | # gallium swrast was found to crash Xorg on startup in x32 qemu |
138 | GALLIUMDRIVERS_x86-x32 = "" | 160 | GALLIUMDRIVERS:x86-x32 = "" |
139 | 161 | GALLIUMDRIVERS:append:x86 = ",i915,iris,crocus" | |
140 | GALLIUMDRIVERS_append ="${@bb.utils.contains('PACKAGECONFIG', 'etnaviv', ',etnaviv', '', d)}" | 162 | GALLIUMDRIVERS:append:x86-64 = ",i915,iris,crocus" |
141 | GALLIUMDRIVERS_append ="${@bb.utils.contains('PACKAGECONFIG', 'freedreno', ',freedreno', '', d)}" | 163 | # i686 is a 32 bit override for mesa-native |
142 | GALLIUMDRIVERS_append ="${@bb.utils.contains('PACKAGECONFIG', 'kmsro', ',kmsro', '', d)}" | 164 | GALLIUMDRIVERS:append:i686 = ",i915,iris,crocus" |
143 | GALLIUMDRIVERS_append ="${@bb.utils.contains('PACKAGECONFIG', 'vc4', ',vc4', '', d)}" | 165 | |
144 | GALLIUMDRIVERS_append ="${@bb.utils.contains('PACKAGECONFIG', 'v3d', ',v3d', '', d)}" | 166 | GALLIUMDRIVERS:append ="${@bb.utils.contains('PACKAGECONFIG', 'etnaviv', ',etnaviv', '', d)}" |
167 | GALLIUMDRIVERS:append ="${@bb.utils.contains('PACKAGECONFIG', 'freedreno', ',freedreno', '', d)}" | ||
168 | GALLIUMDRIVERS:append ="${@bb.utils.contains('PACKAGECONFIG', 'kmsro', ',kmsro', '', d)}" | ||
169 | GALLIUMDRIVERS:append ="${@bb.utils.contains('PACKAGECONFIG', 'vc4', ',vc4', '', d)}" | ||
170 | GALLIUMDRIVERS:append ="${@bb.utils.contains('PACKAGECONFIG', 'v3d', ',v3d', '', d)}" | ||
171 | GALLIUMDRIVERS:append ="${@bb.utils.contains('PACKAGECONFIG', 'zink', ',zink', '', d)}" | ||
145 | 172 | ||
146 | # radeonsi requires LLVM | 173 | # radeonsi requires LLVM |
147 | GALLIUMDRIVERS_RADEONSI = "${@bb.utils.contains('PACKAGECONFIG', 'r600', ',radeonsi', '', d)}" | 174 | GALLIUMDRIVERS_RADEONSI = "${@bb.utils.contains('PACKAGECONFIG', 'r600', ',radeonsi', '', d)}" |
148 | GALLIUMDRIVERS_LLVM = "r300,svga,nouveau${GALLIUMDRIVERS_RADEONSI}" | 175 | GALLIUMDRIVERS_LLVM = ",r300,nouveau${GALLIUMDRIVERS_RADEONSI}" |
176 | GALLIUMDRIVERS_LLVM:append:x86 = ",svga" | ||
177 | GALLIUMDRIVERS_LLVM:append:x86-64 = ",svga" | ||
178 | # i686 is a 32 bit override for mesa-native | ||
179 | GALLIUMDRIVERS_LLVM:append:i686 = ",svga" | ||
149 | 180 | ||
150 | PACKAGECONFIG[r600] = "" | 181 | PACKAGECONFIG[r600] = "" |
151 | PACKAGECONFIG[virgl] = "" | 182 | PACKAGECONFIG[virgl] = "" |
152 | 183 | ||
153 | GALLIUMDRIVERS_append = "${@bb.utils.contains('PACKAGECONFIG', 'gallium-llvm', ',${GALLIUMDRIVERS_LLVM}', '', d)}" | 184 | GALLIUMDRIVERS:append = "${@bb.utils.contains('PACKAGECONFIG', 'gallium-llvm', '${GALLIUMDRIVERS_LLVM}', '', d)}" |
154 | GALLIUMDRIVERS_append = "${@bb.utils.contains('PACKAGECONFIG', 'r600', ',r600', '', d)}" | 185 | GALLIUMDRIVERS:append = "${@bb.utils.contains('PACKAGECONFIG', 'r600', ',r600', '', d)}" |
155 | GALLIUMDRIVERS_append = "${@bb.utils.contains('PACKAGECONFIG', 'virgl', ',virgl', '', d)}" | 186 | GALLIUMDRIVERS:append = "${@bb.utils.contains('PACKAGECONFIG', 'virgl', ',virgl', '', d)}" |
156 | 187 | ||
157 | PACKAGECONFIG[gallium] = "-Dgallium-drivers=${@strip_comma('${GALLIUMDRIVERS}')}, -Dgallium-drivers=''" | 188 | PACKAGECONFIG[gallium] = "-Dgallium-drivers=${@strip_comma('${GALLIUMDRIVERS}')}, -Dgallium-drivers='', libdrm" |
158 | PACKAGECONFIG[gallium-llvm] = "-Dllvm=enabled -Dshared-llvm=enabled, -Dllvm=disabled, llvm${MESA_LLVM_RELEASE} llvm-native \ | 189 | PACKAGECONFIG[gallium-llvm] = "-Dllvm=enabled -Dshared-llvm=enabled, -Dllvm=disabled, llvm llvm-native elfutils" |
159 | elfutils" | ||
160 | PACKAGECONFIG[xa] = "-Dgallium-xa=enabled, -Dgallium-xa=disabled" | 190 | PACKAGECONFIG[xa] = "-Dgallium-xa=enabled, -Dgallium-xa=disabled" |
161 | PACKAGECONFIG[va] = "-Dgallium-va=enabled,-Dgallium-va=disabled,libva-initial" | 191 | PACKAGECONFIG[va] = "-Dgallium-va=enabled,-Dgallium-va=disabled,libva-initial" |
162 | |||
163 | PACKAGECONFIG[vdpau] = "-Dgallium-vdpau=enabled,-Dgallium-vdpau=disabled,libvdpau" | 192 | PACKAGECONFIG[vdpau] = "-Dgallium-vdpau=enabled,-Dgallium-vdpau=disabled,libvdpau" |
164 | 193 | ||
194 | PACKAGECONFIG[imagination] = "-Dimagination-srv=true,-Dimagination-srv=false" | ||
195 | |||
165 | PACKAGECONFIG[lima] = "" | 196 | PACKAGECONFIG[lima] = "" |
166 | GALLIUMDRIVERS_append ="${@bb.utils.contains('PACKAGECONFIG', 'lima', ',lima', '', d)}" | 197 | GALLIUMDRIVERS:append ="${@bb.utils.contains('PACKAGECONFIG', 'lima', ',lima', '', d)}" |
167 | 198 | ||
168 | PACKAGECONFIG[panfrost] = "" | 199 | PACKAGECONFIG[panfrost] = "" |
169 | GALLIUMDRIVERS_append ="${@bb.utils.contains('PACKAGECONFIG', 'panfrost', ',panfrost', '', d)}" | 200 | GALLIUMDRIVERS:append ="${@bb.utils.contains('PACKAGECONFIG', 'panfrost', ',panfrost', '', d)}" |
170 | 201 | ||
171 | OSMESA = "${@bb.utils.contains('PACKAGECONFIG', 'gallium', 'gallium', 'classic', d)}" | 202 | PACKAGECONFIG[vulkan-beta] = "-Dvulkan-beta=true,-Dvulkan-beta=false" |
172 | PACKAGECONFIG[osmesa] = "-Dosmesa=${OSMESA},-Dosmesa=none" | 203 | |
204 | PACKAGECONFIG[osmesa] = "-Dosmesa=true,-Dosmesa=false" | ||
205 | |||
206 | PACKAGECONFIG[perfetto] = "-Dperfetto=true,-Dperfetto=false,libperfetto" | ||
173 | 207 | ||
174 | PACKAGECONFIG[unwind] = "-Dlibunwind=enabled,-Dlibunwind=disabled,libunwind" | 208 | PACKAGECONFIG[unwind] = "-Dlibunwind=enabled,-Dlibunwind=disabled,libunwind" |
175 | 209 | ||
210 | PACKAGECONFIG[lmsensors] = "-Dlmsensors=enabled,-Dlmsensors=disabled,lmsensors" | ||
211 | |||
212 | VIDEO_CODECS ?= "${@bb.utils.contains('LICENSE_FLAGS_ACCEPTED', 'commercial', 'all', 'all_free', d)}" | ||
213 | PACKAGECONFIG[video-codecs] = "-Dvideo-codecs=${VIDEO_CODECS}, -Dvideo-codecs=''" | ||
214 | |||
176 | # llvmpipe is slow if compiled with -fomit-frame-pointer (e.g. -O2) | 215 | # llvmpipe is slow if compiled with -fomit-frame-pointer (e.g. -O2) |
177 | FULL_OPTIMIZATION_append = " -fno-omit-frame-pointer" | 216 | FULL_OPTIMIZATION:append = " -fno-omit-frame-pointer" |
178 | 217 | ||
179 | CFLAGS_append_armv5 = " -DMISSING_64BIT_ATOMICS" | 218 | CFLAGS:append:armv5 = " -DMISSING_64BIT_ATOMICS" |
180 | CFLAGS_append_armv6 = " -DMISSING_64BIT_ATOMICS" | 219 | CFLAGS:append:armv6 = " -DMISSING_64BIT_ATOMICS" |
181 | 220 | ||
182 | # Remove the mesa dependency on mesa-dev, as mesa is empty | 221 | # Remove the mesa dependency on mesa-dev, as mesa is empty |
183 | RDEPENDS_${PN}-dev = "" | 222 | DEV_PKG_DEPENDENCY = "" |
223 | |||
224 | # Khronos documentation says that include/GLES2/gl2ext.h can be used for | ||
225 | # OpenGL ES 3 specification as well as for OpenGL ES 2. | ||
226 | # There can be applications including GLES2/gl2ext.h instead of GLES3/gl3ext.h | ||
227 | # meaning we should probably bring in GLES2/gl2ext.h if someone asks for | ||
228 | # development package of libgles3. | ||
229 | RDEPENDS:libgles3-mesa-dev += "libgles2-mesa-dev" | ||
184 | 230 | ||
185 | # Add dependency so that GLES3 header don't need to be added manually | 231 | RDEPENDS:libopencl-mesa += "${@bb.utils.contains('PACKAGECONFIG', 'opencl', 'libclc spirv-tools', '', d)}" |
186 | RDEPENDS_libgles2-mesa-dev += "libgles3-mesa-dev" | ||
187 | 232 | ||
188 | PACKAGES =+ "libegl-mesa libegl-mesa-dev \ | 233 | PACKAGES =+ "libegl-mesa libegl-mesa-dev \ |
189 | libosmesa libosmesa-dev \ | 234 | libosmesa libosmesa-dev \ |
190 | libgl-mesa libgl-mesa-dev \ | 235 | libgl-mesa libgl-mesa-dev \ |
236 | libglx-mesa libglx-mesa-dev \ | ||
191 | libglapi libglapi-dev \ | 237 | libglapi libglapi-dev \ |
192 | libgbm libgbm-dev \ | 238 | libgbm libgbm-dev \ |
193 | libgles1-mesa libgles1-mesa-dev \ | 239 | libgles1-mesa libgles1-mesa-dev \ |
194 | libgles2-mesa libgles2-mesa-dev \ | 240 | libgles2-mesa libgles2-mesa-dev \ |
195 | libgles3-mesa libgles3-mesa-dev \ | 241 | libgles3-mesa libgles3-mesa-dev \ |
242 | libopencl-mesa libopencl-mesa-dev \ | ||
196 | libxatracker libxatracker-dev \ | 243 | libxatracker libxatracker-dev \ |
197 | mesa-megadriver mesa-vulkan-drivers \ | 244 | mesa-megadriver mesa-vulkan-drivers \ |
198 | mesa-vdpau-drivers \ | 245 | mesa-vdpau-drivers mesa-tools \ |
199 | " | 246 | " |
200 | 247 | ||
201 | do_install_append () { | 248 | do_install:append () { |
202 | # Drivers never need libtool .la files | 249 | # Drivers never need libtool .la files |
203 | rm -f ${D}${libdir}/dri/*.la | 250 | rm -f ${D}${libdir}/dri/*.la |
204 | rm -f ${D}${libdir}/egl/*.la | 251 | rm -f ${D}${libdir}/egl/*.la |
205 | rm -f ${D}${libdir}/gallium-pipe/*.la | 252 | rm -f ${D}${libdir}/gallium-pipe/*.la |
206 | rm -f ${D}${libdir}/gbm/*.la | 253 | rm -f ${D}${libdir}/gbm/*.la |
207 | 254 | ||
208 | # it was packaged in libdricore9.1.3-1 and preventing upgrades when debian.bbclass was used | ||
209 | chrpath --delete ${D}${libdir}/dri/*_dri.so || true | ||
210 | |||
211 | # libwayland-egl has been moved to wayland 1.15+ | 255 | # libwayland-egl has been moved to wayland 1.15+ |
212 | rm -f ${D}${libdir}/libwayland-egl* | 256 | rm -f ${D}${libdir}/libwayland-egl* |
213 | rm -f ${D}${libdir}/pkgconfig/wayland-egl.pc | 257 | rm -f ${D}${libdir}/pkgconfig/wayland-egl.pc |
214 | } | 258 | } |
215 | 259 | ||
260 | do_install:append:class-native () { | ||
261 | if ${@bb.utils.contains('PACKAGECONFIG', 'opencl', 'true', 'false', d)}; then | ||
262 | install -d ${D}${bindir} | ||
263 | install -m0755 ${B}/src/intel/compiler/intel_clc ${D}${bindir} | ||
264 | fi | ||
265 | } | ||
266 | |||
216 | # For the packages that make up the OpenGL interfaces, inject variables so that | 267 | # For the packages that make up the OpenGL interfaces, inject variables so that |
217 | # they don't get Debian-renamed (which would remove the -mesa suffix), and | 268 | # they don't get Debian-renamed (which would remove the -mesa suffix), and |
218 | # RPROVIDEs/RCONFLICTs on the generic libgl name. | 269 | # RPROVIDEs/RCONFLICTs on the generic libgl name. |
@@ -222,87 +273,96 @@ python __anonymous() { | |||
222 | if "-native" in d.getVar("PN"): | 273 | if "-native" in d.getVar("PN"): |
223 | suffix = "-native" | 274 | suffix = "-native" |
224 | for p in (("egl", "libegl", "libegl1"), | 275 | for p in (("egl", "libegl", "libegl1"), |
225 | ("dri", "libgl", "libgl1"), | 276 | ("opengl", "libgl", "libgl1"), |
277 | ("glvnd", "libglx",), | ||
226 | ("gles", "libgles1", "libglesv1-cm1"), | 278 | ("gles", "libgles1", "libglesv1-cm1"), |
227 | ("gles", "libgles2", "libglesv2-2"), | 279 | ("gles", "libgles2", "libglesv2-2"), |
228 | ("gles", "libgles3",)): | 280 | ("gles", "libgles3",), |
281 | ("opencl", "libopencl",)): | ||
229 | if not p[0] in pkgconfig: | 282 | if not p[0] in pkgconfig: |
230 | continue | 283 | continue |
231 | mlprefix = d.getVar("MLPREFIX") | 284 | mlprefix = d.getVar("MLPREFIX") |
232 | fullp = mlprefix + p[1] + "-mesa" + suffix | 285 | fullp = mlprefix + p[1] + "-mesa" + suffix |
233 | mlprefix = d.getVar("MLPREFIX") | 286 | mlprefix = d.getVar("MLPREFIX") |
234 | pkgs = " ".join(mlprefix + x + suffix for x in p[1:]) | 287 | pkgs = " " + " ".join(mlprefix + x + suffix for x in p[1:]) |
235 | d.setVar("DEBIAN_NOAUTONAME_" + fullp, "1") | 288 | d.setVar("DEBIAN_NOAUTONAME:" + fullp, "1") |
236 | d.appendVar("RREPLACES_" + fullp, pkgs) | 289 | d.appendVar("RREPLACES:" + fullp, pkgs) |
237 | d.appendVar("RPROVIDES_" + fullp, pkgs) | 290 | d.appendVar("RPROVIDES:" + fullp, pkgs) |
238 | d.appendVar("RCONFLICTS_" + fullp, pkgs) | 291 | d.appendVar("RCONFLICTS:" + fullp, pkgs) |
239 | 292 | ||
240 | d.appendVar("RRECOMMENDS_" + fullp, " ${MLPREFIX}mesa-megadriver" + suffix) | 293 | d.appendVar("RRECOMMENDS:" + fullp, " ${MLPREFIX}mesa-megadriver" + suffix) |
241 | 294 | ||
242 | # For -dev, the first element is both the Debian and original name | 295 | # For -dev, the first element is both the Debian and original name |
243 | fullp = mlprefix + p[1] + "-mesa-dev" + suffix | 296 | fullp = mlprefix + p[1] + "-mesa-dev" + suffix |
244 | pkgs = mlprefix + p[1] + "-dev" + suffix | 297 | pkgs = " " + mlprefix + p[1] + "-dev" + suffix |
245 | d.setVar("DEBIAN_NOAUTONAME_" + fullp, "1") | 298 | d.setVar("DEBIAN_NOAUTONAME:" + fullp, "1") |
246 | d.appendVar("RREPLACES_" + fullp, pkgs) | 299 | d.appendVar("RREPLACES:" + fullp, pkgs) |
247 | d.appendVar("RPROVIDES_" + fullp, pkgs) | 300 | d.appendVar("RPROVIDES:" + fullp, pkgs) |
248 | d.appendVar("RCONFLICTS_" + fullp, pkgs) | 301 | d.appendVar("RCONFLICTS:" + fullp, pkgs) |
249 | } | 302 | } |
250 | 303 | ||
251 | python mesa_populate_packages() { | 304 | python mesa_populate_packages() { |
252 | pkgs = ['mesa', 'mesa-dev', 'mesa-dbg'] | 305 | pkgs = ['mesa', 'mesa-dev', 'mesa-dbg'] |
253 | for pkg in pkgs: | 306 | for pkg in pkgs: |
254 | d.setVar("RPROVIDES_%s" % pkg, pkg.replace("mesa", "mesa-dri", 1)) | 307 | d.setVar("RPROVIDES:%s" % pkg, pkg.replace("mesa", "mesa-dri", 1)) |
255 | d.setVar("RCONFLICTS_%s" % pkg, pkg.replace("mesa", "mesa-dri", 1)) | 308 | d.setVar("RCONFLICTS:%s" % pkg, pkg.replace("mesa", "mesa-dri", 1)) |
256 | d.setVar("RREPLACES_%s" % pkg, pkg.replace("mesa", "mesa-dri", 1)) | 309 | d.setVar("RREPLACES:%s" % pkg, pkg.replace("mesa", "mesa-dri", 1)) |
257 | 310 | ||
258 | import re | 311 | import re |
259 | dri_drivers_root = oe.path.join(d.getVar('PKGD'), d.getVar('libdir'), "dri") | 312 | dri_drivers_root = oe.path.join(d.getVar('PKGD'), d.getVar('libdir'), "dri") |
260 | if os.path.isdir(dri_drivers_root): | 313 | if os.path.isdir(dri_drivers_root): |
261 | dri_pkgs = os.listdir(dri_drivers_root) | 314 | dri_pkgs = sorted(os.listdir(dri_drivers_root)) |
262 | lib_name = d.expand("${MLPREFIX}mesa-megadriver") | 315 | lib_name = d.expand("${MLPREFIX}mesa-megadriver") |
263 | for p in dri_pkgs: | 316 | for p in dri_pkgs: |
264 | m = re.match(r'^(.*)_dri\.so$', p) | 317 | m = re.match(r'^(.*)_dri\.so$', p) |
265 | if m: | 318 | if m: |
266 | pkg_name = " ${MLPREFIX}mesa-driver-%s" % legitimize_package_name(m.group(1)) | 319 | pkg_name = " ${MLPREFIX}mesa-driver-%s" % legitimize_package_name(m.group(1)) |
267 | d.appendVar("RPROVIDES_%s" % lib_name, pkg_name) | 320 | d.appendVar("RPROVIDES:%s" % lib_name, pkg_name) |
268 | d.appendVar("RCONFLICTS_%s" % lib_name, pkg_name) | 321 | d.appendVar("RCONFLICTS:%s" % lib_name, pkg_name) |
269 | d.appendVar("RREPLACES_%s" % lib_name, pkg_name) | 322 | d.appendVar("RREPLACES:%s" % lib_name, pkg_name) |
270 | 323 | ||
271 | pipe_drivers_root = os.path.join(d.getVar('libdir'), "gallium-pipe") | 324 | pipe_drivers_root = os.path.join(d.getVar('libdir'), "gallium-pipe") |
272 | do_split_packages(d, pipe_drivers_root, r'^pipe_(.*)\.so$', 'mesa-driver-pipe-%s', 'Mesa %s pipe driver', extra_depends='') | 325 | do_split_packages(d, pipe_drivers_root, r'^pipe_(.*)\.so$', 'mesa-driver-pipe-%s', 'Mesa %s pipe driver', extra_depends='') |
273 | } | 326 | } |
274 | 327 | ||
275 | PACKAGESPLITFUNCS_prepend = "mesa_populate_packages " | 328 | PACKAGESPLITFUNCS =+ "mesa_populate_packages" |
276 | 329 | ||
277 | PACKAGES_DYNAMIC += "^mesa-driver-.*" | 330 | PACKAGES_DYNAMIC += "^mesa-driver-.*" |
278 | PACKAGES_DYNAMIC_class-native = "^mesa-driver-.*-native" | 331 | PACKAGES_DYNAMIC:class-native = "^mesa-driver-.*-native" |
279 | 332 | ||
280 | FILES_mesa-megadriver = "${libdir}/dri/* ${datadir}/drirc.d/00-mesa-defaults.conf" | 333 | FILES:mesa-megadriver = "${libdir}/dri/* ${datadir}/drirc.d" |
281 | FILES_mesa-vulkan-drivers = "${libdir}/libvulkan_*.so ${datadir}/vulkan" | 334 | FILES:mesa-vulkan-drivers = "${libdir}/libvulkan_*.so ${libdir}/libpowervr_rogue.so ${datadir}/vulkan" |
282 | FILES_${PN}-vdpau-drivers = "${libdir}/vdpau/*.so.*" | 335 | FILES:${PN}-vdpau-drivers = "${libdir}/vdpau/*.so.*" |
283 | FILES_libegl-mesa = "${libdir}/libEGL.so.*" | 336 | FILES:libegl-mesa = "${libdir}/libEGL*.so.* ${datadir}/glvnd/egl_vendor.d" |
284 | FILES_libgbm = "${libdir}/libgbm.so.*" | 337 | FILES:libgbm = "${libdir}/libgbm.so.*" |
285 | FILES_libgles1-mesa = "${libdir}/libGLESv1*.so.*" | 338 | FILES:libgles1-mesa = "${libdir}/libGLESv1*.so.*" |
286 | FILES_libgles2-mesa = "${libdir}/libGLESv2.so.*" | 339 | FILES:libgles2-mesa = "${libdir}/libGLESv2.so.*" |
287 | FILES_libgl-mesa = "${libdir}/libGL.so.*" | 340 | FILES:libgl-mesa = "${libdir}/libGL.so.*" |
288 | FILES_libglapi = "${libdir}/libglapi.so.*" | 341 | FILES:libglx-mesa = "${libdir}/libGLX*.so.*" |
289 | FILES_libosmesa = "${libdir}/libOSMesa.so.*" | 342 | FILES:libopencl-mesa = "${libdir}/libMesaOpenCL.so.* ${libdir}/gallium-pipe/*.so ${sysconfdir}/OpenCL/vendors/mesa.icd" |
290 | FILES_libxatracker = "${libdir}/libxatracker.so.*" | 343 | FILES:libglapi = "${libdir}/libglapi.so.*" |
291 | 344 | FILES:libosmesa = "${libdir}/libOSMesa.so.*" | |
292 | FILES_${PN}-dev = "${libdir}/pkgconfig/dri.pc ${includedir}/vulkan ${libdir}/vdpau/*.so" | 345 | FILES:libxatracker = "${libdir}/libxatracker.so.*" |
293 | FILES_libegl-mesa-dev = "${libdir}/libEGL.* ${includedir}/EGL ${includedir}/KHR ${libdir}/pkgconfig/egl.pc" | 346 | |
294 | FILES_libgbm-dev = "${libdir}/libgbm.* ${libdir}/pkgconfig/gbm.pc ${includedir}/gbm.h" | 347 | FILES:${PN}-dev = "${libdir}/pkgconfig/dri.pc ${includedir}/vulkan ${libdir}/vdpau/*.so" |
295 | FILES_libgl-mesa-dev = "${libdir}/libGL.* ${includedir}/GL ${libdir}/pkgconfig/gl.pc" | 348 | FILES:libegl-mesa-dev = "${libdir}/libEGL*.* ${includedir}/EGL ${includedir}/KHR ${libdir}/pkgconfig/egl.pc" |
296 | FILES_libglapi-dev = "${libdir}/libglapi.*" | 349 | FILES:libgbm-dev = "${libdir}/libgbm.* ${libdir}/pkgconfig/gbm.pc ${includedir}/gbm.h" |
297 | FILES_libgles1-mesa-dev = "${libdir}/libGLESv1*.* ${includedir}/GLES ${libdir}/pkgconfig/glesv1*.pc" | 350 | FILES:libgl-mesa-dev = "${libdir}/libGL.* ${includedir}/GL ${libdir}/pkgconfig/gl.pc" |
298 | FILES_libgles2-mesa-dev = "${libdir}/libGLESv2.* ${includedir}/GLES2 ${libdir}/pkgconfig/glesv2.pc" | 351 | FILES:libglx-mesa-dev = "${libdir}/libGLX*.*" |
299 | FILES_libgles3-mesa-dev = "${includedir}/GLES3" | 352 | FILES:libglapi-dev = "${libdir}/libglapi.*" |
300 | FILES_libosmesa-dev = "${libdir}/libOSMesa.* ${includedir}/GL/osmesa.h ${libdir}/pkgconfig/osmesa.pc" | 353 | FILES:libgles1-mesa-dev = "${libdir}/libGLESv1*.* ${includedir}/GLES ${libdir}/pkgconfig/glesv1*.pc" |
301 | FILES_libxatracker-dev = "${libdir}/libxatracker.so ${libdir}/libxatracker.la \ | 354 | FILES:libgles2-mesa-dev = "${libdir}/libGLESv2.* ${includedir}/GLES2 ${libdir}/pkgconfig/glesv2.pc" |
355 | FILES:libgles3-mesa-dev = "${includedir}/GLES3" | ||
356 | FILES:libopencl-mesa-dev = "${libdir}/libMesaOpenCL.so" | ||
357 | FILES:libosmesa-dev = "${libdir}/libOSMesa.* ${includedir}/GL/osmesa.h ${libdir}/pkgconfig/osmesa.pc" | ||
358 | FILES:libxatracker-dev = "${libdir}/libxatracker.so ${libdir}/libxatracker.la \ | ||
302 | ${includedir}/xa_tracker.h ${includedir}/xa_composite.h ${includedir}/xa_context.h \ | 359 | ${includedir}/xa_tracker.h ${includedir}/xa_composite.h ${includedir}/xa_context.h \ |
303 | ${libdir}/pkgconfig/xatracker.pc" | 360 | ${libdir}/pkgconfig/xatracker.pc" |
361 | # catch all to get all the tools and data | ||
362 | FILES:${PN}-tools = "${bindir} ${datadir}" | ||
363 | ALLOW_EMPTY:${PN}-tools = "1" | ||
304 | 364 | ||
305 | # Fix upgrade path from mesa to mesa-megadriver | 365 | # Fix upgrade path from mesa to mesa-megadriver |
306 | RREPLACES_mesa-megadriver = "mesa" | 366 | RREPLACES:mesa-megadriver = "mesa" |
307 | RCONFLICTS_mesa-megadriver = "mesa" | 367 | RCONFLICTS:mesa-megadriver = "mesa" |
308 | RPROVIDES_mesa-megadriver = "mesa" | 368 | RPROVIDES:mesa-megadriver = "mesa" |