[Date Prev][Date Next] [Thread Prev][Thread Next] [Date Index] [Thread Index]

Re: Bug#888478: systemd FTBFS on mipsel: /usr/bin/ld: BFD (GNU Binutils for Debian) 2.29.90.20180122 assertion fail ../../bfd/elflink.c:9757



On 2018-01-26 15:19, James Cowgill wrote:
> Hi,
> 
> On 26/01/18 08:57, Aurelien Jarno wrote:
> >> The build was performed on eller.d.o.
> >>
> >> If you reassign to binutils, please set affects.
> >>
> >> I put d-mips@l.d.o into X-Debbugs-Cc. During cross builds I was able to
> >> reproduce a very similar build failure for mips and armhf. A native
> >> build on amd64 seems unaffected. Thus I have included d-arm@l.d.o as
> >> well.
> > 
> > Note that the build also fails on i386 on the same files, but in a
> > different way:
> > 
> > | FAILED: test-ipv4ll
> > | cc  -o test-ipv4ll 'test-ipv4ll@exe/src_libsystemd-network_test-ipv4ll.c.o' -flto -Wl,--no-undefined -Wl,--as-needed -Wl,-z,relro -Wl,-z,now -pie -Wl,--gc-sections -g -O2 -fdebug-prefix-map=/tmp/systemd-236=. -fstack-protector-strong -Wformat -Werror=format-security -Wl,-z,relro -Wl,--start-group src/shared/libsystemd-shared-236.so src/libsystemd-network/libsystemd-network.a -Wl,--end-group '-Wl,-rpath,$ORIGIN/src/shared' -Wl,-rpath-link,/tmp/systemd-236/build-deb/src/shared 
> > | /usr/bin/ld: /tmp/ccFNIZSq.ltrans0.ltrans.o(.text+0x99f): unresolvable R_386_PLT32 relocation against symbol `__umoddi3'
> > | /usr/bin/ld: final link failed: Nonrepresentable section on output
> > | collect2: error: ld returned 1 exit status
> > 
> > That might help debugging the issue as it is more understandable than
> > a simple assert.
> 
> Fairly minimal testcase which triggers both bugs:
> 
> test.c:
> volatile unsigned long long a = 42;
> volatile unsigned long long b = 1;
> 
> int main(void)
> {
>         return (int) (a / b);
> }
> 
> build with:
> gcc -flto -O2 -c test.c
> ar rcs libtest.a test.o
> gcc -flto -Wl,--whole-archive libtest.a -Wl,--no-whole-archive
> 
> On mipsel:
> /usr/bin/ld: BFD (GNU Binutils for Debian) 2.29.90.20180122 assertion fail ../../bfd/elflink.c:9757
> collect2: error: ld returned 1 exit status
> 
> On i386:
> /usr/bin/ld: /tmp/cc5ZOEfW.ltrans0.ltrans.o(.text.startup+0x3d): unresolvable R_386_PLT32 relocation against symbol `__udivdi3'
> /usr/bin/ld: final link failed: Nonrepresentable section on output
> collect2: error: ld returned 1 exit status

Thanks for the reduced testcase. It means it can also be easily
reproduced on amd64 with the following command but slightly different
code:

volatile  __int128 a = 42;
volatile  __int128 b = 1;

int main(void)
{
        return (int) (a / b);
}

/usr/bin/ld: /tmp/ccwdC3bA.ltrans0.ltrans.o(.text.startup+0x21): unresolvable R_X86_64_PLT32 relocation against symbol `__divti3'
/usr/bin/ld: final link failed: Nonrepresentable section on output

Aurelien

-- 
Aurelien Jarno                          GPG: 4096R/1DDD8C9B
aurelien@aurel32.net                 http://www.aurel32.net

Attachment: signature.asc
Description: PGP signature


Reply to: