diff --git a/temp/mesa-git/APKBUILD b/temp/mesa-git/APKBUILD
index afdfe4e3c..1c484c621 100644
--- a/temp/mesa-git/APKBUILD
+++ b/temp/mesa-git/APKBUILD
@@ -9,22 +9,23 @@
# conflicts
pkgname=mesa-git
pkgver=0_git20200116
-pkgrel=0
+pkgrel=1
_commit="68abc0731715b2ec3048d0944250b96a5302b4bc"
-pkgdesc="(Git) Mesa DRI OpenGL library"
+pkgdesc="Mesa DRI OpenGL library (Git)"
url="https://www.mesa3d.org"
arch="all"
license="MIT SGI-B-2.0 BSL-1.0"
subpackages="
$pkgname-dev
- $pkgname-dri-ati:_dri
- $pkgname-dri-nouveau:_dri
- $pkgname-dri-freedreno:_dri
- $pkgname-dri-swrast:_dri
- $pkgname-dri-virtio:_dri
+ $pkgname-dri-classic:_dri
+ $pkgname-dri-gallium:_dri
+ $pkgname-va-gallium:_va
+ $pkgname-vdpau-gallium:_vdpau
$pkgname-glapi $pkgname-egl $pkgname-gl $pkgname-gles
$pkgname-xatracker $pkgname-osmesa $pkgname-gbm
$pkgname-vulkan-ati:_vulkan
+ $pkgname-dri-ati:_dri_deprecated
+ $pkgname-dri-nouveau:_dri_deprecated
"
_llvmver=9
depends_dev="
@@ -40,6 +41,7 @@ makedepends="
bison
eudev-dev
expat-dev
+ findutils
flex
gettext
glslang
@@ -84,7 +86,11 @@ fi
_dri_driverdir=/usr/lib/xorg/modules/dri
_dri_drivers="r100,r200,nouveau"
-_gallium_drivers="r300,r600,radeonsi,nouveau,freedreno,swrast,virgl"
+_gallium_drivers="r300,r600,radeonsi,nouveau,swrast,virgl"
+_gallium_provides="
+ $pkgname-dri-swrast=$pkgver-r$pkgrel
+ $pkgname-dri-virtio=$pkgver-r$pkgrel
+ "
_vulkan_drivers="amd"
_arch_opts=""
_vulkan_overlay_layer=false
@@ -96,10 +102,10 @@ x86*)
_vulkan_overlay_layer=true
makedepends="$makedepends glslang"
subpackages="$subpackages \
- $pkgname-dri-intel:_dri \
- $pkgname-dri-vmwgfx:_dri \
+ $pkgname-dri-intel:_dri_deprecated \
$pkgname-vulkan-intel:_vulkan \
$pkgname-vulkan-layer:_vulkan_layer"
+ _gallium_provides="$_gallium_provides $pkgname-dri-vmwgfx=$pkgver-r$pkgrel"
_arch_opts="-Ddri3=true"
case "$CARCH" in
x86)
@@ -107,15 +113,16 @@ x86*)
esac
;;
armhf|armv7|aarch64)
- _gallium_drivers="${_gallium_drivers},vc4,v3d,kmsro,lima,panfrost,etnaviv,tegra"
- subpackages="$subpackages
- $pkgname-dri-vc4:_dri
- $pkgname-dri-v3d:_dri
- $pkgname-dri-kmsro:_dri
- $pkgname-dri-lima:_dri
- $pkgname-dri-panfrost:_dri
- $pkgname-dri-etnaviv:_dri
- $pkgname-dri-tegra:_dri
+ _gallium_drivers="${_gallium_drivers},vc4,v3d,freedreno,kmsro,lima,panfrost,etnaviv,tegra"
+ _gallium_provides="$_gallium_provides
+ $pkgname-dri-vc4=$pkgver-r$pkgrel
+ $pkgname-dri-v3d=$pkgver-r$pkgrel
+ $pkgname-dri-freedreno=$pkgver-r$pkgrel
+ $pkgname-dri-kmsro=$pkgver-r$pkgrel
+ $pkgname-dri-lima=$pkgver-r$pkgrel
+ $pkgname-dri-panfrost=$pkgver-r$pkgrel
+ $pkgname-dri-etnaviv=$pkgver-r$pkgrel
+ $pkgname-dri-tegra=$pkgver-r$pkgrel
"
;;
esac
@@ -128,7 +135,7 @@ build() {
--sysconfdir=/etc \
--mandir=/usr/share/man \
--localstatedir=/var \
- --buildtype=release \
+ --buildtype=debugoptimized \
-Ddri-drivers-path=$_dri_driverdir \
-Dgallium-drivers=$_gallium_drivers \
-Ddri-drivers=$_dri_drivers \
@@ -169,7 +176,7 @@ package() {
egl() {
pkgdesc="Mesa libEGL runtime libraries"
- depends="mesa-git"
+ depends="$pkgname"
replaces="mesa-egl"
provides="mesa-egl"
@@ -179,7 +186,7 @@ egl() {
gl() {
pkgdesc="Mesa libGL runtime libraries"
- depends="mesa-git"
+ depends="$pkgname"
replaces="mesa-gl"
provides="mesa-gl"
@@ -189,6 +196,7 @@ gl() {
glapi() {
pkgdesc="Mesa shared glapi"
+ depends="$pkgname"
replaces="mesa-gles mesa-glapi"
provides="mesa-glapi"
@@ -198,7 +206,7 @@ glapi() {
gles() {
pkgdesc="Mesa libGLESv2 runtime libraries"
- depends="mesa-git"
+ depends="$pkgname"
replaces="mesa-gles"
provides="mesa-gles"
@@ -208,7 +216,7 @@ gles() {
xatracker() {
pkgdesc="Mesa XA state tracker for vmware"
- depends="mesa-git"
+ depends="$pkgname"
replaces="mesa-xatracker"
provides="mesa-xatracker"
@@ -218,7 +226,7 @@ xatracker() {
osmesa() {
pkgdesc="Mesa offscreen rendering libraries"
- depends="mesa-git"
+ depends="$pkgname"
replaces="mesa-osmesa"
provides="mesa-osmesa"
@@ -228,7 +236,7 @@ osmesa() {
gbm() {
pkgdesc="Mesa gbm library"
- depends="mesa-git"
+ depends="$pkgname"
replaces="mesa-gbm"
provides="mesa-gbm"
@@ -236,42 +244,14 @@ gbm() {
mv "$pkgdir"/usr/lib/libgbm.so.* "$subpkgdir"/usr/lib/
}
-dev() {
- replaces="mesa-dev"
- provides="mesa-dev"
-
- default_dev
-}
-
-_mv_dri() {
- install -d "$subpkgdir"/$_dri_driverdir
-
- while [ $# -gt 0 ]; do
- mv "$pkgdir"/$_dri_driverdir/$1.so \
- "$subpkgdir"/$_dri_driverdir/
- shift
- done
-}
-
-_mv_vdpau() {
- local i
- install -d "$subpkgdir"/usr/lib/vdpau
- for i in "$@"; do
- mv "$pkgdir"/usr/lib/vdpau/libvdpau_$i.* \
- "$subpkgdir"/usr/lib/vdpau/
- done
-}
-
-_mv_gpipe() {
- return 0
- # http://cgit.freedesktop.org/mesa/mesa/commit/?id=44ec468e8033553c26a112cebba41c343db00eb1
- # https://code.google.com/p/chromium/issues/detail?id=412089
-# local i
-# install -d "$subpkgdir"/usr/lib/gallium-pipe
-# for i in "$@"; do
-# mv "$pkgdir"/usr/lib/gallium-pipe/pipe_$i.* \
-# "$subpkgdir"/usr/lib/gallium-pipe/
-# done
+# Move links referencing the same file to the subpackage.
+# Usage: _mv_links
+# where is one of the libraries covered by the megadriver.
+# The example is used to find other links that point to the same file.
+_mv_links() {
+ install -d "$subpkgdir"/$1
+ find -L "$pkgdir"/$1 -samefile "$pkgdir"/$1/$2 -print0 \
+ | xargs -0 -I{} mv {} "$subpkgdir"/$1/
}
_mv_vulkan() {
@@ -284,78 +264,77 @@ _mv_vulkan() {
done
}
-_mv_va() {
- local i
- install -d "$subpkgdir"/usr/lib/dri
- for i in "$@"; do
- mv "$pkgdir"/usr/lib/dri/${i}_drv_video.so \
- "$subpkgdir"/usr/lib/dri/
- done
-}
+# Mesa uses "megadrivers" where multiple drivers are linked into one shared
+# library. This library is then hard-linked to separate files (one for each driver).
+# Each subpackage contains one megadriver so that all the hard-links are preserved.
_dri() {
local n=${subpkgname##*-dri-}
- pkgdesc="(Git) Mesa DRI driver for $n"
- depends="mesa-git"
+ pkgdesc="Mesa $n DRI drivers (Git)"
+ depends="$pkgname"
provides="mesa-dri-$n"
replaces="mesa-dri-$n"
case $n in
- ati)
- _mv_dri radeon_dri r200_dri r300_dri r600_dri radeonsi_dri \
- && _mv_vdpau r300 r600 radeonsi \
- && _mv_gpipe r300 r600 \
- && _mv_va r600 radeonsi
- ;;
- intel)
- _mv_dri i915_dri i965_dri iris_dri
- ;;
- nouveau)
- _mv_dri nouveau_dri nouveau_vieux_dri \
- && _mv_vdpau nouveau \
- && _mv_gpipe nouveau \
- && _mv_va nouveau
- ;;
- freedreno)
- _mv_dri msm_dri kgsl_dri
- ;;
- swrast)
- _mv_dri swrast_dri kms_swrast_dri && _mv_gpipe swrast
- ;;
- vc4)
- _mv_dri vc4_dri
- ;;
- v3d)
- _mv_dri v3d_dri
- ;;
- vmwgfx)
- _mv_dri vmwgfx_dri && _mv_gpipe vmwgfx
- ;;
- virtio)
- _mv_dri virtio_gpu_dri
- ;;
- kmsro)
- _mv_dri exynos_dri hx8357d_dri ili9225_dri ili9341_dri ingenic-drm_dri mcde_dri meson_dri mi0283qt_dri mxsfb-drm_dri pl111_dri repaper_dri rockchip_dri st7586_dri st7735r_dri stm_dri sun4i-drm_dri
- ;;
- lima)
- _mv_dri lima_dri
- ;;
- panfrost)
- _mv_dri panfrost_dri
- ;;
- etnaviv)
- _mv_dri armada-drm_dri imx-drm_dri etnaviv_dri
- ;;
- tegra)
- _mv_dri tegra_dri
+ classic)
+ # libmesa_dri_drivers.so
+ _mv_links $_dri_driverdir radeon_dri.so ;;
+ gallium)
+ # libgallium_dri.so
+ _mv_links $_dri_driverdir swrast_dri.so
+ provides="$provides $_gallium_provides"
;;
esac
}
+# Compatibility packages for upgrading from the old (driver-specific) subpackages
+_dri_deprecated() {
+ local n=${subpkgname##*-dri-}
+ pkgdesc="Mesa DRI drivers for $n (DEPRECATED, Git)"
+ depends="$pkgname-dri-classic $pkgname-dri-gallium"
+ provides="mesa-dri-$n"
+ replaces="mesa-dri-$n"
+
+ case $n in
+ ati|nouveau)
+ depends="$depends $pkgname-va-gallium $pkgname-vdpau-gallium" ;;
+ esac
+
+ mkdir "$subpkgdir"
+}
+
+_va() {
+ local n=${subpkgname##*-va-}
+ pkgdesc="Mesa $n VAAPI drivers (Git)"
+ depends="$pkgname libva"
+ provides="mesa-va-$n"
+ replaces="mesa-va-$n"
+
+ case $n in
+ gallium)
+ # libgallium_drv_video.so
+ _mv_links /usr/lib/dri radeonsi_drv_video.so ;;
+ esac
+}
+
+_vdpau() {
+ local n=${subpkgname##*-vdpau-}
+ pkgdesc="Mesa $n VDPAU drivers (Git)"
+ depends="$pkgname libvdpau"
+ provides="mesa-vdpau-$n"
+ replaces="mesa-vdpau-$n"
+
+ case $n in
+ gallium)
+ # libvdpau_gallium.so.1.0.0
+ _mv_links /usr/lib/vdpau libvdpau_radeonsi.so.1.0.0 ;;
+ esac
+}
+
_vulkan() {
local n=${subpkgname##*-vulkan-}
- pkgdesc="(Git) Mesa Vulkan API driver for $n"
- depends="mesa-git"
+ pkgdesc="Mesa Vulkan API driver for $n (Git)"
+ depends="$pkgname"
replaces="mesa-vulkan-$n"
provides="mesa-vulkan-$n"
@@ -369,6 +348,9 @@ _vulkan() {
_vulkan_layer() {
pkgdesc="Vulkan overlay layer to display information about the application"
+ depends="$pkgname"
+ replaces="mesa-vulkan-layer"
+ provides="mesa-vulkan-layer"
mkdir -p "$subpkgdir"/usr/share/vulkan "$subpkgdir"/usr/lib
mv "$pkgdir"/usr/share/vulkan/explicit_layer.d "$subpkgdir"/usr/share/vulkan