diff options
-rw-r--r-- | graphics/libplacebo/glslang.patch | 18 | ||||
-rw-r--r-- | graphics/libplacebo/libplacebo.SlackBuild | 10 | ||||
-rw-r--r-- | graphics/libplacebo/libplacebo.info | 6 | ||||
-rw-r--r-- | graphics/libplacebo/vulkan.patch | 59 |
4 files changed, 89 insertions, 4 deletions
diff --git a/graphics/libplacebo/glslang.patch b/graphics/libplacebo/glslang.patch new file mode 100644 index 0000000000000..cfeb61bf4ec73 --- /dev/null +++ b/graphics/libplacebo/glslang.patch @@ -0,0 +1,18 @@ +commit 87e11a7e57ec734059924e192656fc70d1ce3f50 +Author: orbea <orbea@riseup.net> +Date: Mon Jun 8 10:29:26 2020 -0700 + + Fix build with newer glslang. + +diff --git a/src/glsl/glslang.cc b/src/glsl/glslang.cc +index 5546120..07cf8f1 100644 +--- a/src/glsl/glslang.cc ++++ b/src/glsl/glslang.cc +@@ -210,6 +210,7 @@ const TBuiltInResource DefaultTBuiltInResource = { + /* .maxTaskWorkGroupSizeY_NV = */ 1, + /* .maxTaskWorkGroupSizeZ_NV = */ 1, + /* .maxMeshViewCountNV = */ 4, ++ /* .maxDualSourceDrawBuffersEXT = */ 1, + #endif + + /* .limits = */ { diff --git a/graphics/libplacebo/libplacebo.SlackBuild b/graphics/libplacebo/libplacebo.SlackBuild index d15c8a61322b7..64f78d87820bd 100644 --- a/graphics/libplacebo/libplacebo.SlackBuild +++ b/graphics/libplacebo/libplacebo.SlackBuild @@ -23,7 +23,7 @@ # ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. PRGNAM=libplacebo -VERSION=${VERSION:-1.29.1} +VERSION=${VERSION:-2.43.1} BUILD=${BUILD:-1} TAG=${TAG:-_SBo} @@ -78,6 +78,14 @@ else RELEASE=plain fi +# Fix the build with newer glslang versions. +patch -p1 < $CWD/glslang.patch + +# vulkan: get rid of deprecated enum members +# https://code.videolan.org/videolan/libplacebo/-/issues/71 +# https://code.videolan.org/videolan/libplacebo/-/commit/45e19e7bbbbfceb197d8826c775e16ef536a4565 +patch -p1 < $CWD/vulkan.patch + CFLAGS="$SLKCFLAGS" \ CXXFLAGS="$SLKCFLAGS" \ meson \ diff --git a/graphics/libplacebo/libplacebo.info b/graphics/libplacebo/libplacebo.info index 2fd1e1161590c..fe87940ce7125 100644 --- a/graphics/libplacebo/libplacebo.info +++ b/graphics/libplacebo/libplacebo.info @@ -1,8 +1,8 @@ PRGNAM="libplacebo" -VERSION="1.29.1" +VERSION="2.43.1" HOMEPAGE="https://code.videolan.org/videolan/libplacebo" -DOWNLOAD="https://code.videolan.org/videolan/libplacebo/-/archive/v1.29.1/libplacebo-v1.29.1.tar.gz" -MD5SUM="07815068c92280858a073400f5b6837d" +DOWNLOAD="https://code.videolan.org/videolan/libplacebo/-/archive/v2.43.1/libplacebo-v2.43.1.tar.gz" +MD5SUM="2d9cad6e8155eccaed6e612520a20793" DOWNLOAD_x86_64="" MD5SUM_x86_64="" REQUIRES="meson vulkan-sdk" diff --git a/graphics/libplacebo/vulkan.patch b/graphics/libplacebo/vulkan.patch new file mode 100644 index 0000000000000..4d424ae310738 --- /dev/null +++ b/graphics/libplacebo/vulkan.patch @@ -0,0 +1,59 @@ +From 45e19e7bbbbfceb197d8826c775e16ef536a4565 Mon Sep 17 00:00:00 2001 +From: Niklas Haas <git@haasn.xyz> +Date: Tue, 5 May 2020 00:13:49 +0200 +Subject: [PATCH] vulkan: get rid of deprecated enum members + +Maybe we should just get rid of the switch coverage check altogether. I +wish we could somehow differentiate between enums defined in our code +and enums defined externally. + +Fixes #71. +--- + src/vulkan/context.c | 4 +++- + src/vulkan/swapchain.c | 7 +------ + 2 files changed, 4 insertions(+), 7 deletions(-) + +diff --git a/src/vulkan/context.c b/src/vulkan/context.c +index 10928a9..14a57cf 100644 +--- a/src/vulkan/context.c ++++ b/src/vulkan/context.c +@@ -685,7 +685,6 @@ VkPhysicalDevice pl_vulkan_choose_device(struct pl_context *ctx, + [VK_PHYSICAL_DEVICE_TYPE_VIRTUAL_GPU] = {"virtual", 3}, + [VK_PHYSICAL_DEVICE_TYPE_CPU] = {"software", 2}, + [VK_PHYSICAL_DEVICE_TYPE_OTHER] = {"other", 1}, +- [VK_PHYSICAL_DEVICE_TYPE_END_RANGE+1] = {0}, + }; + + int best = 0; +@@ -693,6 +692,9 @@ VkPhysicalDevice pl_vulkan_choose_device(struct pl_context *ctx, + VkPhysicalDeviceProperties props = {0}; + GetPhysicalDeviceProperties(devices[i], &props); + VkPhysicalDeviceType t = props.deviceType; ++ if (t > PL_ARRAY_SIZE(types)) ++ continue; ++ + PL_INFO(vk, " GPU %d: %s (%s)", i, props.deviceName, types[t].name); + + if (params->surface) { +diff --git a/src/vulkan/swapchain.c b/src/vulkan/swapchain.c +index bf6fd54..6bf40dd 100644 +--- a/src/vulkan/swapchain.c ++++ b/src/vulkan/swapchain.c +@@ -138,13 +138,8 @@ static bool vk_map_color_space(VkColorSpaceKHR space, struct pl_color_space *out + return false; + #endif + +- // Included to satisfy the switch coverage check +- case VK_COLOR_SPACE_RANGE_SIZE_KHR: +- case VK_COLOR_SPACE_MAX_ENUM_KHR: +- break; ++ default: return false; + } +- +- return false; + } + + static bool pick_surf_format(const struct pl_gpu *gpu, const struct vk_ctx *vk, +-- +2.26.2 + |