ChangeLog rotatation and copyright year update
[deliverable/binutils-gdb.git] / ld / configure.tgt
index d114f2d0be4b59a39cce30ec26a2cc8b2896ba52..ef876b26c7762b1412cd03d2087bc7353dd149d4 100644 (file)
@@ -1,3 +1,21 @@
+# configure.tgt
+#
+#   Copyright (C) 2013-2015 Free Software Foundation, Inc.
+#
+# This file is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; see the file COPYING3.  If not see
+# <http://www.gnu.org/licenses/>.
+
 # This is the linker target specific file.  This is invoked by the
 # autoconf generated configure script.  Putting it in a separate shell
 # file lets us skip running autoconf when modifying target specific
@@ -8,7 +26,7 @@
 #  targ_emul           name of linker emulation to use
 #  targ_extra_emuls    additional linker emulations to provide
 #  targ_extra_libpath  additional linker emulations using LIB_PATH
-#  targ_extra_ofiles   additional objects needed by the emulation
+#  targ_extra_ofiles   additional host-compiled objects needed by the emulation
 #  targ64_extra_emuls  additional linker emulations to provide if
 #                      --enable-64-bit-bfd is given or if host is 64 bit.
 #  targ64_extra_libpath        additional linker emulations using LIB_PATH if
@@ -27,31 +45,47 @@ targ64_extra_libpath=
 # architecture variants should be kept together even if their names
 # break the alpha sorting.
 case "${targ}" in
+aarch64_be-*-elf)      targ_emul=aarch64elfb
+                       targ_extra_emuls="aarch64elf aarch64elf32 aarch64elf32b armelfb armelf" ;;
+aarch64-*-elf)         targ_emul=aarch64elf
+                       targ_extra_emuls="aarch64elf32 aarch64elf32b aarch64elfb armelf armelfb" ;;
+aarch64_be-*-linux*)   targ_emul=aarch64linuxb
+                       targ_extra_libpath="aarch64linux aarch64linux32 aarch64linux32b armelfb_linux_eabi armelf_linux_eabi"
+                       targ_extra_emuls="aarch64elfb aarch64elf aarch64elf32 aarch64elf32b armelfb armelf $targ_extra_libpath" ;;
+aarch64-*-linux*)      targ_emul=aarch64linux
+                       targ_extra_libpath="aarch64linuxb aarch64linux32 aarch64linux32b armelfb_linux_eabi armelf_linux_eabi"
+                       targ_extra_emuls="aarch64elf aarch64elf32 aarch64elf32b aarch64elfb armelf armelfb $targ_extra_libpath" ;;
 alpha*-*-freebsd* | alpha*-*-kfreebsd*-gnu)
                        targ_emul=elf64alpha_fbsd
                        targ_extra_emuls="elf64alpha alpha"
                        tdir_alpha=`echo ${targ_alias} | sed -e 's/freebsd/freebsdecoff/'` ;;
-alpha*-*-linuxecoff*)  targ_emul=alpha targ_extra_emuls=elf64alpha
+alpha*-*-linux*ecoff*) targ_emul=alpha targ_extra_emuls=elf64alpha
                        tdir_elf64alpha=`echo ${targ_alias} | sed -e 's/ecoff//'` ;;
 alpha*-*-linux-*)      targ_emul=elf64alpha targ_extra_emuls=alpha
-                       tdir_alpha=`echo ${targ_alias} | sed -e 's/linux/linuxecoff/'` ;;
+                       tdir_alpha=`echo ${targ_alias} | sed -e 's/linux\(-gnu\)*/linux\1ecoff/'` ;;
 alpha*-*-osf*)         targ_emul=alpha ;;
 alpha*-*-gnu*)         targ_emul=elf64alpha ;;
 alpha*-*-netware*)     targ_emul=alpha ;;
 alpha*-*-netbsd*)      targ_emul=elf64alpha_nbsd ;;
-alpha*-*-openbsd*)     targ_emul=elf64alpha
+alpha*-*-openbsd*)     targ_emul=elf64alpha ;;
+alpha*-*-*vms*)                targ_emul=alphavms
                        ;;
 arc-*-elf*)            targ_emul=arcelf
                        ;;
 arm-epoc-pe)           targ_emul=arm_epoc_pe ; targ_extra_ofiles="deffilep.o pe-dll.o" ;;
-arm-wince-pe | arm-*-wince) targ_emul=arm_wince_pe ; targ_extra_ofiles="deffilep.o pe-dll.o" ;;
+arm*-*-cegcc*)         targ_emul=arm_wince_pe ; targ_extra_ofiles="deffilep.o pe-dll.o"
+                       LIB_PATH='${tooldir}/lib/w32api' ;;
+arm-wince-pe | arm-*-wince | arm*-*-mingw32ce*)
+                       targ_emul=arm_wince_pe ; targ_extra_ofiles="deffilep.o pe-dll.o" ;;
 arm-*-pe)              targ_emul=armpe ; targ_extra_ofiles="deffilep.o pe-dll.o" ;;
 arm-*-aout | armel-*-aout) targ_emul=armaoutl ;;
 armeb-*-aout)          targ_emul=armaoutb ;;
 arm-*-coff)            targ_emul=armcoff ;;
-arm-*-freebsd* | arm-*-kfreebsd*-gnu)
+arm*b-*-freebsd*)      targ_emul=armelfb_fbsd
+                       targ_extra_emuls="armelf_fbsd armelf" ;;
+arm*-*-freebsd* | arm-*-kfreebsd*-gnu)
                        targ_emul=armelf_fbsd
-                       targ_extra_emuls="armelf" ;;
+                       targ_extra_emuls="armelfb_fbsd armelf" ;;
 armeb-*-netbsdelf*)    targ_emul=armelfb_nbsd;
                        targ_extra_emuls="armelf_nbsd armelf armnbsd" ;;
 arm-*-netbsdelf*)      targ_emul=armelf_nbsd;
@@ -61,13 +95,14 @@ arm-*-netbsd*)              targ_emul=armnbsd;
 arm-*-nto*)            targ_emul=armnto ;;
 arm-*-openbsd*)                targ_emul=armnbsd ;;
 arm-*-rtems*)          targ_emul=armelf ;;
-armeb-*-elf)           targ_emul=armelfb ;;
+armeb-*-elf | armeb-*-eabi*)
+                       targ_emul=armelfb ;;
 arm-*-elf | arm*-*-eabi*)
                        targ_emul=armelf ;;
 arm*-*-symbianelf*)     targ_emul=armsymbian;;
 arm-*-kaos*)           targ_emul=armelf ;;
 arm9e-*-elf)           targ_emul=armelf ;;
-arm*b-*-linux-*eabi  targ_emul=armelfb_linux_eabi
+arm*b-*-linux-*eabi*)  targ_emul=armelfb_linux_eabi
                        targ_extra_emuls=armelf_linux_eabi
                        targ_extra_libpath=$targ_extra_emuls
                        ;;
@@ -75,7 +110,7 @@ arm*b-*-linux-*)     targ_emul=armelfb_linux
                        targ_extra_emuls="armelfb armelf armelf_linux"
                        targ_extra_libpath="armelf_linux"
                        ;;
-arm*-*-linux-*eabi   targ_emul=armelf_linux_eabi
+arm*-*-linux-*eabi*)   targ_emul=armelf_linux_eabi
                        targ_extra_emuls=armelfb_linux_eabi
                        targ_extra_libpath=$targ_extra_emuls
                        ;;
@@ -83,7 +118,19 @@ arm*-*-linux-*)             targ_emul=armelf_linux
                        targ_extra_emuls="armelf armelfb armelfb_linux"
                        targ_extra_libpath="armelfb_linux"
                        ;;
-arm*-*-uclinux*eabi)   targ_emul=armelf_linux_eabi
+arm*b-*-nacl*)         targ_emul=armelfb_nacl
+                       targ_extra_emuls="armelf_nacl elf_i386_nacl"
+                       targ_extra_libpath=$targ_extra_emuls
+                       targ64_extra_emuls="elf32_x86_64_nacl elf_x86_64_nacl"
+                       targ64_extra_libpath=$targ64_extra_emuls
+                       ;;
+arm*-*-nacl*)          targ_emul=armelf_nacl
+                       targ_extra_emuls="armelfb_nacl elf_i386_nacl"
+                       targ_extra_libpath=$targ_extra_emuls
+                       targ64_extra_emuls="elf32_x86_64_nacl elf_x86_64_nacl"
+                       targ64_extra_libpath=$targ64_extra_emuls
+                       ;;
+arm*-*-uclinux*eabi*)  targ_emul=armelf_linux_eabi
                        targ_extra_emuls=armelfb_linux_eabi
                        targ_extra_libpath=$targ_extra_emuls
                        ;;
@@ -93,21 +140,8 @@ arm*-*-uclinux*)    targ_emul=armelf_linux
                        ;;
 arm-*-vxworks)         targ_emul=armelf_vxworks ;;
 arm*-*-conix*)         targ_emul=armelf ;;
-thumb-*-linux-* | thumb-*-uclinux*)    targ_emul=armelf_linux; targ_extra_emuls=armelf ;;
-strongarm-*-coff)      targ_emul=armcoff ;;
-strongarm-*-elf)       targ_emul=armelf ;;
-strongarm-*-kaos*)     targ_emul=armelf ;;
-thumb-*-coff)          targ_emul=armcoff ;;
-thumb-*-elf)           targ_emul=armelf ;;
-thumb-epoc-pe)         targ_emul=arm_epoc_pe ;
-                       targ_extra_ofiles="deffilep.o pe-dll.o" ;;
-thumb-*-pe)            targ_emul=armpe ;
-                       targ_extra_ofiles="deffilep.o pe-dll.o" ;;
-xscale-*-coff)         targ_emul=armcoff ;;
-xscale-*-elf)          targ_emul=armelf
-                       ;;
 avr-*-*)               targ_emul=avr2
-                       targ_extra_emuls="avr1 avr3 avr4 avr5 avr6"
+                       targ_extra_emuls="avr1 avr25 avr3 avr31 avr35 avr4 avr5 avr51 avr6 avrxmega1 avrxmega2 avrxmega3 avrxmega4 avrxmega5 avrxmega6 avrxmega7 avrtiny"
                        ;;
 bfin-*-elf)            targ_emul=elf32bfin;
                        targ_extra_emuls="elf32bfinfd"
@@ -146,12 +180,19 @@ d30v-*-*)         targ_emul=d30velf; targ_extra_emuls="d30v_e d30v_o"
                        ;;
 dlx-*-elf*)            targ_emul=elf32_dlx
                        ;;
+epiphany-*-elf)                targ_emul=elf32epiphany
+                       targ_extra_emuls="elf32epiphany_4x4"
+                       ;;
 fido*-*-elf*)          targ_emul=m68kelf ;;
 fr30-*-*)              targ_emul=elf32fr30
                        ;;
 frv-*-*linux*)         targ_emul=elf32frvfd ;;
 frv-*-*)               targ_emul=elf32frv ; targ_extra_emuls="elf32frvfd"
                        ;;
+moxie-*-moxiebox*)     targ_emul=moxiebox
+                       ;;
+moxie-*-*)             targ_emul=elf32moxie
+                       ;;
 h8300-*-hms* | h8300-*-coff* | h8300-*-rtemscoff*)
                        targ_emul=h8300; targ_extra_emuls="h8300h h8300s h8300hn h8300sn h8300sx h8300sxn" ;;
 h8300-*-elf* | h8300-*-rtems*)
@@ -162,7 +203,7 @@ h8500-*-hms* | h8500-*-coff* | h8500-*-rtems*)
                        targ_extra_emuls="h8500s h8500b h8500m h8500c"
                        ;;
 hppa*64*-*-linux-*)    targ_emul=hppa64linux ;;
-hppa*64*-*)            targ_emul=elf64hppa ;;
+hppa*64*-hpux*)                targ_emul=elf64hppa ;;
 hppa*-*-linux-*)       targ_emul=hppalinux ;;
 hppa*-*-*elf*)         targ_emul=hppaelf ;;
 hppa*-*-lites*)                targ_emul=hppaelf ;;
@@ -183,6 +224,7 @@ i[3-7]86-*-coff)    targ_emul=i386coff ;;
 i[3-7]86-*-rtems*)     targ_emul=elf_i386 ;;
 i[3-7]86-*-aros*)      targ_emul=elf_i386 ;;
 i[3-7]86-*-rdos*)      targ_emul=elf_i386 ;;
+x86_64-*-rdos*)                targ_emul=elf64rdos ;;
 i[3-7]86-*-bsd)                targ_emul=i386bsd ;;
 i[3-7]86-*-bsd386)     targ_emul=i386bsd ;;
 i[3-7]86-*-bsdi*)      targ_emul=i386bsd ;;
@@ -193,23 +235,29 @@ i[3-7]86-*-linux*aout*)   targ_emul=i386linux
 i[3-7]86-*-linux*oldld)        targ_emul=i386linux; targ_extra_emuls=elf_i386 ;;
 i[3-7]86-*-linux-*)    targ_emul=elf_i386
                        targ_extra_emuls=i386linux
-                       targ64_extra_emuls=elf_x86_64
+                       targ64_extra_emuls="elf_x86_64 elf32_x86_64 elf_l1om elf_k1om"
                        targ64_extra_libpath=elf_x86_64
+                       targ_extra_libpath=elf32_x86_64
                        tdir_i386linux=${targ_alias}aout ;;
+x86_64-*-linux-gnux32) targ_emul=elf32_x86_64
+                       targ_extra_emuls="elf_x86_64 elf_i386 i386linux elf_l1om elf_k1om"
+                       targ_extra_libpath="elf_i386 elf_x86_64 elf_l1om elf_k1om"
+                       tdir_i386linux=`echo ${targ_alias}aout | sed -e 's/x86_64/i386/' -e 's/-linux-gnux32/-linux-gnu/'`
+                       tdir_elf_i386=`echo ${targ_alias} | sed -e 's/x86_64/i386/' -e 's/-linux-gnux32/-linux-gnu/'` ;;
 x86_64-*-linux-*)      targ_emul=elf_x86_64
-                       targ_extra_emuls="elf_i386 i386linux"
-                       targ_extra_libpath=elf_i386
+                       targ_extra_emuls="elf32_x86_64 elf_i386 i386linux elf_l1om elf_k1om"
+                       targ_extra_libpath="elf_i386 elf32_x86_64 elf_l1om elf_k1om"
                        tdir_i386linux=`echo ${targ_alias}aout | sed -e 's/x86_64/i386/'`
                        tdir_elf_i386=`echo ${targ_alias} | sed -e 's/x86_64/i386/'` ;;
 i[3-7]86-*-sysv[45]*)  targ_emul=elf_i386 ;;
-i[3-7]86-*-solaris2*)  targ_emul=elf_i386_ldso
-                        targ_extra_emuls="elf_i386 elf_x86_64"
+i[3-7]86-*-solaris2*)  targ_emul=elf_i386_sol2
+                        targ_extra_emuls="elf_i386_ldso elf_i386 elf_x86_64_sol2 elf_x86_64 elf_l1om elf_k1om"
                        targ_extra_libpath=$targ_extra_emuls
                         ;;
 x86_64-*-solaris2*)
-                       targ_emul=elf_x86_64
-                       targ_extra_emuls="elf_i386 elf_i386_ldso"
-                       targ_extra_libpath=elf_i386
+                       targ_emul=elf_x86_64_sol2
+                       targ_extra_emuls="elf_x86_64 elf_i386_sol2 elf_i386_ldso elf_i386 elf_l1om elf_k1om"
+                       targ_extra_libpath=$targ_extra_emuls
                        tdir_elf_i386=`echo ${targ_alias} | sed -e 's/x86_64/i386/'` ;;
 i[3-7]86-*-unixware)   targ_emul=elf_i386 ;;
 i[3-7]86-*-solaris*)   targ_emul=elf_i386_ldso
@@ -226,7 +274,7 @@ i[3-7]86-*-netbsdpe*)       targ_emul=i386pe
 i[3-7]86-*-netbsd*)    targ_emul=i386nbsd
                        targ_extra_emuls=elf_i386 ;;
 x86_64-*-netbsd*)      targ_emul=elf_x86_64
-                       targ_extra_emuls="elf_i386 i386nbsd"
+                       targ_extra_emuls="elf_i386 i386nbsd elf_l1om elf_k1om"
                        tdir_elf_i386=`echo ${targ_alias} | \
                            sed -e 's/x86_64/i386/'`
                        case "${tdir_elf_i386}" in
@@ -237,17 +285,23 @@ x86_64-*-netbsd*) targ_emul=elf_x86_64
 i[3-7]86-*-netware)    targ_emul=i386nw ;;
 i[3-7]86-*-elf*)       targ_emul=elf_i386 ;;
 x86_64-*-elf*)         targ_emul=elf_x86_64
-                       targ_extra_emuls=elf_i386
+                       targ_extra_emuls="elf_i386 elf32_x86_64 elf_l1om elf_k1om"
+                       targ_extra_libpath="elf_i386 elf32_x86_64 elf_l1om elf_k1om"
+                       tdir_elf_i386=`echo ${targ_alias} | sed -e 's/x86_64/i386/'`
                        ;;
 i[3-7]86-*-kaos*)      targ_emul=elf_i386 ;;
 i[3-7]86-*-freebsdaout* | i[3-7]86-*-freebsd[12].* | i[3-7]86-*-freebsd[12])
                        targ_emul=i386bsd ;;
-i[3-7]86-*-freebsd* | i[3-7]86-*-kfreebsd*-gnu | i[3-7]86-*-dragonfly*)
+i[3-7]86-*-dragonfly*) targ_emul=elf_i386
+                       targ_extra_emuls="i386bsd" ;;
+x86_64-*-dragonfly*)   targ_emul=elf_x86_64
+                       targ_extra_emuls="elf_i386 elf_l1om elf_k1om" ;;
+i[3-7]86-*-freebsd* | i[3-7]86-*-kfreebsd*-gnu)
                        targ_emul=elf_i386_fbsd
                        targ_extra_emuls="elf_i386 i386bsd" ;;
 x86_64-*-freebsd* | x86_64-*-kfreebsd*-gnu)
                        targ_emul=elf_x86_64_fbsd
-                       targ_extra_emuls="elf_i386_fbsd elf_x86_64 elf_i386"
+                       targ_extra_emuls="elf_i386_fbsd elf_x86_64 elf_i386 elf_l1om elf_l1om_fbsd elf_k1om elf_k1om_fbsd"
                        targ_extra_libpath="elf_i386_fbsd"
                        tdir_elf_i386_fbsd=`echo ${targ_alias} \
                            | sed -e 's/x86_64/i386/'`
@@ -264,12 +318,20 @@ i[3-7]86-*-winnt*)        targ_emul=i386pe ;
 i[3-7]86-*-pe)         targ_emul=i386pe ;
                        targ_extra_ofiles="deffilep.o pe-dll.o" ;;
 i[3-7]86-*-cygwin*)    targ_emul=i386pe ;
-                       targ_extra_ofiles="deffilep.o pe-dll.o"
+                       targ_extra_ofiles="deffilep.o pe-dll.o" ;
                        test "$targ" != "$host" && LIB_PATH='${tooldir}/lib/w32api' ;;
 i[3-7]86-*-mingw32*)   targ_emul=i386pe ;
                        targ_extra_ofiles="deffilep.o pe-dll.o" ;;
+x86_64-*-pe | x86_64-*-pep) targ_emul=i386pep ;
+                       targ_extra_emuls=i386pe ;
+                       targ_extra_ofiles="deffilep.o pep-dll.o pe-dll.o" ;;
+x86_64-*-cygwin)       targ_emul=i386pep ;
+                       targ_extra_emuls=i386pe
+                       targ_extra_ofiles="deffilep.o pep-dll.o pe-dll.o"
+                       test "$targ" != "$host" && LIB_PATH='${tooldir}/lib/w32api' ;;
 x86_64-*-mingw*)       targ_emul=i386pep ;
-                       targ_extra_ofiles="deffilep.o pep-dll.o" ;;
+                       targ_extra_emuls=i386pe
+                       targ_extra_ofiles="deffilep.o pep-dll.o pe-dll.o" ;;
 i[3-7]86-*-interix*)   targ_emul=i386pe_posix;
                        targ_extra_ofiles="deffilep.o pe-dll.o" ;;
 i[3-7]86-*-beospe*)    targ_emul=i386beos ;;
@@ -277,6 +339,17 @@ i[3-7]86-*-beos*)  targ_emul=elf_i386_be ;;
 i[3-7]86-*-vxworks*)   targ_emul=elf_i386_vxworks ;;
 i[3-7]86-*-chaos)      targ_emul=elf_i386_chaos
                        ;;
+i[3-7]86-*-nacl*)      targ_emul=elf_i386_nacl
+                       targ_extra_emuls="armelf_nacl armelfb_nacl"
+                       targ_extra_libpath=$targ_extra_emuls
+                       targ64_extra_emuls="elf32_x86_64_nacl elf_x86_64_nacl"
+                       targ64_extra_libpath=$targ64_extra_emuls
+                       ;;
+x86_64-*-nacl*)                targ_emul=elf32_x86_64_nacl
+                       targ_extra_emuls="elf_i386_nacl elf_x86_64_nacl armelf_nacl armelfb_nacl"
+                       targ_extra_libpath=$targ_extra_emuls
+                       tdir_elf_i386_nacl=`echo ${targ_alias} | sed -e 's/x86_64/i386/'`
+                       ;;
 i860-*-coff)           targ_emul=coff_i860 ;;
 i860-stardent-sysv4* | i860-stardent-elf*)
                        targ_emul=elf32_i860
@@ -295,22 +368,28 @@ ia64-*-freebsd* | ia64-*-kfreebsd*-gnu)
                        targ_extra_emuls="elf64_ia64" ;;
 ia64-*-netbsd*)                targ_emul=elf64_ia64 ;;
 ia64-*-linux*)         targ_emul=elf64_ia64 ;;
+ia64-*-*vms*)          targ_emul=elf64_ia64_vms ;;
 ia64-*-aix*)           targ_emul=elf64_aix
                        ;;
 ip2k-*-elf)            targ_emul=elf32ip2k
                        ;;
 iq2000-*-elf)           targ_emul=elf32iq2000 ; targ_extra_emuls="elf32iq10"
                        ;;
-m32c-*-elf)            targ_emul=elf32m32c
+lm32-*-*linux*)         targ_emul=elf32lm32fd ;;
+lm32-*-*)               targ_emul=elf32lm32 ; targ_extra_emuls="elf32lm32fd"
+                        ;;
+m32c-*-elf | m32c-*-rtems*)
+                       targ_emul=elf32m32c
                        ;;
 m32r*le-*-elf*)         targ_emul=m32rlelf ;;
-m32r*-*-elf*)           targ_emul=m32relf ;;
+m32r*-*-elf* | m32r*-*-rtems*)
+                       targ_emul=m32relf ;;
 m32r*le-*-linux-*)      targ_emul=m32rlelf_linux ;;
 m32r*-*-linux-*)        targ_emul=m32relf_linux
                        ;;
-m68hc11-*-*|m6811-*-*) targ_emul=m68hc11elf 
+m68hc11-*-*|m6811-*-*) targ_emul=m68hc11elf
                        targ_extra_emuls="m68hc11elfb m68hc12elf m68hc12elfb" ;;
-m68hc12-*-*|m6812-*-*) targ_emul=m68hc12elf 
+m68hc12-*-*|m6812-*-*) targ_emul=m68hc12elf
                        targ_extra_emuls="m68hc12elfb m68hc11elf m68hc11elfb" ;;
 m68*-sun-sunos[34]*)   targ_emul=sun3 ;;
 m68*-wrs-vxworks*)     targ_emul=sun3 ;;
@@ -344,31 +423,34 @@ m68*-*-rtems*)            targ_emul=m68kelf
                        ;;
 m8*-*-*)               targ_emul=m88kbcs
                        ;;
-maxq-*-coff)            targ_emul=maxqcoff
-                       ;;
 mcore-*-pe)            targ_emul=mcorepe ;
                        targ_extra_ofiles="deffilep.o pe-dll.o" ;;
 mcore-*-elf)           targ_emul=elf32mcore
                        ;;
 mep-*-elf)             targ_emul=elf32mep ;;
-mips*-*-pe)            targ_emul=mipspe ;
-                       targ_extra_ofiles="deffilep.o pe-dll.o" ;;
-mips*-dec-ultrix*)     targ_emul=mipslit ;;
-mips*-dec-osf*)                targ_emul=mipslit ;;
+metag-*-*)             targ_emul=elf32metag ;;
+microblazeel*-linux*)  targ_emul="elf32mbel_linux"
+                       targ_extra_emuls="elf32mb_linux"
+                       ;;
+microblaze*-linux*)    targ_emul="elf32mb_linux"
+                       targ_extra_emuls="elf32mbel_linux"
+                       ;;
+microblazeel*)         targ_emul=elf32microblazeel
+                       targ_extra_emuls=elf32microblaze
+                       ;;
+microblaze*)           targ_emul=elf32microblaze
+                       targ_extra_emuls=elf32microblazeel
+                       ;;
 mips*-sgi-irix5*)      targ_emul=elf32bsmip ;;
 mips*-sgi-irix6*)      targ_emul=elf32bmipn32
                        targ_extra_emuls="elf32bsmip elf64bmip"
                        targ_extra_libpath=$targ_extra_emuls ;;
-mips*-sgi-irix*)       targ_emul=mipsbig ;;
-mips*el-*-ecoff*)      targ_emul=mipsidtl ;;
-mips*-*-ecoff*)                targ_emul=mipsidt ;;
 mips*el-*-netbsd*)     targ_emul=elf32ltsmip
                        targ_extra_emuls="elf32btsmip elf64ltsmip elf64btsmip"
                        ;;
 mips*-*-netbsd*)       targ_emul=elf32btsmip
                        targ_extra_emuls="elf32ltsmip elf64btsmip elf64ltsmip"
                        ;;
-mips*-*-bsd*)          targ_emul=mipsbig ;;
 mips*vr4300el-*-elf*)  targ_emul=elf32l4300 ;;
 mips*vr4300-*-elf*)    targ_emul=elf32b4300 ;;
 mips*vr4100el-*-elf*)  targ_emul=elf32l4300 ;;
@@ -377,8 +459,15 @@ mips*vr5000el-*-elf*)      targ_emul=elf32l4300 ;;
 mips*vr5000-*-elf*)    targ_emul=elf32b4300 ;;
 mips*el-sde-elf*)      targ_emul=elf32ltsmip
                        targ_extra_emuls="elf32btsmip elf32ltsmipn32 elf64ltsmip elf32btsmipn32 elf64btsmip" ;;
-mips*-sde-elf*)                targ_emul=elf32btsmip
+mips*-sde-elf* | mips*-mti-elf* | mips*-img-elf*)
+                       targ_emul=elf32btsmip
                        targ_extra_emuls="elf32ltsmip elf32btsmipn32 elf64btsmip elf32ltsmipn32 elf64ltsmip" ;;
+mips64*el-ps2-elf*)    targ_emul=elf32lr5900n32
+                       targ_extra_emuls="elf32lr5900"
+                       targ_extra_libpath=$targ_extra_emuls ;;
+mips*el-ps2-elf*)      targ_emul=elf32lr5900
+                       targ_extra_emuls="elf32lr5900n32"
+                       targ_extra_libpath=$targ_extra_emuls ;;
 mips*el-*-elf*)                targ_emul=elf32elmip ;;
 mips*-*-elf*)          targ_emul=elf32ebmip ;;
 mips*-*-rtems*)                targ_emul=elf32ebmip ;;
@@ -399,7 +488,22 @@ mips*el-*-linux-*) targ_emul=elf32ltsmip
 mips*-*-linux-*)       targ_emul=elf32btsmip
                        targ_extra_emuls="elf32ltsmip elf32btsmipn32 elf64btsmip elf32ltsmipn32 elf64ltsmip"
                        targ_extra_libpath=$targ_extra_emuls ;;
-mips*-*-lnews*)                targ_emul=mipslnews ;;
+mips64*el-*-freebsd* | mips64*el-*-kfreebsd*-gnu)
+                       targ_emul=elf32ltsmipn32_fbsd
+                       targ_extra_emuls="elf32ltsmip elf32btsmip elf32ltsmipn32 elf32btsmipn32 elf64ltsmip elf64btsmip elf32ltsmip_fbsd elf32btsmip_fbsd elf32btsmipn32_fbsd elf64ltsmip_fbsd elf64btsmip_fbsd"
+                       targ_extra_libpath=$targ_extra_emuls ;;
+mips64*-*-freebsd* | mips64*-*-kfreebsd*-gnu)
+                       targ_emul=elf32btsmipn32_fbsd
+                       targ_extra_emuls="elf32ltsmip elf32btsmip elf32ltsmipn32 elf32btsmipn32 elf64ltsmip elf64btsmip elf32ltsmip_fbsd elf32btsmip_fbsd elf32ltsmipn32_fbsd elf64ltsmip_fbsd elf64btsmip_fbsd"
+                       targ_extra_libpath=$targ_extra_emuls ;;
+mips*el-*-freebsd* | mips*el-*-kfreebsd*-gnu)
+                       targ_emul=elf32ltsmip_fbsd
+                       targ_extra_emuls="elf32ltsmip elf32btsmip elf32ltsmipn32 elf32btsmipn32 elf64ltsmip elf64btsmip elf32ltsmipn32_fbsd elf32btsmip_fbsd elf32btsmipn32_fbsd elf64ltsmip_fbsd elf64btsmip_fbsd"
+                       targ_extra_libpath=$targ_extra_emuls ;;
+mips*-*-freebsd* | mips*-*-kfreebsd*-gnu)
+                       targ_emul=elf32btsmip_fbsd
+                       targ_extra_emuls="elf32ltsmip elf32btsmip elf32ltsmipn32 elf32btsmipn32 elf64ltsmip elf64btsmip elf32ltsmip_fbsd elf32btsmipn32_fbsd elf32ltsmipn32_fbsd elf64ltsmip_fbsd elf64btsmip_fbsd"
+                       targ_extra_libpath=$targ_extra_emuls ;;
 mips*-*-sysv4*)         targ_emul=elf32btsmip
                        ;;
 mmix-*-*)              targ_emul=mmo
@@ -412,16 +516,25 @@ mn10300-*-*)              targ_emul=mn10300
                        ;;
 mt-*elf)                targ_emul=elf32mt
                        ;;
-msp430-*-*)             targ_emul=msp430x110
-                        targ_extra_emuls="msp430x112 msp430x1101 msp430x1111 msp430x1121 msp430x1122 msp430x1132 msp430x122 msp430x123 msp430x1222 msp430x1232 msp430x133 msp430x135 msp430x1331 msp430x1351 msp430x147 msp430x148 msp430x149 msp430x155 msp430x156 msp430x157 msp430x167 msp430x168 msp430x169 msp430x1610 msp430x1611 msp430x1612 msp430x2101 msp430x2111 msp430x2121 msp430x2131 msp430x311 msp430x312 msp430x313 msp430x314 msp430x315 msp430x323 msp430x325 msp430x336 msp430x337 msp430x412 msp430x413 msp430x415 msp430x417 msp430xE423 msp430xE425 msp430xE427 msp430xW423 msp430xW425 msp430xW427 msp430xG437 msp430xG438 msp430xG439 msp430x435 msp430x436 msp430x437 msp430x447 msp430x448 msp430x449"
+msp430-*-*)             targ_emul=msp430
+                       targ_extra_emuls="msp430X"
+                       ;;
+nds32*le-*-elf*)       targ_emul=nds32elf
+                       targ_extra_emuls="nds32elf16m nds32belf nds32belf16m"
                        ;;
+nds32*be-*-elf*)       targ_emul=nds32belf
+                       targ_extra_emuls="nds32elf nds32elf16m nds32belf16m"
+                       ;;
+nds32*le-*-linux-gnu*) targ_emul=nds32elf_linux ;;
+nds32*be-*-linux-gnu*) targ_emul=nds32belf_linux ;;
+nios2*-*-linux*)       targ_emul=nios2linux ;;
+nios2*-*-*)            targ_emul=nios2elf ;;
 ns32k-pc532-mach* | ns32k-pc532-ux*)  targ_emul=pc532macha ;;
 ns32k-*-netbsd* | ns32k-pc532-lites*) targ_emul=ns32knbsd
                        ;;
-openrisc-*-*)          targ_emul=elf32openrisc ;;
-or32-*-coff)           targ_emul=or32 ;;
-or32-*-elf)            targ_emul=or32elf ;;
-or32-*-rtems*)          targ_emul=or32elf
+or1k-*-elf | or1knd-*-elf)             targ_emul=elf32or1k ;;
+or1k-*-linux* | or1knd-*-linux*)       targ_emul=elf32or1k_linux ;;
+or1k-*-rtems* | or1knd-*-rtems*)       targ_emul=elf32or1k
                        ;;
 pdp11-*-*)             targ_emul=pdp11
                        ;;
@@ -429,67 +542,73 @@ pjl*-*-*)         targ_emul=pjlelf ; targ_extra_emuls="elf_i386" ;;
 pj*-*-*)               targ_emul=pjelf
                        ;;
 powerpc-*-freebsd* | powerpc-*-kfreebsd*-gnu)
-                       targ_emul=elf32ppc_fbsd;
-                       targ_extra_emuls="elf32ppc elf32ppcsim";
+                       targ_emul=elf32ppc_fbsd
+                       targ_extra_emuls="elf32ppc elf32ppcsim"
                        targ_extra_libpath=elf32ppc;
                        tdir_elf32ppcsim=`echo ${targ_alias} | sed -e 's/ppc/ppcsim/'` ;;
-powerpc*-*-linux*)     case "${targ}" in
+powerpc64-*-freebsd*)
+                       targ_emul=elf64ppc_fbsd
+                       targ_extra_emuls="elf64ppc elf32ppc_fbsd elf32ppc"
+                       targ_extra_libpath="elf32ppc_fbsd elf32ppc"
+                       tdir_elf32ppc=`echo "${targ_alias}" | sed -e 's/64//'`
+                       tdir_elf32ppc_fbsd=$tdir_elf32ppc
+                       ;;
+powerpc-*-vxworks*)
+                       targ_emul=elf32ppcvxworks
+                       targ_extra_emuls="elf32ppc elf32ppclinux elf32ppcsim" ;;
+powerpc*-*-elf* | powerpc*-*-eabi* | powerpc*-*-sysv* \
+  | powerpc*-*-linux* | powerpc*-*-netbsd* | powerpc*-*-openbsd* \
+  | powerpc*-*-solaris* | powerpc*-*-kaos* | powerpc*-*-vxworks*)
+                       case "${targ}" in
                        *64*)   targ_emul=elf64ppc
-                               targ_extra_emuls="elf32ppclinux elf32ppc elf32ppcsim"
-                               targ_extra_libpath="elf32ppclinux elf32ppc"
-                               tdir_elf32ppc=`echo "${targ_alias}" | sed -e 's/64//'`
-                               tdir_elf32ppclinux=$tdir_elf32ppc
-                               tdir_elf32ppcsim=$tdir_elf32ppc
+                               targ_extra_emuls="elf32ppc elf32ppclinux elf32ppcsim"
+                               targ_extra_libpath="elf32ppc elf32ppclinux"
+                               td=tdir_elf32ppc
+                               case "${targ}" in
+                               powerpc*le-*) td=tdir_elf32lppc;;
+                               esac
+                               eval ${td}=`echo "${targ_alias}" | sed -e 's/64//'`
+                               eval ${td}linux=\$${td}
+                               eval ${td}sim=\$${td}
                                ;;
-                       *)      targ_emul=elf32ppclinux
+                       *linux*) targ_emul=elf32ppclinux
                                targ_extra_emuls="elf32ppc elf32ppcsim"
                                targ_extra_libpath=elf32ppc
                                targ64_extra_emuls=elf64ppc
                                targ64_extra_libpath=elf64ppc
                                ;;
-                       esac ;;
-powerpc*le-*-elf* | powerpc*le-*-eabi* | powerpc*le-*-solaris* \
-  | powerpc*le-*-sysv* | powerpc*le-*-vxworks*)
-                      case "${targ}" in
-                      *64*)    targ_emul=elf64lppc
-                               targ_extra_emuls="elf32lppc elf32lppcsim"
-                               tdir_elf32lppc=`echo "${targ_alias}" | sed -e 's/64//'`
-                               tdir_elf32lppcsim=$tdir_elf32lppc
-                               ;;
-                       *)      targ_emul=elf32lppc
-                               targ_extra_emuls="elf32ppcsim" ;;
-                       esac ;;
-powerpc*-*-elf* | powerpc*-*-eabi* | powerpc*-*-sysv* \
-  | powerpc*-*-netbsd* | powerpc-*-openbsd* | powerpc*-*-kaos*)
-                      case "${targ}" in
-                      *64*)    targ_emul=elf64ppc
-                               targ_extra_emuls="elf32ppc elf32ppclinux elf32ppcsim"
-                               tdir_elf32ppc=`echo "${targ_alias}" | sed -e 's/64//'`
-                               tdir_elf32ppclinux=$tdir_elf32ppc
-                               tdir_elf32ppcsim=$tdir_elf32ppc
-                               ;;
                        *)      targ_emul=elf32ppc
-                               targ_extra_emuls="elf32ppclinux elf32ppcsim" ;;
+                               targ_extra_emuls="elf32ppclinux elf32ppcsim"
+                               targ_extra_libpath=elf32ppclinux
+                               targ64_extra_emuls=elf64ppc
+                               targ64_extra_libpath=elf64ppc
+                               ;;
+                       esac
+                       case "${targ}" in
+                       powerpc*le-*)
+                               for z in targ_emul targ_extra_emuls targ_extra_libpath targ64_extra_emuls targ64_extra_libpath
+                               do
+                                 eval ${z}=\"`eval echo \\$${z} | sed -e 's/ppc/lppc/g'`\"
+                               done
                        esac ;;
-powerpc-*-vxworks*)
-                       targ_emul=elf32ppcvxworks
-                       targ_extra_emuls="elf32ppc elf32ppclinux elf32ppcsim" ;;
 powerpc-*-nto*)         targ_emul=elf32ppcnto ;;
 powerpcle-*-nto*)       targ_emul=elf32lppcnto ;;
 powerpc-*-rtems*)      targ_emul=elf32ppc ;;
 powerpc-*-macos*)      targ_emul=ppcmacos ;;
 powerpc-*-netware*)    targ_emul=ppcnw ;;
-powerpcle-*-pe)         targ_emul=ppcpe ;;
-powerpcle-*-winnt*)     targ_emul=ppcpe ;;
-powerpcle-*-cygwin*)    targ_emul=ppcpe ;;
-powerpc-*-aix5*)       targ_emul=aix5ppc ;;
+powerpcle-*-pe | powerpcle-*-winnt* | powerpcle-*-cygwin*)
+                       targ_emul=ppcpe
+                       targ_extra_ofiles="deffilep.o pe-dll.o" ;;
+powerpc-*-aix[5-9]*)   targ_emul=aix5ppc ;;
 powerpc-*-aix*)                targ_emul=aixppc ;;
 powerpc-*-beos*)       targ_emul=aixppc ;;
 powerpc-*-windiss*)    targ_emul=elf32ppcwindiss ;;
 powerpc-*-lynxos*)     targ_emul=ppclynx ;;
-rs6000-*-aix5*)                targ_emul=aix5rs6 ;;
+rs6000-*-aix[5-9]*)    targ_emul=aix5rs6 ;;
 rs6000-*-aix*)         targ_emul=aixrs6
                        ;;
+rl78-*-*)              targ_emul=elf32rl78 ;;
+rx-*-*)                        targ_emul=elf32rx ;;
 s390x-*-linux*)         targ_emul=elf64_s390
                        targ_extra_emuls=elf_s390
                        targ_extra_libpath=$targ_extra_emuls
@@ -501,7 +620,8 @@ s390-*-linux*)          targ_emul=elf_s390
                        targ64_extra_libpath=elf64_s390
                        tdir_elf64_s390=`echo ${targ_alias} | sed -e 's/s390/s390x/'`
                        ;;
-score-*-elf)            targ_emul=scoreelf ;;
+score-*-elf)            targ_emul=score7_elf
+                       targ_extra_emuls=score3_elf ;;
 sh-*-linux*)           targ_emul=shlelf_linux
                        targ_extra_emuls=shelf_linux
                        targ_extra_libpath=shelf_linux ;;
@@ -534,7 +654,7 @@ sh-*-elf* | sh[1234]*-*-elf | sh-*-rtems* | sh-*-kaos*)
                        targ_extra_emuls="shlelf sh shl" ;;
 sh-*-uclinux* | sh[12]-*-uclinux*)
                        targ_emul=shelf_uclinux
-                       targ_extra_emuls="shelf shlelf sh shl" ;;
+                       targ_extra_emuls="shelf shlelf sh shl shelf_fd shlelf_fd" ;;
 sh-*-vxworks)          targ_emul=shelf_vxworks
                        targ_extra_emuls=shlelf_vxworks ;;
 sh-*-nto*)             targ_emul=shelf_nto
@@ -550,6 +670,7 @@ sh64-*-elf*)                targ_emul=shelf
                        targ_extra_libpath=$targ_extra_emuls ;;
 sparc64-*-aout*)       targ_emul=sparcaout ;;
 sparc64-*-elf*)                targ_emul=elf64_sparc ;;
+sparc64-*-rtems*)      targ_emul=elf64_sparc ;;
 sparc-sun-sunos4*)     targ_emul=sun4 ;;
 sparclite*-*-elf)      targ_emul=elf32_sparc ;;
 sparclite*-*-coff)     targ_emul=coff_sparc ;;
@@ -586,30 +707,45 @@ sparc64-*-netbsd* | sparc64-*-openbsd*)
 sparc*-*-netbsd*elf*)  targ_emul=elf32_sparc ;;
 sparc*-*-netbsd*)      targ_emul=sparcnbsd ;;
 sparc-*-solaris2.[0-6] | sparc-*-solaris2.[0-6].*)
-                       targ_emul=elf32_sparc ;;
-sparc-*-solaris2*)     targ_emul=elf32_sparc
-                       targ_extra_emuls="elf64_sparc"
+                       targ_emul=elf32_sparc_sol2
+                       targ_extra_emuls=elf32_sparc ;;
+sparc-*-solaris2*)     targ_emul=elf32_sparc_sol2
+                       targ_extra_emuls="elf32_sparc elf64_sparc_sol2 elf64_sparc"
                        targ_extra_libpath=$targ_extra_emuls
                        tdir_elf64_sparc=`echo ${targ_alias} | sed -e 's/32//'` ;;
 sparcv9-*-solaris2* | sparc64-*-solaris2*)
-                       targ_emul=elf64_sparc
-                       targ_extra_emuls="elf32_sparc"
+                       targ_emul=elf64_sparc_sol2
+                       targ_extra_emuls="elf64_sparc elf32_sparc_sol2 elf32_sparc"
                        targ_extra_libpath=$targ_extra_emuls
                        tdir_elf32_sparc=`echo ${targ_alias} | sed -e 's/64//'` ;;
 sparc*-*-solaris2*)    targ_emul=elf32_sparc ;;
 sparc*-wrs-vxworks*)   targ_emul=sparcaout ;;
-sparc*-*-rtems*)        targ_emul=elf32_sparc
+sparc-*-rtems*)                targ_emul=elf32_sparc
                        ;;
 spu-*-elf*)            targ_emul=elf32_spu ;;
 tic30-*-*aout*)                targ_emul=tic30aout ;;
 tic30-*-*coff*)                targ_emul=tic30coff ;;
 tic4x-*-* | c4x-*-*)    targ_emul=tic4xcoff ; targ_extra_emuls="tic3xcoff tic3xcoff_onchip" ;;
 tic54x-*-* | c54x*-*-*)        targ_emul=tic54xcoff ;;
+tic6x-*-elf)           targ_emul=elf32_tic6x_elf_le
+                       targ_extra_emuls="elf32_tic6x_elf_be elf32_tic6x_le elf32_tic6x_be"
+                       targ_extra_libpath=$targ_extra_emuls
+                       ;;
+tic6x-*-uclinux)       targ_emul=elf32_tic6x_linux_le
+                       targ_extra_emuls="elf32_tic6x_linux_be elf32_tic6x_le elf32_tic6x_be"
+                       targ_extra_libpath=$targ_extra_emuls
+                       ;;
 tic80-*-*)             targ_emul=tic80coff
                        ;;
-v850-*-*)              targ_emul=v850 ;;
-v850e-*-*)             targ_emul=v850 ;;
-v850ea-*-*)            targ_emul=v850
+tilegx-*-*)            targ_emul=elf64tilegx
+                       targ_extra_emuls="elf64tilegx_be elf32tilegx elf32tilegx_be"
+                       targ_extra_libpath=$targ_extra_emuls ;;
+tilegxbe-*-*)          targ_emul=elf64tilegx_be
+                       targ_extra_emuls="elf64tilegx elf32tilegx elf32tilegx_be"
+                       targ_extra_libpath=$targ_extra_emuls ;;
+tilepro-*-*)           targ_emul=elf32tilepro ;;
+v850*-*-*)             targ_emul=v850_rh850
+                       targ_extra_emuls=v850
                        ;;
 vax-dec-ultrix* | vax-dec-bsd*) targ_emul=vax ;;
 vax-*-netbsdelf*)      targ_emul=elf32vax
@@ -619,15 +755,19 @@ vax-*-netbsdaout* | vax-*-netbsd*)
                        targ_extra_emuls=elf32vax ;;
 vax-*-linux-*)         targ_emul=elf32vax
                        ;;
+visium-*-elf)          targ_emul=elf32visium
+                       ;;
 w65-*-*)               targ_emul=w65
                        ;;
-xc16x-*-elf)           targ_emul=elf32xc16x 
+xc16x-*-elf)           targ_emul=elf32xc16x
                         targ_extra_emuls="elf32xc16xl elf32xc16xs"
                         ;;
 xstormy16-*-*)         targ_emul=elf32xstormy16
                        ;;
 xtensa*-*-*)           targ_emul=elf32xtensa
                        ;;
+xgate-*-*)             targ_emul=xgateelf
+                       ;;
 z80-*-coff)            targ_emul=z80
                        ;;
 z8k-*-coff)            targ_emul=z8002; targ_extra_emuls=z8001
@@ -646,7 +786,11 @@ esac
 NATIVE_LIB_DIRS='/usr/local/lib /lib /usr/lib'
 case "${target}" in
 
-*-*-freebsd* | *-*-dragonfly*)
+*-*-dragonfly*)
+  NATIVE_LIB_DIRS='/lib /usr/lib /usr/pkg/lib /usr/local/lib'
+  ;;
+
+*-*-freebsd*)
   NATIVE_LIB_DIRS='/lib /usr/lib /usr/local/lib'
   ;;
 
@@ -676,19 +820,16 @@ sparc*-*-solaris2*)
 
 spu-*-elf*)
   # This allows to build a pair of PPU/SPU toolchains with common sysroot.
-  NATIVE_LIB_DIRS='/usr/spu/lib'
+  NATIVE_LIB_DIRS='/lib'
   ;;
 
-i[03-9x]86-*-cygwin*)
+i[03-9x]86-*-cygwin* | x86_64-*-cygwin*)
   NATIVE_LIB_DIRS='/usr/lib /usr/lib/w32api'
   ;;
 
 *-*-linux*)
   ;;
 
-*-*-freebsd* | *-*-dragonfly*)
-  ;;
-
 *-*-netbsd*)
   ;;
 
This page took 0.033425 seconds and 4 git commands to generate.