Mesa (master): radv: restrict exported symbols with static llvm
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Wed Aug 19 11:32:56 UTC 2020
Module: Mesa
Branch: master
Commit: 41bb6459d3a7dba21ff811069dc4757d7789fd12
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=41bb6459d3a7dba21ff811069dc4757d7789fd12
Author: Emil Velikov <emil.velikov at collabora.com>
Date: Thu Aug 6 09:14:07 2020 +0100
radv: restrict exported symbols with static llvm
Like the gallium --version-script magic but for radv.
The long term goal is to make LLVM support optional, remove it even, so
let's keep the hunk in an if block.
v2: fold if checks (Eric)
v3 (Tomeu): Remove spaces within [] (Dylan)
Signed-off-by: Emil Velikov <emil.velikov at collabora.com>
Signed-off-by: Tomeu Vizoso <tomeu.vizoso at collabora.com>
Reviewed-by: Bas Nieuwenhuizen <bas at basnieuwenhuizen.nl> (v1)
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/6203>
---
src/amd/vulkan/meson.build | 15 ++++++++++++++-
src/amd/vulkan/vulkan.sym | 11 +++++++++++
2 files changed, 25 insertions(+), 1 deletion(-)
diff --git a/src/amd/vulkan/meson.build b/src/amd/vulkan/meson.build
index 907e45cc0e7..d1557799671 100644
--- a/src/amd/vulkan/meson.build
+++ b/src/amd/vulkan/meson.build
@@ -148,6 +148,16 @@ if with_platform_android
]
endif
+# When static linking LLVM, all its symbols are public API.
+# That may cause symbol collision, so explicitly demote everything.
+libvulkan_radeon_ld_args = []
+libvulkan_radeon_link_depends = []
+
+if with_llvm and with_ld_version_script
+ libvulkan_radeon_ld_args += ['-Wl,--version-script', join_paths(meson.current_source_dir(), 'vulkan.sym')]
+ libvulkan_radeon_link_depends += files('vulkan.sym')
+endif
+
libvulkan_radeon = shared_library(
'vulkan_radeon',
[libradv_files, radv_entrypoints, radv_extensions_c, amd_vk_format_table_c, sha1_h],
@@ -164,7 +174,10 @@ libvulkan_radeon = shared_library(
],
c_args : [no_override_init_args, radv_flags],
cpp_args : [radv_flags],
- link_args : [ld_args_build_id, ld_args_bsymbolic, ld_args_gc_sections],
+ link_args : [
+ ld_args_build_id, ld_args_bsymbolic, ld_args_gc_sections, libvulkan_radeon_ld_args,
+ ],
+ link_depends : [libvulkan_radeon_link_depends,],
gnu_symbol_visibility : 'hidden',
install : true,
)
diff --git a/src/amd/vulkan/vulkan.sym b/src/amd/vulkan/vulkan.sym
new file mode 100644
index 00000000000..c85a22e905a
--- /dev/null
+++ b/src/amd/vulkan/vulkan.sym
@@ -0,0 +1,11 @@
+{
+ global:
+ vk_icdGetInstanceProcAddr;
+ vk_icdGetPhysicalDeviceProcAddr;
+ vk_icdNegotiateLoaderICDInterfaceVersion;
+
+ local:
+ # When static linking LLVM, all its symbols are public API.
+ # That may cause symbol collision, so explicitly demote everything.
+ *;
+};
More information about the mesa-commit
mailing list