mirror of
https://github.com/crosstool-ng/crosstool-ng.git
synced 2025-01-17 10:19:45 +00:00
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:
parent
7280facf18
commit
443f51a2dc
@ -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:
|
||||||
|
@ -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 /
|
||||||
|
@ -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 \
|
||||||
|
Loading…
Reference in New Issue
Block a user