aboutsummaryrefslogtreecommitdiff
path: root/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa
diff options
context:
space:
mode:
Diffstat (limited to 'infra/libkookie/nixpkgs/pkgs/development/libraries/mesa')
-rw-r--r--infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/default.nix248
-rw-r--r--infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/disk_cache-include-dri-driver-path-in-cache-key.patch74
-rw-r--r--infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/missing-includes.patch22
-rw-r--r--infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/opencl-install-dir.patch12
-rw-r--r--infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/stubs.nix75
5 files changed, 431 insertions, 0 deletions
diff --git a/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/default.nix b/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/default.nix
new file mode 100644
index 000000000000..891e11dbadf9
--- /dev/null
+++ b/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/default.nix
@@ -0,0 +1,248 @@
+{ stdenv, lib, fetchurl, fetchpatch, buildPackages
+, pkgconfig, intltool, ninja, meson
+, file, flex, bison, expat, libdrm, xorg, wayland, wayland-protocols, openssl
+, llvmPackages, libffi, libomxil-bellagio, libva-minimal
+, libelf, libvdpau, python3Packages
+, libglvnd
+, enableRadv ? true
+, galliumDrivers ? ["auto"]
+, driDrivers ? ["auto"]
+, vulkanDrivers ? ["auto"]
+, eglPlatforms ? [ "x11" ] ++ lib.optionals stdenv.isLinux [ "wayland" ]
+, OpenGL, Xplugin
+, withValgrind ? stdenv.hostPlatform.isLinux && !stdenv.hostPlatform.isAarch32, valgrind-light
+, enableGalliumNine ? stdenv.isLinux
+, enableOSMesa ? stdenv.isLinux
+}:
+
+/** Packaging design:
+ - The basic mesa ($out) contains headers and libraries (GLU is in libGLU now).
+ This or the mesa attribute (which also contains GLU) are small (~ 2 MB, mostly headers)
+ and are designed to be the buildInput of other packages.
+ - DRI drivers are compiled into $drivers output, which is much bigger and
+ depends on LLVM. These should be searched at runtime in
+ "/run/opengl-driver{,-32}/lib/*" and so are kind-of impure (given by NixOS).
+ (I suppose on non-NixOS one would create the appropriate symlinks from there.)
+ - libOSMesa is in $osmesa (~4 MB)
+*/
+
+with stdenv.lib;
+
+let
+ # Release calendar: https://www.mesa3d.org/release-calendar.html
+ # Release frequency: https://www.mesa3d.org/releasing.html#schedule
+ version = "20.2.3";
+ branch = versions.major version;
+in
+
+stdenv.mkDerivation {
+ pname = "mesa";
+ inherit version;
+
+ src = fetchurl {
+ urls = [
+ "https://mesa.freedesktop.org/archive/mesa-${version}.tar.xz"
+ "ftp://ftp.freedesktop.org/pub/mesa/mesa-${version}.tar.xz"
+ "ftp://ftp.freedesktop.org/pub/mesa/${version}/mesa-${version}.tar.xz"
+ "ftp://ftp.freedesktop.org/pub/mesa/older-versions/${branch}.x/${version}/mesa-${version}.tar.xz"
+ ];
+ sha256 = "0axqrqg1fas91fx30qjwhcp4yasdvk919hjds4lga7ak247286xf";
+ };
+
+ prePatch = "patchShebangs .";
+
+ # TODO:
+ # revive ./dricore-gallium.patch when it gets ported (from Ubuntu), as it saved
+ # ~35 MB in $drivers; watch https://launchpad.net/ubuntu/+source/mesa/+changelog
+ patches = [
+ ./missing-includes.patch # dev_t needs sys/stat.h, time_t needs time.h, etc.-- fixes build w/musl
+ ./opencl-install-dir.patch
+ ./disk_cache-include-dri-driver-path-in-cache-key.patch
+ ]
+ ++ lib.optionals stdenv.hostPlatform.isMusl [
+ # Fix `-Werror=int-conversion` pthread warnings on musl.
+ # TODO: Remove when https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/6121 is merged and available
+ (fetchpatch {
+ name = "nine_debug-Make-tid-more-type-correct";
+ # Patch adjusted for version `20.1`, before the big mesa dirs change
+ # `gallium: rename 'state tracker' to 'frontend'`.
+ # Patch for versions after that change is at
+ # https://gitlab.freedesktop.org/mesa/mesa/commit/aebbf819df6d1e3b4745ef16d0e833300ad67044.patch
+ url = "https://gitlab.freedesktop.org/nh2/mesa/commit/3385c49684375f1153a52ed7ccda3f5135268a41.patch";
+ sha256 = "1ci694sqjll44c9g2md4krhk6qlvq51r7ad5rnnfdnf3l8ys0i50";
+ })
+ ]
+ # do not prefix user provided dri-drivers-path
+ ++ lib.optional (lib.versionOlder version "19.0.0") (fetchpatch {
+ url = "https://gitlab.freedesktop.org/mesa/mesa/commit/f6556ec7d126b31da37c08d7cb657250505e01a0.patch";
+ sha256 = "0z6phi8hbrbb32kkp1js7ggzviq7faz1ria36wi4jbc4in2392d9";
+ })
+ ++ lib.optionals (lib.versionOlder version "19.1.0") [
+ # do not prefix user provided d3d-drivers-path
+ (fetchpatch {
+ url = "https://gitlab.freedesktop.org/mesa/mesa/commit/dcc48664197c7e44684ccfb970a4ae083974d145.patch";
+ sha256 = "1nhs0xpx3hiy8zfb5gx1zd7j7xha6h0hr7yingm93130a5902lkb";
+ })
+
+ # don't build libGLES*.so with GLVND
+ (fetchpatch {
+ url = "https://gitlab.freedesktop.org/mesa/mesa/commit/b01524fff05eef66e8cd24f1c5aacefed4209f03.patch";
+ sha256 = "1pszr6acx2xw469zq89n156p3bf3xf84qpbjw5fr1sj642lbyh7c";
+ })
+ ];
+
+ postPatch = ''
+ substituteInPlace meson.build --replace \
+ "find_program('pkg-config')" \
+ "find_program('${buildPackages.pkg-config.targetPrefix}pkg-config')"
+
+ # The drirc.d directory cannot be installed to $drivers as that would cause a cyclic dependency:
+ substituteInPlace src/util/xmlconfig.c --replace \
+ 'DATADIR "/drirc.d"' '"${placeholder "out"}/drirc.d"'
+ substituteInPlace src/util/meson.build --replace \
+ "get_option('datadir')" "'${placeholder "out"}'"
+ '';
+
+ outputs = [ "out" "dev" "drivers" ] ++ lib.optional enableOSMesa "osmesa";
+
+ # TODO: Figure out how to enable opencl without having a runtime dependency on clang
+ mesonFlags = [
+ "--sysconfdir=/etc"
+ "--datadir=${placeholder "drivers"}/share" # Vendor files
+
+ # Don't build in debug mode
+ # https://gitlab.freedesktop.org/mesa/mesa/blob/master/docs/meson.html#L327
+ "-Db_ndebug=true"
+
+ "-Ddisk-cache-key=${placeholder "drivers"}"
+ "-Ddri-search-path=${libglvnd.driverLink}/lib/dri"
+
+ "-Dplatforms=${concatStringsSep "," eglPlatforms}"
+ "-Ddri-drivers=${concatStringsSep "," driDrivers}"
+ "-Dgallium-drivers=${concatStringsSep "," galliumDrivers}"
+ "-Dvulkan-drivers=${concatStringsSep "," vulkanDrivers}"
+
+ "-Ddri-drivers-path=${placeholder "drivers"}/lib/dri"
+ "-Dvdpau-libs-path=${placeholder "drivers"}/lib/vdpau"
+ "-Dxvmc-libs-path=${placeholder "drivers"}/lib"
+ "-Domx-libs-path=${placeholder "drivers"}/lib/bellagio"
+ "-Dva-libs-path=${placeholder "drivers"}/lib/dri"
+ "-Dd3d-drivers-path=${placeholder "drivers"}/lib/d3d"
+ "-Dgallium-nine=${boolToString enableGalliumNine}" # Direct3D in Wine
+ "-Dosmesa=${if enableOSMesa then "gallium" else "none"}" # used by wine
+ ] ++ optionals stdenv.isLinux [
+ "-Dglvnd=true"
+ ];
+
+ buildInputs = with xorg; [
+ expat llvmPackages.llvm libglvnd xorgproto
+ libX11 libXext libxcb libXt libXfixes libxshmfence libXrandr
+ libffi libvdpau libelf libXvMC
+ libpthreadstubs openssl /*or another sha1 provider*/
+ ] ++ lib.optionals (elem "wayland" eglPlatforms) [ wayland wayland-protocols ]
+ ++ lib.optionals stdenv.isLinux [ libomxil-bellagio libva-minimal ]
+ ++ lib.optional withValgrind valgrind-light;
+
+ depsBuildBuild = [ pkgconfig ];
+
+ nativeBuildInputs = [
+ pkgconfig meson ninja
+ intltool bison flex file
+ python3Packages.python python3Packages.Mako
+ ] ++ lib.optionals (elem "wayland" eglPlatforms) [
+ wayland # For wayland-scanner during the build
+ ];
+
+ propagatedBuildInputs = with xorg; [
+ libXdamage libXxf86vm
+ ] ++ optional stdenv.isLinux libdrm
+ ++ optionals stdenv.isDarwin [ OpenGL Xplugin ];
+
+ enableParallelBuilding = true;
+ doCheck = false;
+
+ postInstall = ''
+ # Some installs don't have any drivers so this directory is never created.
+ mkdir -p $drivers $osmesa
+ '' + optionalString stdenv.isLinux ''
+ mkdir -p $drivers/lib
+
+ if [ -n "$(shopt -s nullglob; echo "$out/lib/libxatracker"*)" -o -n "$(shopt -s nullglob; echo "$out/lib/libvulkan_"*)" ]; then
+ # move gallium-related stuff to $drivers, so $out doesn't depend on LLVM
+ mv -t $drivers/lib \
+ $out/lib/libxatracker* \
+ $out/lib/libvulkan_*
+ fi
+
+ if [ -n "$(shopt -s nullglob; echo "$out"/lib/lib*_mesa*)" ]; then
+ # Move other drivers to a separate output
+ mv $out/lib/lib*_mesa* $drivers/lib
+ fi
+
+ # Update search path used by glvnd
+ for js in $drivers/share/glvnd/egl_vendor.d/*.json; do
+ substituteInPlace "$js" --replace '"libEGL_' '"'"$drivers/lib/libEGL_"
+ done
+
+ # Update search path used by Vulkan (it's pointing to $out but
+ # drivers are in $drivers)
+ for js in $drivers/share/vulkan/icd.d/*.json; do
+ substituteInPlace "$js" --replace "$out" "$drivers"
+ done
+ '' + lib.optionalString enableOSMesa ''
+ # move libOSMesa to $osmesa, as it's relatively big
+ mkdir -p $osmesa/lib
+ mv -t $osmesa/lib/ $out/lib/libOSMesa*
+ '';
+
+ # TODO:
+ # check $out doesn't depend on llvm: builder failures are ignored
+ # for some reason grep -qv '${llvmPackages.llvm}' -R "$out";
+ postFixup = optionalString stdenv.isLinux ''
+ # set the default search path for DRI drivers; used e.g. by X server
+ substituteInPlace "$dev/lib/pkgconfig/dri.pc" --replace "$drivers" "${libglvnd.driverLink}"
+
+ # remove pkgconfig files for GL/EGL; they are provided by libGL.
+ rm -f $dev/lib/pkgconfig/{gl,egl}.pc
+
+ # Update search path used by pkg-config
+ for pc in $dev/lib/pkgconfig/{d3d,dri,xatracker}.pc; do
+ if [ -f "$pc" ]; then
+ substituteInPlace "$pc" --replace $out $drivers
+ fi
+ done
+
+ # add RPATH so the drivers can find the moved libgallium and libdricore9
+ # moved here to avoid problems with stripping patchelfed files
+ for lib in $drivers/lib/*.so* $drivers/lib/*/*.so*; do
+ if [[ ! -L "$lib" ]]; then
+ patchelf --set-rpath "$(patchelf --print-rpath $lib):$drivers/lib" "$lib"
+ fi
+ done
+ '';
+
+ NIX_CFLAGS_COMPILE = stdenv.lib.optionalString stdenv.isDarwin "-fno-common";
+
+ passthru = {
+ inherit libdrm;
+ inherit (libglvnd) driverLink;
+ };
+
+ meta = {
+ description = "An open source 3D graphics library";
+ longDescription = ''
+ The Mesa project began as an open-source implementation of the OpenGL
+ specification - a system for rendering interactive 3D graphics. Over the
+ years the project has grown to implement more graphics APIs, including
+ OpenGL ES (versions 1, 2, 3), OpenCL, OpenMAX, VDPAU, VA API, XvMC, and
+ Vulkan. A variety of device drivers allows the Mesa libraries to be used
+ in many different environments ranging from software emulation to
+ complete hardware acceleration for modern GPUs.
+ '';
+ homepage = "https://www.mesa3d.org/";
+ changelog = "https://www.mesa3d.org/relnotes/${version}.html";
+ license = licenses.mit; # X11 variant, in most files
+ platforms = platforms.mesaPlatforms;
+ maintainers = with maintainers; [ primeos vcunat ]; # Help is welcome :)
+ };
+}
diff --git a/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/disk_cache-include-dri-driver-path-in-cache-key.patch b/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/disk_cache-include-dri-driver-path-in-cache-key.patch
new file mode 100644
index 000000000000..fa78f4ae730a
--- /dev/null
+++ b/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/disk_cache-include-dri-driver-path-in-cache-key.patch
@@ -0,0 +1,74 @@
+From 980164fd92f5c2302624cd046d30ff21e6e4ba8a Mon Sep 17 00:00:00 2001
+From: David McFarland <corngood@gmail.com>
+Date: Mon, 6 Aug 2018 15:52:11 -0300
+Subject: [PATCH] disk_cache: include dri driver path in cache key
+
+This fixes invalid cache hits on NixOS where all shared library
+timestamps in /nix/store are zero.
+---
+ meson_options.txt | 6 ++++++
+ src/util/disk_cache.c | 3 +++
+ src/util/meson.build | 7 ++++++-
+ 3 files changed, 15 insertions(+), 1 deletion(-)
+
+diff --git a/meson_options.txt b/meson_options.txt
+index 2d39d13b6ad..daf06480a60 100644
+--- a/meson_options.txt
++++ b/meson_options.txt
+@@ -368,6 +368,12 @@ option(
+ value : true,
+ description : 'Enable direct rendering in GLX and EGL for DRI',
+ )
++option(
++ 'disk-cache-key',
++ type : 'string',
++ value : '',
++ description : 'Mesa cache key.'
++)
+ option(
+ 'prefer-iris',
+ type : 'boolean',
+diff --git a/src/util/disk_cache.c b/src/util/disk_cache.c
+index a92d621927a..3bd65c6890c 100644
+--- a/src/util/disk_cache.c
++++ b/src/util/disk_cache.c
+@@ -401,8 +401,10 @@ disk_cache_create(const char *gpu_name, const char *driver_id,
+
+ /* Create driver id keys */
+ size_t id_size = strlen(driver_id) + 1;
++ size_t key_size = strlen(DISK_CACHE_KEY) + 1;
+ size_t gpu_name_size = strlen(gpu_name) + 1;
+ cache->driver_keys_blob_size += id_size;
++ cache->driver_keys_blob_size += key_size;
+ cache->driver_keys_blob_size += gpu_name_size;
+
+ /* We sometimes store entire structs that contains a pointers in the cache,
+@@ -423,6 +425,7 @@ disk_cache_create(const char *gpu_name, const char *driver_id,
+ uint8_t *drv_key_blob = cache->driver_keys_blob;
+ DRV_KEY_CPY(drv_key_blob, &cache_version, cv_size)
+ DRV_KEY_CPY(drv_key_blob, driver_id, id_size)
++ DRV_KEY_CPY(drv_key_blob, DISK_CACHE_KEY, key_size)
+ DRV_KEY_CPY(drv_key_blob, gpu_name, gpu_name_size)
+ DRV_KEY_CPY(drv_key_blob, &ptr_size, ptr_size_size)
+ DRV_KEY_CPY(drv_key_blob, &driver_flags, driver_flags_size)
+diff --git a/src/util/meson.build b/src/util/meson.build
+index 0893f64793b..d46ce85a85f 100644
+--- a/src/util/meson.build
++++ b/src/util/meson.build
+@@ -179,7 +179,12 @@ _libmesa_util = static_library(
+ include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux],
+ dependencies : deps_for_libmesa_util,
+ link_with: libmesa_format,
+- c_args : [c_msvc_compat_args],
++ c_args : [
++ c_msvc_compat_args,
++ '-DDISK_CACHE_KEY="@0@"'.format(
++ get_option('disk-cache-key')
++ ),
++ ],
+ gnu_symbol_visibility : 'hidden',
+ build_by_default : false
+ )
+--
+2.28.0
+
diff --git a/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/missing-includes.patch b/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/missing-includes.patch
new file mode 100644
index 000000000000..72488893c6b6
--- /dev/null
+++ b/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/missing-includes.patch
@@ -0,0 +1,22 @@
+--- ./src/gallium/winsys/svga/drm/vmw_screen.h.orig
++++ ./src/gallium/winsys/svga/drm/vmw_screen.h
+@@ -34,7 +34,7 @@
+ #ifndef VMW_SCREEN_H_
+ #define VMW_SCREEN_H_
+
+-
++#include <sys/stat.h>
+ #include "pipe/p_compiler.h"
+ #include "pipe/p_state.h"
+
+--- ./src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.h
++++ ./src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.h
+@@ -28,6 +28,8 @@
+ #ifndef RADV_AMDGPU_WINSYS_H
+ #define RADV_AMDGPU_WINSYS_H
+
++#include <sys/types.h>
++
+ #include "radv_radeon_winsys.h"
+ #include "ac_gpu_info.h"
+ #include "addrlib/addrinterface.h"<Paste>
diff --git a/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/opencl-install-dir.patch b/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/opencl-install-dir.patch
new file mode 100644
index 000000000000..fe85d2c90bb2
--- /dev/null
+++ b/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/opencl-install-dir.patch
@@ -0,0 +1,12 @@
+diff --git a/src/gallium/targets/opencl/meson.build b/src/gallium/targets/opencl/meson.build
+index 317ad8dab4a..5567308caf0 100644
+--- a/src/gallium/targets/opencl/meson.build
++++ b/src/gallium/targets/opencl/meson.build
+@@ -68,6 +68,6 @@ if with_opencl_icd
+ input : 'mesa.icd.in',
+ output : 'mesa.icd',
+ install : true,
+- install_dir : join_paths(get_option('sysconfdir'), 'OpenCL', 'vendors'),
++ install_dir : join_paths(get_option('prefix'), 'etc', 'OpenCL', 'vendors'),
+ )
+ endif
diff --git a/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/stubs.nix b/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/stubs.nix
new file mode 100644
index 000000000000..a53f2dc28e77
--- /dev/null
+++ b/infra/libkookie/nixpkgs/pkgs/development/libraries/mesa/stubs.nix
@@ -0,0 +1,75 @@
+{ stdenv
+, libglvnd, mesa
+, OpenGL }:
+
+stdenv.mkDerivation {
+ inherit (libglvnd) version;
+ pname = "libGL";
+ outputs = [ "out" "dev" ];
+
+ # On macOS, libglvnd is not supported, so we just use what mesa
+ # build. We need to also include OpenGL.framework, and some
+ # extra tricks to go along with. We add mesa’s libGLX to support
+ # the X extensions to OpenGL.
+ buildCommand = if stdenv.hostPlatform.isDarwin then ''
+ mkdir -p $out/nix-support $dev
+ echo ${OpenGL} >> $out/nix-support/propagated-build-inputs
+ ln -s ${mesa.out}/lib $out/lib
+
+ mkdir -p $dev/lib/pkgconfig $dev/nix-support
+ echo "$out" > $dev/nix-support/propagated-build-inputs
+ ln -s ${mesa.dev}/include $dev/include
+
+ cat <<EOF >$dev/lib/pkgconfig/gl.pc
+ Name: gl
+ Description: gl library
+ Version: ${mesa.version}
+ Libs: -L${mesa.out}/lib -lGL
+ Cflags: -I${mesa.dev}/include
+ EOF
+
+ cat <<EOF >$dev/lib/pkgconfig/glesv1_cm.pc
+ Name: glesv1_cm
+ Description: glesv1_cm library
+ Version: ${mesa.version}
+ Libs: -L${mesa.out}/lib -lGLESv1_CM
+ Cflags: -I${mesa.dev}/include
+ EOF
+
+ cat <<EOF >$dev/lib/pkgconfig/glesv2.pc
+ Name: glesv2
+ Description: glesv2 library
+ Version: ${mesa.version}
+ Libs: -L${mesa.out}/lib -lGLESv2
+ Cflags: -I${mesa.dev}/include
+ EOF
+ ''
+
+ # Otherwise, setup gl stubs to use libglvnd.
+ else ''
+ mkdir -p $out/nix-support
+ ln -s ${libglvnd.out}/lib $out/lib
+
+ mkdir -p $dev/{,lib/pkgconfig,nix-support}
+ echo "$out ${libglvnd} ${libglvnd.dev}" > $dev/nix-support/propagated-build-inputs
+ ln -s ${mesa.dev}/include $dev/include
+
+ genPkgConfig() {
+ local name="$1"
+ local lib="$2"
+
+ cat <<EOF >$dev/lib/pkgconfig/$name.pc
+ Name: $name
+ Description: $lib library
+ Version: ${mesa.version}
+ Libs: -L${libglvnd.out}/lib -l$lib
+ Cflags: -I${mesa.dev}/include -I${libglvnd.dev}/include
+ EOF
+ }
+
+ genPkgConfig gl GL
+ genPkgConfig egl EGL
+ genPkgConfig glesv1_cm GLESv1_CM
+ genPkgConfig glesv2 GLESv2
+ '';
+}