1999-05-03 07:29:11 +00:00
|
|
|
dnl Process this file with autoconf to produce a configure script.
|
|
|
|
dnl
|
|
|
|
|
|
|
|
AC_PREREQ(2.13)
|
|
|
|
AC_INIT(z8k-dis.c)
|
|
|
|
|
|
|
|
AC_CANONICAL_SYSTEM
|
|
|
|
AC_ISC_POSIX
|
|
|
|
|
|
|
|
# We currently only use the version number for the name of any shared
|
|
|
|
# library. For user convenience, we always use the same version
|
|
|
|
# number that BFD is using.
|
|
|
|
changequote(,)dnl
|
|
|
|
BFD_VERSION=`grep INIT_AUTOMAKE ${srcdir}/../bfd/configure.in | sed -n -e 's/[ ]//g' -e 's/^.*,\(.*\)).*$/\1/p'`
|
|
|
|
changequote([,])dnl
|
|
|
|
|
|
|
|
AM_INIT_AUTOMAKE(opcodes, ${BFD_VERSION})
|
|
|
|
|
|
|
|
dnl These must be called before AM_PROG_LIBTOOL, because it may want
|
|
|
|
dnl to call AC_CHECK_PROG.
|
|
|
|
AC_CHECK_TOOL(AR, ar)
|
|
|
|
AC_CHECK_TOOL(RANLIB, ranlib, :)
|
|
|
|
|
|
|
|
dnl Default to a non shared library. This may be overridden by the
|
|
|
|
dnl configure option --enable-shared.
|
|
|
|
AM_DISABLE_SHARED
|
|
|
|
|
|
|
|
AM_PROG_LIBTOOL
|
|
|
|
|
|
|
|
AC_ARG_ENABLE(targets,
|
|
|
|
[ --enable-targets alternative target configurations],
|
|
|
|
[case "${enableval}" in
|
|
|
|
yes | "") AC_ERROR(enable-targets option must specify target names or 'all')
|
|
|
|
;;
|
|
|
|
no) enable_targets= ;;
|
|
|
|
*) enable_targets=$enableval ;;
|
|
|
|
esac])dnl
|
|
|
|
AC_ARG_ENABLE(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 opcodes commonbfdlib option]) ;;
|
|
|
|
esac])dnl
|
|
|
|
|
2000-04-09 12:17:43 +00:00
|
|
|
build_warnings="-W -Wall"
|
|
|
|
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 07:29:11 +00:00
|
|
|
AM_CONFIG_HEADER(config.h:config.in)
|
|
|
|
|
|
|
|
if test -z "$target" ; then
|
|
|
|
AC_MSG_ERROR(Unrecognized target system type; please check config.sub.)
|
|
|
|
fi
|
|
|
|
AC_ARG_PROGRAM
|
|
|
|
|
|
|
|
AM_MAINTAINER_MODE
|
|
|
|
AC_EXEEXT
|
|
|
|
|
|
|
|
# host-specific stuff:
|
|
|
|
|
|
|
|
AC_PROG_CC
|
|
|
|
|
|
|
|
ALL_LINGUAS=
|
|
|
|
CY_GNU_GETTEXT
|
|
|
|
|
|
|
|
. ${srcdir}/../bfd/configure.host
|
|
|
|
|
|
|
|
AC_SUBST(HDEFINES)
|
|
|
|
AC_PROG_INSTALL
|
|
|
|
|
|
|
|
AC_CHECK_HEADERS(string.h strings.h stdlib.h)
|
|
|
|
|
2000-07-29 00:33:34 +00:00
|
|
|
cgen_maint=no
|
|
|
|
cgendir='$(srcdir)/../cgen'
|
|
|
|
|
|
|
|
AC_ARG_ENABLE(cgen-maint,
|
|
|
|
[ --enable-cgen-maint[=dir] build cgen generated files],
|
|
|
|
[case "${enableval}" in
|
|
|
|
yes) cgen_maint=yes ;;
|
|
|
|
no) cgen_maint=no ;;
|
|
|
|
*)
|
|
|
|
# argument is cgen install directory (not implemented yet).
|
|
|
|
# Having a `share' directory might be more appropriate for the .scm,
|
|
|
|
# .cpu, etc. files.
|
|
|
|
cgen_maint=yes
|
|
|
|
cgendir=${cgen_maint}/lib/cgen
|
|
|
|
;;
|
|
|
|
esac])dnl
|
|
|
|
AM_CONDITIONAL(CGEN_MAINT, test x${cgen_maint} = xyes)
|
|
|
|
AC_SUBST(cgendir)
|
1999-05-03 07:29:11 +00:00
|
|
|
|
|
|
|
using_cgen=no
|
|
|
|
|
|
|
|
# Horrible hacks to build DLLs on Windows.
|
|
|
|
WIN32LDFLAGS=
|
|
|
|
WIN32LIBADD=
|
|
|
|
case "${host}" in
|
|
|
|
*-*-cygwin*)
|
|
|
|
if test "$enable_shared" = "yes"; then
|
|
|
|
WIN32LDFLAGS="-no-undefined"
|
|
|
|
WIN32LIBADD="-L`pwd`/../bfd -lbfd -L`pwd`/../libiberty -liberty -L`pwd`/../intl -lintl -lcygwin"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
AC_SUBST(WIN32LDFLAGS)
|
|
|
|
AC_SUBST(WIN32LIBADD)
|
|
|
|
|
|
|
|
# target-specific stuff:
|
|
|
|
|
|
|
|
# Canonicalize the secondary target names.
|
|
|
|
if test -n "$enable_targets" ; then
|
|
|
|
for targ in `echo $enable_targets | sed 's/,/ /g'`
|
|
|
|
do
|
1999-09-14 23:29:35 +00:00
|
|
|
result=`$ac_config_sub $targ 2>/dev/null`
|
1999-05-03 07:29:11 +00:00
|
|
|
if test -n "$result" ; then
|
|
|
|
canon_targets="$canon_targets $result"
|
|
|
|
else
|
|
|
|
# Allow targets that config.sub doesn't recognize, like "all".
|
|
|
|
canon_targets="$canon_targets $targ"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
|
|
|
all_targets=false
|
|
|
|
selarchs=
|
|
|
|
for targ in $target $canon_targets
|
|
|
|
do
|
|
|
|
if test "x$targ" = "xall" ; then
|
|
|
|
all_targets=true
|
|
|
|
else
|
|
|
|
. $srcdir/../bfd/config.bfd
|
|
|
|
selarchs="$selarchs $targ_archs"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
# Utility var, documents generic cgen support files.
|
|
|
|
|
|
|
|
cgen_files="cgen-opc.lo cgen-asm.lo cgen-dis.lo"
|
|
|
|
|
|
|
|
# We don't do any links based on the target system, just makefile config.
|
|
|
|
|
|
|
|
if test x${all_targets} = xfalse ; then
|
|
|
|
|
|
|
|
# Target architecture .o files.
|
|
|
|
ta=
|
|
|
|
|
|
|
|
for arch in $selarchs
|
|
|
|
do
|
|
|
|
ad=`echo $arch | sed -e s/bfd_//g -e s/_arch//g`
|
|
|
|
archdefs="$archdefs -DARCH_$ad"
|
|
|
|
case "$arch" in
|
|
|
|
bfd_a29k_arch) ta="$ta a29k-dis.lo" ;;
|
|
|
|
bfd_alliant_arch) ;;
|
|
|
|
bfd_alpha_arch) ta="$ta alpha-dis.lo alpha-opc.lo" ;;
|
|
|
|
bfd_arc_arch) ta="$ta arc-dis.lo arc-opc.lo" ;;
|
|
|
|
bfd_arm_arch) ta="$ta arm-dis.lo" ;;
|
2000-03-27 08:39:14 +00:00
|
|
|
bfd_avr_arch) ta="$ta avr-dis.lo" ;;
|
1999-05-03 07:29:11 +00:00
|
|
|
bfd_convex_arch) ;;
|
2000-07-20 16:46:28 +00:00
|
|
|
bfd_cris_arch) ta="$ta cris-dis.lo cris-opc.lo" ;;
|
1999-05-03 07:29:11 +00:00
|
|
|
bfd_d10v_arch) ta="$ta d10v-dis.lo d10v-opc.lo" ;;
|
|
|
|
bfd_d30v_arch) ta="$ta d30v-dis.lo d30v-opc.lo" ;;
|
|
|
|
bfd_fr30_arch) ta="$ta fr30-asm.lo fr30-desc.lo fr30-dis.lo fr30-ibld.lo fr30-opc.lo" using_cgen=yes ;;
|
|
|
|
bfd_h8300_arch) ta="$ta h8300-dis.lo" ;;
|
|
|
|
bfd_h8500_arch) ta="$ta h8500-dis.lo" ;;
|
|
|
|
bfd_hppa_arch) ta="$ta hppa-dis.lo" ;;
|
2000-02-23 13:52:23 +00:00
|
|
|
bfd_i370_arch) ta="$ta i370-dis.lo i370-opc.lo" ;;
|
1999-05-03 07:29:11 +00:00
|
|
|
bfd_i386_arch) ta="$ta i386-dis.lo" ;;
|
2000-07-22 Jason Eckhardt <jle@cygnus.com>
* include/opcode/i860.h (btne, bte, bla): Changed these opcodes
to use sbroff ('r') instead of split16 ('s').
(J, K, L, M): New operand types for 16-bit aligned fields.
(ld.x, {p}fld.x, fst.x, pst.d): Changed these opcodes to
use I, J, K, L, M instead of just I.
(T, U): New operand types for split 16-bit aligned fields.
(st.x): Changed these opcodes to use S, T, U instead of just S.
(andh, andnoth, orh, xorh): Deleted 3-register forms as they do not
exist on the i860.
(pfgt.sd, pfle.sd): Deleted these as they do not exist on the i860.
(pfeq.ss, pfeq.dd): New opcodes.
(st.s): Fixed incorrect mask bits.
(fmlow): Fixed incorrect mask bits.
(fzchkl, pfzchkl): Fixed incorrect mask bits.
(faddz, pfaddz): Fixed incorrect mask bits.
(form, pform): Fixed incorrect mask bits.
(pfld.l): Fixed incorrect mask bits.
(fst.q): Fixed incorrect mask bits.
(all floating point opcodes): Fixed incorrect mask bits for
handling of dual bit.
* include/elf/i860.h: New file.
(elf_i860_reloc_type): Defined ELF32 i860 relocations.
* bfd/cpu-i860.c: Added comments.
* bfd/elf32-i860.c (TARGET_LITTLE_SYM): Defined to
bfd_elf32_i860_little_vec.
(TARGET_LITTLE_NAME): Defined to "elf32-i860-little".
(ELF_MAXPAGESIZE): Changed to 4096.
* bfd/targets.c (bfd_elf32_i860_little_vec): Declaration of
new target.
(bfd_target_vector): Added bfd_elf32_i860_little_vec.
* bfd/config.bfd (i860-stardent-sysv4*, i860-stardent-elf*): Added
config for little endian elf32 i860.
(targ_defvec): Define for the new config above
as "bfd_elf32_i860_little_vec".
(targ_selvecs): Define for the new config above
as "bfd_elf32_i860_vec bfd_elf32_i860_little_vec"
* bfd/configure.in (bfd_elf32_i860_little_vec): Added recognition
of new target vec.
* bfd/configure: Regenerated.
* opcodes/i860-dis.c: New file.
(print_insn_i860): New function.
(print_br_address): New function.
(sign_extend): New function.
(BITWISE_OP): New macro.
(I860_REG_PREFIX): New macro.
(grnames, frnames, crnames): New structures.
* opcodes/disassemble.c (ARCH_i860): Define.
(disassembler): Add check for bfd_arch_i860 to set disassemble
function to print_insn_i860.
* include/dis-asm.h (print_insn_i860): Add prototype.
* opcodes/Makefile.in (CFILES): Added i860-dis.c.
(ALL_MACHINES): Added i860-dis.lo.
(i860-dis.lo): New dependences.
* opcodes/configure.in: New bits for bfd_i860_arch.
* opcodes/configure: Regenerated.
2000-07-28 21:10:20 +00:00
|
|
|
bfd_i860_arch) ta="$ta i860-dis.lo" ;;
|
1999-05-03 07:29:11 +00:00
|
|
|
bfd_i960_arch) ta="$ta i960-dis.lo" ;;
|
2000-04-21 20:22:24 +00:00
|
|
|
bfd_ia64_arch) ta="$ta ia64-dis.lo ia64-opc.lo" ;;
|
1999-05-03 07:29:11 +00:00
|
|
|
bfd_m32r_arch) ta="$ta m32r-asm.lo m32r-desc.lo m32r-dis.lo m32r-ibld.lo m32r-opc.lo m32r-opinst.lo" using_cgen=yes ;;
|
2000-06-19 01:22:44 +00:00
|
|
|
bfd_m68hc11_arch) ta="$ta m68hc11-dis.lo m68hc11-opc.lo" ;;
|
|
|
|
bfd_m68hc12_arch) ta="$ta m68hc11-dis.lo m68hc11-opc.lo" ;;
|
1999-05-03 07:29:11 +00:00
|
|
|
bfd_m68k_arch) ta="$ta m68k-dis.lo m68k-opc.lo" ;;
|
|
|
|
bfd_m88k_arch) ta="$ta m88k-dis.lo" ;;
|
|
|
|
bfd_mcore_arch) ta="$ta mcore-dis.lo" ;;
|
|
|
|
bfd_mips_arch) ta="$ta mips-dis.lo mips-opc.lo mips16-opc.lo" ;;
|
|
|
|
bfd_mn10200_arch) ta="$ta m10200-dis.lo m10200-opc.lo" ;;
|
|
|
|
bfd_mn10300_arch) ta="$ta m10300-dis.lo m10300-opc.lo" ;;
|
|
|
|
bfd_ns32k_arch) ta="$ta ns32k-dis.lo" ;;
|
1999-09-04 17:14:37 +00:00
|
|
|
bfd_pj_arch) ta="$ta pj-dis.lo pj-opc.lo" ;;
|
1999-05-03 07:29:11 +00:00
|
|
|
bfd_powerpc_arch) ta="$ta ppc-dis.lo ppc-opc.lo" ;;
|
|
|
|
bfd_pyramid_arch) ;;
|
|
|
|
bfd_romp_arch) ;;
|
|
|
|
bfd_rs6000_arch) ta="$ta ppc-dis.lo ppc-opc.lo" ;;
|
Add XCOFF64 support.
bfd:
* Makefile.am (coff64-rs6000.lo): New rule.
* Makefile.in: Regenerate.
* coff-rs6000.c (xcoff_mkobject, xcoff_copy_private_bfd_data,
xcoff_is_local_label_name, xcoff_rtype2howto,
xcoff_reloc_type_lookup, xcoff_slurp_armap, xcoff_archive_p,
xcoff_read_ar_hdr, xcoff_openr_next_archived_file, xcoff_write_armap,
xcoff_write_archive_contents): No longer static, and prefix with _bfd_.
(NO_COFF_SYMBOLS): Define.
(xcoff64_swap_sym_in, xcoff64_swap_sym_out, xcoff64_swap_aux_in,
xcoff64_swap_aux_out): New functions; handle xcoff symbol tables
internally.
(MINUS_ONE): New macro.
(xcoff_howto_tabl, xcoff_reloc_type_lookup): Add 64 bit POS
relocation.
(coff_SWAP_sym_in, coff_SWAP_sym_out, coff_SWAP_aux_in,
coff_SWAP_aux_out): Map to the new functions.
* coff64-rs6000.c: New file.
* libcoff.h (bfd_coff_backend_data): Add new fields
_bfd_coff_force_symnames_in_strings and
_bfd_coff_debug_string_prefix_length.
(bfd_coff_force_symnames_in_strings,
bfd_coff_debug_string_prefix_length): New macros for above fields.
* coffcode.h (coff_set_arch_mach_hook): Handle XCOFF64 magic.
Set machine to 620 for XCOFF64. Use bfd_coff_swap_sym_in instead
of using coff_swap_sym_in directly.
(FORCE_SYMNAMES_IN_STRINGS): New macro, defined for XCOFF64.
(coff_set_flags) Set magic for XCOFF64.
(coff_compute_section_file_positions): Add symbol name length to
string section length if bfd_coff_debug_string_prefix_length is
true.
(coff_write_object_contents): Don't do reloc overflow for XCOFF64.
(coff_slurp_line_table): Use bfd_coff_swap_lineno_in instead of
using coff_swap_lineno_in directly.
(bfd_coff_backend_data): Add _bfd_coff_force_symnames_in_strings
and _bfd_coff_debug_string_prefix_length fields.
* coffgen.c (coff_fix_symbol_name, coff_write_symbols): Force
symbol names into strings table when
bfd_coff_force_symnames_in_strings is true.
* coffswap.h (MAX_SCNHDR_NRELOC, MAX_SCNHDR_NLNNO, GET_RELOC_VADDR,
SET_RELOC_VADDR): New macros.
(coff_swap_reloc_in, coff_swap_reloc_out): Use above macros.
(coff_swap_aux_in, coff_swap_aux_out): Remove RS6000COFF_C
code.
(coff_swap_aouthdr_in, coff_swap_aouthdr_out): Handle XCOFF64
changes within RS6000COFF_C specific code.
(coff_swap_scnhdr_out): Use PUT_SCNHDR_NLNNO, PUT_SCNHDR_NRELOC,
MAX_SCNHDR_NRELOC, and MAX_SCNHDR_NLNNO.
* reloc.c (bfd_perform_relocation, bfd_install_relocation):
Extend existing hack on target name.
* xcofflink.c (XCOFF_XVECP): Extend existing hack on
target name.
* coff-tic54x.c (ticof): Keep up to date with new fields
in bfd_coff_backend_data.
* config.bfd: Add bfd_powerpc_64_arch to targ_arch and define
targ_selvecs to include rs6000coff64_vec for rs6000.
* configure.in: Add rs6000coff64_vec case.
* cpu-powerpc.c: New bfd_arch_info_type.
gas:
* as.c (parse_args): Allow md_parse_option to override -a listing
option.
* config/obj-coff.c (add_lineno): Change type of offset parameter
from "int" to "bfd_vma."
* config/tc-ppc.c (md_pseudo_table): Add "llong" and "machine."
(ppc_mach, ppc_subseg_align, ppc_target_format): New.
(ppc_change_csect): Align correctly for XCOFF64.
(ppc_machine): New function, which discards "ppc_machine" line.
(ppc_tc): Cons for 8 when code is 64 bit.
(md_apply_fix3): Don't check operand->insert. Handle 64 bit
relocations.
(md_parse_option): Handle -a64 and -a32.
(ppc_xcoff64): New.
* config/tc-ppc.h (TARGET_MACH): Define.
(TARGET_FORMAT): Move to function.
(SUB_SEGMENT_ALIGN): Use ppc_subseg_align.
include:
* include/coff/rs6k64.h: New file.
opcodes:
* configure.in: Add bfd_powerpc_64_arch.
* disassemble.c (disassembler): Use print_insn_big_powerpc for
64 bit code.
2000-04-26 15:09:44 +00:00
|
|
|
bfd_powerpc_64_arch) ta="$ta ppc-dis.lo ppc-opc.lo" ;;
|
2000-12-16 22:01:44 +00:00
|
|
|
bfd_sh_arch)
|
|
|
|
ta="$ta sh-dis.lo" ;;
|
1999-05-03 07:29:11 +00:00
|
|
|
bfd_sparc_arch) ta="$ta sparc-dis.lo sparc-opc.lo" ;;
|
|
|
|
bfd_tahoe_arch) ;;
|
|
|
|
bfd_tic30_arch) ta="$ta tic30-dis.lo" ;;
|
2000-05-06 17:14:34 +00:00
|
|
|
bfd_tic54x_arch) ta="$ta tic54x-dis.lo tic54x-opc.lo" ;;
|
1999-05-03 07:29:11 +00:00
|
|
|
bfd_tic80_arch) ta="$ta tic80-dis.lo tic80-opc.lo" ;;
|
|
|
|
bfd_v850_arch) ta="$ta v850-opc.lo v850-dis.lo" ;;
|
|
|
|
bfd_v850e_arch) ta="$ta v850-opc.lo v850-dis.lo" ;;
|
|
|
|
bfd_v850ea_arch) ta="$ta v850-opc.lo v850-dis.lo" ;;
|
|
|
|
bfd_vax_arch) ta="$ta vax-dis.lo" ;;
|
|
|
|
bfd_w65_arch) ta="$ta w65-dis.lo" ;;
|
|
|
|
bfd_we32k_arch) ;;
|
|
|
|
bfd_z8k_arch) ta="$ta z8k-dis.lo" ;;
|
|
|
|
|
|
|
|
"") ;;
|
|
|
|
*) AC_MSG_ERROR(*** unknown target architecture $arch) ;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
if test $using_cgen = yes ; then
|
|
|
|
ta="$ta $cgen_files"
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Weed out duplicate .o files.
|
|
|
|
f=""
|
|
|
|
for i in $ta ; do
|
|
|
|
case " $f " in
|
|
|
|
*" $i "*) ;;
|
|
|
|
*) f="$f $i" ;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
ta="$f"
|
|
|
|
|
|
|
|
# And duplicate -D flags.
|
|
|
|
f=""
|
|
|
|
for i in $archdefs ; do
|
|
|
|
case " $f " in
|
|
|
|
*" $i "*) ;;
|
|
|
|
*) f="$f $i" ;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
archdefs="$f"
|
|
|
|
|
|
|
|
BFD_MACHINES="$ta"
|
|
|
|
|
|
|
|
else # all_targets is true
|
|
|
|
archdefs=-DARCH_all
|
|
|
|
BFD_MACHINES='$(ALL_MACHINES)'
|
|
|
|
fi
|
|
|
|
|
|
|
|
AC_SUBST(archdefs)
|
|
|
|
AC_SUBST(BFD_MACHINES)
|
|
|
|
|
|
|
|
AC_OUTPUT(Makefile po/Makefile.in:po/Make-in,
|
|
|
|
[sed -e '/POTFILES =/r po/POTFILES' po/Makefile.in > po/Makefile])
|