<html><head><meta http-equiv="Content-Type" content="text/html; charset=us-ascii"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class=""><div class=""><br class=""></div> I hate these kinds of make rules that hide what the compiler is doing (in the name of having less output, I guess) it makes it difficult to figure out what is going wrong.<div class=""><br class=""></div><div class=""> Anyways, either some of the MPI libraries are missing from the link line or they are in the wrong order and thus it is not able to search them properly. Here is a bunch of discussions on why that error message can appear <a href="https://stackoverflow.com/questions/19901934/libpthread-so-0-error-adding-symbols-dso-missing-from-command-line" class="">https://stackoverflow.com/questions/19901934/libpthread-so-0-error-adding-symbols-dso-missing-from-command-line</a></div><div class=""><br class=""></div><div class=""><br class=""></div><div class=""> Barry</div><div class=""><br class=""><div><br class=""><blockquote type="cite" class=""><div class="">On Oct 7, 2022, at 11:45 PM, Rob Kudyba <<a href="mailto:rk3199@columbia.edu" class="">rk3199@columbia.edu</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class=""><div dir="ltr" class="">The error changes now and at an earlier place, 66% vs 70%:<div class=""><font face="monospace" class="">make LDFLAGS="-Wl,--copy-dt-needed-entries"<br class="">Consolidate compiler generated dependencies of target fmt<br class="">[ 12%] Built target fmt<br class="">Consolidate compiler generated dependencies of target richdem<br class="">[ 37%] Built target richdem<br class="">Consolidate compiler generated dependencies of target wtm<br class="">[ 62%] Built target wtm<br class="">Consolidate compiler generated dependencies of target wtm.x<br class="">[ 66%] Linking CXX executable wtm.x<br class="">/usr/bin/ld: libwtm.a(transient_groundwater.cpp.o): undefined reference to symbol 'MPI_Abort'<br class="">/path/to/openmpi-4.1.1_ucx_cuda_11.0.3_support/lib/libmpi.so.40: error adding symbols: DSO missing from command line<br class="">collect2: error: ld returned 1 exit status<br class="">make[2]: *** [CMakeFiles/wtm.x.dir/build.make:103: wtm.x] Error 1<br class="">make[1]: *** [CMakeFiles/Makefile2:225: CMakeFiles/wtm.x.dir/all] Error 2<br class="">make: *** [Makefile:136: all] Error 2</font><br class=""></div><div class=""><br class=""></div></div>So perhaps PET_Sc is now being found. Any other suggestions?<div class=""><br class=""><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Oct 7, 2022 at 11:18 PM Rob Kudyba <<a href="mailto:rk3199@columbia.edu" class="">rk3199@columbia.edu</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><div dir="ltr" class=""><div dir="ltr" class=""><br class=""></div><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><div dir="ltr" class=""><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><div dir="ltr" class=""><div dir="ltr" class="">Thanks for the quick reply. I added these options to make and make check still produce the warnings so I used the command like this:<div class=""><font face="monospace" class="">make PETSC_DIR=/path/to/petsc PETSC_ARCH=arch-linux-c-debug MPIEXEC="mpiexec -mca orte_base_help_aggregate 0 --mca opal_warn_on_missing_libcuda 0 -mca pml ucx --mca btl '^openib'" check<br class="">Running check examples to verify correct installation<br class="">Using PETSC_DIR=/path/to/petsc and PETSC_ARCH=arch-linux-c-debug<br class="">C/C++ example src/snes/tutorials/ex19 run successfully with 1 MPI process<br class="">C/C++ example src/snes/tutorials/ex19 run successfully with 2 MPI processes<br class="">Completed test examples</font><br class=""></div><div class=""><br class=""></div><div class="">Could be useful for the FAQ.</div></div></div></blockquote><div class="">You mentioned you had "OpenMPI 4.1.1 with CUDA aware", so I think a workable mpicc should automatically find cuda libraries. Maybe you unloaded cuda libraries?</div></div></div></blockquote><div class="">Oh let me clarify, OpenMPI is CUDA aware however this code and the node where PET_Sc is compiling does not have a GPU, hence not needed and using the MPIEXEC option worked during the 'check' to suppress the warning. </div><div class=""><br class=""></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><div dir="ltr" class=""><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><div dir="ltr" class=""><div dir="ltr" class=""><div class="">I'm not trying to use PetSC to compile and linking appears to go awry:</div><div class=""><font face="monospace" class="">[ 58%] Building CXX object CMakeFiles/wtm.dir/src/update_effective_storativity.cpp.o<br class="">[ 62%] Linking CXX static library libwtm.a<br class="">[ 62%] Built target wtm<br class="">[ 66%] Building CXX object CMakeFiles/wtm.x.dir/src/WTM.cpp.o<br class="">[ 70%] Linking CXX executable wtm.x<br class="">/usr/bin/ld: cannot find -lpetsc<br class="">collect2: error: ld returned 1 exit status<br class="">make[2]: *** [CMakeFiles/wtm.x.dir/build.make:103: wtm.x] Error 1<br class="">make[1]: *** [CMakeFiles/Makefile2:269: CMakeFiles/wtm.x.dir/all] Error 2<br class="">make: *** [Makefile:136: all] Error 2</font></div></div></div></blockquote><div class="">It seems cmake could not find petsc. Look at $PETSC_DIR/share/petsc/CMakeLists.txt and try to modify your CMakeLists.txt.</div></div></div></blockquote><div class=""><br class=""></div><div class="">There is an explicit reference to the path in CMakeLists.txt:</div><div class=""><font face="monospace" class=""># NOTE: You may need to update this path to identify PETSc's location<br class="">set(ENV{PKG_CONFIG_PATH} "$ENV{PKG_CONFIG_PATH}:/path/to/petsc/arch-linux-cxx-debug/lib/pkgconfig/")<br class="">pkg_check_modules(PETSC PETSc>=3.17.1 IMPORTED_TARGET REQUIRED)<br class="">message(STATUS "Found PETSc ${PETSC_VERSION}")</font></div><div class=""><font face="monospace" class="">add_subdirectory(common/richdem EXCLUDE_FROM_ALL)<br class="">add_subdirectory(common/fmt EXCLUDE_FROM_ALL)<br class=""></font></div><div class=""> </div><div class="">And that exists:</div><div class=""><font face="monospace" class="">ls /path/to/petsc/arch-linux-cxx-debug/lib/pkgconfig/<br class="">petsc.pc PETSc.pc</font><br class=""></div><div class=""><br class=""></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><div dir="ltr" class=""><div class="gmail_quote"><div class=""> Is there an environment variable I'm missing? I've <a href="https://www.mail-archive.com/search?l=petsc-users@mcs.anl.gov&q=subject:%22%5C%5Bpetsc%5C-users%5C%5D+CMake+error+in+PETSc%22&o=newest&f=1" target="_blank" class="">seen the suggestion</a> to add it to <font face="monospace" class="">LD_LIBRARY_PATH</font> which I did with export <font face="monospace" class="">LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$PETSC_DIR/$PETSC_ARCH/lib</font> and that points to:</div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><div dir="ltr" class=""><div dir="ltr" class=""><div class=""><font face="monospace" class="">ls -l /path/to/petsc/arch-linux-c-debug/lib<br class="">total 83732<br class="">lrwxrwxrwx 1 rk3199 user 18 Oct 7 13:56 libpetsc.so -> libpetsc.so.3.18.0<br class="">lrwxrwxrwx 1 rk3199 user 18 Oct 7 13:56 libpetsc.so.3.18 -> libpetsc.so.3.18.0<br class="">-rwxr-xr-x 1 rk3199 user 85719200 Oct 7 13:56 libpetsc.so.3.18.0<br class="">drwxr-xr-x 3 rk3199 user 4096 Oct 6 10:22 petsc<br class="">drwxr-xr-x 2 rk3199 user 4096 Oct 6 10:23 pkgconfig</font><br class=""></div></div><div class=""><br class=""></div>Anything else to check?</div></blockquote><div class="">If modifying CMakeLists.txt does not work, you can try export <font face="monospace" class="">LIBRARY_PATH=$LIBRARY_PATH:$PETSC_DIR/$PETSC_ARCH/lib</font></div><div class=""><span style="font-family:monospace" class="">LD_LIBRARY_PATH</span>is is for run time, but the error happened at link time, <br class=""></div></div></div></blockquote><div class=""><br class=""></div><div class="">Yes that's what I already had. Any other debug that I can provide?</div><div class=""><br class=""></div><div class=""> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><div dir="ltr" class=""><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"><div dir="ltr" class=""><div class=""><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Oct 7, 2022 at 1:53 PM Satish Balay <<a href="mailto:balay@mcs.anl.gov" target="_blank" class="">balay@mcs.anl.gov</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex">you can try<br class="">
<br class="">
make PETSC_DIR=/path/to/petsc PETSC_ARCH=arch-linux-c-debug MPIEXEC="mpiexec -mca orte_base_help_aggregate 0 --mca opal_warn_on_missing_libcuda 0 -mca pml ucx --mca btl '^openib'"<br class="">
<br class="">
Wrt configure - it can be set with --with-mpiexec option - its saved in PETSC_ARCH/lib/petsc/conf/petscvariables<br class="">
<br class="">
Satish<br class="">
<br class="">
On Fri, 7 Oct 2022, Rob Kudyba wrote:<br class="">
<br class="">
> We are on RHEL 8, using modules that we can load/unload various version of<br class="">
> packages/libraries, and I have OpenMPI 4.1.1 with CUDA aware loaded along<br class="">
> with GDAL 3.3.0, GCC 10.2.0, and cmake 3.22.1<br class="">
> <br class="">
> make PETSC_DIR=/path/to/petsc PETSC_ARCH=arch-linux-c-debug check<br class="">
> fails with the below errors,<br class="">
> Running check examples to verify correct installation<br class="">
> <br class="">
> Using PETSC_DIR=/path/to/petsc and PETSC_ARCH=arch-linux-c-debug<br class="">
> Possible error running C/C++ src/snes/tutorials/ex19 with 1 MPI process<br class="">
> See <a href="https://petsc.org/release/faq/" rel="noreferrer" target="_blank" class="">https://petsc.org/release/faq/</a><br class="">
> --------------------------------------------------------------------------<br class="">
> The library attempted to open the following supporting CUDA libraries,<br class="">
> but each of them failed. CUDA-aware support is disabled.<br class="">
> libcuda.so.1: cannot open shared object file: No such file or directory<br class="">
> libcuda.dylib: cannot open shared object file: No such file or directory<br class="">
> /usr/lib64/libcuda.so.1: cannot open shared object file: No such file or<br class="">
> directory<br class="">
> /usr/lib64/libcuda.dylib: cannot open shared object file: No such file or<br class="">
> directory<br class="">
> If you are not interested in CUDA-aware support, then run with<br class="">
> --mca opal_warn_on_missing_libcuda 0 to suppress this message. If you are<br class="">
> interested<br class="">
> in CUDA-aware support, then try setting LD_LIBRARY_PATH to the location<br class="">
> of libcuda.so.1 to get passed this issue.<br class="">
> --------------------------------------------------------------------------<br class="">
> --------------------------------------------------------------------------<br class="">
> WARNING: There was an error initializing an OpenFabrics device.<br class="">
> <br class="">
> Local host: g117<br class="">
> Local device: mlx5_0<br class="">
> --------------------------------------------------------------------------<br class="">
> lid velocity = 0.0016, prandtl # = 1., grashof # = 1.<br class="">
> Number of SNES iterations = 2<br class="">
> Possible error running C/C++ src/snes/tutorials/ex19 with 2 MPI processes<br class="">
> See <a href="https://petsc.org/release/faq/" rel="noreferrer" target="_blank" class="">https://petsc.org/release/faq/</a><br class="">
> <br class="">
> The library attempted to open the following supporting CUDA libraries,<br class="">
> but each of them failed. CUDA-aware support is disabled.<br class="">
> libcuda.so.1: cannot open shared object file: No such file or directory<br class="">
> libcuda.dylib: cannot open shared object file: No such file or directory<br class="">
> /usr/lib64/libcuda.so.1: cannot open shared object file: No such file or<br class="">
> directory<br class="">
> /usr/lib64/libcuda.dylib: cannot open shared object file: No such file or<br class="">
> directory<br class="">
> If you are not interested in CUDA-aware support, then run with<br class="">
> --mca opal_warn_on_missing_libcuda 0 to suppress this message. If you are<br class="">
> interested in CUDA-aware support, then try setting LD_LIBRARY_PATH to the<br class="">
> locationof libcuda.so.1 to get passed this issue.<br class="">
> <br class="">
> WARNING: There was an error initializing an OpenFabrics device.<br class="">
> <br class="">
> Local host: xxx<br class="">
> Local device: mlx5_0<br class="">
> <br class="">
> lid velocity = 0.0016, prandtl # = 1., grashof # = 1.<br class="">
> Number of SNES iterations = 2<br class="">
> [g117:4162783] 1 more process has sent help message<br class="">
> help-mpi-common-cuda.txt / dlopen failed<br class="">
> [g117:4162783] Set MCA parameter "orte_base_help_aggregate" to 0 to see all<br class="">
> help / error messages<br class="">
> [g117:4162783] 1 more process has sent help message help-mpi-btl-openib.txt<br class="">
> / error in device init<br class="">
> Completed test examples<br class="">
> Error while running make check<br class="">
> gmake[1]: *** [makefile:149: check] Error 1<br class="">
> make: *** [GNUmakefile:17: check] Error 2<br class="">
> <br class="">
> Where is $MPI_RUN set? I'd like to be able to pass options such as --mca<br class="">
> orte_base_help_aggregate 0 --mca opal_warn_on_missing_libcuda 0 -mca pml<br class="">
> ucx --mca btl '^openib' which will help me troubleshoot and hide unneeded<br class="">
> warnings.<br class="">
> <br class="">
> Thanks,<br class="">
> Rob<br class="">
> <br class="">
<br class="">
</blockquote></div></div></div>
</blockquote></div></div>
</blockquote></div></div>
</blockquote></div></div></div>
</div></blockquote></div><br class=""></div></body></html>