# There are too many Ada sources to check against here. Let's
# always force the recursive make.
+
+# A native x86_64 compiler defaulting to -m32 is not suitable to build
+# 64bit host tools. Arrange to build the tools with the base compiler
+# in this case, as we do for cross configurations.
+
+m32_target=$(filter x86_64%abi32, $(target))
+not_m32_target=$(if $(m32_target),,$(target))
+
ifeq ($(build), $(host))
- ifeq ($(host), $(target))
- # This is a regular native. So use the compiler from our current build
- # tree.
+ native_target=$(filter $(host), $(target))
+
+ ifneq ($(and $(native_target), $(not_m32_target)),)
+ # This is a regular native. Use the compiler from our
+ # current build tree.
ADA_TOOLS_FLAGS_TO_PASS=\
CC="../../xgcc -B../../" \
CXX="$(CXX)" \
GNATLINK="../../gnatlink" \
GNATBIND="../../gnatbind"
else
- # This is a regular cross compiler. Use the native compiler to compile
- # the tools.
+ # This is a regular cross compiler or a 64bit native defaulting to -m32.
+ # Use the base native compiler to compile the tools.
# put the host RTS dir first in the PATH to hide the default runtime
# files that are among the sources
+$(GCC_LINK) -o $@ $(CFLAGS) ada/b_gnatb.o $(GNATBIND_OBJS) $(EXTRA_HOST_OBJS) ggc-none.o libcommon-target.a $(LIBS) $(SYSLIBS) $(GNATLIB)
# use target-gcc target-gnatmake target-gnatbind target-gnatlink
+
+native_gnattools1=$(if $(not_m32_target),gnattools1,gnattools1-re)
+
gnattools: $(CONFIG_H) prefix.o force
- $(MAKE) -C ada $(ADA_TOOLS_FLAGS_TO_PASS) gnattools1
+ $(MAKE) -C ada $(ADA_TOOLS_FLAGS_TO_PASS) $(native_gnattools1)
$(MAKE) -C ada $(ADA_TOOLS_FLAGS_TO_PASS) gnattools2
regnattools:
endif
endif
+# The x86_64-*abi32 compilers are x86_64 compilers defaulting to -m32
+ifeq ($(strip $(filter-out x86_64 %abi32, $(target_cpu) $(target_os))),)
+ ifneq ($(strip $(MULTISUBDIR)),/64)
+ target_cpu:=i686
+ endif
+endif
+
# Configuration of host tools
# Under linux, host tools need to be linked with -ldl
x86_64-*-darwin*)
;;
x86_64-*-*)
+ # Pick a default with_abi and with_multilib_list for m32
+ # restricted toolchains
+ case ${target} in
+ *abi32)
+ case ${with_abi} in
+ "" | 32 | m32)
+ with_abi=m32
+ ;;
+ *)
+ echo "Invalid --with-abi=$with_abi for m32 target"
+ exit 1
+ esac
+ case ${with_multilib_list} in
+ default | *m32*)
+ ;;
+ *)
+ echo "Invalid multilib list for abi32 target"
+ exit 1
+ esac
+ ;;
+ esac
+
case ${with_abi} in
"")
if test "x$with_multilib_list" = xmx32; then
x32 | mx32)
tm_file="i386/biarchx32.h ${tm_file}"
;;
+ 32 | m32)
+ tm_defines="${tm_defines} TARGET_BI_ARCH=1"
+ ;;
*)
echo "Unknown ABI used in --with-abi=$with_abi"
exit 1
# ../gcc/ada/gcc-interface/config-lang.in as well.
if test "x$cross_compiling/$build/$host" = "xno/$host/$target" ; then
default_gnattools_target="gnattools-native"
+ # When natively-building x86_64-*abi32 tools without bootstrap,
+ # use the native toolchain to build gnattools, expecting its
+ # libraries to be compatible with whichever multilib was used to
+ # build other tools. This requires the compiler being built to be
+ # gnatbind-compatible with the one used for the build.
+ case $enable_bootstrap/$target in
+ no/x86_64-*abi32)
+ default_gnattools_target="gnattools-cross"
+ ;;
+ esac
else
default_gnattools_target="gnattools-cross"
fi
# ../gcc/ada/gcc-interface/config-lang.in as well.
if test "x$cross_compiling/$build/$host" = "xno/$host/$target" ; then
default_gnattools_target="gnattools-native"
+ # When natively-building x86_64-*abi32 tools without bootstrap,
+ # use the native toolchain to build gnattools, expecting its
+ # libraries to be compatible with whichever multilib was used to
+ # build other tools. This requires the compiler being built to be
+ # gnatbind-compatible with the one used for the build.
+ case $enable_bootstrap/$target in
+ no/x86_64-*abi32)
+ default_gnattools_target="gnattools-cross"
+ ;;
+ esac
else
default_gnattools_target="gnattools-cross"
fi