1999-05-03 15:29:11 +08:00
|
|
|
dnl Process this file with autoconf to produce a configure script.
|
|
|
|
dnl
|
|
|
|
dnl And be careful when changing it! If you must add tests with square
|
|
|
|
dnl brackets, be sure changequote invocations surround it.
|
|
|
|
dnl
|
|
|
|
dnl
|
|
|
|
dnl v2.5 needed for --bindir et al
|
2003-09-03 01:59:13 +08:00
|
|
|
AC_PREREQ(2.57)
|
1999-05-03 15:29:11 +08:00
|
|
|
AC_INIT(as.h)
|
|
|
|
|
2003-09-03 01:59:13 +08:00
|
|
|
dnl Autoconf 2.57 will find the aux dir without this. However, unless
|
|
|
|
dnl we specify this explicitly, automake-1.7 will assume that ylwrap is in
|
|
|
|
dnl gas/ instead of gas/../.
|
|
|
|
AC_CONFIG_AUX_DIR(..)
|
1999-05-03 15:29:11 +08:00
|
|
|
AC_CANONICAL_SYSTEM
|
2000-09-08 05:08:51 +08:00
|
|
|
AC_ISC_POSIX
|
1999-05-03 15:29:11 +08:00
|
|
|
|
2001-02-27 14:43:56 +08:00
|
|
|
changequote(,)dnl
|
|
|
|
BFD_VERSION=`sed -n -e 's/^.._INIT_AUTOMAKE.*,[ ]*\([^ ]*\)[ ]*).*/\1/p' < ${srcdir}/../bfd/configure.in`
|
|
|
|
changequote([,])dnl
|
|
|
|
AM_INIT_AUTOMAKE(gas, ${BFD_VERSION})
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
AM_PROG_LIBTOOL
|
|
|
|
|
|
|
|
user_bfd_gas=
|
|
|
|
AC_ARG_ENABLE(bfd-assembler,
|
|
|
|
[ --enable-bfd-assembler use BFD back end for writing object files],
|
|
|
|
[case "${enableval}" in
|
|
|
|
yes) need_bfd=yes user_bfd_gas=yes ;;
|
|
|
|
no) user_bfd_gas=no ;;
|
|
|
|
*) AC_MSG_ERROR(bad value ${enableval} given for bfd-assembler option) ;;
|
|
|
|
esac])dnl
|
|
|
|
AC_ARG_ENABLE(targets,
|
|
|
|
[ targets alternative target configurations besides the primary],
|
|
|
|
[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(commonbfdlib,
|
|
|
|
[ --enable-commonbfdlib build shared BFD/opcodes/libiberty library],
|
|
|
|
[case "${enableval}" in
|
|
|
|
yes) commonbfdlib=true ;;
|
|
|
|
no) commonbfdlib=false ;;
|
|
|
|
*) AC_MSG_ERROR([bad value ${enableval} for BFD commonbfdlib option]) ;;
|
|
|
|
esac])dnl
|
|
|
|
|
|
|
|
using_cgen=no
|
|
|
|
|
2001-08-10 18:56:47 +08:00
|
|
|
build_warnings="-W -Wall -Wstrict-prototypes -Wmissing-prototypes"
|
2000-04-09 20:17:43 +08:00
|
|
|
AC_ARG_ENABLE(build-warnings,
|
|
|
|
[ --enable-build-warnings Enable build-time compiler warnings if gcc is used],
|
|
|
|
[case "${enableval}" in
|
|
|
|
yes) ;;
|
|
|
|
no) build_warnings="-w";;
|
|
|
|
,*) t=`echo "${enableval}" | sed -e "s/,/ /g"`
|
|
|
|
build_warnings="${build_warnings} ${t}";;
|
|
|
|
*,) t=`echo "${enableval}" | sed -e "s/,/ /g"`
|
|
|
|
build_warnings="${t} ${build_warnings}";;
|
|
|
|
*) build_warnings=`echo "${enableval}" | sed -e "s/,/ /g"`;;
|
|
|
|
esac
|
|
|
|
if test x"$silent" != x"yes" && test x"$build_warnings" != x""; then
|
|
|
|
echo "Setting warning flags = $build_warnings" 6>&1
|
|
|
|
fi])dnl
|
|
|
|
WARN_CFLAGS=""
|
|
|
|
if test "x${build_warnings}" != x -a "x$GCC" = xyes ; then
|
|
|
|
WARN_CFLAGS="${build_warnings}"
|
|
|
|
fi
|
|
|
|
AC_SUBST(WARN_CFLAGS)
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
# Generate a header file
|
|
|
|
AM_CONFIG_HEADER(config.h:config.in)
|
|
|
|
|
1999-08-08 23:56:55 +08:00
|
|
|
# If we are on a DOS filesystem, we must use gdb.ini rather than
|
|
|
|
# .gdbinit.
|
|
|
|
case "${host}" in
|
2002-11-12 01:21:33 +08:00
|
|
|
*-*-msdos* | *-*-go32* | *-*-mingw32* | *-*-windows*)
|
1999-08-08 23:56:55 +08:00
|
|
|
GDBINIT="gdb.ini"
|
2003-09-03 01:59:13 +08:00
|
|
|
AC_CONFIG_FILES(gdb.ini:gdbinit.in)
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
GDBINIT=".gdbinit"
|
|
|
|
AC_CONFIG_FILES(.gdbinit:gdbinit.in)
|
1999-08-08 23:56:55 +08:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
AC_SUBST(GDBINIT)
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
te_file=generic
|
|
|
|
|
|
|
|
# Makefile target for installing gas in $(tooldir)/bin.
|
|
|
|
install_tooldir=install-exec-tooldir
|
|
|
|
|
|
|
|
canon_targets=""
|
2000-03-03 04:15:33 +08:00
|
|
|
all_targets=no
|
1999-05-03 15:29:11 +08:00
|
|
|
if test -n "$enable_targets" ; then
|
|
|
|
for t in `echo $enable_targets | sed 's/,/ /g'`; do
|
2000-03-03 04:15:33 +08:00
|
|
|
if test $t = "all"; then
|
|
|
|
all_targets=yes
|
|
|
|
continue
|
|
|
|
fi
|
1999-09-15 07:29:35 +08:00
|
|
|
result=`$ac_config_sub $t 2>/dev/null`
|
1999-05-03 15:29:11 +08:00
|
|
|
if test -n "$result" ; then
|
|
|
|
canon_targets="$canon_targets $result"
|
|
|
|
# else
|
|
|
|
# # Permit "all", etc. We don't support it yet though.
|
|
|
|
# canon_targets="$canon_targets $t"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
GAS_UNIQ(canon_targets)
|
|
|
|
fi
|
|
|
|
|
|
|
|
emulations=""
|
|
|
|
|
|
|
|
for this_target in $target $canon_targets ; do
|
|
|
|
|
|
|
|
changequote(,)dnl
|
|
|
|
eval `echo $this_target | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/cpu=\1 vendor=\2 os=\3/'`
|
|
|
|
changequote([,])dnl
|
|
|
|
|
|
|
|
# check for architecture variants
|
|
|
|
arch=
|
|
|
|
endian=
|
|
|
|
case ${cpu} in
|
2003-07-10 12:44:56 +08:00
|
|
|
am33_2.0) cpu_type=mn10300 endian=little ;;
|
1999-05-03 15:29:11 +08:00
|
|
|
alpha*) cpu_type=alpha ;;
|
2002-10-31 01:05:41 +08:00
|
|
|
arm*b|xscale*b|strongarm*b) cpu_type=arm endian=big ;;
|
|
|
|
arm*|xscale*|strongarm*) cpu_type=arm endian=little ;;
|
2003-06-18 17:49:59 +08:00
|
|
|
c4x*) cpu_type=tic4x ;;
|
1999-05-03 15:29:11 +08:00
|
|
|
hppa*) cpu_type=hppa ;;
|
|
|
|
changequote(,)dnl
|
2003-05-17 00:30:27 +08:00
|
|
|
i[3-7]86) cpu_type=i386 arch=i386;;
|
2000-12-31 02:05:10 +08:00
|
|
|
x86_64) cpu_type=i386 arch=x86_64;;
|
2000-04-22 04:22:24 +08:00
|
|
|
ia64) cpu_type=ia64 ;;
|
2002-07-19 15:52:40 +08:00
|
|
|
ip2k) cpu_type=ip2k endian=big ;;
|
2003-01-04 05:47:21 +08:00
|
|
|
iq2000) cpu_type=iq2000 endian=big ;;
|
2000-10-28 02:57:33 +08:00
|
|
|
m6811|m6812|m68hc12) cpu_type=m68hc11 ;;
|
1999-05-03 15:29:11 +08:00
|
|
|
m680[012346]0) cpu_type=m68k ;;
|
|
|
|
changequote([,])dnl
|
|
|
|
m68008) cpu_type=m68k ;;
|
|
|
|
m683??) cpu_type=m68k ;;
|
|
|
|
m5200) cpu_type=m68k ;;
|
|
|
|
m8*) cpu_type=m88k ;;
|
|
|
|
mips*el) cpu_type=mips endian=little ;;
|
|
|
|
mips*) cpu_type=mips endian=big ;;
|
2002-02-01 01:33:08 +08:00
|
|
|
or32*) cpu_type=or32 endian=big ;;
|
1999-09-05 01:29:22 +08:00
|
|
|
pjl*) cpu_type=pj endian=little ;;
|
|
|
|
pj*) cpu_type=pj endian=big ;;
|
* configure.in: Recognise powerpc*le*, not just powerpcle*.
* configure: Regenerate.
* config/tc-ppc.c (PPC_LO, PPC_HI, PPC_HA, PPC_HIGHER,
PPC_HIGHERA, PPC_HIGHEST, PPC_HIGHESTA, SEX16): New macros.
(md_assemble): Use them.
(ppc_machine): Support stub for ELF64 as well as XCOFF.
(md_pseudo_table): Add "llong", "quad".
(md_parse_option): Match default_cpu of powerpc*.
(ppc_arch): Likewise.
(ppc_subseg_align): Only for OBJ_XCOFF.
(ppc_target_format): Return elf64-powerpc strings for 64 bit ELF.
(md_begin): Select PPC_OPCODE_64 for 64 bit.
(ppc_insert_operand): Don't bother testing 'file' before calling
as_bad_where. Use as_bad_where for operand->insert errors.
(mapping): Add ELF64 relocation modifiers.
(ppc_elf_suffix): Replace symbol on BFD_RELOC_PPC64_TOC reloc
expressions with abs_symbol.
(ppc_elf_cons): Correct offset for little endian targets.
(ppc_elf_frob_symbol): New.
(md_assemble): Add support for 64 bit ELF relocs.
(ppc_tc): Ensure 8 byte alignment when 64 bit.
(ppc_is_toc_sym): Only define for OBJ_XCOFF and OBJ_ELF. Match
".toc" section for 64 bit ELF.
(ppc_fix_adjustable): New. Macro body moved from tc-ppc.h.
(md_apply_fix3): Silence warning with ATTRIBUTE_UNUSED. Only do
the ppc_is_toc_sym check for OBJ_XCOFF and OBJ_ELF. For 64 bit,
use BFD_RELOC_PPC64_TOC16_DS instead of BFD_RELOC_PPC_TOC16.
Expand on comments, error message. Add support for 64 bit relocs,
and use PPC_HI etc. macros.
* config/tc-ppc.h (MAX_MEM_FOR_RS_ALIGN_CODE): Define.
(HANDLE_ALIGN): Define to generate nops in code sections rather
than zeros.
(TC_FORCE_RELOCATION): Force for BFD_RELOC_PPC64_TOC.
(ELF_TC_SPECIAL_SECTIONS): Add 64 bit ELF sections.
(tc_fix_adjustable): Move body of macro to tc-ppc.c.
(ppc_fix_adjustable): Declare.
(tc_frob_symbol): Define.
(ppc_elf_frob_symbol): Declare.
2001-08-27 18:42:16 +08:00
|
|
|
powerpc*le*) cpu_type=ppc endian=little ;;
|
1999-05-03 15:29:11 +08:00
|
|
|
powerpc*) cpu_type=ppc endian=big ;;
|
|
|
|
rs6000*) cpu_type=ppc ;;
|
2001-02-10 08:58:38 +08:00
|
|
|
s390x*) cpu_type=s390 arch=s390x ;;
|
|
|
|
s390*) cpu_type=s390 arch=s390 ;;
|
bfd:
* Makefile.am (BFD32_BACKENDS): Add elf32-sh64-nbsd.lo.
(BFD32_BACKENDS_CFILES): Add elf32-sh64-nbsd.c.
(BFD64_BACKENDS): Add elf64-sh64-nbsd.lo.
(BFD64_BACKENDS_CFILES): Add elf64-sh64-nbsd.c.
(elf32-sh64-nbsd.lo, elf64-sh64-nbsd.lo): New rules.
* Makefile.in: Regenerate.
* config.bfd (sh5le-*-netbsd*, sh5-*-netbsd*, sh64le-*-netbsd*)
(sh64-*-netbsd*): New targets.
* configure.in: Add bfd_elf32_sh64nbsd_vec, bfd_elf32_sh64lnbsd_vec,
bfd_elf64_sh64nbsd_vec, and bfd_elf64_sh64lnbsd_vec.
* configure: Regenerate.
* elf32-sh64-nbsd.c: New file.
* elf64-sh64-nbsd.c: New file.
* targets.c: Add extern decls for bfd_elf32_sh64nbsd_vec,
bfd_elf32_sh64lnbsd_vec, bfd_elf64_sh64nbsd_vec, and
bfd_elf64_sh64lnbsd_vec.
gas:
* configure.in (sh5*): Set cpu_type to sh64 and endian to big.
(sh5le*, sh64le*): Set cpu_type to sh64 and endian to little.
(sh5*-*-netbsd*, sh64*-*-netbsd*): New targets.
* configure: Regenerate.
* config/tc-sh64.c (sh64_target_format): Add support for NetBSD
environment.
ld:
* Makefile.am (ALL_EMULATIONS): Add eshelf32_nbsd.o,
eshlelf32_nbsd.o, eshelf64_nbsd.o, and eshlelf64_nbsd.o.
(eshelf32_nbsd.c, eshelf64_nbsd.c, eshlelf32_nbsd.c)
(eshlelf64_nbsd.c): New rules.
* Makefile.in: Regenerate.
* configure.tgt (sh5le-*-netbsd*, sh5-*-netbsd*, sh64le-*-netbsd*)
(sh64-*-netbsd*): New targets.
* emulparams/shelf32_nbsd.sh: New file.
* emulparams/shelf64_nbsd.sh: New file.
* emulparams/shlelf32_nbsd.sh: New file.
* emulparams/shlelf64_nbsd.sh: New file.
opcodes:
* configure.in: Add "sh5*-*" to list of targets which include
sh64 support.
* configure: Regenerate.
2002-06-04 10:57:44 +08:00
|
|
|
sh5*) cpu_type=sh64 endian=big ;;
|
|
|
|
sh5le*) cpu_type=sh64 endian=little ;;
|
|
|
|
sh64*) cpu_type=sh64 endian=big ;;
|
|
|
|
sh64le*) cpu_type=sh64 endian=little ;;
|
2002-01-08 12:23:02 +08:00
|
|
|
sh*le) cpu_type=sh endian=little ;;
|
2001-10-16 10:36:20 +08:00
|
|
|
sh*) cpu_type=sh endian=big ;;
|
1999-05-03 15:29:11 +08:00
|
|
|
sparclite*) cpu_type=sparc arch=sparclite ;;
|
|
|
|
sparclet*) cpu_type=sparc arch=sparclet ;;
|
|
|
|
sparc64*) cpu_type=sparc arch=v9-64 ;;
|
|
|
|
sparc86x*) cpu_type=sparc arch=sparc86x ;;
|
|
|
|
sparc*) cpu_type=sparc arch=sparclite ;; # ??? See tc-sparc.c.
|
|
|
|
v850*) cpu_type=v850 ;;
|
2003-04-01 23:50:31 +08:00
|
|
|
xtensa*) cpu_type=xtensa arch=xtensa ;;
|
1999-05-03 15:29:11 +08:00
|
|
|
*) cpu_type=${cpu} ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
if test ${this_target} = $target ; then
|
|
|
|
target_cpu_type=${cpu_type}
|
|
|
|
elif test ${target_cpu_type} != ${cpu_type} ; then
|
|
|
|
continue
|
|
|
|
fi
|
|
|
|
|
|
|
|
generic_target=${cpu_type}-$vendor-$os
|
|
|
|
dev=no
|
|
|
|
bfd_gas=no
|
|
|
|
em=generic
|
|
|
|
|
|
|
|
# assign object format
|
|
|
|
case ${generic_target} in
|
2002-08-09 11:42:15 +08:00
|
|
|
a29k-*-coff) fmt=coff ;;
|
|
|
|
a29k-amd-udi) fmt=coff ;;
|
|
|
|
a29k-amd-ebmon) fmt=coff ;;
|
|
|
|
a29k-nyu-sym1) fmt=coff ;;
|
|
|
|
a29k-*-rtems*) fmt=coff ;;
|
|
|
|
a29k-*-vxworks*) fmt=coff ;;
|
|
|
|
|
|
|
|
alpha*-*-*vms*) fmt=evax ;;
|
|
|
|
alpha*-*-netware*) fmt=ecoff ;;
|
|
|
|
alpha*-*-osf*) fmt=ecoff ;;
|
|
|
|
alpha*-*-linuxecoff*) fmt=ecoff ;;
|
|
|
|
alpha*-*-linux-gnu*) fmt=elf em=linux ;;
|
|
|
|
alpha*-*-netbsd*) fmt=elf em=nbsd ;;
|
|
|
|
alpha*-*-openbsd*) fmt=elf em=obsd ;;
|
|
|
|
|
2003-07-10 12:44:56 +08:00
|
|
|
# cpu_type for am33_2.0 is set to mn10300
|
|
|
|
mn10300-*-linux*) fmt=elf bfd_gas=yes em=linux ;;
|
|
|
|
|
2002-08-09 11:42:15 +08:00
|
|
|
arc-*-elf*) fmt=elf ;;
|
|
|
|
|
|
|
|
arm-*-aout) fmt=aout ;;
|
|
|
|
arm-*-coff | thumb-*-coff) fmt=coff ;;
|
2003-09-16 08:45:49 +08:00
|
|
|
arm-*-rtems* | thumb-*-rtems*) fmt=elf ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
arm-*-elf | thumb-*-elf) fmt=elf ;;
|
2003-02-11 21:47:08 +08:00
|
|
|
arm-*-kaos*) fmt=elf ;;
|
2000-01-11 03:48:27 +08:00
|
|
|
arm*-*-conix*) fmt=elf ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
arm-*-linux*aout*) fmt=aout em=linux ;;
|
|
|
|
arm*-*-linux-gnu*) fmt=elf em=linux ;;
|
|
|
|
arm*-*-uclinux*) fmt=elf em=linux ;;
|
2001-12-20 11:19:03 +08:00
|
|
|
arm-*-netbsdelf*) fmt=elf em=nbsd ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
arm-*-*n*bsd*) fmt=aout em=nbsd ;;
|
|
|
|
arm-**-nto*) fmt=elf ;;
|
|
|
|
arm-*-oabi | thumb-*-oabi) fmt=elf ;;
|
|
|
|
arm-epoc-pe | thumb-epoc-pe) fmt=coff em=epoc-pe ;;
|
2003-11-11 20:05:08 +08:00
|
|
|
arm-wince-pe | arm-*-wince) fmt=coff em=wince-pe ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
arm-*-pe | thumb-*-pe) fmt=coff em=pe ;;
|
|
|
|
arm-*-riscix*) fmt=aout em=riscix ;;
|
|
|
|
|
|
|
|
avr-*-*) fmt=elf ;;
|
|
|
|
|
2003-06-16 08:38:58 +08:00
|
|
|
cris-*-linux-gnu*) fmt=multi bfd_gas=yes em=linux ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
cris-*-*) fmt=multi bfd_gas=yes ;;
|
|
|
|
|
|
|
|
d10v-*-*) fmt=elf ;;
|
|
|
|
d30v-*-*) fmt=elf ;;
|
|
|
|
dlx-*-*) fmt=elf ;;
|
|
|
|
|
|
|
|
fr30-*-*) fmt=elf ;;
|
|
|
|
frv-*-*) fmt=elf ;;
|
|
|
|
|
|
|
|
hppa-*-linux*) case ${cpu} in
|
|
|
|
hppa*64*) fmt=elf em=hppalinux64;;
|
|
|
|
hppa*) fmt=elf em=linux;;
|
|
|
|
esac ;;
|
|
|
|
hppa-*-*elf*) fmt=elf em=hppa ;;
|
|
|
|
hppa-*-lites*) fmt=elf em=hppa ;;
|
|
|
|
hppa-*-netbsd*) fmt=elf em=nbsd ;;
|
|
|
|
hppa-*-openbsd*) fmt=elf em=hppa ;;
|
|
|
|
hppa-*-osf*) fmt=som em=hppa ;;
|
|
|
|
hppa-*-rtems*) fmt=elf em=hppa ;;
|
|
|
|
hppa-*-hpux11*) case ${cpu} in
|
|
|
|
hppa*64*) fmt=elf em=hppa64 ;;
|
|
|
|
hppa*) fmt=som em=hppa ;;
|
|
|
|
esac ;;
|
|
|
|
hppa-*-hpux*) fmt=som em=hppa ;;
|
|
|
|
hppa-*-mpeix*) fmt=som em=hppa ;;
|
|
|
|
hppa-*-bsd*) fmt=som em=hppa ;;
|
|
|
|
hppa-*-hiux*) fmt=som em=hppa ;;
|
|
|
|
|
|
|
|
h8300-*-rtems*) fmt=coff ;;
|
|
|
|
h8300-*-coff) fmt=coff ;;
|
|
|
|
h8300-*-elf) fmt=elf ;;
|
|
|
|
h8500-*-rtems*) fmt=coff ;;
|
|
|
|
h8500-*-coff) fmt=coff ;;
|
|
|
|
|
|
|
|
i370-*-elf* | i370-*-linux*) fmt=elf ;;
|
|
|
|
i386-ibm-aix*) fmt=coff em=i386aix ;;
|
|
|
|
i386-sequent-bsd*) fmt=aout em=dynix ;;
|
|
|
|
i386-*-beospe*) fmt=coff em=pe ;;
|
|
|
|
i386-*-beos*) fmt=elf ;;
|
|
|
|
i386-*-coff) fmt=coff ;;
|
|
|
|
i386-*-elf) fmt=elf ;;
|
2003-02-11 21:47:08 +08:00
|
|
|
i386-*-kaos*) fmt=elf ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
i386-*-bsd*) fmt=aout em=386bsd ;;
|
|
|
|
i386-*-netbsd0.8) fmt=aout em=386bsd ;;
|
|
|
|
i386-*-netbsdpe*) fmt=coff em=pe ;;
|
2003-10-06 17:12:39 +08:00
|
|
|
i386-*-netbsd*-gnu* | \
|
|
|
|
i386-*-knetbsd*-gnu | \
|
2002-08-09 11:42:15 +08:00
|
|
|
i386-*-netbsdelf*) fmt=elf em=nbsd ;;
|
|
|
|
i386-*-*n*bsd*) case ${cpu} in
|
|
|
|
x86_64) fmt=elf em=nbsd ;;
|
|
|
|
*) fmt=aout em=nbsd ;;
|
|
|
|
esac ;;
|
|
|
|
i386-*-linux*aout*) fmt=aout em=linux ;;
|
|
|
|
i386-*-linux*oldld) fmt=aout em=linux ;;
|
|
|
|
i386-*-linux*coff*) fmt=coff em=linux ;;
|
|
|
|
i386-*-linux-gnu*) fmt=elf em=linux ;;
|
|
|
|
x86_64-*-linux-gnu*) fmt=elf em=linux ;;
|
|
|
|
i386-*-lynxos*) fmt=coff em=lynx ;;
|
2000-05-23 16:53:54 +08:00
|
|
|
changequote(,)dnl
|
2002-08-09 11:42:15 +08:00
|
|
|
i386-*-sysv[45]*) fmt=elf ;;
|
|
|
|
i386-*-solaris*) fmt=elf ;;
|
|
|
|
i386-*-freebsdaout*) fmt=aout em=386bsd ;;
|
|
|
|
i386-*-freebsd[12].*) fmt=aout em=386bsd ;;
|
|
|
|
i386-*-freebsd[12]) fmt=aout em=386bsd ;;
|
2000-05-23 16:53:54 +08:00
|
|
|
changequote([,])dnl
|
2003-09-03 17:32:21 +08:00
|
|
|
i386-*-freebsd* | i386-*-kfreebsd*-gnu)
|
|
|
|
fmt=elf em=freebsd ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
i386-*-sysv*) fmt=coff ;;
|
|
|
|
i386-*-sco3.2v5*coff) fmt=coff ;;
|
|
|
|
i386-*-isc*) fmt=coff ;;
|
|
|
|
i386-*-sco3.2v5*) fmt=elf
|
|
|
|
if test ${this_target} = $target; then
|
|
|
|
AC_DEFINE(SCO_ELF, 1, [Define if defaulting to ELF on SCO 5.])
|
|
|
|
fi ;;
|
|
|
|
i386-*-sco3.2*) fmt=coff ;;
|
|
|
|
i386-*-vsta) fmt=aout ;;
|
|
|
|
i386-*-msdosdjgpp* \
|
|
|
|
| i386-*-go32* \
|
|
|
|
| i386-go32-rtems*) fmt=coff em=go32
|
|
|
|
AC_DEFINE(STRICTCOFF, 1, [Using strict COFF?]) ;;
|
|
|
|
i386-*-rtemself*) fmt=elf ;;
|
|
|
|
i386-*-rtemscoff*) fmt=coff ;;
|
|
|
|
i386-*-rtems*) fmt=elf ;;
|
|
|
|
i386-*-gnu*) fmt=elf ;;
|
|
|
|
i386-*-mach*) fmt=aout em=mach ;;
|
|
|
|
i386-*-msdos*) fmt=aout ;;
|
|
|
|
i386-*-moss*) fmt=elf ;;
|
|
|
|
i386-*-pe) fmt=coff em=pe ;;
|
|
|
|
i386-*-cygwin*) fmt=coff em=pe ;;
|
|
|
|
i386-*-interix*) fmt=coff em=interix ;;
|
|
|
|
i386-*-mingw32*) fmt=coff em=pe ;;
|
|
|
|
i386-*-nto-qnx*) fmt=elf ;;
|
|
|
|
i386-*-*nt*) fmt=coff em=pe ;;
|
|
|
|
i386-*-chaos) fmt=elf ;;
|
|
|
|
|
|
|
|
i860-*-*) fmt=elf endian=little
|
|
|
|
AC_MSG_WARN(GAS support for ${generic_target} is preliminary and a work in progress) ;;
|
|
|
|
i960-*-bout) fmt=bout ;;
|
|
|
|
i960-*-coff) fmt=coff em=ic960 ;;
|
|
|
|
i960-*-rtems*) fmt=coff em=ic960 ;;
|
|
|
|
i960-*-nindy*) fmt=bout ;;
|
|
|
|
i960-*-vxworks5.0) fmt=bout ;;
|
|
|
|
i960-*-vxworks5.*) fmt=coff em=ic960 ;;
|
|
|
|
i960-*-vxworks*) fmt=bout ;;
|
|
|
|
i960-*-elf*) fmt=elf ;;
|
|
|
|
|
|
|
|
ia64-*-elf*) fmt=elf ;;
|
|
|
|
ia64-*-aix*) fmt=elf em=ia64aix ;;
|
|
|
|
ia64-*-linux-gnu*) fmt=elf em=linux ;;
|
|
|
|
ia64-*-hpux*) fmt=elf em=hpux ;;
|
|
|
|
ia64-*-netbsd*) fmt=elf em=nbsd ;;
|
|
|
|
|
|
|
|
ip2k-*-*) fmt=elf ;;
|
|
|
|
|
2003-01-04 05:47:21 +08:00
|
|
|
iq2000-*-elf) fmt=elf bfd_gas=yes ;;
|
|
|
|
|
2002-08-09 11:42:15 +08:00
|
|
|
m32r-*-*) fmt=elf ;;
|
|
|
|
|
|
|
|
m68hc11-*-* | m6811-*-*) fmt=elf ;;
|
|
|
|
m68hc12-*-* | m6812-*-*) fmt=elf ;;
|
|
|
|
|
|
|
|
m68k-*-vxworks*) fmt=aout em=sun3 ;;
|
|
|
|
m68k-ericsson-ose) fmt=aout em=sun3 ;;
|
|
|
|
m68k-*-sunos*) fmt=aout em=sun3 ;;
|
|
|
|
m68k-motorola-sysv*) fmt=coff em=delta ;;
|
|
|
|
m68k-bull-sysv3*) fmt=coff em=dpx2 ;;
|
|
|
|
m68k-apollo-*) fmt=coff em=apollo ;;
|
|
|
|
m68k-*-elf*) fmt=elf ;;
|
|
|
|
m68k-*-sysv4*) fmt=elf em=svr4 ;;
|
|
|
|
m68k-*-sysv*) fmt=coff ;;
|
|
|
|
m68k-*-coff | m68k-*-rtemscoff*) fmt=coff ;;
|
|
|
|
m68k-*-rtems*) fmt=elf ;;
|
|
|
|
m68k-*-hpux*) fmt=hp300 em=hp300 ;;
|
|
|
|
m68k-*-linux*aout*) fmt=aout em=linux ;;
|
|
|
|
m68k-*-linux-gnu*) fmt=elf em=linux ;;
|
|
|
|
m68k-*-gnu*) fmt=elf ;;
|
|
|
|
m68k-*-lynxos*) fmt=coff em=lynx ;;
|
|
|
|
m68k-*-netbsdelf*) fmt=elf em=nbsd ;;
|
|
|
|
m68k-*-netbsd*) fmt=aout em=nbsd bfd_gas=yes ;;
|
|
|
|
m68k-*-openbsd*) fmt=aout em=nbsd bfd_gas=yes ;;
|
|
|
|
m68k-apple-aux*) fmt=coff em=aux ;;
|
|
|
|
m68k-*-psos*) fmt=elf em=psos;;
|
|
|
|
|
|
|
|
m88k-motorola-sysv3*) fmt=coff em=delt88 ;;
|
|
|
|
m88k-*-coff*) fmt=coff ;;
|
|
|
|
|
|
|
|
mcore-*-elf) fmt=elf ;;
|
|
|
|
mcore-*-pe) fmt=coff em=pe bfd_gas=yes ;;
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
# don't change em like *-*-bsd does
|
2002-08-09 11:42:15 +08:00
|
|
|
mips-dec-openbsd*) fmt=elf endian=little ;;
|
|
|
|
mips-dec-bsd*) fmt=aout endian=little ;;
|
|
|
|
mips-sony-bsd*) fmt=ecoff ;;
|
|
|
|
mips-*-bsd*)
|
|
|
|
AC_MSG_ERROR(Unknown vendor for mips-bsd configuration.) ;;
|
|
|
|
mips-*-ultrix*) fmt=ecoff endian=little ;;
|
|
|
|
mips-*-osf*) fmt=ecoff endian=little ;;
|
|
|
|
mips-*-ecoff*) fmt=ecoff ;;
|
|
|
|
mips-*-pe*) fmt=coff endian=little em=pe ;;
|
2003-01-28 06:45:58 +08:00
|
|
|
mips-*-irix6*) fmt=elf em=irix ;;
|
|
|
|
mips-*-irix5*) fmt=elf em=irix ;;
|
|
|
|
mips-*-irix*) fmt=ecoff em=irix ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
mips-*-lnews*) fmt=ecoff em=lnews ;;
|
|
|
|
mips-*-riscos*) fmt=ecoff ;;
|
|
|
|
mips*-*-linux*) fmt=elf em=tmips ;;
|
|
|
|
mips-*-sysv4*MP* | mips-*-gnu*) fmt=elf em=tmips ;;
|
|
|
|
mips-*-sysv*) fmt=ecoff ;;
|
|
|
|
mips-*-elf* | mips-*-rtems*) fmt=elf ;;
|
2003-04-29 07:48:42 +08:00
|
|
|
mips-*-netbsd*) fmt=elf ;;
|
|
|
|
mips-*-openbsd*) fmt=elf ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
|
|
|
|
mmix-*-*) fmt=elf ;;
|
|
|
|
mn10200-*-*) fmt=elf ;;
|
|
|
|
mn10300-*-*) fmt=elf ;;
|
2002-12-31 03:25:13 +08:00
|
|
|
msp430-*-*) fmt=elf ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
openrisc-*-*) fmt=elf ;;
|
|
|
|
or32-*-rtems*) fmt=coff ;;
|
|
|
|
or32-*-coff) fmt=coff ;;
|
|
|
|
or32-*-elf) fmt=elf ;;
|
|
|
|
pj*) fmt=elf ;;
|
|
|
|
|
|
|
|
ppc-*-pe | ppc-*-cygwin*) fmt=coff em=pe ;;
|
|
|
|
ppc-*-winnt*) fmt=coff em=pe ;;
|
2003-12-03 23:07:17 +08:00
|
|
|
changequote(,)dnl
|
|
|
|
ppc-*-aix5.[01]) fmt=coff em=aix5 ;;
|
|
|
|
changequote([,])dnl
|
|
|
|
ppc-*-aix5.*) fmt=coff em=aix5
|
|
|
|
AC_DEFINE(AIX_WEAK_SUPPORT, 1,
|
|
|
|
[Define if using AIX 5.2 value for C_WEAKEXT.])
|
|
|
|
;;
|
2002-08-09 11:42:15 +08:00
|
|
|
ppc-*-aix*) fmt=coff ;;
|
|
|
|
ppc-*-beos*) fmt=coff ;;
|
|
|
|
ppc-*-*n*bsd* | ppc-*-elf*) fmt=elf ;;
|
|
|
|
ppc-*-eabi* | ppc-*-sysv4*) fmt=elf ;;
|
2003-10-16 21:16:26 +08:00
|
|
|
ppc-*-linux-gnu*) fmt=elf em=linux
|
2002-08-09 11:42:15 +08:00
|
|
|
case "$endian" in
|
|
|
|
big) ;;
|
|
|
|
*) AC_MSG_ERROR(GNU/Linux must be configured big endian) ;;
|
|
|
|
esac ;;
|
|
|
|
ppc-*-solaris*) fmt=elf
|
|
|
|
if test ${this_target} = $target; then
|
|
|
|
AC_DEFINE(TARGET_SOLARIS_COMMENT, 1,
|
|
|
|
[Define if default target is PowerPC Solaris.])
|
|
|
|
fi
|
|
|
|
if test x${endian} = xbig; then
|
|
|
|
AC_MSG_ERROR(Solaris must be configured little endian)
|
|
|
|
fi ;;
|
|
|
|
ppc-*-rtems*) fmt=elf ;;
|
|
|
|
ppc-*-macos* | ppc-*-mpw*) fmt=coff em=macos ;;
|
|
|
|
ppc-*-netware*) fmt=elf em=ppcnw ;;
|
2002-08-09 23:38:24 +08:00
|
|
|
ppc-**-nto*) fmt=elf ;;
|
2003-02-11 21:47:08 +08:00
|
|
|
ppc-*-kaos*) fmt=elf ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
|
|
|
|
s390x-*-linux-gnu*) fmt=elf em=linux ;;
|
|
|
|
s390-*-linux-gnu*) fmt=elf em=linux ;;
|
|
|
|
|
|
|
|
sh*-*-linux*) fmt=elf em=linux
|
|
|
|
case ${cpu} in
|
|
|
|
sh*eb) endian=big ;;
|
|
|
|
*) endian=little ;;
|
|
|
|
esac ;;
|
|
|
|
sh5*-*-netbsd*) fmt=elf em=nbsd ;;
|
|
|
|
sh64*-*-netbsd*) fmt=elf em=nbsd ;;
|
|
|
|
sh*-*-netbsdelf*) fmt=elf em=nbsd ;;
|
|
|
|
sh-*-elf*) fmt=elf ;;
|
|
|
|
sh-*-coff*) fmt=coff ;;
|
2002-08-23 01:27:20 +08:00
|
|
|
sh-*-nto*) fmt=elf ;;
|
|
|
|
sh-*-pe*) fmt=coff em=pe bfd_gas=yes endian=little ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
sh-*-rtemself*) fmt=elf ;;
|
|
|
|
sh-*-rtems*) fmt=coff ;;
|
2003-02-11 21:47:08 +08:00
|
|
|
sh-*-kaos*) fmt=elf ;;
|
|
|
|
shle*-*-kaos*) fmt=elf ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
sh64-*-elf*) fmt=elf ;;
|
|
|
|
|
|
|
|
ns32k-pc532-mach*) fmt=aout em=pc532mach ;;
|
|
|
|
ns32k-pc532-ux*) fmt=aout em=pc532mach ;;
|
|
|
|
ns32k-pc532-lites*) fmt=aout em=nbsd532 ;;
|
|
|
|
ns32k-*-*n*bsd*) fmt=aout em=nbsd532 ;;
|
|
|
|
|
|
|
|
sparc-*-rtemsaout*) fmt=aout ;;
|
|
|
|
sparc-*-rtemself*) fmt=elf ;;
|
|
|
|
sparc-*-rtems*) fmt=elf ;;
|
|
|
|
sparc-*-sunos4*) fmt=aout em=sun3 ;;
|
|
|
|
sparc-*-aout | sparc*-*-vxworks*) fmt=aout em=sparcaout ;;
|
|
|
|
sparc-*-coff) fmt=coff ;;
|
|
|
|
sparc-*-linux*aout*) fmt=aout em=linux ;;
|
|
|
|
sparc-*-linux-gnu*) fmt=elf em=linux ;;
|
|
|
|
sparc-*-lynxos*) fmt=coff em=lynx ;;
|
|
|
|
sparc-fujitsu-none) fmt=aout ;;
|
|
|
|
sparc-*-elf) fmt=elf ;;
|
|
|
|
sparc-*-sysv4*) fmt=elf ;;
|
|
|
|
sparc-*-solaris*) fmt=elf ;;
|
|
|
|
sparc-*-netbsdelf*) fmt=elf em=nbsd ;;
|
|
|
|
sparc-*-*n*bsd*) case ${cpu} in
|
|
|
|
sparc64) fmt=elf em=nbsd ;;
|
|
|
|
*) fmt=aout em=nbsd ;;
|
|
|
|
esac ;;
|
|
|
|
strongarm-*-coff) fmt=coff ;;
|
|
|
|
strongarm-*-elf) fmt=elf ;;
|
2003-02-11 21:47:08 +08:00
|
|
|
strongarm-*-kaos*) fmt=elf ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
xscale-*-coff) fmt=coff ;;
|
|
|
|
xscale-*-elf) fmt=elf ;;
|
|
|
|
|
|
|
|
tic30-*-*aout*) fmt=aout bfd_gas=yes ;;
|
|
|
|
tic30-*-*coff*) fmt=coff bfd_gas=yes ;;
|
2002-08-28 18:38:51 +08:00
|
|
|
tic4x-*-* | c4x-*-*) fmt=coff bfd_gas=yes ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
tic54x-*-* | c54x*-*-*) fmt=coff bfd_gas=yes need_libm=yes;;
|
|
|
|
tic80-*-*) fmt=coff ;;
|
|
|
|
|
|
|
|
v850-*-*) fmt=elf ;;
|
|
|
|
v850e-*-*) fmt=elf ;;
|
|
|
|
v850ea-*-*) fmt=elf ;;
|
|
|
|
|
|
|
|
vax-*-netbsdelf*) fmt=elf em=nbsd ;;
|
|
|
|
vax-*-netbsd*) fmt=aout em=nbsd ;;
|
|
|
|
vax-*-bsd* | vax-*-ultrix*) fmt=aout ;;
|
2003-12-03 23:07:17 +08:00
|
|
|
vax-*-linux-gnu*) fmt=elf em=linux bfd_gas=yes ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
vax-*-vms) fmt=vms ;;
|
|
|
|
|
|
|
|
w65-*-*) fmt=coff ;;
|
|
|
|
|
|
|
|
xstormy16-*-*) fmt=elf ;;
|
|
|
|
|
2003-04-01 23:50:31 +08:00
|
|
|
xtensa-*-*) fmt=elf ;;
|
|
|
|
|
2002-08-09 11:42:15 +08:00
|
|
|
z8k-*-coff | z8k-*-sim) fmt=coff ;;
|
|
|
|
|
|
|
|
*-*-aout | *-*-scout) fmt=aout ;;
|
2003-09-03 17:32:21 +08:00
|
|
|
*-*-freebsd* | *-*-kfreebsd*-gnu) fmt=elf em=freebsd ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
*-*-nindy*) fmt=bout ;;
|
|
|
|
*-*-bsd*) fmt=aout em=sun3 ;;
|
|
|
|
*-*-generic) fmt=generic ;;
|
|
|
|
*-*-xray | *-*-hms) fmt=coff ;;
|
|
|
|
*-*-sim) fmt=coff ;;
|
|
|
|
*-*-elf | *-*-sysv4* | *-*-solaris*) fmt=elf dev=yes ;;
|
2003-10-30 03:48:00 +08:00
|
|
|
*-*-aros*) fmt=elf em=linux bfd_gas=yes ;;
|
|
|
|
*-*-vxworks | *-*-windiss) fmt=elf ;;
|
2002-08-09 11:42:15 +08:00
|
|
|
*-*-netware) fmt=elf ;;
|
1999-05-03 15:29:11 +08:00
|
|
|
esac
|
|
|
|
|
|
|
|
if test ${this_target} = $target ; then
|
|
|
|
endian_def=
|
|
|
|
if test x${endian} = xbig; then
|
|
|
|
endian_def=1
|
|
|
|
elif test x${endian} = xlittle; then
|
|
|
|
endian_def=0
|
|
|
|
fi
|
|
|
|
if test x${endian_def} != x; then
|
|
|
|
AC_DEFINE_UNQUOTED(TARGET_BYTES_BIG_ENDIAN, $endian_def,
|
|
|
|
[Define as 1 if big endian.])
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
case ${cpu_type}-${fmt} in
|
2002-08-09 11:42:15 +08:00
|
|
|
alpha*-* | arm-* | i386-* | ia64*-* | mips-* | ns32k-* \
|
|
|
|
| pdp11-* | ppc-* | sparc-* | strongarm-* | xscale-* \
|
|
|
|
| *-elf | *-ecoff | *-som)
|
|
|
|
bfd_gas=yes ;;
|
1999-05-03 15:29:11 +08:00
|
|
|
esac
|
|
|
|
|
|
|
|
# Other random stuff.
|
|
|
|
|
[gas/]
* doc/c-mips.texi: Remove -mcpu. Document -mabi.
* configure.in (MIPS_CPU_STRING_DEFAULT): New configuration macro.
(USE_E_MIPS_ABI_O32, MIPS_DEFAULT_64BIT): New configuration macros.
* configure, config.in: Regenerate.
* config/tc-mips.c (file_mips_abi): Rename to mips_abi.
(mips_set_options): Remove "abi" field.
(mips_opts): Update accordingly. Replace all uses of mips_opts.abi
with mips_abi.
(mips_cpu): Remove.
(mips_arch_string, mips_arch_info): New vars.
(mips_tune_string, mips_tune_info): New vars.
(ABI_NEEDS_32BIT_REGS, ABI_NEEDS_64BIT_REGS): New macros.
(HAVE_32BIT_GPRS, HAVE_32BIT_FPRS): Don't check the ABI.
(mips_isa_to_str, mips_cpu_to_str): Remove.
(mips_ip): If the selected architecture is a generic ISA rather
than a processor, only mention the ISA level in error messages.
(OPTION_MCPU): Remove.
(OPTION_FP64): New.
(md_longopts): Add -mfp64, remove -mcpu.
(mips_set_option_string): New fn.
(md_parse_option): Make -mipsN update file_mips_isa rather than
mips_opts.isa. Use mips_set_option_string to set -march or -mtune.
Don't let -mgp32 and -mfp32 change the ABI.
(show): Move to end of file. Constify string argument.
(md_show_usage): Move to the end of the file. Read available
architectures from mips_cpu_info_table.
(mips_set_architecture): New fn.
(mips_after_parse_args): Rework. Remove -mcpu handling. -mipsN
is an alias for -march=mipsN. Don't change the ABI based on other
flags. Infer the register size from the ABI as well as the
architecture. Complain about more conflicting arguments.
Unify logic with GCC.
(s_mipsset): Don't change the ABI.
(mips_elf_final_processing): Check USE_E_MIPS_ABI_O32.
(mips_cpu_info_table): Remove Generic-MIPS* entries, keeping just
"mipsN"-type entries. Remove entries that vary only in the
manufacturer's prefix, or that have "000" replaced by "k".
Remove TARGET_CPU entries. Make r2000 entry use CPU_R3000.
(mips_strict_matching_cpu_name_p, mips_matching_cpu_name_p): New fns.
(mips_parse_cpu): New fn.
(mips_cpu_info_from_name, mips_cpu_info_from_cpu): Remove.
(mips_cpu_info_from_isa): Minor formatting tweak.
[gas/testsuite]
* gas/mips/mips-gp32-fp64.d,
* gas/mips/mips-gp32-fp64-pic.d: Add -mfp64.
2002-07-25 17:48:07 +08:00
|
|
|
case ${cpu_type} in
|
|
|
|
mips)
|
|
|
|
# Set mips_cpu to the name of the default CPU.
|
|
|
|
case ${target_cpu} in
|
|
|
|
mips | mipsbe | mipseb | mipsle | mipsel | mips64 | mips64el)
|
|
|
|
mips_cpu=from-abi
|
|
|
|
;;
|
|
|
|
mipsisa32 | mipsisa32el)
|
|
|
|
mips_cpu=mips32
|
|
|
|
;;
|
[ bfd/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* aoutx.h (NAME(aout,machine_type)): Add bfd_mach_mipsisa32r2 case.
* archures.c (bfd_mach_mipsisa32r2): New define.
* bfd-in2.h: Regenerate.
* cpu-mips.c (I_mipsisa32r2): New enum value.
(arch_info_struct): Add entry for I_mipsisa32r2.
* elfxx-mips.c (elf_mips_isa, _bfd_elf_mips_mach)
(_bfd_mips_elf_print_private_bfd_data): Handle E_MIPS_ARCH_32R2.
(_bfd_mips_elf_final_write_processing): Add
bfd_mach_mipsisa32r2 case.
(_bfd_mips_elf_merge_private_bfd_data): Handle merging of
binaries marked as using MIPS32 Release 2.
[ binutils/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* doc/binutils.texi (objdump): Note MIPS HWR (Hardware Register)
changes in MIPS -M options.
[ gas/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* configure.in: Recognize mipsisa32r2, mipsisa32r2el, and
CPU variants.
* configure: Regenerate.
* config/tc-mips.c (ISA_HAS_DROR, ISA_HAS_ROR): New defines.
(macro_build): Handle "K" operand.
(macro2): Use ISA_HAS_DROR and ISA_HAS_ROR in the places where
CPU_HAS_DROR and CPU_HAS_ROR are currently used.
(mips_ip): New variable "lastpos", and implement "+A", "+B",
and "+C" operands for MIPS32 Release 2 ins/ext instructions.
Implement "K" operand for MIPS32 Release 2 rdhwr instruction.
(validate_mips_insn): Implement "+" as a way to extend the
allowed operands, and implement "K", "+A", "+B", and "+C"
operands.
(OPTION_MIPS32R2): New define.
(md_longopts): Add entry for OPTION_MIPS32R2.
(OPTION_ELF_BASE): Adjust to accomodate OPTIONS_MIPS32R2.
(md_parse_option): Handle OPTION_MIPS32R2.
(s_mipsset): Reimplement handling of ".set mipsN" options
and add support for ".set mips32r2".
(mips_cpu_info_table): Add entry for "mips32r2" (MIPS32 Release 2).
(md_show_usage): Document "-mips32r2" option.
* doc/as.texinfo: Document "-mips32r2" option.
* doc/c-mips.texi: Likewise.
[ gas/testsuite/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* gas/mips/cp0-names-mips32r2.d: New test.
* gas/mips/hwr-names-mips32r2.d: New test.
* gas/mips/hwr-names-numeric.d: New test.
* gas/mips/hwr-names.s: New test source file.
* gas/mips/mips32r2.d: New test.
* gas/mips/mips32r2.s: New test source file.
* gas/mips/mips32r2-ill.l: New test.
* gas/mips/mips32r2-ill.s: New test source file.
* gas/mips/mips.exp: Add mips32r2 architecture data array
entry. Run new tests mentioned above.
[ include/elf/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* mips.h (E_MIPS_ARCH_32R2): New define.
[ include/opcode/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* mips.h: Document "+" as the start of two-character operand
type names, and add new "K", "+A", "+B", and "+C" operand types.
(OP_MASK_INSMSB, OP_SH_INSMSB, OP_MASK_EXTMSB)
(OP_SH_EXTMSB, INSN_ISA32R2, ISA_MIPS32R2, CPU_MIPS32R2): New
defines.
[ opcodes/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* mips-dis.c (mips_cp0_names_mips3264r2, mips_hwr_names_numeric)
(mips_hwr_names_mips3264r2): New arrays.
(mips_arch_choice): New "hwr_names" member.
(mips_arch_choices): Adjust for structure change, and add a new
entry for "mips32r2" ISA.
(mips_hwr_names): New variable.
(set_default_mips_dis_options): Set mips_hwr_names.
(parse_mips_dis_option): New "hwr-names" option which sets
mips_hwr_names, and adjust "reg-names=ARCH" to set mips_hwr_names.
(print_insn_arg): Change return type to "int"
and use that to indicate number of characters consumed.
Add support for "+" operand extension character, "+A", "+B",
"+C", and "K" operands.
(print_insn_mips): Adjust for changes to print_insn_arg.
(print_mips_disassembler_options): Adjust for "hwr-names"
addition and "reg-names" change.
* mips-opc (I33): New define (shorthand for INSN_ISA32R2).
(mips_builtin_opcodes): Note that "nop" and "ssnop" are special
forms of "sll". Add new MIPS32 Release 2 instructions: ehb,
di, ei, ext, ins, jr.hb, jalr.hb, mfhc1, mfhc2, mthc1, mthc2,
rdhwr, rdpgpr, seb, seh, synci, wrpgpr, wsbh.
Note that hardware rotate instructions (ror, rorv) can be
used on MIPS32 Release 2, and add the official mnemonics
for them (rotr, rotrv) and the similar "rotl" mnemonic for
left-rotate.
2002-12-31 15:29:29 +08:00
|
|
|
mipsisa32r2 | mipsisa32r2el)
|
|
|
|
mips_cpu=mips32r2
|
|
|
|
;;
|
[gas/]
* doc/c-mips.texi: Remove -mcpu. Document -mabi.
* configure.in (MIPS_CPU_STRING_DEFAULT): New configuration macro.
(USE_E_MIPS_ABI_O32, MIPS_DEFAULT_64BIT): New configuration macros.
* configure, config.in: Regenerate.
* config/tc-mips.c (file_mips_abi): Rename to mips_abi.
(mips_set_options): Remove "abi" field.
(mips_opts): Update accordingly. Replace all uses of mips_opts.abi
with mips_abi.
(mips_cpu): Remove.
(mips_arch_string, mips_arch_info): New vars.
(mips_tune_string, mips_tune_info): New vars.
(ABI_NEEDS_32BIT_REGS, ABI_NEEDS_64BIT_REGS): New macros.
(HAVE_32BIT_GPRS, HAVE_32BIT_FPRS): Don't check the ABI.
(mips_isa_to_str, mips_cpu_to_str): Remove.
(mips_ip): If the selected architecture is a generic ISA rather
than a processor, only mention the ISA level in error messages.
(OPTION_MCPU): Remove.
(OPTION_FP64): New.
(md_longopts): Add -mfp64, remove -mcpu.
(mips_set_option_string): New fn.
(md_parse_option): Make -mipsN update file_mips_isa rather than
mips_opts.isa. Use mips_set_option_string to set -march or -mtune.
Don't let -mgp32 and -mfp32 change the ABI.
(show): Move to end of file. Constify string argument.
(md_show_usage): Move to the end of the file. Read available
architectures from mips_cpu_info_table.
(mips_set_architecture): New fn.
(mips_after_parse_args): Rework. Remove -mcpu handling. -mipsN
is an alias for -march=mipsN. Don't change the ABI based on other
flags. Infer the register size from the ABI as well as the
architecture. Complain about more conflicting arguments.
Unify logic with GCC.
(s_mipsset): Don't change the ABI.
(mips_elf_final_processing): Check USE_E_MIPS_ABI_O32.
(mips_cpu_info_table): Remove Generic-MIPS* entries, keeping just
"mipsN"-type entries. Remove entries that vary only in the
manufacturer's prefix, or that have "000" replaced by "k".
Remove TARGET_CPU entries. Make r2000 entry use CPU_R3000.
(mips_strict_matching_cpu_name_p, mips_matching_cpu_name_p): New fns.
(mips_parse_cpu): New fn.
(mips_cpu_info_from_name, mips_cpu_info_from_cpu): Remove.
(mips_cpu_info_from_isa): Minor formatting tweak.
[gas/testsuite]
* gas/mips/mips-gp32-fp64.d,
* gas/mips/mips-gp32-fp64-pic.d: Add -mfp64.
2002-07-25 17:48:07 +08:00
|
|
|
mipsisa64 | mipsisa64el)
|
|
|
|
mips_cpu=mips64
|
|
|
|
;;
|
[ bfd/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* archures.c (bfd_mach_mipsisa64r2): New define.
* bfd-in2.h: Regenerate.
* aoutx.h (NAME(aout,machine_type)): Handle bfd_mach_mipsisa64r2.
* cpu-mips.c (I_mipsisa64r2): New enum value.
(arch_info_struct): Add entry for I_mipsisa64r2.
* elfxx-mips.c (_bfd_elf_mips_mach)
(_bfd_mips_elf_print_private_bfd_data): Handle E_MIPS_ARCH_64R2.
(mips_set_isa_flags): Add bfd_mach_mipsisa64r2 case.
(mips_mach_extensions): Add entry for bfd_mach_mipsisa64r2.
[ binutils/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* readelf.c (get_machine_flags): Handle E_MIPS_ARCH_64R2.
[ gas/Changelog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* configure.in (mipsisa64r2, mipsisa64r2el, mipsisa64r2*): New CPUs.
* configure: Regenerate.
* config/tc-mips.c (imm2_expr): New variable.
(md_assemble, mips16_ip): Initialize imm2_expr.
(ISA_HAS_64BIT_REGS, ISA_HAS_DROR, ISA_HAS_ROR): Add ISA_MIPS64R2.
(macro_build): Handle +A, +B, +C, +E, +F, +G, and +H format operands.
(macro): Handle M_DEXT and M_DINS.
(validate_mips_insn): Handle +E, +F, +G, +H, and +I format operands.
(mips_ip): Likewise.
(OPTION_MIPS64R2): New define.
(md_longopts): New entry for -mips64r2 (OPTION_MIPS64R2).
OPTION_ASE_BASE): Increase to compensate for OPTION_MIPS64R2.
(md_parse_option): Handle OPTION_MIPS64R2.
(s_mipsset): Handle setting "mips64r2" ISA.
(mips_cpu_info_table): Add mips64r2.
(md_show_usage): Document -mips64r2 option.
* doc/as.texinfo: Docuemnt -mips64r2 option.
* doc/c-mips.texi: Likewise.
[ gas/testsuite/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* gas/mips/cp0-names-mips64r2.d: New file.
* gas/mips/cp0sel-names-mips64r2.d: New file.
* gas/mips/elf_arch_mips64r2.d: New file.
* gas/mips/hwr-names-mips64r2.d: New file.
* gas/mips/mips32r2-ill-fp64.l: New file.
* gas/mips/mips32r2-ill-fp64.s: New file.
* gas/mips/mips64r2-ill.l: New file.
* gas/mips/mips64r2-ill.s: New file.
* gas/mips/mips64r2.d: New file.
* gas/mips/mips64r2.s: New file.
* gas/mips/mips.exp: Define "mips64r2" arch, and run new tests.
[ include/elf/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* mips.h (E_MIPS_ARCH_64R2): New define.
[ include/opcode/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* mips.h: Document +E, +F, +G, +H, and +I operand types.
Update documentation of I, +B and +C operand types.
(INSN_ISA64R2, ISA_MIPS64R2, CPU_MIPS64R2): New defines.
(M_DEXT, M_DINS): New enum values.
[ ld/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* ldmain.c (get_emulation): Ignore "-mips64r2".
[ ld/testsuite/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* ld-mips-elf/mips-elf-flags.exp: Add tests for combinations
with MIPS64r2.
[ opcodes/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* mips-dis.c (mips_arch_choices): Add entry for "mips64r2"
(print_insn_args): Add handing for +E, +F, +G, and +H.
* mips-opc.c (I65): New define for MIPS64r2.
(mips_builtin_opcodes): Add "dext", "dextm", "dextu", "dins",
"dinsm", "dinsu", "drotl", "drotr", "drotr32", "drotrv", "dsbh",
and "dshd" for MIPS64r2. Adjust "dror", "dror32", and "drorv" to
be supported on MIPS64r2.
2003-10-01 00:17:15 +08:00
|
|
|
mipsisa64r2 | mipsisa64r2el)
|
|
|
|
mips_cpu=mips64r2
|
|
|
|
;;
|
[gas/]
* doc/c-mips.texi: Remove -mcpu. Document -mabi.
* configure.in (MIPS_CPU_STRING_DEFAULT): New configuration macro.
(USE_E_MIPS_ABI_O32, MIPS_DEFAULT_64BIT): New configuration macros.
* configure, config.in: Regenerate.
* config/tc-mips.c (file_mips_abi): Rename to mips_abi.
(mips_set_options): Remove "abi" field.
(mips_opts): Update accordingly. Replace all uses of mips_opts.abi
with mips_abi.
(mips_cpu): Remove.
(mips_arch_string, mips_arch_info): New vars.
(mips_tune_string, mips_tune_info): New vars.
(ABI_NEEDS_32BIT_REGS, ABI_NEEDS_64BIT_REGS): New macros.
(HAVE_32BIT_GPRS, HAVE_32BIT_FPRS): Don't check the ABI.
(mips_isa_to_str, mips_cpu_to_str): Remove.
(mips_ip): If the selected architecture is a generic ISA rather
than a processor, only mention the ISA level in error messages.
(OPTION_MCPU): Remove.
(OPTION_FP64): New.
(md_longopts): Add -mfp64, remove -mcpu.
(mips_set_option_string): New fn.
(md_parse_option): Make -mipsN update file_mips_isa rather than
mips_opts.isa. Use mips_set_option_string to set -march or -mtune.
Don't let -mgp32 and -mfp32 change the ABI.
(show): Move to end of file. Constify string argument.
(md_show_usage): Move to the end of the file. Read available
architectures from mips_cpu_info_table.
(mips_set_architecture): New fn.
(mips_after_parse_args): Rework. Remove -mcpu handling. -mipsN
is an alias for -march=mipsN. Don't change the ABI based on other
flags. Infer the register size from the ABI as well as the
architecture. Complain about more conflicting arguments.
Unify logic with GCC.
(s_mipsset): Don't change the ABI.
(mips_elf_final_processing): Check USE_E_MIPS_ABI_O32.
(mips_cpu_info_table): Remove Generic-MIPS* entries, keeping just
"mipsN"-type entries. Remove entries that vary only in the
manufacturer's prefix, or that have "000" replaced by "k".
Remove TARGET_CPU entries. Make r2000 entry use CPU_R3000.
(mips_strict_matching_cpu_name_p, mips_matching_cpu_name_p): New fns.
(mips_parse_cpu): New fn.
(mips_cpu_info_from_name, mips_cpu_info_from_cpu): Remove.
(mips_cpu_info_from_isa): Minor formatting tweak.
[gas/testsuite]
* gas/mips/mips-gp32-fp64.d,
* gas/mips/mips-gp32-fp64-pic.d: Add -mfp64.
2002-07-25 17:48:07 +08:00
|
|
|
mipstx39 | mipstx39el)
|
|
|
|
mips_cpu=r3900
|
|
|
|
;;
|
2002-10-14 14:59:06 +08:00
|
|
|
mips64vr | mips64vrel)
|
|
|
|
mips_cpu=vr4100
|
|
|
|
;;
|
[ bfd/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* archures.c (bfd_mach_mipsisa64r2): New define.
* bfd-in2.h: Regenerate.
* aoutx.h (NAME(aout,machine_type)): Handle bfd_mach_mipsisa64r2.
* cpu-mips.c (I_mipsisa64r2): New enum value.
(arch_info_struct): Add entry for I_mipsisa64r2.
* elfxx-mips.c (_bfd_elf_mips_mach)
(_bfd_mips_elf_print_private_bfd_data): Handle E_MIPS_ARCH_64R2.
(mips_set_isa_flags): Add bfd_mach_mipsisa64r2 case.
(mips_mach_extensions): Add entry for bfd_mach_mipsisa64r2.
[ binutils/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* readelf.c (get_machine_flags): Handle E_MIPS_ARCH_64R2.
[ gas/Changelog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* configure.in (mipsisa64r2, mipsisa64r2el, mipsisa64r2*): New CPUs.
* configure: Regenerate.
* config/tc-mips.c (imm2_expr): New variable.
(md_assemble, mips16_ip): Initialize imm2_expr.
(ISA_HAS_64BIT_REGS, ISA_HAS_DROR, ISA_HAS_ROR): Add ISA_MIPS64R2.
(macro_build): Handle +A, +B, +C, +E, +F, +G, and +H format operands.
(macro): Handle M_DEXT and M_DINS.
(validate_mips_insn): Handle +E, +F, +G, +H, and +I format operands.
(mips_ip): Likewise.
(OPTION_MIPS64R2): New define.
(md_longopts): New entry for -mips64r2 (OPTION_MIPS64R2).
OPTION_ASE_BASE): Increase to compensate for OPTION_MIPS64R2.
(md_parse_option): Handle OPTION_MIPS64R2.
(s_mipsset): Handle setting "mips64r2" ISA.
(mips_cpu_info_table): Add mips64r2.
(md_show_usage): Document -mips64r2 option.
* doc/as.texinfo: Docuemnt -mips64r2 option.
* doc/c-mips.texi: Likewise.
[ gas/testsuite/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* gas/mips/cp0-names-mips64r2.d: New file.
* gas/mips/cp0sel-names-mips64r2.d: New file.
* gas/mips/elf_arch_mips64r2.d: New file.
* gas/mips/hwr-names-mips64r2.d: New file.
* gas/mips/mips32r2-ill-fp64.l: New file.
* gas/mips/mips32r2-ill-fp64.s: New file.
* gas/mips/mips64r2-ill.l: New file.
* gas/mips/mips64r2-ill.s: New file.
* gas/mips/mips64r2.d: New file.
* gas/mips/mips64r2.s: New file.
* gas/mips/mips.exp: Define "mips64r2" arch, and run new tests.
[ include/elf/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* mips.h (E_MIPS_ARCH_64R2): New define.
[ include/opcode/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* mips.h: Document +E, +F, +G, +H, and +I operand types.
Update documentation of I, +B and +C operand types.
(INSN_ISA64R2, ISA_MIPS64R2, CPU_MIPS64R2): New defines.
(M_DEXT, M_DINS): New enum values.
[ ld/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* ldmain.c (get_emulation): Ignore "-mips64r2".
[ ld/testsuite/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* ld-mips-elf/mips-elf-flags.exp: Add tests for combinations
with MIPS64r2.
[ opcodes/ChangeLog ]
2003-09-30 Chris Demetriou <cgd@broadcom.com>
* mips-dis.c (mips_arch_choices): Add entry for "mips64r2"
(print_insn_args): Add handing for +E, +F, +G, and +H.
* mips-opc.c (I65): New define for MIPS64r2.
(mips_builtin_opcodes): Add "dext", "dextm", "dextu", "dins",
"dinsm", "dinsu", "drotl", "drotr", "drotr32", "drotrv", "dsbh",
and "dshd" for MIPS64r2. Adjust "dror", "dror32", and "drorv" to
be supported on MIPS64r2.
2003-10-01 00:17:15 +08:00
|
|
|
mipsisa32r2* | mipsisa64r2*)
|
[ bfd/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* aoutx.h (NAME(aout,machine_type)): Add bfd_mach_mipsisa32r2 case.
* archures.c (bfd_mach_mipsisa32r2): New define.
* bfd-in2.h: Regenerate.
* cpu-mips.c (I_mipsisa32r2): New enum value.
(arch_info_struct): Add entry for I_mipsisa32r2.
* elfxx-mips.c (elf_mips_isa, _bfd_elf_mips_mach)
(_bfd_mips_elf_print_private_bfd_data): Handle E_MIPS_ARCH_32R2.
(_bfd_mips_elf_final_write_processing): Add
bfd_mach_mipsisa32r2 case.
(_bfd_mips_elf_merge_private_bfd_data): Handle merging of
binaries marked as using MIPS32 Release 2.
[ binutils/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* doc/binutils.texi (objdump): Note MIPS HWR (Hardware Register)
changes in MIPS -M options.
[ gas/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* configure.in: Recognize mipsisa32r2, mipsisa32r2el, and
CPU variants.
* configure: Regenerate.
* config/tc-mips.c (ISA_HAS_DROR, ISA_HAS_ROR): New defines.
(macro_build): Handle "K" operand.
(macro2): Use ISA_HAS_DROR and ISA_HAS_ROR in the places where
CPU_HAS_DROR and CPU_HAS_ROR are currently used.
(mips_ip): New variable "lastpos", and implement "+A", "+B",
and "+C" operands for MIPS32 Release 2 ins/ext instructions.
Implement "K" operand for MIPS32 Release 2 rdhwr instruction.
(validate_mips_insn): Implement "+" as a way to extend the
allowed operands, and implement "K", "+A", "+B", and "+C"
operands.
(OPTION_MIPS32R2): New define.
(md_longopts): Add entry for OPTION_MIPS32R2.
(OPTION_ELF_BASE): Adjust to accomodate OPTIONS_MIPS32R2.
(md_parse_option): Handle OPTION_MIPS32R2.
(s_mipsset): Reimplement handling of ".set mipsN" options
and add support for ".set mips32r2".
(mips_cpu_info_table): Add entry for "mips32r2" (MIPS32 Release 2).
(md_show_usage): Document "-mips32r2" option.
* doc/as.texinfo: Document "-mips32r2" option.
* doc/c-mips.texi: Likewise.
[ gas/testsuite/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* gas/mips/cp0-names-mips32r2.d: New test.
* gas/mips/hwr-names-mips32r2.d: New test.
* gas/mips/hwr-names-numeric.d: New test.
* gas/mips/hwr-names.s: New test source file.
* gas/mips/mips32r2.d: New test.
* gas/mips/mips32r2.s: New test source file.
* gas/mips/mips32r2-ill.l: New test.
* gas/mips/mips32r2-ill.s: New test source file.
* gas/mips/mips.exp: Add mips32r2 architecture data array
entry. Run new tests mentioned above.
[ include/elf/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* mips.h (E_MIPS_ARCH_32R2): New define.
[ include/opcode/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* mips.h: Document "+" as the start of two-character operand
type names, and add new "K", "+A", "+B", and "+C" operand types.
(OP_MASK_INSMSB, OP_SH_INSMSB, OP_MASK_EXTMSB)
(OP_SH_EXTMSB, INSN_ISA32R2, ISA_MIPS32R2, CPU_MIPS32R2): New
defines.
[ opcodes/ChangeLog ]
2002-12-30 Chris Demetriou <cgd@broadcom.com>
* mips-dis.c (mips_cp0_names_mips3264r2, mips_hwr_names_numeric)
(mips_hwr_names_mips3264r2): New arrays.
(mips_arch_choice): New "hwr_names" member.
(mips_arch_choices): Adjust for structure change, and add a new
entry for "mips32r2" ISA.
(mips_hwr_names): New variable.
(set_default_mips_dis_options): Set mips_hwr_names.
(parse_mips_dis_option): New "hwr-names" option which sets
mips_hwr_names, and adjust "reg-names=ARCH" to set mips_hwr_names.
(print_insn_arg): Change return type to "int"
and use that to indicate number of characters consumed.
Add support for "+" operand extension character, "+A", "+B",
"+C", and "K" operands.
(print_insn_mips): Adjust for changes to print_insn_arg.
(print_mips_disassembler_options): Adjust for "hwr-names"
addition and "reg-names" change.
* mips-opc (I33): New define (shorthand for INSN_ISA32R2).
(mips_builtin_opcodes): Note that "nop" and "ssnop" are special
forms of "sll". Add new MIPS32 Release 2 instructions: ehb,
di, ei, ext, ins, jr.hb, jalr.hb, mfhc1, mfhc2, mthc1, mthc2,
rdhwr, rdpgpr, seb, seh, synci, wrpgpr, wsbh.
Note that hardware rotate instructions (ror, rorv) can be
used on MIPS32 Release 2, and add the official mnemonics
for them (rotr, rotrv) and the similar "rotl" mnemonic for
left-rotate.
2002-12-31 15:29:29 +08:00
|
|
|
changequote(,)dnl
|
|
|
|
mips_cpu=`echo $target_cpu | sed -e 's/[a-z]*..r2//' -e 's/el$//'`
|
|
|
|
changequote([,])dnl
|
|
|
|
;;
|
[gas/]
* doc/c-mips.texi: Remove -mcpu. Document -mabi.
* configure.in (MIPS_CPU_STRING_DEFAULT): New configuration macro.
(USE_E_MIPS_ABI_O32, MIPS_DEFAULT_64BIT): New configuration macros.
* configure, config.in: Regenerate.
* config/tc-mips.c (file_mips_abi): Rename to mips_abi.
(mips_set_options): Remove "abi" field.
(mips_opts): Update accordingly. Replace all uses of mips_opts.abi
with mips_abi.
(mips_cpu): Remove.
(mips_arch_string, mips_arch_info): New vars.
(mips_tune_string, mips_tune_info): New vars.
(ABI_NEEDS_32BIT_REGS, ABI_NEEDS_64BIT_REGS): New macros.
(HAVE_32BIT_GPRS, HAVE_32BIT_FPRS): Don't check the ABI.
(mips_isa_to_str, mips_cpu_to_str): Remove.
(mips_ip): If the selected architecture is a generic ISA rather
than a processor, only mention the ISA level in error messages.
(OPTION_MCPU): Remove.
(OPTION_FP64): New.
(md_longopts): Add -mfp64, remove -mcpu.
(mips_set_option_string): New fn.
(md_parse_option): Make -mipsN update file_mips_isa rather than
mips_opts.isa. Use mips_set_option_string to set -march or -mtune.
Don't let -mgp32 and -mfp32 change the ABI.
(show): Move to end of file. Constify string argument.
(md_show_usage): Move to the end of the file. Read available
architectures from mips_cpu_info_table.
(mips_set_architecture): New fn.
(mips_after_parse_args): Rework. Remove -mcpu handling. -mipsN
is an alias for -march=mipsN. Don't change the ABI based on other
flags. Infer the register size from the ABI as well as the
architecture. Complain about more conflicting arguments.
Unify logic with GCC.
(s_mipsset): Don't change the ABI.
(mips_elf_final_processing): Check USE_E_MIPS_ABI_O32.
(mips_cpu_info_table): Remove Generic-MIPS* entries, keeping just
"mipsN"-type entries. Remove entries that vary only in the
manufacturer's prefix, or that have "000" replaced by "k".
Remove TARGET_CPU entries. Make r2000 entry use CPU_R3000.
(mips_strict_matching_cpu_name_p, mips_matching_cpu_name_p): New fns.
(mips_parse_cpu): New fn.
(mips_cpu_info_from_name, mips_cpu_info_from_cpu): Remove.
(mips_cpu_info_from_isa): Minor formatting tweak.
[gas/testsuite]
* gas/mips/mips-gp32-fp64.d,
* gas/mips/mips-gp32-fp64-pic.d: Add -mfp64.
2002-07-25 17:48:07 +08:00
|
|
|
mips64* | mipsisa64* | mipsisa32*)
|
|
|
|
changequote(,)dnl
|
|
|
|
mips_cpu=`echo $target_cpu | sed -e 's/[a-z]*..//' -e 's/el$//'`
|
|
|
|
changequote([,])dnl
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
AC_ERROR($target_cpu isn't a supported MIPS CPU name)
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
# See whether it's appropriate to set E_MIPS_ABI_O32 for o32
|
|
|
|
# binaries. It's a GNU extension that some OSes don't understand.
|
|
|
|
# The value only matters on ELF targets.
|
|
|
|
case ${target} in
|
|
|
|
*-*-irix*)
|
|
|
|
use_e_mips_abi_o32=0
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
use_e_mips_abi_o32=1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
# Decide whether to generate 32-bit or 64-bit code by default.
|
|
|
|
# Used to resolve -march=from-abi when an embedded ABI is selected.
|
|
|
|
case ${target} in
|
|
|
|
mips64*-*-* | mipsisa64*-*-*)
|
|
|
|
mips_default_64bit=1
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
mips_default_64bit=0
|
|
|
|
;;
|
|
|
|
esac
|
2003-05-07 13:10:45 +08:00
|
|
|
# Decide which ABI to target by default.
|
|
|
|
case ${target} in
|
|
|
|
mips64*-linux* | mips-sgi-irix6*)
|
|
|
|
mips_default_abi=N32_ABI
|
|
|
|
;;
|
|
|
|
mips*-linux*)
|
|
|
|
mips_default_abi=O32_ABI
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
mips_default_abi=NO_ABI
|
|
|
|
;;
|
|
|
|
esac
|
[gas/]
* doc/c-mips.texi: Remove -mcpu. Document -mabi.
* configure.in (MIPS_CPU_STRING_DEFAULT): New configuration macro.
(USE_E_MIPS_ABI_O32, MIPS_DEFAULT_64BIT): New configuration macros.
* configure, config.in: Regenerate.
* config/tc-mips.c (file_mips_abi): Rename to mips_abi.
(mips_set_options): Remove "abi" field.
(mips_opts): Update accordingly. Replace all uses of mips_opts.abi
with mips_abi.
(mips_cpu): Remove.
(mips_arch_string, mips_arch_info): New vars.
(mips_tune_string, mips_tune_info): New vars.
(ABI_NEEDS_32BIT_REGS, ABI_NEEDS_64BIT_REGS): New macros.
(HAVE_32BIT_GPRS, HAVE_32BIT_FPRS): Don't check the ABI.
(mips_isa_to_str, mips_cpu_to_str): Remove.
(mips_ip): If the selected architecture is a generic ISA rather
than a processor, only mention the ISA level in error messages.
(OPTION_MCPU): Remove.
(OPTION_FP64): New.
(md_longopts): Add -mfp64, remove -mcpu.
(mips_set_option_string): New fn.
(md_parse_option): Make -mipsN update file_mips_isa rather than
mips_opts.isa. Use mips_set_option_string to set -march or -mtune.
Don't let -mgp32 and -mfp32 change the ABI.
(show): Move to end of file. Constify string argument.
(md_show_usage): Move to the end of the file. Read available
architectures from mips_cpu_info_table.
(mips_set_architecture): New fn.
(mips_after_parse_args): Rework. Remove -mcpu handling. -mipsN
is an alias for -march=mipsN. Don't change the ABI based on other
flags. Infer the register size from the ABI as well as the
architecture. Complain about more conflicting arguments.
Unify logic with GCC.
(s_mipsset): Don't change the ABI.
(mips_elf_final_processing): Check USE_E_MIPS_ABI_O32.
(mips_cpu_info_table): Remove Generic-MIPS* entries, keeping just
"mipsN"-type entries. Remove entries that vary only in the
manufacturer's prefix, or that have "000" replaced by "k".
Remove TARGET_CPU entries. Make r2000 entry use CPU_R3000.
(mips_strict_matching_cpu_name_p, mips_matching_cpu_name_p): New fns.
(mips_parse_cpu): New fn.
(mips_cpu_info_from_name, mips_cpu_info_from_cpu): Remove.
(mips_cpu_info_from_isa): Minor formatting tweak.
[gas/testsuite]
* gas/mips/mips-gp32-fp64.d,
* gas/mips/mips-gp32-fp64-pic.d: Add -mfp64.
2002-07-25 17:48:07 +08:00
|
|
|
AC_DEFINE_UNQUOTED(MIPS_CPU_STRING_DEFAULT, "$mips_cpu",
|
|
|
|
[Default CPU for MIPS targets. ])
|
|
|
|
AC_DEFINE_UNQUOTED(USE_E_MIPS_ABI_O32, $use_e_mips_abi_o32,
|
|
|
|
[Allow use of E_MIPS_ABI_O32 on MIPS targets. ])
|
|
|
|
AC_DEFINE_UNQUOTED(MIPS_DEFAULT_64BIT, $mips_default_64bit,
|
|
|
|
[Generate 64-bit code by default on MIPS targets. ])
|
2003-05-07 13:10:45 +08:00
|
|
|
AC_DEFINE_UNQUOTED(MIPS_DEFAULT_ABI, $mips_default_abi,
|
|
|
|
[Choose a default ABI for MIPS targets. ])
|
[gas/]
* doc/c-mips.texi: Remove -mcpu. Document -mabi.
* configure.in (MIPS_CPU_STRING_DEFAULT): New configuration macro.
(USE_E_MIPS_ABI_O32, MIPS_DEFAULT_64BIT): New configuration macros.
* configure, config.in: Regenerate.
* config/tc-mips.c (file_mips_abi): Rename to mips_abi.
(mips_set_options): Remove "abi" field.
(mips_opts): Update accordingly. Replace all uses of mips_opts.abi
with mips_abi.
(mips_cpu): Remove.
(mips_arch_string, mips_arch_info): New vars.
(mips_tune_string, mips_tune_info): New vars.
(ABI_NEEDS_32BIT_REGS, ABI_NEEDS_64BIT_REGS): New macros.
(HAVE_32BIT_GPRS, HAVE_32BIT_FPRS): Don't check the ABI.
(mips_isa_to_str, mips_cpu_to_str): Remove.
(mips_ip): If the selected architecture is a generic ISA rather
than a processor, only mention the ISA level in error messages.
(OPTION_MCPU): Remove.
(OPTION_FP64): New.
(md_longopts): Add -mfp64, remove -mcpu.
(mips_set_option_string): New fn.
(md_parse_option): Make -mipsN update file_mips_isa rather than
mips_opts.isa. Use mips_set_option_string to set -march or -mtune.
Don't let -mgp32 and -mfp32 change the ABI.
(show): Move to end of file. Constify string argument.
(md_show_usage): Move to the end of the file. Read available
architectures from mips_cpu_info_table.
(mips_set_architecture): New fn.
(mips_after_parse_args): Rework. Remove -mcpu handling. -mipsN
is an alias for -march=mipsN. Don't change the ABI based on other
flags. Infer the register size from the ABI as well as the
architecture. Complain about more conflicting arguments.
Unify logic with GCC.
(s_mipsset): Don't change the ABI.
(mips_elf_final_processing): Check USE_E_MIPS_ABI_O32.
(mips_cpu_info_table): Remove Generic-MIPS* entries, keeping just
"mipsN"-type entries. Remove entries that vary only in the
manufacturer's prefix, or that have "000" replaced by "k".
Remove TARGET_CPU entries. Make r2000 entry use CPU_R3000.
(mips_strict_matching_cpu_name_p, mips_matching_cpu_name_p): New fns.
(mips_parse_cpu): New fn.
(mips_cpu_info_from_name, mips_cpu_info_from_cpu): Remove.
(mips_cpu_info_from_isa): Minor formatting tweak.
[gas/testsuite]
* gas/mips/mips-gp32-fp64.d,
* gas/mips/mips-gp32-fp64-pic.d: Add -mfp64.
2002-07-25 17:48:07 +08:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
# Do we need the opcodes library?
|
|
|
|
case ${cpu_type} in
|
|
|
|
vax | i386 | tic30)
|
|
|
|
;;
|
|
|
|
|
|
|
|
*)
|
|
|
|
need_opcodes=yes
|
|
|
|
|
|
|
|
case "${enable_shared}" in
|
|
|
|
yes) shared_opcodes=true ;;
|
|
|
|
*opcodes*) shared_opcodes=true ;;
|
|
|
|
*) shared_opcodes=false ;;
|
|
|
|
esac
|
|
|
|
if test "${shared_opcodes}" = "true"; then
|
|
|
|
# A shared libopcodes must be linked against libbfd.
|
|
|
|
need_bfd=yes
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
# Any other special object files needed ?
|
|
|
|
case ${cpu_type} in
|
2003-01-04 05:47:21 +08:00
|
|
|
fr30 | ip2k | iq2000 | m32r | openrisc)
|
1999-05-03 15:29:11 +08:00
|
|
|
using_cgen=yes
|
|
|
|
;;
|
|
|
|
|
2002-06-19 05:15:21 +08:00
|
|
|
frv)
|
|
|
|
using_cgen=yes
|
|
|
|
;;
|
1999-05-03 15:29:11 +08:00
|
|
|
m68k)
|
|
|
|
case ${extra_objects} in
|
|
|
|
*m68k-parse.o*) ;;
|
|
|
|
*) extra_objects="$extra_objects m68k-parse.o" ;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
|
|
|
|
mips)
|
|
|
|
echo ${extra_objects} | grep -s "itbl-parse.o"
|
|
|
|
if test $? -ne 0 ; then
|
|
|
|
extra_objects="$extra_objects itbl-parse.o"
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo ${extra_objects} | grep -s "itbl-lex.o"
|
|
|
|
if test $? -ne 0 ; then
|
|
|
|
extra_objects="$extra_objects itbl-lex.o"
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo ${extra_objects} | grep -s "itbl-ops.o"
|
|
|
|
if test $? -ne 0 ; then
|
|
|
|
extra_objects="$extra_objects itbl-ops.o"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
|
2001-10-17 13:38:42 +08:00
|
|
|
i386 | s390 | sparc)
|
1999-05-03 15:29:11 +08:00
|
|
|
if test $this_target = $target ; then
|
|
|
|
AC_DEFINE_UNQUOTED(DEFAULT_ARCH, "${arch}", [Default architecture.])
|
|
|
|
fi
|
|
|
|
;;
|
2001-12-08 11:46:03 +08:00
|
|
|
|
|
|
|
xstormy16)
|
|
|
|
using_cgen=yes
|
|
|
|
;;
|
|
|
|
|
2003-04-01 23:50:31 +08:00
|
|
|
xtensa)
|
|
|
|
echo ${extra_objects} | grep -s "xtensa-relax.o"
|
|
|
|
if test $? -ne 0 ; then
|
|
|
|
extra_objects="$extra_objects xtensa-relax.o"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
*)
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
if test $using_cgen = yes ; then
|
|
|
|
case "x${extra_objects}" in
|
|
|
|
*cgen.o*) ;;
|
|
|
|
*) extra_objects="$extra_objects cgen.o" ;;
|
|
|
|
esac
|
|
|
|
fi
|
|
|
|
|
|
|
|
# See if we really can support this configuration with the emulation code.
|
|
|
|
|
|
|
|
if test $this_target = $target ; then
|
|
|
|
primary_bfd_gas=$bfd_gas
|
|
|
|
obj_format=$fmt
|
|
|
|
te_file=$em
|
|
|
|
|
|
|
|
if test $bfd_gas = no ; then
|
|
|
|
# Can't support other configurations this way.
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
elif test $bfd_gas = no ; then
|
|
|
|
# Can't support this configuration.
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
|
|
|
|
# From target name and format, produce a list of supported emulations.
|
|
|
|
|
|
|
|
case ${generic_target}-${fmt} in
|
|
|
|
mips-*-irix5*-*) emulation="mipsbelf mipslelf mipself mipsbecoff mipslecoff mipsecoff" ;;
|
2001-09-14 14:22:46 +08:00
|
|
|
mips*-*-linux*-*) case "$endian" in
|
2001-06-08 01:23:14 +08:00
|
|
|
big) emulation="mipsbelf mipslelf mipself" ;;
|
|
|
|
*) emulation="mipslelf mipsbelf mipself" ;;
|
1999-05-03 15:29:11 +08:00
|
|
|
esac ;;
|
|
|
|
mips-*-lnews*-ecoff) ;;
|
|
|
|
mips-*-*-ecoff) case "$endian" in
|
|
|
|
big) emulation="mipsbecoff mipslecoff mipsecoff" ;;
|
|
|
|
*) emulation="mipslecoff mipsbecoff mipsecoff" ;;
|
|
|
|
esac ;;
|
|
|
|
mips-*-*-elf) case "$endian" in
|
|
|
|
big) emulation="mipsbelf mipslelf mipself" ;;
|
|
|
|
*) emulation="mipslelf mipsbelf mipself" ;;
|
|
|
|
esac ;;
|
2000-07-13 22:57:49 +08:00
|
|
|
mips-*-sysv4*MP*-*) emulation="mipsbelf mipslelf mipself mipsbecoff mipslecoff mipsecoff" ;;
|
2000-06-19 07:47:18 +08:00
|
|
|
# i386-pc-pe-coff != i386-pc-coff.
|
|
|
|
i386-*-pe-coff) ;;
|
2000-01-27 06:48:31 +08:00
|
|
|
# Uncommenting the next line will turn on support for i386 AOUT
|
|
|
|
# for the default linux configuration
|
|
|
|
# i386-*-linux*-elf) emulation="i386elf i386aout" ;;
|
|
|
|
#
|
|
|
|
i386-*-aout) emulation="i386aout" ;;
|
1999-09-02 23:12:01 +08:00
|
|
|
i386-*-coff) emulation="i386coff" ;;
|
2000-01-27 06:48:31 +08:00
|
|
|
i386-*-elf) emulation="i386elf" ;;
|
2000-07-21 01:45:28 +08:00
|
|
|
|
2001-03-27 10:48:19 +08:00
|
|
|
# Always all formats. The first stated emulation becomes the default.
|
|
|
|
cris-*-*aout*) emulation="crisaout criself" ;;
|
|
|
|
cris-*-*) emulation="criself crisaout" ;;
|
1999-05-03 15:29:11 +08:00
|
|
|
esac
|
|
|
|
|
|
|
|
emulations="$emulations $emulation"
|
|
|
|
|
|
|
|
done
|
|
|
|
|
2000-03-03 04:15:33 +08:00
|
|
|
# Turn on all targets if possible
|
|
|
|
if test ${all_targets} = "yes"; then
|
|
|
|
case ${target_cpu_type} in
|
|
|
|
i386)
|
|
|
|
case ${obj_format} in
|
|
|
|
aout)
|
|
|
|
emulations="$emulations i386coff i386elf"
|
|
|
|
;;
|
|
|
|
coff)
|
|
|
|
emulations="$emulations i386aout i386elf"
|
|
|
|
;;
|
|
|
|
elf)
|
|
|
|
emulations="$emulations i386aout i386coff"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
fi
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
# Assign floating point type. Most processors with FP support
|
|
|
|
# IEEE FP. On those that don't support FP at all, usually IEEE
|
|
|
|
# is emulated.
|
|
|
|
case ${target_cpu} in
|
|
|
|
vax | tahoe ) atof=${target_cpu} ;;
|
2001-02-19 07:33:11 +08:00
|
|
|
pdp11) atof=vax ;;
|
1999-05-03 15:29:11 +08:00
|
|
|
*) atof=ieee ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
case "${obj_format}" in
|
|
|
|
"") AC_MSG_ERROR(GAS does not know what format to use for target ${target}) ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
# Unfortunately the cpu in cpu-opc.h file isn't always $(TARGET_CPU).
|
|
|
|
cgen_cpu_prefix=""
|
|
|
|
if test $using_cgen = yes ; then
|
|
|
|
case ${target_cpu} in
|
|
|
|
*) cgen_cpu_prefix=${target_cpu} ;;
|
|
|
|
esac
|
|
|
|
AC_SUBST(cgen_cpu_prefix)
|
|
|
|
AC_DEFINE(USING_CGEN, 1, [Using cgen code?])
|
|
|
|
fi
|
|
|
|
|
|
|
|
dnl
|
|
|
|
dnl Make sure the desired support files exist.
|
|
|
|
dnl
|
|
|
|
|
|
|
|
if test ! -r ${srcdir}/config/tc-${target_cpu_type}.c; then
|
|
|
|
AC_MSG_ERROR(GAS does not support target CPU ${target_cpu_type})
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test ! -r ${srcdir}/config/obj-${obj_format}.c; then
|
|
|
|
AC_MSG_ERROR(GAS does not have support for object file format ${obj_format})
|
|
|
|
fi
|
|
|
|
|
|
|
|
case ${user_bfd_gas}-${primary_bfd_gas} in
|
|
|
|
yes-yes | no-no)
|
|
|
|
# We didn't override user's choice.
|
|
|
|
;;
|
|
|
|
no-yes)
|
|
|
|
AC_MSG_WARN(Use of BFD is required for ${target}; overriding config options.)
|
|
|
|
;;
|
|
|
|
no-preferred)
|
|
|
|
primary_bfd_gas=no
|
|
|
|
;;
|
|
|
|
*-preferred)
|
|
|
|
primary_bfd_gas=yes
|
|
|
|
;;
|
|
|
|
yes-*)
|
|
|
|
primary_bfd_gas=yes
|
|
|
|
;;
|
|
|
|
-*)
|
|
|
|
# User specified nothing.
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
# Some COFF configurations want these random other flags set.
|
|
|
|
case ${obj_format} in
|
|
|
|
coff)
|
|
|
|
case ${target_cpu_type} in
|
|
|
|
i386) AC_DEFINE(I386COFF, 1, [Using i386 COFF?]) ;;
|
|
|
|
m68k) AC_DEFINE(M68KCOFF, 1, [Using m68k COFF?]) ;;
|
|
|
|
m88k) AC_DEFINE(M88KCOFF, 1, [Using m88k COFF?]) ;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
# Getting this done right is going to be a bitch. Each configuration specified
|
|
|
|
# with --enable-targets=... should be checked for environment, format, cpu, and
|
|
|
|
# bfd_gas setting.
|
|
|
|
#
|
|
|
|
# For each configuration, the necessary object file support code must be linked
|
|
|
|
# in. This might be only one, it might be up to four. The necessary emulation
|
|
|
|
# code needs to be provided, too.
|
|
|
|
#
|
|
|
|
# And then there's "--enable-targets=all"....
|
|
|
|
#
|
|
|
|
# For now, just always do it for MIPS ELF or ECOFF configurations. Sigh.
|
|
|
|
|
|
|
|
formats="${obj_format}"
|
|
|
|
emfiles=""
|
|
|
|
EMULATIONS=""
|
|
|
|
GAS_UNIQ(emulations)
|
|
|
|
for em in . $emulations ; do
|
|
|
|
case $em in
|
|
|
|
.) continue ;;
|
2001-02-11 06:25:10 +08:00
|
|
|
mipsbelf | mipslelf | mipself)
|
1999-05-03 15:29:11 +08:00
|
|
|
fmt=elf file=mipself ;;
|
2001-02-11 06:25:10 +08:00
|
|
|
mipsbecoff | mipslecoff | mipsecoff)
|
1999-05-03 15:29:11 +08:00
|
|
|
fmt=ecoff file=mipsecoff ;;
|
2000-05-22 02:26:10 +08:00
|
|
|
*coff)
|
|
|
|
fmt=coff file=$em ;;
|
|
|
|
*aout)
|
|
|
|
fmt=aout file=$em ;;
|
|
|
|
*elf)
|
|
|
|
fmt=elf file=$em ;;
|
1999-05-03 15:29:11 +08:00
|
|
|
esac
|
|
|
|
formats="$formats $fmt"
|
|
|
|
emfiles="$emfiles e-$file.o"
|
|
|
|
EMULATIONS="$EMULATIONS &$em,"
|
|
|
|
done
|
|
|
|
GAS_UNIQ(formats)
|
|
|
|
GAS_UNIQ(emfiles)
|
|
|
|
if test `set . $formats ; shift ; echo $#` -gt 1 ; then
|
|
|
|
for fmt in $formats ; do
|
|
|
|
case $fmt in
|
|
|
|
aout) AC_DEFINE(OBJ_MAYBE_AOUT, 1, [a.out support?]) ;;
|
|
|
|
bout) AC_DEFINE(OBJ_MAYBE_BOUT, 1, [b.out support?]) ;;
|
|
|
|
coff) AC_DEFINE(OBJ_MAYBE_COFF, 1, [COFF support?]) ;;
|
|
|
|
ecoff) AC_DEFINE(OBJ_MAYBE_ECOFF, 1, [ECOFF support?]) ;;
|
|
|
|
elf) AC_DEFINE(OBJ_MAYBE_ELF, 1, [ELF support?]) ;;
|
|
|
|
generic) AC_DEFINE(OBJ_MAYBE_GENERIC, 1, [generic support?]) ;;
|
|
|
|
hp300) AC_DEFINE(OBJ_MAYBE_HP300, 1, [HP300 support?]) ;;
|
|
|
|
ieee) AC_DEFINE(OBJ_MAYBE_IEEE, 1, [IEEE support?]) ;;
|
|
|
|
som) AC_DEFINE(OBJ_MAYBE_SOM, 1, [SOM support?]) ;;
|
|
|
|
vms) AC_DEFINE(OBJ_MAYBE_VMS, 1, [VMS support?]) ;;
|
|
|
|
esac
|
|
|
|
extra_objects="$extra_objects obj-$fmt.o"
|
|
|
|
done
|
|
|
|
obj_format=multi
|
|
|
|
fi
|
|
|
|
if test `set . $emfiles ; shift ; echo $#` -gt 0 ; then
|
|
|
|
DEFAULT_EMULATION=`set . $emulations ; echo $2`
|
1999-09-02 23:12:01 +08:00
|
|
|
# e-mips* has more than one emulation per file, e-i386* has just one at the
|
|
|
|
# moment. If only one emulation is specified, then don't define
|
|
|
|
# USE_EMULATIONS or include any of the e-files as they will only be bloat.
|
|
|
|
case "${obj_format}${emfiles}" in
|
|
|
|
multi* | *mips*)
|
|
|
|
extra_objects="$extra_objects $emfiles"
|
|
|
|
AC_DEFINE(USE_EMULATIONS, 1, [Use emulation support?]) ;;
|
|
|
|
esac
|
1999-05-03 15:29:11 +08:00
|
|
|
fi
|
|
|
|
AC_SUBST(extra_objects)
|
|
|
|
AC_DEFINE_UNQUOTED(EMULATIONS, $EMULATIONS, [Supported emulations.])
|
|
|
|
AC_DEFINE_UNQUOTED(DEFAULT_EMULATION, "$DEFAULT_EMULATION",
|
|
|
|
[Default emulation.])
|
|
|
|
|
|
|
|
case ${primary_bfd_gas}-${target_cpu_type}-${obj_format} in
|
|
|
|
yes-*-coff) need_bfd=yes ;;
|
|
|
|
no-*-coff) need_bfd=yes
|
|
|
|
AC_DEFINE(MANY_SEGMENTS, 1, [old COFF support?]) ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
reject_dev_configs=yes
|
|
|
|
|
|
|
|
case ${reject_dev_configs}-${dev} in
|
|
|
|
yes-yes) # Oops.
|
|
|
|
AC_MSG_ERROR(GAS does not support the ${generic_target} configuration.)
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
AC_SUBST(target_cpu_type)
|
|
|
|
AC_SUBST(obj_format)
|
|
|
|
AC_SUBST(te_file)
|
|
|
|
AC_SUBST(install_tooldir)
|
|
|
|
AC_SUBST(atof)
|
|
|
|
dnl AC_SUBST(emulation)
|
|
|
|
|
|
|
|
case "${primary_bfd_gas}" in
|
|
|
|
yes) AC_DEFINE(BFD_ASSEMBLER, 1, [Use BFD interface?])
|
|
|
|
need_bfd=yes ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
# do we need the opcodes library?
|
|
|
|
case "${need_opcodes}" in
|
|
|
|
yes)
|
|
|
|
OPCODES_LIB=../opcodes/libopcodes.la
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
case "${need_bfd}" in
|
|
|
|
yes)
|
|
|
|
BFDLIB=../bfd/libbfd.la
|
2002-10-16 21:27:04 +08:00
|
|
|
BFDVER_H=../bfd/bfdver.h
|
2002-05-25 20:53:29 +08:00
|
|
|
ALL_OBJ_DEPS="$ALL_OBJ_DEPS"' ../bfd/bfd.h $(INCDIR)/symcat.h'
|
1999-05-03 15:29:11 +08:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
AC_SUBST(BFDLIB)
|
|
|
|
AC_SUBST(OPCODES_LIB)
|
|
|
|
|
2002-10-16 21:27:04 +08:00
|
|
|
AC_SUBST(BFDVER_H)
|
1999-05-03 15:29:11 +08:00
|
|
|
AC_SUBST(ALL_OBJ_DEPS)
|
|
|
|
|
|
|
|
AC_DEFINE_UNQUOTED(TARGET_ALIAS, "${target_alias}", [Target alias.])
|
|
|
|
AC_DEFINE_UNQUOTED(TARGET_CANONICAL, "${target}", [Canonical target.])
|
|
|
|
AC_DEFINE_UNQUOTED(TARGET_CPU, "${target_cpu}", [Target CPU.])
|
|
|
|
AC_DEFINE_UNQUOTED(TARGET_VENDOR, "${target_vendor}", [Target vendor.])
|
|
|
|
AC_DEFINE_UNQUOTED(TARGET_OS, "${target_os}", [Target OS.])
|
|
|
|
|
|
|
|
AC_PROG_CC
|
|
|
|
|
|
|
|
AC_PROG_YACC
|
|
|
|
AM_PROG_LEX
|
|
|
|
|
2002-02-26 18:28:13 +08:00
|
|
|
ALL_LINGUAS="fr tr es"
|
1999-05-03 15:29:11 +08:00
|
|
|
CY_GNU_GETTEXT
|
|
|
|
|
|
|
|
AM_MAINTAINER_MODE
|
|
|
|
AC_EXEEXT
|
|
|
|
|
|
|
|
AC_CHECK_HEADERS(string.h stdlib.h memory.h strings.h unistd.h stdarg.h varargs.h errno.h sys/types.h)
|
|
|
|
|
|
|
|
# Put this here so that autoconf's "cross-compiling" message doesn't confuse
|
|
|
|
# people who are not cross-compiling but are compiling cross-assemblers.
|
|
|
|
AC_MSG_CHECKING(whether compiling a cross-assembler)
|
|
|
|
if test "${host}" = "${target}"; then
|
|
|
|
cross_gas=no
|
|
|
|
else
|
|
|
|
cross_gas=yes
|
|
|
|
AC_DEFINE(CROSS_COMPILE, 1, [Compiling cross-assembler?])
|
|
|
|
fi
|
|
|
|
AC_MSG_RESULT($cross_gas)
|
|
|
|
|
|
|
|
dnl ansidecl.h will deal with const
|
|
|
|
dnl AC_CONST
|
|
|
|
AC_FUNC_ALLOCA
|
|
|
|
AC_C_INLINE
|
|
|
|
|
|
|
|
# VMS doesn't have unlink.
|
|
|
|
AC_CHECK_FUNCS(unlink remove, break)
|
|
|
|
|
|
|
|
# Some systems don't have sbrk().
|
|
|
|
AC_CHECK_FUNCS(sbrk)
|
|
|
|
|
2000-06-20 21:52:32 +08:00
|
|
|
# do we need the math library?
|
|
|
|
case "${need_libm}" in
|
|
|
|
yes)
|
|
|
|
AC_CHECK_LIBM
|
|
|
|
AC_SUBST(LIBM)
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
1999-05-03 15:29:11 +08:00
|
|
|
# Some non-ANSI preprocessors botch requoting inside strings. That's bad
|
|
|
|
# enough, but on some of those systems, the assert macro relies on requoting
|
|
|
|
# working properly!
|
|
|
|
GAS_WORKING_ASSERT
|
|
|
|
|
|
|
|
# On some systems, the system header files may not declare malloc, realloc,
|
|
|
|
# and free. There are places where gas needs these functions to have been
|
|
|
|
# declared -- such as when taking their addresses.
|
|
|
|
gas_test_headers="
|
|
|
|
#ifdef HAVE_MEMORY_H
|
|
|
|
#include <memory.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_STRING_H
|
|
|
|
#include <string.h>
|
|
|
|
#else
|
|
|
|
#ifdef HAVE_STRINGS_H
|
|
|
|
#include <strings.h>
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_STDLIB_H
|
|
|
|
#include <stdlib.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_UNISTD_H
|
|
|
|
#include <unistd.h>
|
|
|
|
#endif
|
|
|
|
"
|
|
|
|
GAS_CHECK_DECL_NEEDED(strstr, f, char *(*f)(), $gas_test_headers)
|
|
|
|
GAS_CHECK_DECL_NEEDED(malloc, f, char *(*f)(), $gas_test_headers)
|
|
|
|
GAS_CHECK_DECL_NEEDED(free, f, void (*f)(), $gas_test_headers)
|
|
|
|
GAS_CHECK_DECL_NEEDED(sbrk, f, char *(*f)(), $gas_test_headers)
|
|
|
|
GAS_CHECK_DECL_NEEDED(environ, f, char **f, $gas_test_headers)
|
|
|
|
|
|
|
|
# Does errno.h declare errno, or do we have to add a separate declaration
|
|
|
|
# for it?
|
|
|
|
GAS_CHECK_DECL_NEEDED(errno, f, int f, [
|
|
|
|
#ifdef HAVE_ERRNO_H
|
|
|
|
#include <errno.h>
|
|
|
|
#endif
|
|
|
|
])
|
|
|
|
|
|
|
|
dnl This must come last.
|
|
|
|
|
|
|
|
dnl We used to make symlinks to files in the source directory, but now
|
|
|
|
dnl we just use the right name for .c files, and create .h files in
|
|
|
|
dnl the build directory which include the right .h file. Make sure
|
|
|
|
dnl the old symlinks don't exist, so that a reconfigure in an existing
|
|
|
|
dnl directory behaves reasonably.
|
|
|
|
|
2003-09-03 01:59:13 +08:00
|
|
|
AC_CONFIG_FILES(Makefile doc/Makefile po/Makefile.in:po/Make-in)
|
|
|
|
AC_CONFIG_COMMANDS([default],
|
1999-05-03 15:29:11 +08:00
|
|
|
[rm -f targ-cpu.c targ-cpu.h obj-format.h obj-format.c targ-env.h atof-targ.c itbl-cpu.h
|
|
|
|
echo '#include "tc-'"${target_cpu_type}"'.h"' > targ-cpu.h
|
|
|
|
echo '#include "obj-'"${obj_format}"'.h"' > obj-format.h
|
|
|
|
echo '#include "te-'"${te_file}"'.h"' > targ-env.h
|
|
|
|
echo '#include "itbl-'"${target_cpu_type}"'.h"' > itbl-cpu.h
|
|
|
|
if test "x$cgen_cpu_prefix" != x ; then
|
|
|
|
echo '#include "opcodes/'"${cgen_cpu_prefix}"'-desc.h"' > cgen-desc.h
|
|
|
|
fi
|
|
|
|
|
|
|
|
sed -e '/POTFILES =/r po/POTFILES' po/Makefile.in > po/Makefile],
|
|
|
|
[target_cpu_type=${target_cpu_type}
|
|
|
|
cgen_cpu_prefix=${cgen_cpu_prefix}
|
|
|
|
obj_format=${obj_format}
|
|
|
|
te_file=${te_file}])
|
2003-09-03 01:59:13 +08:00
|
|
|
|
|
|
|
AC_OUTPUT
|