Skip to content
This repository has been archived by the owner on May 14, 2024. It is now read-only.

Ensure Clang/LLVM symbols are exposed for plugins #43

Closed
wants to merge 1 commit into from

Conversation

wsmoses
Copy link

@wsmoses wsmoses commented Mar 18, 2022

Ideally should also be forward/backported to other relevant ROCM versions.

HIPRtc currently does not correctly support LLVM plugins. Specifically, symbols defined within LLVM and/or clang are not available by any plugins when they are loaded. This is partially due to the fact that the one location with these symbols (libamd_comgr) does not mark these symbols as being available globally when it is loaded.

This patch is the second of two pieces required to support LLVM plugins on ROCm, the first of which is a change to mark libamd_comgr as having its symbols loaded globally (ROCm/ROCclr#32).

Specifically, successfully exporting these symbols will result in the following (note the capital T) when built:

wsmoses@noether:~/rocm/ROCm-CompilerSupport/lib/comgr/build$ nm libamd_comgr.so.2.4 | grep _ZN4llvm2cl18GenericOptionValue6anchorEv
0000000005677990 T _ZN4llvm2cl18GenericOptionValue6anchorEv
0000000005677990 t _ZN4llvm2cl18GenericOptionValue6anchorEv.localalias.28

cc @jedbrown @LeilaGhaffari

@searlmc1
Copy link
Collaborator

searlmc1 commented Apr 11, 2022

Adding @b-sumner

@aaronmondal
Copy link

How would this affect downstream targets that also link LLVM? Our custom comgr build files here and our rocclr buildfiles here currently "blindly" link the entire LLVM.

When trying to integrate the OpenSYCL plugins into our toolchains I encountered curious issues because the new-style passmanager plugins didn't work correctly (AdaptiveCpp/AdaptiveCpp#766). Do these two patches address such issues or am I misunderstanding something?

Linking the whole-archive llvm libs would make comgr gigantic right? Is this really necessary or would it be possible to keep only relevant plugin-related symbols from LLVM?

@lamb-j
Copy link
Collaborator

lamb-j commented Nov 15, 2023

After some discussion, we decided against incorporating this PR. This would require Comgr to make symbols outside its documented API public. We can't immediately expose LLVM symbols in the Comgr DSO because users of Comgr may use other projects that expose LLVM symbols, and because it falls outside the intended role/scope of Comgr.

Some alternatives would be to upstream the desired plugin, or to do a custom build of Comgr/Rocm with this type of patch applied.

@lamb-j lamb-j closed this Nov 15, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants