-
Notifications
You must be signed in to change notification settings - Fork 172
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Bug]: Poor default Tensile_COMPILER on Linux #1525
Comments
@trixirt for 6.2 it was hipcc without path verification. In both cases (hipcc and now amdclang++) an OS stock c++ compiler is not supported for hip device code. I agree we can consider compiler specification outside of Tensile_COMPILER variable, but detection should be done in the Tensile component. If the path pointed before to include hipcc it should also find amdclang++. Please provide your error messages as will discuss with Tensile how to work around your build issues. Provide your PATH variable and other relevant information. |
We are moving away from hipcc. Once it is removed from tensile, the only compiler that we will support on linux is amdclang++. Perhaps I am missing a use case here so please provide more detail. If |
On Fedora, the complier used for rocm is not called amdclang++, it is either hipcc or clang++. hipcc is in the normal PATH, so we were getting lucky in 6.2. In either case on 6.2 or 6.3, there is no checking that the default compiler is in the PATH. I am working around this by setting -DTensile_COMPILER= at configure time. I would expect the Tensile_COMPILER to be checked in the same manner as the CMAKE_CXX_COMPILER, failing a configure time, not during the build. |
@trixirt can you provide a minimal docker file to reproduce your environment and the command you are running to build rocBLAS. |
Well can Fedora add the amdclang++ as an symlink to their ROCm llvm toolchain to match supported toolchain status. If we want to pass along our rocblas CMAKE_CXX_COMPILER it would still need amdclang++ . We could consider even removing that tensile variable from the build command and leave Tensile to determine it's own via cmake vars and env overrides. It was required to be when we switched to amdclang++ in rocblas but Tensile was still stuck using deprecated hipcc. Is all hipcc removed now in Tensile? I thought that still had pending changes. Fedora likely needs to add the workaround as 6.3 is released, for 6.4 maybe we can change. |
A better default for the Tensile_COMPILER would be the CMAKE_CXX_COMPILER. hipcc is still shipped with 6.3, I would expect folks to use it until it is removed completely. When will this happen ? |
rocBLAS for 6.3 should be built by default with amdclang++ as set in the toolchain-linux.cmake file. Using a different compiler with potentially different defaults is not advised. |
Hmm only pearl hipcc was communicated as deprecated, together with all the other pearl tools like the old hipify implementation. As far as i am aware the deprecation of the c++ implementation at https://github.com/ROCm/llvm-project/tree/amd-staging/amd/hipcc has not been communicated publicly. The readme of hipcc also only mentions replaceing the deprecated pearl implementation. If the new c++ implementation of hipcc is also intended to be deprecated this is something that should be better communicated. |
Will see if any compiler people chime in here, so maybe only the perl version was officially deprecated. It is no longer the default for building rocBLAS with ROCm 6.3 and later. As the behaviours (e.g. default flags) are not guaranteed to match you may diverge from what is in our tested build. |
This option sets the Tensile_COMPILER on Linux
https://github.com/ROCm/rocBLAS/blob/develop/cmake/build-options.cmake#L78
No checking is made if amdclang++ is in the PATH.
clang++ or hipcc or whatever the user passed in as the CMAKE_CXX_COMPILER would have been a better choice. On most Linux distros, there is no amdclang++.
Found on Fedora Rawhide while updating to 6.3
The text was updated successfully, but these errors were encountered: