From fc32fdcda52bca6244d26d8c79e45bb20b448500 Mon Sep 17 00:00:00 2001 From: Laszlo Agocs Date: Wed, 9 Mar 2022 15:21:32 +0100 Subject: vulkan: Try loading libvulkan.so.1 first Change-Id: I876899fbfc126136f2842e9361e21ac10af8f14b Fixes: QTBUG-101592 Reviewed-by: Andy Nichols (cherry picked from commit 888b75aa12e2cf35ee760bcf5cb1ed60fe0c0770) Reviewed-by: Qt Cherry-pick Bot --- src/gui/vulkan/qbasicvulkanplatforminstance.cpp | 40 ++++++++++++++++++++----- src/gui/vulkan/qbasicvulkanplatforminstance_p.h | 4 +-- 2 files changed, 35 insertions(+), 9 deletions(-) (limited to 'src/gui/vulkan') diff --git a/src/gui/vulkan/qbasicvulkanplatforminstance.cpp b/src/gui/vulkan/qbasicvulkanplatforminstance.cpp index 233f884ce6..dd39f71ba0 100644 --- a/src/gui/vulkan/qbasicvulkanplatforminstance.cpp +++ b/src/gui/vulkan/qbasicvulkanplatforminstance.cpp @@ -81,19 +81,45 @@ QBasicPlatformVulkanInstance::~QBasicPlatformVulkanInstance() m_vkDestroyInstance(m_vkInst, nullptr); } -void QBasicPlatformVulkanInstance::loadVulkanLibrary(const QString &defaultLibraryName) +void QBasicPlatformVulkanInstance::loadVulkanLibrary(const QString &defaultLibraryName, int defaultLibraryVersion) { + QVarLengthArray, 3> loadList; + + // First in the list of libraries to try is the manual override, relevant on + // embedded systems without a Vulkan loader and possibly with custom vendor + // library names. if (qEnvironmentVariableIsSet("QT_VULKAN_LIB")) - m_vulkanLib.setFileName(QString::fromUtf8(qgetenv("QT_VULKAN_LIB"))); - else - m_vulkanLib.setFileName(defaultLibraryName); + loadList.append({ QString::fromUtf8(qgetenv("QT_VULKAN_LIB")), -1 }); + + // Then what the platform specified. On Linux the version is likely 1, thus + // preferring libvulkan.so.1 over libvulkan.so. + loadList.append({ defaultLibraryName, defaultLibraryVersion }); + + // If there was a version given, we must still try without it if the first + // attempt fails, so that libvulkan.so is picked up if the .so.1 is not + // present on the system (so loaderless embedded systems still work). + if (defaultLibraryVersion >= 0) + loadList.append({ defaultLibraryName, -1 }); + + bool ok = false; + for (const auto &lib : loadList) { + m_vulkanLib.reset(new QLibrary); + if (lib.second >= 0) + m_vulkanLib->setFileNameAndVersion(lib.first, lib.second); + else + m_vulkanLib->setFileName(lib.first); + if (m_vulkanLib->load()) { + ok = true; + break; + } + } - if (!m_vulkanLib.load()) { - qWarning("Failed to load %s: %s", qPrintable(m_vulkanLib.fileName()), qPrintable(m_vulkanLib.errorString())); + if (!ok) { + qWarning("Failed to load %s: %s", qPrintable(m_vulkanLib->fileName()), qPrintable(m_vulkanLib->errorString())); return; } - init(&m_vulkanLib); + init(m_vulkanLib.get()); } void QBasicPlatformVulkanInstance::init(QLibrary *lib) diff --git a/src/gui/vulkan/qbasicvulkanplatforminstance_p.h b/src/gui/vulkan/qbasicvulkanplatforminstance_p.h index 2391452f03..fe8bf48cae 100644 --- a/src/gui/vulkan/qbasicvulkanplatforminstance_p.h +++ b/src/gui/vulkan/qbasicvulkanplatforminstance_p.h @@ -80,7 +80,7 @@ public: const QList *debugFilters() const { return &m_debugFilters; } protected: - void loadVulkanLibrary(const QString &defaultLibraryName); + void loadVulkanLibrary(const QString &defaultLibraryName, int defaultLibraryVersion = -1); void init(QLibrary *lib); void initInstance(QVulkanInstance *instance, const QByteArrayList &extraExts); @@ -92,7 +92,7 @@ protected: private: void setupDebugOutput(); - QLibrary m_vulkanLib; + std::unique_ptr m_vulkanLib; bool m_ownsVkInst; VkResult m_errorCode; -- cgit v1.2.3