[MacPorts] #65924: Linker crash when using GCC 12
MacPorts
noreply at macports.org
Sun Oct 2 17:58:23 UTC 2022
#65924: Linker crash when using GCC 12
-----------------------+--------------------
Reporter: szhorvat | Owner: (none)
Type: defect | Status: new
Priority: Normal | Milestone:
Component: ports | Version:
Resolution: | Keywords:
Port: gcc12 |
-----------------------+--------------------
Description changed by szhorvat:
Old description:
> When I use GCC 12 to build a certain project, the linker crashes at the
> final linking stage. This happens on an M1 Mac with the following OS:
>
> {{{
> ProductName: macOS
> ProductVersion: 12.6
> BuildVersion: 21G115
> }}}
>
> It does NOT happen on an Intel Mac with:
>
> {{{
> ProductName: Mac OS X
> ProductVersion: 10.14.6
> BuildVersion: 18G9323
> }}}
>
> The project I was trying to build is igraph, see
> https://github.com/igraph/igraph/ For reference, the build command was:
>
> {{{
> mkdir build && cd build
> CC=gcc-mp-11 CXX=g++-mp-11 cmake .. -DBUILD_SHARED_LIBS=ON
> cmake --build .
> }}}
>
> The error from the linking step is:
>
> {{{
> 0 0x1050541a0 __assert_rtn + 140
> 1 0x104edba8c
> mach_o::relocatable::Parser<arm64>::parse(mach_o::relocatable::ParserOptions
> const&) + 4536
> 2 0x104eadd38 mach_o::relocatable::Parser<arm64>::parse(unsigned char
> const*, unsigned long long, char const*, long, ld::File::Ordinal,
> mach_o::relocatable::ParserOptions const&) + 148
> 3 0x104f164ac ld::tool::InputFiles::makeFile(Options::FileInfo const&,
> bool) + 1468
> 4 0x104f19360 ___ZN2ld4tool10InputFilesC2ER7Options_block_invoke + 56
> 5 0x1b86d81f4 _dispatch_client_callout2 + 20
> 6 0x1b86eb954 _dispatch_apply_invoke + 224
> 7 0x1b86d81b4 _dispatch_client_callout + 20
> 8 0x1b86e9a04 _dispatch_root_queue_drain + 680
> 9 0x1b86ea104 _dispatch_worker_thread2 + 164
> 10 0x1b8898324 _pthread_wqthread + 228
> A linker snapshot was created at:
> /tmp/libigraph.3.0.0.dylib-2022-10-02-195512.ld-snapshot
> ld: Assertion failed: (_file->_atomsArrayCount == computedAtomCount &&
> "more atoms allocated than expected"), function parse, file
> macho_relocatable_file.cpp, line 2061.
> collect2: error: ld returned 1 exit status
> ninja: build stopped: subcommand failed.
> }}}
>
> I cannot reproduce this when linking a trivial one-file C++ program, and
> I could not yet track down what precisely causes the problem. My main
> machine is the Intel one (where everything works fine), and it's not
> always convenient for me to use the M1 one.
New description:
When I use GCC 12 to build a certain project, the linker crashes at the
final linking stage. This happens on an M1 Mac with the following OS:
{{{
ProductName: macOS
ProductVersion: 12.6
BuildVersion: 21G115
}}}
It does NOT happen on an Intel Mac with:
{{{
ProductName: Mac OS X
ProductVersion: 10.14.6
BuildVersion: 18G9323
}}}
The project I was trying to build is igraph, see
https://github.com/igraph/igraph/ For reference, the build command was:
{{{
mkdir build && cd build
CC=gcc-mp-11 CXX=g++-mp-11 cmake .. -DBUILD_SHARED_LIBS=ON
cmake --build .
}}}
The error from the linking step is:
{{{
0 0x1050541a0 __assert_rtn + 140
1 0x104edba8c
mach_o::relocatable::Parser<arm64>::parse(mach_o::relocatable::ParserOptions
const&) + 4536
2 0x104eadd38 mach_o::relocatable::Parser<arm64>::parse(unsigned char
const*, unsigned long long, char const*, long, ld::File::Ordinal,
mach_o::relocatable::ParserOptions const&) + 148
3 0x104f164ac ld::tool::InputFiles::makeFile(Options::FileInfo const&,
bool) + 1468
4 0x104f19360 ___ZN2ld4tool10InputFilesC2ER7Options_block_invoke + 56
5 0x1b86d81f4 _dispatch_client_callout2 + 20
6 0x1b86eb954 _dispatch_apply_invoke + 224
7 0x1b86d81b4 _dispatch_client_callout + 20
8 0x1b86e9a04 _dispatch_root_queue_drain + 680
9 0x1b86ea104 _dispatch_worker_thread2 + 164
10 0x1b8898324 _pthread_wqthread + 228
A linker snapshot was created at:
/tmp/libigraph.3.0.0.dylib-2022-10-02-195512.ld-snapshot
ld: Assertion failed: (_file->_atomsArrayCount == computedAtomCount &&
"more atoms allocated than expected"), function parse, file
macho_relocatable_file.cpp, line 2061.
collect2: error: ld returned 1 exit status
ninja: build stopped: subcommand failed.
}}}
I cannot reproduce this when linking a trivial one-file C++ program, and I
could not yet track down what precisely causes the problem. My main
machine is the Intel one (where everything works fine), and it's not
always convenient for me to use the M1 one.
Notes:
- I have the latest `gcc12` port installed (as of today).
- The same happens with `gcc11`.
--
--
Ticket URL: <https://trac.macports.org/ticket/65924#comment:1>
MacPorts <https://www.macports.org/>
Ports system for macOS
More information about the macports-tickets
mailing list