libc/glibc: fix building for seemingly native toolchains

Build glibc with -O2 as a fix/workaround to building
seemingly-native toolchains.

See:
- docs/overview.txt
- docs/known-issues.txt
- http://sourceware.org/ml/crossgcc/2009-09/msg00055.html
This commit is contained in:
Yann E. MORIN" 2009-10-02 22:10:38 +02:00
parent 7280facf18
commit 443f51a2dc
3 changed files with 24 additions and 6 deletions

View File

@ -51,8 +51,10 @@ Fix:
None known. None known.
Workaround: Workaround:
If this happens for you, stick with glibc-2.6.1 for now. It seems that using -O2 in the CFLAGS fixes the problem. It has been
Or investigate! :-) confirmed in the following threads:
http://sourceware.org/ml/crossgcc/2009-09/msg00055.html (for glibc)
http://sourceware.org/ml/crossgcc/2009-10/msg00001.html (for eglibc)
-------------------------------- --------------------------------
Symptoms: Symptoms:

View File

@ -28,6 +28,7 @@ Running crosstool-NG
Tools wrapper Tools wrapper
Using the toolchain Using the toolchain
Toolchain types Toolchain types
Seemingly-native toolchains
Internals Internals
Makefile front-end Makefile front-end
Kconfig parser Kconfig parser
@ -590,6 +591,21 @@ anyway!)
were all being hashed out, Canada had three national political parties. were all being hashed out, Canada had three national political parties.
http://en.wikipedia.org/wiki/Cross_compiler http://en.wikipedia.org/wiki/Cross_compiler
Seemingly-native toolchains |
----------------------------+
Seemingly-native toolchains are toolchains that target the same architecture
as the one it is built on, and on which it will run, but the machine tuple
may be different (eg i686 vs. i386, or x86_64-unknown-linux-gnu vs.
x86_64-pc-linux-gnu). This also applies if the target architecture is of the
same kind (eg. x86 vs. x86_64, or ppc vs. ppc64).
Such toolchain is tricky to build, as the configure scripts may incorrectly
assume that files (headers and libs) from the build (or host) machine can be
used by the cross-compiler it is going to build. The problem seems to arise
only with glibc (and eglibc?) starting with version 2.7.
_____________ _____________
/ /
Internals / Internals /

View File

@ -180,7 +180,7 @@ do_libc_headers() {
libc_cv_ppc_machine=yes \ libc_cv_ppc_machine=yes \
CT_DoExecLog ALL \ CT_DoExecLog ALL \
make CFLAGS="-O -DBOOTSTRAP_GCC" \ make CFLAGS="-O2 -DBOOTSTRAP_GCC" \
OBJDUMP_FOR_HOST="${CT_TARGET}-objdump" \ OBJDUMP_FOR_HOST="${CT_TARGET}-objdump" \
PARALLELMFLAGS="${PARALLELMFLAGS}" \ PARALLELMFLAGS="${PARALLELMFLAGS}" \
sysdeps/gnu/errlist.c sysdeps/gnu/errlist.c
@ -197,7 +197,7 @@ do_libc_headers() {
CT_DoExecLog ALL \ CT_DoExecLog ALL \
make cross-compiling=yes \ make cross-compiling=yes \
install_root=${CT_SYSROOT_DIR} \ install_root=${CT_SYSROOT_DIR} \
CFLAGS="-O -DBOOTSTRAP_GCC" \ CFLAGS="-O2 -DBOOTSTRAP_GCC" \
${LIBC_SYSROOT_ARG} \ ${LIBC_SYSROOT_ARG} \
OBJDUMP_FOR_HOST="${CT_TARGET}-objdump" \ OBJDUMP_FOR_HOST="${CT_TARGET}-objdump" \
PARALLELMFLAGS="${PARALLELMFLAGS}" \ PARALLELMFLAGS="${PARALLELMFLAGS}" \
@ -325,7 +325,7 @@ do_libc_start_files() {
# Please see the comment for the configure step in do_libc(). # Please see the comment for the configure step in do_libc().
BUILD_CC="${CT_BUILD}-gcc" \ BUILD_CC="${CT_BUILD}-gcc" \
CFLAGS="${CT_TARGET_CFLAGS} ${CT_LIBC_GLIBC_EXTRA_CFLAGS} -O " \ CFLAGS="${CT_TARGET_CFLAGS} ${CT_LIBC_GLIBC_EXTRA_CFLAGS} -O2" \
CC="${cross_cc} ${CT_LIBC_EXTRA_CC_ARGS} ${extra_cc_args}" \ CC="${cross_cc} ${CT_LIBC_EXTRA_CC_ARGS} ${extra_cc_args}" \
AR=${CT_TARGET}-ar \ AR=${CT_TARGET}-ar \
RANLIB=${CT_TARGET}-ranlib \ RANLIB=${CT_TARGET}-ranlib \
@ -457,7 +457,7 @@ do_libc() {
# silly messages. GNU folks again, he? # silly messages. GNU folks again, he?
BUILD_CC="${CT_BUILD}-gcc" \ BUILD_CC="${CT_BUILD}-gcc" \
CFLAGS="${CT_TARGET_CFLAGS} ${CT_LIBC_GLIBC_EXTRA_CFLAGS} -O" \ CFLAGS="${CT_TARGET_CFLAGS} ${CT_LIBC_GLIBC_EXTRA_CFLAGS} -O2" \
CC="${CT_TARGET}-gcc ${CT_LIBC_EXTRA_CC_ARGS} ${extra_cc_args}" \ CC="${CT_TARGET}-gcc ${CT_LIBC_EXTRA_CC_ARGS} ${extra_cc_args}" \
AR=${CT_TARGET}-ar \ AR=${CT_TARGET}-ar \
RANLIB=${CT_TARGET}-ranlib \ RANLIB=${CT_TARGET}-ranlib \