X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=ld%2Fconfigure.in;h=01b802eeaeea7b63850795067480a8a91239ed7a;hb=feb129926a8d12656f1ca4b7a8bb10268d3af4fb;hp=ba5e5b809e8572f248cc70dabb95fc274565f4e6;hpb=417ced0de7d535ea4ab39e4606df5ef8a457cbd4;p=deliverable%2Fbinutils-gdb.git diff --git a/ld/configure.in b/ld/configure.in index ba5e5b809e..01b802eeae 100644 --- a/ld/configure.in +++ b/ld/configure.in @@ -1,192 +1,173 @@ -# This file is a shell script fragment that supplies the information -# necessary to tailor a template configure script into the configure -# script appropriate for this directory. For more information, check -# any existing configure script. +dnl Process this file with autoconf to produce a configure script +dnl +AC_PREREG(2.13) +AC_INIT(ldmain.c) + +AC_CANONICAL_SYSTEM + +AM_INIT_AUTOMAKE(ld, 2.9.5) + +AM_PROG_LIBTOOL + +AC_ARG_ENABLE(targets, +[ --enable-targets alternative target configurations], +[case "${enableval}" in + yes | "") AC_ERROR(enable-targets option must specify target names or 'all') + ;; + no) enable_targets= ;; + *) enable_targets=$enableval ;; +esac])dnl +AC_ARG_ENABLE(64-bit-bfd, +[ --enable-64-bit-bfd 64-bit support (on hosts with narrower word sizes)], +[case "${enableval}" in + yes) want64=true ;; + no) want64=false ;; + *) AC_MSG_ERROR(bad value ${enableval} for 64-bit-bfd option) ;; +esac],[want64=false])dnl + +AM_CONFIG_HEADER(config.h:config.in) + +if test -z "$target" ; then + AC_MSG_ERROR(Unrecognized target system type; please check config.sub.) +fi +if test -z "$host" ; then + AC_MSG_ERROR(Unrecognized host system type; please check config.sub.) +fi -srctrigger=ldmain.c -srcname="linker" -target_dependent=true +# host-specific stuff: -# per-host: +AC_PROG_CC +AC_PROG_INSTALL -. ${srcdir}/../bfd/configure.host +ALL_LINGUAS= +CY_GNU_GETTEXT -host_makefile_frag= +AC_EXEEXT -if [ -f ${srcdir}/config/${my_host}.mh ] ; then - host_makefile_frag=config/${my_host}.mh -fi +AC_PROG_YACC +AM_PROG_LEX -# per-target: - -# Canonicalize the secondary target names. -if [ -n "$enable_targets" ]; then - for targ in `echo $enable_targets | sed 's/,/ /g'` - do - result=`$configsub $targ 2>/dev/null` - if [ -n "$result" ]; then - canon_targets="$canon_targets $result" - else - # Allow targets that config.sub doesn't recognize, like "all". - canon_targets="$canon_targets $targ" - fi - done -fi +AM_MAINTAINER_MODE -all_targets=false +. ${srcdir}/configure.host -for targ in $target $canon_targets -do +AC_SUBST(HDEFINES) +AC_SUBST(HOSTING_CRT0) +AC_SUBST(HOSTING_LIBS) +AC_SUBST(NATIVE_LIB_DIRS) + +AC_CHECK_HEADERS(string.h strings.h stdlib.h unistd.h) +AC_CHECK_FUNCS(sbrk) +AC_HEADER_DIRENT + +BFD_BINARY_FOPEN + +BFD_NEED_DECLARATION(strstr) +BFD_NEED_DECLARATION(free) +BFD_NEED_DECLARATION(sbrk) +BFD_NEED_DECLARATION(getenv) +BFD_NEED_DECLARATION(environ) + +# target-specific stuff: + +all_targets= +EMUL= +all_emuls= +all_emul_extras= +all_libpath= + +dnl We need to get an arbitrary number of tdir definitions into +dnl Makefile. We can't do it using AC_SUBST, because autoconf does +dnl not permit literal newlines in an AC_SUBST variables. So we use a +dnl file. +rm -f tdirs -case "${targ}" in - -# start-sanitize-arc - arc-*-elf*) ld_target=arc-elf ;; -# end-sanitize-arc - sparc-sun-sunos4*) ld_target=sun4 ;; - sparclite*-*-coff) ld_target=coff-sparc ;; - sparclite*-fujitsu-*) ld_target=sun4 ;; - sparc*-*-aout) ld_target=sun4 ;; - sparc*-*-coff) ld_target=coff-sparc ;; - sparc64-*-elf*) ld_target=sparc64-elf ;; - sparc64*) ld_target=sun4 ;; - sparc*-*-elf) ld_target=sun4sol2 ;; - sparc*-*-lynxos*) ld_target=sparc-lynx ;; - sparc*-*-netbsd*) ld_target=sparc-nbsd ;; - sparc*-*-solaris2*) ld_target=sun4sol2 ;; - sparc*-wrs-vxworks*) ld_target=sun4 ;; - i960-wrs-vxworks5.0*) ld_target=i960 ;; - i960-wrs-vxworks5*) ld_target=i960coff ;; - i960-wrs-vxworks*) ld_target=i960 ;; - i960-*-coff) ld_target=i960coff ;; - i960-intel-nindy) ld_target=i960 ;; - m68*-sun-sunos[34]*) ld_target=sun3 ;; - m68*-wrs-vxworks*) ld_target=vxworks68 ;; - m68*-ericsson-ose) ld_target=ose68 ;; - *-tandem-none) ld_target=st2000 ;; # FIXME needs better name - i[345]86-*-vsta) ld_target=vsta ;; - i[345]86-*-go32) ld_target=i386-go32 ;; - i[345]86-*-aix*) ld_target=i386-coff ;; - i[345]86-*-sco*) ld_target=i386-coff ;; - i[345]86-*-lynxos*) ld_target=i386-lynx ;; - i[345]86-*-coff) ld_target=i386-coff ;; - i[345]86-*-bsd) ld_target=i386-bsd ;; - i[345]86-*-bsd386) ld_target=i386-bsd ;; - i[345]86-*-bsdi*) ld_target=i386-bsd ;; - i[345]86-*-aout) ld_target=i386-aout ;; - i[345]86-*-linuxaout*) ld_target=i386-laout ;; - i[345]86-*-linux*) ld_target=i386-linux ;; - i[345]86-*-sysv4*) ld_target=i386-elf ;; - i[345]86-*-unixware) ld_target=i386-elf ;; - i[345]86-*-netbsd*) ld_target=i386-nbsd ;; - i[345]86-*-netware) ld_target=i386-nw ;; - i[345]86-*-elf*) ld_target=i386-elf ;; - i[345]86-*-sysv*) ld_target=i386-coff ;; - i[345]86-*-mach*) ld_target=i386-mach ;; - i[345]86-*-gnuelf*) ld_target=i386-gelf ;; - i[345]86-*-gnu*) ld_target=i386-gnu ;; - m8*-*-*) ld_target=m88k-bcs ;; - a29k-*-udi) ld_target=sa29200 ;; - a29k-*-ebmon) ld_target=ebmon29k ;; - a29k-*-*) ld_target=coff-a29k ;; -# arm-*-riscix*) ld_target=riscix ;; - h8300-*-hms) ld_target=coff-h8300 ;; - h8300h-*-hms) ld_target=cf-h8300h ;; - h8500-*-hms) ld_target=coff-h8500 ;; - sh-*-*) ld_target=coff-sh ;; -# start-sanitize-rce - rce-*-aout) ld_target=rce-aout ;; -# end-sanitize-rce - m68k-sony-*) ld_target=news ;; - m68k-hp-bsd*) ld_target=hp300bsd ;; - m68*-*-aout) ld_target=m68k ;; - m68*-*-coff) ld_target=m68k-coff ;; - m68*-*-elf) ld_target=m68k-elf ;; - m68*-*-hpux*) ld_target=hp300hpux ;; - m68*-*-lynxos*) ld_target=m68k-lynx ;; - m68*-*-netbsd*) ld_target=m68k-nbsd ;; - m68*-*-*) - echo '***' "Unknown m68k target vendor for ld:" ${target_vendor} 1>&2 - exit 1 ;; - hppa*-*-*elf*) ld_target=hppaelf ;; - hppa*-*-lites*) ld_target=hppaelf ;; - vax-dec-ultrix* | vax-dec-bsd*) ld_target=vax ;; - mips*-dec-ultrix*) ld_target=mips-lit ;; - mips*-sgi-irix5*) ld_target=mipsb-elf32 ;; - mips*-sgi-irix*) ld_target=mips-big ;; - mips*el-*-ecoff*) ld_target=mipsl-idt ;; - mips*-*-ecoff*) ld_target=mips-idt ;; - mips*-dec-bsd*) ld_target=mipsbsd ;; - mips*el-*-elf*) ld_target=mipsl-elf32 ;; - mips*-*-elf*) ld_target=mipsb-elf32 ;; - alpha-*-osf*) ld_target=alpha ;; - alpha-*-netware*) ld_target=alpha ;; - z8k-*-sim | z8k-*-coff) ld_target=z8ksim ;; - ns32k-pc532-mach) ld_target=pc532mach ;; - ns32k-pc532-netbsd*) ld_target=ns32k-nbsd ;; - powerpc-*-elf* | powerpc-*-eabi*) ld_target=ppc-elf32 ;; - powerpcle-*-elf* | powerpcle-*-eabi*) ld_target=ppcle-elf32 ;; - powerpc-*-netware*) ld_target=ppc-nw ;; - w65-*-*) ld_target=coff-w65 ;; - *-*-aout) ld_target=${target_cpu}-${target_vendor} ;; - *-*-coff) ld_target=${target_cpu}-${target_vendor} ;; - *-*-netware) ld_target=${target_cpu}-nw ;; - - all) ld_target=all ;; -esac - - if [ "x$ld_target" = "xall" ]; then - all_targets=true +for targ_alias in `echo $target_alias $enable_targets | sed 's/,/ /g'` +do + if test "$targ_alias" = "all"; then + all_targets=true + else + # Canonicalize the secondary target names. + result=`${CONFIG_SHELL-/bin/sh} $ac_config_sub $targ_alias 2>/dev/null` + if test -n "$result"; then + targ=$result else - if [ ! -f ${srcdir}/config/${ld_target}.mt ] ; then - echo '***' No file ${srcdir}/config/${ld_target}.mt 1>&2 - echo '***' GNU LD does not support target ${ld_target} 1>&2 - echo '***' Look in ld/configure.in for supported targets 1>&2 - exit 1 - fi - - if [ "x$targ" = "x$target" ]; then - target_makefile_frag=${srcdir}/config/${ld_target}.mt - else - target_extra_frags="$target_extra_frags ${srcdir}/config/${ld_target}.mt" - fi + targ=$targ_alias fi -done - -# We don't do any links based on the target system, just makefile config. -# post-target: + . ${srcdir}/configure.tgt -rm -f Makefile.tmp Makefile.2 -mv Makefile Makefile.tmp + if test "$targ" = "$target"; then + EMUL=$targ_emul + fi -if [ x${all_targets} = xfalse ]; then + for i in $targ_emul $targ_extra_emuls $targ_extra_libpath; do + case " $all_emuls " in + *" e${i}.o "*) ;; + *) + all_emuls="$all_emuls e${i}.o" + eval result=\$tdir_$i + test -z "$result" && result=$targ_alias + echo tdir_$i=$result >> tdirs + ;; + esac + done - allfrags="$target_makefile_frag $target_extra_frags" + for i in $targ_emul $targ_extra_libpath; do + case " $all_libpath " in + *" ${i} "*) ;; + *) + if test -z "$all_libpath"; then + all_libpath=${i} + else + all_libpath="$all_libpath ${i}" + fi + ;; + esac + done - # The emulations in all the configured targets. - tb=`sed -n ' - s/EMUL[ ]*=[ ]*\([^ ]*\)/e\1.o/p - s/EMUL_EXTRA.*=[ ]*\([^ ]*\)/e\1.o/p - ' $allfrags` - # uniq the list. - f="" - for i in $tb ; do - case " $f " in - *" $i "*) ;; - *) f="$f $i" ;; + for i in $targ_extra_ofiles; do + case " $all_emul_extras " in + *" ${i} "*) ;; + *) + all_emul_extras="$all_emul_extras ${i}" + ;; esac done - tb="$f" + fi +done - echo "EMULATION_OFILES = $tb" >> Makefile.2 +AC_SUBST(EMUL) + +TDIRS=tdirs +AC_SUBST_FILE(TDIRS) + +dnl FIXME: We will build a 64 bit BFD for a 64 bit host or a 64 bit +dnl target, and in those cases we should also build the 64 bit +dnl emulations. +if test x${all_targets} = xtrue; then + if test x${want64} = xtrue; then + EMULATION_OFILES='$(ALL_EMULATIONS) $(ALL_64_EMULATIONS)' + else + EMULATION_OFILES='$(ALL_EMULATIONS)' + fi + EMUL_EXTRA_OFILES='$(ALL_EMUL_EXTRA_OFILES)' +else + EMULATION_OFILES=$all_emuls + EMUL_EXTRA_OFILES=$all_emul_extras +fi +AC_SUBST(EMULATION_OFILES) +AC_SUBST(EMUL_EXTRA_OFILES) -else # all_targets is true - echo 'EMULATION_OFILES = $(ALL_EMULATIONS)' >> Makefile.2 -fi # all_targets is true +EMULATION_LIBPATH=$all_libpath +AC_SUBST(EMULATION_LIBPATH) -cat Makefile.tmp >> Makefile.2 -rm -f Makefile.tmp -mv Makefile.2 Makefile +if test x${enable_static} = xno; then + TESTBFDLIB="--rpath ../bfd/.libs ../bfd/.libs/libbfd.so" +else + TESTBFDLIB="../bfd/.libs/libbfd.a" +fi +AC_SUBST(TESTBFDLIB) -mkdir ldscripts 2>/dev/null +AC_OUTPUT(Makefile po/Makefile.in:po/Make-in, +[sed -e '/POTFILES =/r po/POTFILES' po/Makefile.in > po/Makefile])