AW: arm mulltilib build

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

 



Hi Richard,

thanks for your valuable help and sorry for my late reaction, I was on a rather long vacation trip.

Richard Earnshaw wrote:
> That's not what I see on a arm-none-eabi cross build.  In the install
> directory I get the following in the lib subtree:
> ....
> I suggest you check that the install step completed successfully.

You are right, I had an error my in gcc's build setup. After fixing that, I also see gcc's multilib libraries as expected.

> It's relatively unusual to use the 'aprofile' multilib list for glibc
> variants; most code doesn't benefit hugely from more specific options
> and dynamic function selection and symbol binding can mitigate some of
> the more egregious cases.

I more or less expected that, because aprofile also includes thumb support, which doesn't seem to be supported by glibc at all. I used it nonetheless, because it was the only valid ARM multilib configuration I could find. However, I would be very grateful if anyone could give some other suggestions of decent examples for gcc's --multilib-list switch, preferably those that would be most appropriate for an ARM glibc setup.

Again, thanks for any help,

Chris  


-----Ursprüngliche Nachricht-----
Von: Richard Earnshaw (lists) [mailto:Richard.Earnshaw@xxxxxxx] 
Gesendet: Freitag, 13. Januar 2017 16:08
An: Warlich, Christof (PD PA CI R&D 3); gcc-help (gcc-help@xxxxxxxxxxx)
Betreff: Re: arm mulltilib build

On 11/01/17 07:22, Warlich, Christof wrote:
> Hi,
> 
> I have a conceptual question w.r.t. an arm miltilib build (e.g. using --with-multilib-list=aprofile):
> 
> Comparing the arm multilib build with an x86_64 multilib build, I see that for x86_64, dedicated binaries (e.g. libgcc.a) are built for each subarch, i.e. I get:
> 
> $toolchain_root/lib/gcc/x86_64-linux-gnu/6.3.0/libgcc.a
> $toolchain_root/lib/gcc/x86_64-linux-gnu/6.3.0/32/libgcc.a
> $toolchain_root/lib/gcc/x86_64-linux-gnu/6.3.0/x32/libgcc.a
> 
> when passing --with-multilib-list=m64,m32,mx32 to GCC's configure script.
> 
> On the other hand, the ARM multilib build always only generates one libgcc.a, i,e,:
> 
> $toolchain_root/lib/gcc/arm-linux-gnueabi/6.3.0/libgcc.a
> 

That's not what I see on a arm-none-eabi cross build.  In the install
directory I get the following in the lib subtree:

./lib
./lib/v8-a
./lib/v8-a/simdv8
./lib/v8-a/simdv8/hard
./lib/v8-a/simdv8/hard/cpu-init
./lib/v8-a/simdv8/softfp
./lib/v8-a/simdv8/softfp/cpu-init
./lib/v8-a/cpu-init
./lib/thumb
./lib/thumb/v8-a
./lib/thumb/v8-a/simdv8
./lib/thumb/v8-a/simdv8/hard
./lib/thumb/v8-a/simdv8/hard/cpu-init
./lib/thumb/v8-a/simdv8/softfp
./lib/thumb/v8-a/simdv8/softfp/cpu-init
./lib/thumb/v8-a/cpu-init
./lib/thumb/cpu-init
./lib/thumb/v7-a
./lib/thumb/v7-a/fpv3
./lib/thumb/v7-a/fpv3/hard
./lib/thumb/v7-a/fpv3/hard/cpu-init
./lib/thumb/v7-a/fpv3/softfp
./lib/thumb/v7-a/fpv3/softfp/cpu-init
./lib/thumb/v7-a/simdv1
./lib/thumb/v7-a/simdv1/hard
./lib/thumb/v7-a/simdv1/hard/cpu-init
./lib/thumb/v7-a/simdv1/softfp
./lib/thumb/v7-a/simdv1/softfp/cpu-init
./lib/thumb/v7-a/cpu-init
./lib/thumb/v7ve
./lib/thumb/v7ve/fpv4
./lib/thumb/v7ve/fpv4/hard
./lib/thumb/v7ve/fpv4/hard/cpu-init
./lib/thumb/v7ve/fpv4/softfp
./lib/thumb/v7ve/fpv4/softfp/cpu-init
./lib/thumb/v7ve/cpu-init
./lib/thumb/v7ve/simdvfpv4
./lib/thumb/v7ve/simdvfpv4/hard
./lib/thumb/v7ve/simdvfpv4/hard/cpu-init
./lib/thumb/v7ve/simdvfpv4/softfp
./lib/thumb/v7ve/simdvfpv4/softfp/cpu-init
./lib/cpu-init
./lib/ldscripts
./lib/v7-a
./lib/v7-a/fpv3
./lib/v7-a/fpv3/hard
./lib/v7-a/fpv3/hard/cpu-init
./lib/v7-a/fpv3/softfp
./lib/v7-a/fpv3/softfp/cpu-init
./lib/v7-a/simdv1
./lib/v7-a/simdv1/hard
./lib/v7-a/simdv1/hard/cpu-init
./lib/v7-a/simdv1/softfp
./lib/v7-a/simdv1/softfp/cpu-init
./lib/v7-a/cpu-init
./lib/v7ve
./lib/v7ve/fpv4
./lib/v7ve/fpv4/hard
./lib/v7ve/fpv4/hard/cpu-init
./lib/v7ve/fpv4/softfp
./lib/v7ve/fpv4/softfp/cpu-init
./lib/v7ve/cpu-init
./lib/v7ve/simdvfpv4
./lib/v7ve/simdvfpv4/hard
./lib/v7ve/simdvfpv4/hard/cpu-init
./lib/v7ve/simdvfpv4/softfp
./lib/v7ve/simdvfpv4/softfp/cpu-init

with, for example:

$ lsl ./lib/v7ve/simdvfpv4/softfp
total 42228
drwxr-xr-x 3 rearnsha rearnsha     4096 Jan 13 15:01 .
drwxr-xr-x 4 rearnsha rearnsha     4096 Jan 13 14:57 ..
-rw-r--r-- 1 rearnsha rearnsha      509 Jan 13 14:59
aprofile-validation.specs
-rw-r--r-- 1 rearnsha rearnsha      493 Jan 13 14:59 aprofile-ve.specs
drwxr-xr-x 2 rearnsha rearnsha     4096 Jan 13 14:59 cpu-init
-rw-r--r-- 1 rearnsha rearnsha     2920 Jan 13 14:59 crt0.o
-rw-r--r-- 1 rearnsha rearnsha      195 Jan 13 14:59 iq80310.specs
-rw-r--r-- 2 rearnsha rearnsha  6002740 Jan 13 14:59 libc.a
-rw-r--r-- 2 rearnsha rearnsha  6002740 Jan 13 14:59 libg.a
-rw-r--r-- 1 rearnsha rearnsha  8335630 Jan 13 15:00 libgfortran.a
-rwxr-xr-x 1 rearnsha rearnsha     1120 Jan 13 15:00 libgfortran.la
-rw-r--r-- 1 rearnsha rearnsha      188 Jan 13 15:00 libgfortran.spec
-rw-r--r-- 1 rearnsha rearnsha    17044 Jan 13 14:59 libgloss-linux.a
-rw-r--r-- 1 rearnsha rearnsha  2873304 Jan 13 14:59 libm.a
-rw-r--r-- 1 rearnsha rearnsha   167258 Jan 13 14:59 libnosys.a
-rw-r--r-- 1 rearnsha rearnsha   703972 Jan 13 15:00 libobjc.a
-rwxr-xr-x 1 rearnsha rearnsha     1104 Jan 13 15:00 libobjc.la
-rw-r--r-- 1 rearnsha rearnsha    63412 Jan 13 14:59 librdimon.a
-rw-r--r-- 1 rearnsha rearnsha    57790 Jan 13 14:59 librdpmon.a
-rw-r--r-- 1 rearnsha rearnsha   121194 Jan 13 14:59 libssp.a
-rwxr-xr-x 1 rearnsha rearnsha     1123 Jan 13 14:59 libssp.la
-rw-r--r-- 1 rearnsha rearnsha     2654 Jan 13 14:59 libssp_nonshared.a
-rwxr-xr-x 1 rearnsha rearnsha     1153 Jan 13 14:59 libssp_nonshared.la
-rw-r--r-- 1 rearnsha rearnsha 17619664 Jan 13 15:01 libstdc++.a
-rw-r--r-- 1 rearnsha rearnsha     2472 Jan 13 15:01 libstdc++.a-gdb.py
-rwxr-xr-x 1 rearnsha rearnsha      955 Jan 13 15:01 libstdc++.la
-rw-r--r-- 1 rearnsha rearnsha  1109888 Jan 13 15:01 libsupc++.a
-rwxr-xr-x 1 rearnsha rearnsha      950 Jan 13 15:01 libsupc++.la
-rw-r--r-- 1 rearnsha rearnsha     8140 Jan 13 14:59 linux-crt0.o
-rw-r--r-- 1 rearnsha rearnsha      121 Jan 13 14:59 linux.specs
-rw-r--r-- 1 rearnsha rearnsha      680 Jan 13 14:59 nano.specs
-rw-r--r-- 1 rearnsha rearnsha      277 Jan 13 14:59 nosys.specs
-rw-r--r-- 1 rearnsha rearnsha      192 Jan 13 14:59 pid.specs
-rw-r--r-- 1 rearnsha rearnsha     3044 Jan 13 14:59 rdimon-crt0.o
-rw-r--r-- 1 rearnsha rearnsha      419 Jan 13 14:59 rdimon.specs
-rw-r--r-- 1 rearnsha rearnsha     2344 Jan 13 14:59 rdpmon-crt0.o
-rw-r--r-- 1 rearnsha rearnsha      147 Jan 13 14:59 rdpmon.specs
-rw-r--r-- 1 rearnsha rearnsha     1920 Jan 13 14:59 redboot-crt0.o
-rw-r--r-- 1 rearnsha rearnsha     6119 Jan 13 14:59 redboot.ld
-rw-r--r-- 1 rearnsha rearnsha      192 Jan 13 14:59 redboot.specs
-rw-r--r-- 1 rearnsha rearnsha    17568 Jan 13 14:59 redboot-syscalls.o

I suggest you check that the install step completed successfully.

> My question: How could this possibly work? I'd rather assumed that, similar to an x86_64 multilib build, dedicated binaries are needed for each of the available subarchs according to the output of:
> 
> $ /disk2/ccache/install/arm-audis4-linux-gnueabihf@x86_64-linux-gnu/bin/arm-audis4-linux-gnueabihf-gcc -print-multi-lib
> .;
> thumb;@mthumb
> v7-a;@march=armv7-a
> v7ve;@march=armv7ve
> v8-a;@march=armv8-a
> v7-a/fpv3/softfp;@march=armv7-a@mfpu=vfpv3-d16@mfloat-abi=softfp
> v7-a/fpv3/hard;@march=armv7-a@mfpu=vfpv3-d16@mfloat-abi=hard
> v7-a/simdv1/softfp;@march=armv7-a@mfpu=neon@mfloat-abi=softfp
> v7-a/simdv1/hard;@march=armv7-a@mfpu=neon@mfloat-abi=hard
> v7ve/fpv4/softfp;@march=armv7ve@mfpu=vfpv4-d16@mfloat-abi=softfp
> v7ve/fpv4/hard;@march=armv7ve@mfpu=vfpv4-d16@mfloat-abi=hard
> v7ve/simdvfpv4/softfp;@march=armv7ve@mfpu=neon-vfpv4@mfloat-abi=softfp
> v7ve/simdvfpv4/hard;@march=armv7ve@mfpu=neon-vfpv4@mfloat-abi=hard
> v8-a/simdv8/softfp;@march=armv8-a@mfpu=neon-fp-armv8@mfloat-abi=softfp
> v8-a/simdv8/hard;@march=armv8-a@mfpu=neon-fp-armv8@mfloat-abi=hard
> thumb/v7-a;@mthumb@march=armv7-a
> thumb/v7ve;@mthumb@march=armv7ve
> thumb/v8-a;@mthumb@march=armv8-a
> thumb/v7-a/fpv3/softfp;@mthumb@march=armv7-a@mfpu=vfpv3-d16@mfloat-abi=softfp
> thumb/v7-a/fpv3/hard;@mthumb@march=armv7-a@mfpu=vfpv3-d16@mfloat-abi=hard
> thumb/v7-a/simdv1/softfp;@mthumb@march=armv7-a@mfpu=neon@mfloat-abi=softfp
> thumb/v7-a/simdv1/hard;@mthumb@march=armv7-a@mfpu=neon@mfloat-abi=hard
> thumb/v7ve/fpv4/softfp;@mthumb@march=armv7ve@mfpu=vfpv4-d16@mfloat-abi=softfp
> thumb/v7ve/fpv4/hard;@mthumb@march=armv7ve@mfpu=vfpv4-d16@mfloat-abi=hard
> thumb/v7ve/simdvfpv4/softfp;@mthumb@march=armv7ve@mfpu=neon-vfpv4@mfloat-abi=softfp
> thumb/v7ve/simdvfpv4/hard;@mthumb@march=armv7ve@mfpu=neon-vfpv4@mfloat-abi=hard
> thumb/v8-a/simdv8/softfp;@mthumb@march=armv8-a@mfpu=neon-fp-armv8@mfloat-abi=softfp
> thumb/v8-a/simdv8/hard;@mthumb@march=armv8-a@mfpu=neon-fp-armv8@mfloat-abi=hard
> 
> And what about a related multilib GLIBC for arm? Do I also only need only one? 
> 

Depends on your needs, but you'll need at a minimum one for each
float-abi variant.

It's relatively unusual to use the 'aprofile' multilib list for glibc
variants; most code doesn't benefit hugely from more specific options
and dynamic function selection and symbol binding can mitigate some of
the more egregious cases.

R.

> Thanks for sharing your thoughts,
> 
> Chris
> 
> 
> 





[Index of Archives]     [Linux C Programming]     [Linux Kernel]     [eCos]     [Fedora Development]     [Fedora Announce]     [Autoconf]     [The DWARVES Debugging Tools]     [Yosemite Campsites]     [Yosemite News]     [Linux GCC]

  Powered by Linux