Skip to content
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

[flang][regression] Can't build flang. Incorrect dependencies specified for libFIROpenACCSupport.so? #123377

Closed
pawosm-arm opened this issue Jan 17, 2025 · 9 comments · Fixed by #123784
Assignees
Labels
build-problem flang Flang issues not falling into any other category

Comments

@pawosm-arm
Copy link
Contributor

I'm configuring the build as such:

cmake /path/to/llvm \
-DBUILD_SHARED_LIBS=True \
-DCMAKE_BUILD_TYPE=Debug \
-DLLVM_BINUTILS_INCDIR=/usr/include \
-DLIBOMP_FORTRAN_MODULES=True \
-DLIBOMP_COPY_EXPORTS=False \
-DLIBOMP_USE_HWLOC=False \
-DLIBOMP_OMPT_SUPPORT=ON \
-DLLVM_ENABLE_LLD=True \
-DLLVM_ENABLE_FFI=False \
-DLLVM_TARGETS_TO_BUILD="AArch64" \
-DLLVM_ENABLE_PROJECTS="llvm;clang;flang" \
-DLLVM_ENABLE_RUNTIMES="compiler-rt;openmp" \
-DCMAKE_INSTALL_PREFIX=/some/prefix

Since this machine has somewhat limited resources, I'm running 12 build processes only. The build fails as such:

[ 98%] Building CXX object tools/flang/lib/Optimizer/Transforms/CMakeFiles/FIRTransforms.dir/PolymorphicOpConversion.cpp.o
ld.lld: error: undefined symbol: Fortran::evaluate::ProcedureRef::~ProcedureRef()
>>> referenced by call.h:282 (flang/include/flang/Evaluate/call.h:282)
>>>               CMakeFiles/FIROpenACCSupport.dir/FIROpenACCTypeInterfaces.cpp.o:(Fortran::evaluate::FunctionRef<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 1> >::~FunctionRef())
>>> referenced by call.h:282 (flang/include/flang/Evaluate/call.h:282)
>>>               CMakeFiles/FIROpenACCSupport.dir/FIROpenACCTypeInterfaces.cpp.o:(Fortran::evaluate::FunctionRef<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 2> >::~FunctionRef())
>>> referenced by call.h:282 (flang/include/flang/Evaluate/call.h:282)
>>>               CMakeFiles/FIROpenACCSupport.dir/FIROpenACCTypeInterfaces.cpp.o:(Fortran::evaluate::FunctionRef<Fortran::evaluate::Type<(Fortran::common::TypeCategory)0, 4> >::~FunctionRef())
>>> referenced 19 more times
@llvmbot llvmbot added the flang Flang issues not falling into any other category label Jan 17, 2025
@pawosm-arm pawosm-arm changed the title [flang] Can't build flang. Incorrect dependencies specified for libFIROpenACCSupport.so? [flang][regression] Can't build flang. Incorrect dependencies specified for libFIROpenACCSupport.so? Jan 18, 2025
@pawosm-arm
Copy link
Contributor Author

pawosm-arm commented Jan 18, 2025

I've verified that I can build flang from before this commit: #122495 so this is a regression.

@thesamesam
Copy link
Member

cc @mgorny

@mgorny
Copy link
Member

mgorny commented Jan 18, 2025

I'm confused now. Did you bisect it to #120966 or #122495?

@pawosm-arm
Copy link
Contributor Author

pawosm-arm commented Jan 18, 2025

@mgorny I didn't bisect it, it would take more time than I have for it today. I've confirmed that I can build flang from one commit before the one which introduced the problematic file into flang, later on I've found your commit which changes the way dependencies are specified

@mgorny
Copy link
Member

mgorny commented Jan 18, 2025

I'm building LLVM again today, so I'll try reproducing with a fresh ccache.

@pawosm-arm
Copy link
Contributor Author

pawosm-arm commented Jan 18, 2025

@mgorny seems it happens with the commit just before yours too, so again the last known 'good' commit was the one before #122495 and apparently your change despite touching the same files was not the root cause of this regression.

@mgorny
Copy link
Member

mgorny commented Jan 18, 2025

I'm guessing that you're hitting the problem because of -DBUILD_SHARED_LIBS=True which isn't really well-tested. In fact, I thought it used not to work with Flang, but that was a long time ago.

@pawosm-arm
Copy link
Contributor Author

Must have been a very long time ago indeed as for many reasons I'm building it like that for as long as I remember. The problem of wrongly specified dependencies returns from time to time, but usually the patches were released fairly promptly.

@mgorny
Copy link
Member

mgorny commented Jan 18, 2025

Sorry, I recalled wrong. It was LLDB that caused problems, because its libraries used to have lots of cyclic dependencies. I used shared libs myself for a long time. My guess would be that some target is missing a direct dependency.

@jeanPerier jeanPerier self-assigned this Jan 21, 2025
github-actions bot pushed a commit to arm/arm-toolchain that referenced this issue Jan 21, 2025
…passes (#123784)

Move OpenACC/OpenMP helpers from Lower/DirectivesCommon.h that are also
used in OpenACC and OpenMP mlir passes into a new
Optimizer/Builder/DirectivesCommon.h so that parser and evaluate headers
are not included in Optimizer libraries (this both introduce
compile-time and link-time pointless overheads).

This should fix llvm/llvm-project#123377
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
build-problem flang Flang issues not falling into any other category
Projects
None yet
Development

Successfully merging a pull request may close this issue.

6 participants