[arch-commits] Commit in mesa/trunk (2 files)

Laurent Carlier lcarlier at archlinux.org
Tue Feb 23 18:07:39 UTC 2021


    Date: Tuesday, February 23, 2021 @ 18:07:39
  Author: lcarlier
Revision: 408683

upgpkg: mesa 20.3.4-3: FS#69744

Added:
  mesa/trunk/0001-vulkan-device_select-Stop-using-device-properties-2.patch
Modified:
  mesa/trunk/PKGBUILD

----------------------------------------------------------------+
 0001-vulkan-device_select-Stop-using-device-properties-2.patch |  109 ++++++++++
 PKGBUILD                                                       |   18 +
 2 files changed, 124 insertions(+), 3 deletions(-)

Added: 0001-vulkan-device_select-Stop-using-device-properties-2.patch
===================================================================
--- 0001-vulkan-device_select-Stop-using-device-properties-2.patch	                        (rev 0)
+++ 0001-vulkan-device_select-Stop-using-device-properties-2.patch	2021-02-23 18:07:39 UTC (rev 408683)
@@ -0,0 +1,109 @@
+From ccacfc317e4fac62052a22e2d092d15541e2877e Mon Sep 17 00:00:00 2001
+From: Bas Nieuwenhuizen <bas at basnieuwenhuizen.nl>
+Date: Mon, 11 Jan 2021 15:20:40 +0100
+Subject: [PATCH] vulkan/device_select: Stop using device properties 2.
+
+We have to choose between:
+1) Stop handling two identical GPUs
+2) Stop having crashes with other layers active.
+3) Fix the Vulkan Loader.
+
+Since nobody seems to want to spend enough effort to do 3 the
+effective choice is between 1 and 2. This is choosing 2, as
+two identical GPUs is pretty uncommon since crossfire doesn't
+work on Linux anyway.
+
+(And it would only work sporadically as the game needs to enable the
+ extension)
+
+CC: mesa-stable
+Closes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/3801
+Reviewed-by: Dave Airlie <airlied at redhat.com>
+Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/8414>
+(cherry picked from commit 38ce8d4d00c2b0e567b6dd36876cf171acb1dbc7)
+Signed-off-by: Laurent Carlier <lordheavym at gmail.com>
+---
+ .../device-select-layer/device_select_layer.c | 30 +++++++++++--------
+ 1 file changed, 18 insertions(+), 12 deletions(-)
+
+diff --git a/src/vulkan/device-select-layer/device_select_layer.c b/src/vulkan/device-select-layer/device_select_layer.c
+index c381ac33fd1..134a3bd22dd 100644
+--- a/src/vulkan/device-select-layer/device_select_layer.c
++++ b/src/vulkan/device-select-layer/device_select_layer.c
+@@ -51,8 +51,8 @@ struct instance_info {
+    PFN_GetPhysicalDeviceProcAddr  GetPhysicalDeviceProcAddr;
+    PFN_vkEnumerateDeviceExtensionProperties EnumerateDeviceExtensionProperties;
+    PFN_vkGetPhysicalDeviceProperties GetPhysicalDeviceProperties;
+-   PFN_vkGetPhysicalDeviceProperties2KHR GetPhysicalDeviceProperties2KHR;
+-   bool has_props2, has_pci_bus;
++   PFN_vkGetPhysicalDeviceProperties2 GetPhysicalDeviceProperties2;
++   bool has_pci_bus, has_vulkan11;
+    bool has_wayland, has_xcb;
+ };
+ 
+@@ -150,8 +150,6 @@ static VkResult device_select_CreateInstance(const VkInstanceCreateInfo *pCreate
+    }
+ 
+    for (unsigned i = 0; i < pCreateInfo->enabledExtensionCount; i++) {
+-      if (!strcmp(pCreateInfo->ppEnabledExtensionNames[i], VK_KHR_GET_PHYSICAL_DEVICE_PROPERTIES_2_EXTENSION_NAME))
+-         info->has_props2 = true;
+ #ifdef VK_USE_PLATFORM_WAYLAND_KHR
+       if (!strcmp(pCreateInfo->ppEnabledExtensionNames[i], VK_KHR_WAYLAND_SURFACE_EXTENSION_NAME))
+          info->has_wayland = true;
+@@ -162,6 +160,14 @@ static VkResult device_select_CreateInstance(const VkInstanceCreateInfo *pCreate
+ #endif
+    }
+ 
++   /*
++    * The loader is currently not able to handle GetPhysicalDeviceProperties2KHR calls in
++    * EnumeratePhysicalDevices when there are other layers present. To avoid mysterious crashes
++    * for users just use only the vulkan version for now.
++    */
++   info->has_vulkan11 = pCreateInfo->pApplicationInfo &&
++                        pCreateInfo->pApplicationInfo->apiVersion >= VK_MAKE_VERSION(1, 1, 0);
++
+    info->GetPhysicalDeviceProcAddr = (PFN_GetPhysicalDeviceProcAddr)info->GetInstanceProcAddr(*pInstance, "vk_layerGetPhysicalDeviceProcAddr");
+ #define DEVSEL_GET_CB(func) info->func = (PFN_vk##func)info->GetInstanceProcAddr(*pInstance, "vk" #func)
+    DEVSEL_GET_CB(DestroyInstance);
+@@ -169,8 +175,8 @@ static VkResult device_select_CreateInstance(const VkInstanceCreateInfo *pCreate
+    DEVSEL_GET_CB(EnumeratePhysicalDeviceGroups);
+    DEVSEL_GET_CB(GetPhysicalDeviceProperties);
+    DEVSEL_GET_CB(EnumerateDeviceExtensionProperties);
+-   if (info->has_props2)
+-      DEVSEL_GET_CB(GetPhysicalDeviceProperties2KHR);
++   if (info->has_vulkan11)
++      DEVSEL_GET_CB(GetPhysicalDeviceProperties2);
+ #undef DEVSEL_GET_CB
+ 
+    device_select_layer_add_instance(*pInstance, info);
+@@ -197,10 +203,10 @@ static void print_gpu(const struct instance_info *info, unsigned index, VkPhysic
+    VkPhysicalDeviceProperties2KHR properties = (VkPhysicalDeviceProperties2KHR){
+       .sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2_KHR
+    };
+-   if (info->has_props2 && info->has_pci_bus)
++   if (info->has_vulkan11 && info->has_pci_bus)
+       properties.pNext = &ext_pci_properties;
+-   if (info->GetPhysicalDeviceProperties2KHR)
+-      info->GetPhysicalDeviceProperties2KHR(device, &properties);
++   if (info->GetPhysicalDeviceProperties2)
++      info->GetPhysicalDeviceProperties2(device, &properties);
+    else
+       info->GetPhysicalDeviceProperties(device, &properties.properties);
+ 
+@@ -243,10 +249,10 @@ static bool fill_drm_device_info(const struct instance_info *info,
+       .sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2_KHR
+    };
+ 
+-   if (info->has_props2 && info->has_pci_bus)
++   if (info->has_vulkan11 && info->has_pci_bus)
+       properties.pNext = &ext_pci_properties;
+-   if (info->GetPhysicalDeviceProperties2KHR)
+-     info->GetPhysicalDeviceProperties2KHR(device, &properties);
++   if (info->GetPhysicalDeviceProperties2)
++     info->GetPhysicalDeviceProperties2(device, &properties);
+    else
+      info->GetPhysicalDeviceProperties(device, &properties.properties);
+ 
+-- 
+2.30.1
+

Modified: PKGBUILD
===================================================================
--- PKGBUILD	2021-02-23 17:06:37 UTC (rev 408682)
+++ PKGBUILD	2021-02-23 18:07:39 UTC (rev 408683)
@@ -7,7 +7,7 @@
 pkgname=('vulkan-mesa-layers' 'opencl-mesa' 'vulkan-intel' 'vulkan-radeon' 'vulkan-swrast' 'libva-mesa-driver' 'mesa-vdpau' 'mesa')
 pkgdesc="An open-source implementation of the OpenGL specification"
 pkgver=20.3.4
-pkgrel=2
+pkgrel=3
 arch=('x86_64')
 makedepends=('python-mako' 'libxml2' 'libx11' 'xorgproto' 'libdrm' 'libxshmfence' 'libxxf86vm'
              'libxdamage' 'libvdpau' 'libva' 'wayland' 'wayland-protocols' 'zstd' 'elfutils' 'llvm'
@@ -16,10 +16,12 @@
 url="https://www.mesa3d.org/"
 license=('custom')
 source=(https://mesa.freedesktop.org/archive/mesa-${pkgver}.tar.xz{,.sig}
-        LICENSE)
+        LICENSE
+        0001-vulkan-device_select-Stop-using-device-properties-2.patch)
 sha512sums=('81c4d032213b4aef842f1594e0e89bc0045f7ca7ce5f267b62a0f8236eb12ab09c1f780d8b3776b3072f37cd0bd8829f8a1330a749ccf462471b262ef8097477'
             'SKIP'
-            'f9f0d0ccf166fe6cb684478b6f1e1ab1f2850431c06aa041738563eb1808a004e52cdec823c103c9e180f03ffc083e95974d291353f0220fe52ae6d4897fecc7')
+            'f9f0d0ccf166fe6cb684478b6f1e1ab1f2850431c06aa041738563eb1808a004e52cdec823c103c9e180f03ffc083e95974d291353f0220fe52ae6d4897fecc7'
+            '73a923dac10616ab46b825cd45f73ca849ddad69432dbf680c1129cc9a92004218affa33bd1a6ee185fa0143ccd3d3622ba40512ec049a160a61cc13fe92da0a')
 validpgpkeys=('8703B6700E7EE06D7A39B8D6EDAE37B02CEB490D'  # Emil Velikov <emil.l.velikov at gmail.com>
               '946D09B5E4C9845E63075FF1D961C596A7203456'  # Andres Gomez <tanty at igalia.com>
               'E3E8F480C52ADD73B278EE78E1ECBE07D7D70895'  # Juan Antonio Suárez Romero (Igalia, S.L.) <jasuarez at igalia.com>
@@ -27,6 +29,13 @@
               '71C4B75620BC75708B4BDB254C95FAAB3EB073EC'  # Dylan Baker <dylan at pnwbakers.com>
               '57551DE15B968F6341C248F68D8E31AFC32428A6') # Eric Engestrom <eric at engestrom.ch>
 
+prepare() {
+  cd mesa-$pkgver
+  
+  # FS#69744
+  patch -Np1 -i ../0001-vulkan-device_select-Stop-using-device-properties-2.patch
+}
+
 build() {
   arch-meson mesa-$pkgver build \
     -D b_lto=true \
@@ -152,6 +161,7 @@
 package_libva-mesa-driver() {
   pkgdesc="VA-API implementation for gallium"
   depends=('libdrm' 'libx11' 'llvm-libs' 'expat' 'libelf' 'libxshmfence')
+  depends+=('libexpat.so')
 
   _install fakeinstall/usr/lib/dri/*_drv_video.so
 
@@ -161,6 +171,7 @@
 package_mesa-vdpau() {
   pkgdesc="Mesa VDPAU drivers"
   depends=('libdrm' 'libx11' 'llvm-libs' 'expat' 'libelf' 'libxshmfence')
+  depends+=('libexpat.so')
 
   _install fakeinstall/usr/lib/vdpau
 
@@ -171,6 +182,7 @@
   depends=('libdrm' 'wayland' 'libxxf86vm' 'libxdamage' 'libxshmfence' 'libelf'
            'libomxil-bellagio' 'libunwind' 'llvm-libs' 'lm_sensors' 'libglvnd'
            'zstd' 'vulkan-icd-loader')
+  depends+=('libsensors.so' 'libexpat.so' 'libvulkan.so')
   optdepends=('opengl-man-pages: for the OpenGL API man pages'
               'mesa-vdpau: for accelerated video playback'
               'libva-mesa-driver: for accelerated video playback')



More information about the arch-commits mailing list