[petsc-dev] (arm64) could not find object file symbol for symbol ___muldc3
Barry Smith
bsmith at petsc.dev
Wed Apr 7 11:29:45 CDT 2021
Ok, thanks. I am not sure how to handle it. libgcc_s.1.dylib never appears in the configure process and we don't actually test that the Fortran compiler can link C; for 25 years it just always could.
Barry
> On Apr 7, 2021, at 10:49 AM, Blaise A Bourdin <bourdin at lsu.edu> wrote:
>
> No luck with -lgcc but it looks like this symbol is defined in
> /usr/local/Cellar/gcc/10.2.0_4/lib/gcc/10/libgcc_s.1.dylib
> 00000000000039b0 T ___muldc3
>
> So adding -lgcc_s.1 eliminates the warning.
> I assume that the issue is with gcc-10 on macOS ARM. I can try to report it to upstream to although building a small test may be a bit challenging.
>
> Regards,
> Blaise
>
>> On Apr 6, 2021, at 5:32 PM, Barry Smith <bsmith at petsc.dev <mailto:bsmith at petsc.dev>> wrote:
>>
>>
>> Blaise,
>>
>> Thanks, can you try cd src/snes/tutorials and then cut and paste the huge line that you sent earlier that begins with mpif90 -Wl,-bind_at_load ..... and add at the end -lgcc and see if that line successfully links the Fortran code?
>>
>> Thanks
>>
>> Barry
>>
>>
>>
>>> On Apr 6, 2021, at 12:22 PM, Blaise A Bourdin <bourdin at lsu.edu <mailto:bourdin at lsu.edu>> wrote:
>>>
>>> Hi Barry,
>>>
>>>>
>>>> Please send configure.log
>>> See attached
>>>
>>>>
>>>> It would also be helpful if you could run
>>>>
>>>> nm -o /usr/lib/lib* | grep muldc3
>>>
>>> That is uneventful (I have no idea how these broken symbolic link got there and can’t delete them because of SIP)…
>>> SiMini:lib $ nm -o /usr/lib/lib* | grep muldc3
>>> /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/nm: error: /usr/lib/libhunspell-1.2.0.dylib: No such file or directory.
>>> /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/nm: error: /usr/lib/libhunspell-1.2.dylib: No such file or directory.
>>> /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/nm: error: /usr/lib/libiodbc.2.dylib: No such file or directory.
>>> /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/nm: error: /usr/lib/libiodbc.dylib: No such file or directory.
>>> /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/nm: error: /usr/lib/libiodbcinst.2.dylib: No such file or directory.
>>> /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/nm: error: /usr/lib/libiodbcinst.dylib: No such file or directory.
>>> /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/nm: error: /usr/lib/libstdc++.6.dylib: No such file or directory.
>>> /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/nm: error: /usr/lib/libstdc++.dylib: No such file or directory.
>>>
>>> Blaise
>>>
>>>
>>>
>>>>
>>>> Our cross language linker tests are not adding all the libraries they need to add when using Fortran for linking.
>>>>
>>>> Barry
>>>>
>>>>
>>>>
>>>>> On Apr 6, 2021, at 11:00 AM, Matthew Knepley <knepley at gmail.com <mailto:knepley at gmail.com>> wrote:
>>>>>
>>>>> On Tue, Apr 6, 2021 at 11:04 AM Blaise A Bourdin <bourdin at lsu.edu <mailto:bourdin at lsu.edu>> wrote:
>>>>> Hi,
>>>>>
>>>>> I am having the following warning when compiling any fortran example (currently on main, but it’s been going on for a little while) on a ARM mac.
>>>>>
>>>>>
>>>>> *******************Error detected during compile or link!*******************
>>>>> See http://www.mcs.anl.gov/petsc/documentation/faq.html <https://nam04.safelinks.protection.outlook.com/?url=http%3A%2F%2Fwww.mcs.anl.gov%2Fpetsc%2Fdocumentation%2Ffaq.html&data=04%7C01%7Cbourdin%40lsu.edu%7C7df7aff43faa4aa853dc08d8f94bd292%7C2d4dad3f50ae47d983a09ae2b1f466f8%7C0%7C0%7C637533451348637504%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&sdata=afb7L7ous6bquDeChU2Gx9Oxu19C4F7Qo9gaATzs0q4%3D&reserved=0>
>>>>> /opt/HPC/petsc-main/src/snes/tutorials ex5f
>>>>> *********************************************************
>>>>> mpif90 -Wl,-bind_at_load -Wl,-multiply_defined,suppress -Wl,-multiply_defined -Wl,suppress -Wl,-commons,use_dylibs -Wl,-search_paths_first -Wl,-no_compact_unwind -ffree-line-length-none -fallow-argument-mismatch -fPIC -g -ffree-line-length-none -fallow-argument-mismatch -fPIC -g -I/opt/HPC/petsc-main/include -I/opt/HPC/petsc-main/bigsur-gcc10.2-arm64-reallybasic-g/include -I/opt/X11/include ex5f.F90 -Wl,-rpath,/opt/HPC/petsc-main/bigsur-gcc10.2-arm64-reallybasic-g/lib -L/opt/HPC/petsc-main/bigsur-gcc10.2-arm64-reallybasic-g/lib -Wl,-rpath,/opt/X11/lib -L/opt/X11/lib -Wl,-rpath,/opt/homebrew/Cellar/mpich/3.4.1_2/lib -L/opt/homebrew/Cellar/mpich/3.4.1_2/lib -Wl,-rpath,/opt/homebrew/Cellar/gcc/10.2.0_4/lib/gcc/10/gcc/aarch64-apple-darwin20/10.2.1 -L/opt/homebrew/Cellar/gcc/10.2.0_4/lib/gcc/10/gcc/aarch64-apple-darwin20/10.2.1 -Wl,-rpath,/opt/homebrew/Cellar/gcc/10.2.0_4/lib/gcc/10 -L/opt/homebrew/Cellar/gcc/10.2.0_4/lib/gcc/10 -lpetsc -llapack -lblas -lX11 -lc++ -ldl -lmpifort -lmpi -lpmpi -lgfortran -lemutls_w -lm -lc++ -ldl -o ex5f
>>>>> warning: (arm64) could not find object file symbol for symbol muldc3
>>>>> Fortran example src/snes/tutorials/ex5f run successfully with 1 MPI process
>>>>>
>>>>>
>>>>> For reference, here is how I configured petsc:
>>>>> ./configure --CFLAGS='-Wimplicit-function-declaration' --FFLAGS="-ffree-line-length-none -fallow-argument-mismatch" --with-debugging=1 --with-shared-libraries=1 --with-x11=1
>>>>>
>>>>> It looks like this symbol is referenced in: sfpack.o
>>>>>
>>>>> SiMini:petsc-main (main)$ grep -ri muldc3 bigsur-gcc10.2-arm64-reallybasic-g/*
>>>>> Binary file bigsur-gcc10.2-arm64-reallybasic-g/lib/libpetsc.3.015.0.dylib matches
>>>>> Binary file bigsur-gcc10.2-arm64-reallybasic-g/lib/libpetsc.3.015.dylib matches
>>>>> bigsur-gcc10.2-arm64-reallybasic-g/lib/petsc/conf/check.log:warning: (arm64) could not find object file symbol for symbol ___muldc3
>>>>> Binary file bigsur-gcc10.2-arm64-reallybasic-g/lib/libpetsc.dylib matches
>>>>> Binary file bigsur-gcc10.2-arm64-reallybasic-g/obj/vec/is/sf/impls/basic/sfpack.o matches
>>>>>
>>>>> SiMini:petsc-main (main)$ nm bigsur-gcc10.2-arm64-reallybasic-g/obj/vec/is/sf/impls/basic/sfpack.o | grep muldc3
>>>>> U ___muldc3
>>>>>
>>>>> Google tells me it is a gcc thing for complex multiplication. Ah, I think this is the problem:
>>>>>
>>>>> https://lists.mcs.anl.gov/pipermail/mpich-discuss/2012-August/012920.html <https://nam04.safelinks.protection.outlook.com/?url=https%3A%2F%2Flists.mcs.anl.gov%2Fpipermail%2Fmpich-discuss%2F2012-August%2F012920.html&data=04%7C01%7Cbourdin%40lsu.edu%7C7df7aff43faa4aa853dc08d8f94bd292%7C2d4dad3f50ae47d983a09ae2b1f466f8%7C0%7C0%7C637533451348642492%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&sdata=YS2BBoI%2BhyomGpXKxA%2Fzpy%2FeA9r5smQnAq2ALrPGQ9s%3D&reserved=0>
>>>>>
>>>>> It is in the C library and you are linking from Fortran, so the compatibility libraries are not correct.
>>>>>
>>>>> Thanks,
>>>>>
>>>>> Matt
>>>>>
>>>>> Any idea?
>>>>> Blaise
>>>>>
>>>>>
>>>>> --
>>>>> A.K. & Shirley Barton Professor of Mathematics
>>>>> Adjunct Professor of Mechanical Engineering
>>>>> Adjunct of the Center for Computation & Technology
>>>>> Louisiana State University, Lockett Hall Room 344, Baton Rouge, LA 70803, USA
>>>>> Tel. +1 (225) 578 1612, Fax +1 (225) 578 4276 Web http://www.math.lsu.edu/~bourdin <http://www.math.lsu.edu/~bourdin>
>>>>>
>>>>>
>>>>> --
>>>>> What most experimenters take for granted before they begin their experiments is infinitely more interesting than any results to which their experiments lead.
>>>>> -- Norbert Wiener
>>>>>
>>>>> https://www.cse.buffalo.edu/~knepley/ <https://nam04.safelinks.protection.outlook.com/?url=http:%2F%2Fwww.cse.buffalo.edu%2F~knepley%2F&data=04%7C01%7Cbourdin%40lsu.edu%7C7df7aff43faa4aa853dc08d8f94bd292%7C2d4dad3f50ae47d983a09ae2b1f466f8%7C0%7C0%7C637533451348647483%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&sdata=LgObsaA9qG7xidNGs2%2Ft38SnC5thdvzOd6WHpS0ivcQ%3D&reserved=0>
>>>>
>>>
>>> --
>>> A.K. & Shirley Barton Professor of Mathematics
>>> Adjunct Professor of Mechanical Engineering
>>> Adjunct of the Center for Computation & Technology
>>> Louisiana State University, Lockett Hall Room 344, Baton Rouge, LA 70803, USA
>>> Tel. +1 (225) 578 1612, Fax +1 (225) 578 4276 Web http://www.math.lsu.edu/~bourdin <http://www.math.lsu.edu/~bourdin>
>>> <configure.log>
>>
>
> --
> A.K. & Shirley Barton Professor of Mathematics
> Adjunct Professor of Mechanical Engineering
> Adjunct of the Center for Computation & Technology
> Louisiana State University, Lockett Hall Room 344, Baton Rouge, LA 70803, USA
> Tel. +1 (225) 578 1612, Fax +1 (225) 578 4276 Web http://www.math.lsu.edu/~bourdin <http://www.math.lsu.edu/~bourdin>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.mcs.anl.gov/pipermail/petsc-dev/attachments/20210407/34ace5cf/attachment-0001.html>
More information about the petsc-dev
mailing list