mirror of
https://github.com/crosstool-ng/crosstool-ng.git
synced 2025-01-02 19:16:39 +00:00
gcc: Don't mess with --with-host-libstdcxx if recent GCC (6+) is used
"--with-host-libstdcxx" option was removed in GCC 6.x, see [1] because of [2]. So it makes no sense to use it with later GCC versions. Frankly I don't like that implementation with yet another set of "if XXX", but since we still support GCC down to 4.8.5 what else we may do? Well, technically we may keep using things as they are now, because surprisingly GCC's configure script doesn't mind accepting meaningless options, but as a person who's looking at differences between various builds and drill-down to peculiarities of various config options, I'd prefer to not pollute configure with garbage. But for all the rest... well, it works now and maybe nodody else cares. [1] https://gcc.gnu.org/git/?p=gcc.git&a=commit;h=5dc85f7ec719a79ecfbcdd8563b07e5f0f365e65 [2] https://gcc.gnu.org/bugzilla/show_bug.cgi?id=67092 Signed-off-by: Alexey Brodkin <abrodkin@synopsys.com>
This commit is contained in:
parent
4de586cd2e
commit
e075bdfc94
@ -436,9 +436,11 @@ do_gcc_core_backend() {
|
|||||||
# with the same block in do_gcc_backend, below.
|
# with the same block in do_gcc_backend, below.
|
||||||
if [ "${build_staticlinked}" = "yes" ]; then
|
if [ "${build_staticlinked}" = "yes" ]; then
|
||||||
core_LDFLAGS+=("-static")
|
core_LDFLAGS+=("-static")
|
||||||
|
if [ "${CT_GCC_older_than_6}" = "y" ]; then
|
||||||
host_libstdcxx_flags+=("-static-libgcc")
|
host_libstdcxx_flags+=("-static-libgcc")
|
||||||
host_libstdcxx_flags+=("-Wl,-Bstatic,-lstdc++")
|
host_libstdcxx_flags+=("-Wl,-Bstatic,-lstdc++")
|
||||||
host_libstdcxx_flags+=("-lm")
|
host_libstdcxx_flags+=("-lm")
|
||||||
|
fi
|
||||||
# Companion libraries are build static (eg !shared), so
|
# Companion libraries are build static (eg !shared), so
|
||||||
# the libstdc++ is not pulled automatically, although it
|
# the libstdc++ is not pulled automatically, although it
|
||||||
# is needed. Shoe-horn it in our LDFLAGS
|
# is needed. Shoe-horn it in our LDFLAGS
|
||||||
@ -446,7 +448,7 @@ do_gcc_core_backend() {
|
|||||||
core_LDFLAGS+=("-lstdc++")
|
core_LDFLAGS+=("-lstdc++")
|
||||||
core_LDFLAGS+=("-lm")
|
core_LDFLAGS+=("-lm")
|
||||||
else
|
else
|
||||||
if [ "${CT_CC_GCC_STATIC_LIBSTDCXX}" = "y" ]; then
|
if [ "${CT_CC_GCC_STATIC_LIBSTDCXX}" = "y" -a "${CT_GCC_older_than_6}" = "y" ]; then
|
||||||
# this is from CodeSourcery arm-2010q1-202-arm-none-linux-gnueabi.src.tar.bz2
|
# this is from CodeSourcery arm-2010q1-202-arm-none-linux-gnueabi.src.tar.bz2
|
||||||
# build script
|
# build script
|
||||||
# INFO: if the host gcc is gcc-4.5 then presumably we could use -static-libstdc++,
|
# INFO: if the host gcc is gcc-4.5 then presumably we could use -static-libstdc++,
|
||||||
@ -1084,9 +1086,11 @@ do_gcc_backend() {
|
|||||||
# with the same block in do_gcc_core_backend, above.
|
# with the same block in do_gcc_core_backend, above.
|
||||||
if [ "${CT_STATIC_TOOLCHAIN}" = "y" ]; then
|
if [ "${CT_STATIC_TOOLCHAIN}" = "y" ]; then
|
||||||
final_LDFLAGS+=("-static")
|
final_LDFLAGS+=("-static")
|
||||||
|
if [ "${CT_GCC_older_than_6}" = "y" ]; then
|
||||||
host_libstdcxx_flags+=("-static-libgcc")
|
host_libstdcxx_flags+=("-static-libgcc")
|
||||||
host_libstdcxx_flags+=("-Wl,-Bstatic,-lstdc++")
|
host_libstdcxx_flags+=("-Wl,-Bstatic,-lstdc++")
|
||||||
host_libstdcxx_flags+=("-lm")
|
host_libstdcxx_flags+=("-lm")
|
||||||
|
fi
|
||||||
# Companion libraries are build static (eg !shared), so
|
# Companion libraries are build static (eg !shared), so
|
||||||
# the libstdc++ is not pulled automatically, although it
|
# the libstdc++ is not pulled automatically, although it
|
||||||
# is needed. Shoe-horn it in our LDFLAGS
|
# is needed. Shoe-horn it in our LDFLAGS
|
||||||
@ -1094,7 +1098,7 @@ do_gcc_backend() {
|
|||||||
final_LDFLAGS+=("-lstdc++")
|
final_LDFLAGS+=("-lstdc++")
|
||||||
final_LDFLAGS+=("-lm")
|
final_LDFLAGS+=("-lm")
|
||||||
else
|
else
|
||||||
if [ "${CT_CC_GCC_STATIC_LIBSTDCXX}" = "y" ]; then
|
if [ "${CT_CC_GCC_STATIC_LIBSTDCXX}" = "y" -a "${CT_GCC_older_than_6}" = "y" ]; then
|
||||||
# this is from CodeSourcery arm-2010q1-202-arm-none-linux-gnueabi.src.tar.bz2
|
# this is from CodeSourcery arm-2010q1-202-arm-none-linux-gnueabi.src.tar.bz2
|
||||||
# build script
|
# build script
|
||||||
# INFO: if the host gcc is gcc-4.5 then presumably we could use -static-libstdc++,
|
# INFO: if the host gcc is gcc-4.5 then presumably we could use -static-libstdc++,
|
||||||
|
Loading…
Reference in New Issue
Block a user