58d6951de5
* target-descriptions.c (tdesc_register_type): Make public. (tdesc_unnumbered_register): New function. (tdesc_register_reggroup_p): Allow missing pseudo_register_reggroup_p. * target-descriptions.h (tdesc_register_type): Declare. (tdesc_unnumbered_register): Declare. * arm-tdep.c (arm_neon_quad_read, arm_neon_quad_write): New functions. (arm_push_dummy_call): Use arm_neon_quad_write. (arm_neon_double_type, arm_neon_quad_type): New functions. (arm_register_type): Handle VFP and NEON registers. Override the types of double-precision registers for NEON. Disable FPA registers if they are not present. (arm_dwarf_reg_to_regnum): Add current VFP and NEON register numbers. (arm_return_value): Use arm_neon_quad_write and arm_neon_quad_read. (arm_register_name): Handle VFP single and NEON quad registers. (arm_pseudo_read, arm_pseudo_write): New functions. (arm_gdbarch_init): Check for VFP and NEON in the target description. Assign numbers to double-precision registers. Register VFP and NEON pseudo registers. Remove a shadowed "i" variable. * arm-tdep.h (enum gdb_regnum): Add ARM_D0_REGNUM and ARM_D31_REGNUM. (struct gdbarch_tdep): Add have_neon_pseudos, have_neon, have_vfp_registers, have_vfp_pseudos, neon_double_type, and neon_quad_type. * features/Makefile: Make expedite settings only architecture specific. (WHICH): Add new ARM descriptions. * features/arm-with-neon.xml, features/arm-with-vfpv2.c, features/arm-with-vfpv3.c, features/arm-vfpv2.xml, features/arm-vfpv3.xml, features/arm-with-vfpv2.xml, features/arm-with-vfpv3.xml, features/arm-with-neon.c: New files. * regformats/arm-with-neon.dat, regformats/arm-with-vfpv2.dat, regformats/arm-with-vfpv3.dat: Generate. doc/ * gdb.texinfo (ARM Features): Document org.gnu.gdb.arm.vfp and org.gnu.gdb.arm.neon. gdbserver/ * linux-low.c (linux_write_memory): Update debugging output. * Makefile.in (clean): Add new descriptions. (arm-with-vfpv2.o, arm-with-vfpv2.c, arm-with-vfpv3.o) (arm-with-vfpv3.c, arm-with-neon.o, arm-with-neon.c): New rules. * configure.srv: Add new files for arm*-*-linux*. * linux-arm-low.c: Add new declarations. (PTRACE_GETVFPREGS, PTRACE_SETVFPREGS): Define if undefined. (arm_hwcap, HWCAP_VFP, HWCAP_IWMMXT, HWCAP_NEON, HWCAP_VFPv3) (HWCAP_VFPv3D16): New. (arm_fill_wmmxregset, arm_store_wmmxregset): Check HWCAP_IWMMXT instead of __IWMMXT__. (arm_fill_vfpregset, arm_store_vfpregset, arm_get_hwcap) (arm_arch_setup): New. (target_regsets): Remove #ifdef. Add VFP regset. (the_low_target): Use arm_arch_setup. testsuite/ * gdb.base/float.exp: Handle VFP registers.
202 lines
7.4 KiB
Text
202 lines
7.4 KiB
Text
# Mappings from configuration triplets to gdbserver build options.
|
|
# This is invoked from the autoconf-generated configure script, to
|
|
# produce the appropriate Makefile substitutions.
|
|
|
|
# This file sets the following shell variables:
|
|
# srv_regobj The register protocol appropriate for this target.
|
|
# srv_tgtobj Any other target-specific modules appropriate
|
|
# for this target.
|
|
# srv_hostio_err The object implementing the hostio_last_error
|
|
# target method.
|
|
# srv_xmlfiles All XML files which should be available for
|
|
# gdbserver in this configuration.
|
|
#
|
|
# In addition, on GNU/Linux the following shell variables will be set:
|
|
# srv_linux_regsets Set to "yes" if ptrace(PTRACE_GETREGS) and friends
|
|
# may be available on this platform; unset otherwise.
|
|
# They will only be used if <sys/ptrace.h> defines
|
|
# PTRACE_GETREGS.
|
|
# srv_linux_usrregs Set to "yes" if we can get at registers via
|
|
# PTRACE_PEEKUSR / PTRACE_POKEUSR.
|
|
|
|
# Default hostio_last_error implementation
|
|
srv_hostio_err_objs="hostio-errno.o"
|
|
|
|
# Input is taken from the "${target}" variable.
|
|
|
|
case "${target}" in
|
|
arm*-*-linux*) srv_regobj="reg-arm.o arm-with-iwmmxt.o"
|
|
srv_regobj="${srv_regobj} arm-with-vfpv2.o"
|
|
srv_regobj="${srv_regobj} arm-with-vfpv3.o"
|
|
srv_regobj="${srv_regobj} arm-with-neon.o"
|
|
srv_tgtobj="linux-low.o linux-arm-low.o"
|
|
srv_xmlfiles="arm-with-iwmmxt.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} arm-with-vfpv2.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} arm-with-vfpv3.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} arm-with-neon.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} arm-core.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} xscale-iwmmxt.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} arm-vfpv2.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} arm-vfpv3.xml"
|
|
srv_linux_usrregs=yes
|
|
srv_linux_regsets=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
arm*-*-mingw32ce*) srv_regobj=reg-arm.o
|
|
srv_tgtobj="win32-low.o win32-arm-low.o"
|
|
srv_tgtobj="${srv_tgtobj} wincecompat.o"
|
|
# hostio_last_error implementation is in win32-low.c
|
|
srv_hostio_err_objs=""
|
|
srv_mingw=yes
|
|
srv_mingwce=yes
|
|
;;
|
|
crisv32-*-linux*) srv_regobj=reg-crisv32.o
|
|
srv_tgtobj="linux-low.o linux-crisv32-low.o"
|
|
srv_linux_regsets=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
cris-*-linux*) srv_regobj=reg-cris.o
|
|
srv_tgtobj="linux-low.o linux-cris-low.o"
|
|
srv_linux_usrregs=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
i[34567]86-*-cygwin*) srv_regobj=reg-i386.o
|
|
srv_tgtobj="i386-low.o win32-low.o win32-i386-low.o"
|
|
;;
|
|
i[34567]86-*-linux*) srv_regobj=reg-i386-linux.o
|
|
srv_tgtobj="linux-low.o linux-x86-low.o i386-low.o i387-fp.o"
|
|
srv_linux_usrregs=yes
|
|
srv_linux_regsets=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
i[34567]86-*-mingw32ce*)
|
|
srv_regobj=reg-i386.o
|
|
srv_tgtobj="i386-low.o win32-low.o win32-i386-low.o"
|
|
srv_tgtobj="${srv_tgtobj} wincecompat.o"
|
|
# hostio_last_error implementation is in win32-low.c
|
|
srv_hostio_err_objs=""
|
|
srv_mingw=yes
|
|
srv_mingwce=yes
|
|
;;
|
|
i[34567]86-*-mingw*) srv_regobj=reg-i386.o
|
|
srv_tgtobj="i386-low.o win32-low.o win32-i386-low.o"
|
|
srv_mingw=yes
|
|
;;
|
|
i[34567]86-*-nto*) srv_regobj=reg-i386.o
|
|
srv_tgtobj="nto-low.o nto-x86-low.o"
|
|
srv_qnx="yes"
|
|
;;
|
|
ia64-*-linux*) srv_regobj=reg-ia64.o
|
|
srv_tgtobj="linux-low.o linux-ia64-low.o"
|
|
srv_linux_usrregs=yes
|
|
;;
|
|
m32r*-*-linux*) srv_regobj=reg-m32r.o
|
|
srv_tgtobj="linux-low.o linux-m32r-low.o"
|
|
srv_linux_usrregs=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
m68*-*-linux*) srv_regobj=reg-m68k.o
|
|
srv_tgtobj="linux-low.o linux-m68k-low.o"
|
|
srv_linux_usrregs=yes
|
|
srv_linux_regsets=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
m68*-*-uclinux*) srv_regobj=reg-m68k.o
|
|
srv_tgtobj="linux-low.o linux-m68k-low.o"
|
|
srv_linux_usrregs=yes
|
|
srv_linux_regsets=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
mips*-*-linux*) srv_regobj="mips-linux.o mips64-linux.o"
|
|
srv_tgtobj="linux-low.o linux-mips-low.o"
|
|
srv_xmlfiles="mips-linux.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} mips-cpu.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} mips-cp0.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} mips-fpu.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} mips64-linux.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} mips64-cpu.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} mips64-cp0.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} mips64-fpu.xml"
|
|
srv_linux_regsets=yes
|
|
srv_linux_usrregs=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
powerpc*-*-linux*) srv_regobj="powerpc-32l.o"
|
|
srv_regobj="${srv_regobj} powerpc-altivec32l.o"
|
|
srv_regobj="${srv_regobj} powerpc-vsx32l.o"
|
|
srv_regobj="${srv_regobj} powerpc-isa205-32l.o"
|
|
srv_regobj="${srv_regobj} powerpc-isa205-altivec32l.o"
|
|
srv_regobj="${srv_regobj} powerpc-isa205-vsx32l.o"
|
|
srv_regobj="${srv_regobj} powerpc-e500l.o"
|
|
srv_regobj="${srv_regobj} powerpc-64l.o"
|
|
srv_regobj="${srv_regobj} powerpc-altivec64l.o"
|
|
srv_regobj="${srv_regobj} powerpc-vsx64l.o"
|
|
srv_regobj="${srv_regobj} powerpc-isa205-64l.o"
|
|
srv_regobj="${srv_regobj} powerpc-isa205-altivec64l.o"
|
|
srv_regobj="${srv_regobj} powerpc-isa205-vsx64l.o"
|
|
srv_tgtobj="linux-low.o linux-ppc-low.o"
|
|
srv_xmlfiles="rs6000/powerpc-32l.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/powerpc-altivec32l.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/powerpc-vsx32l.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/powerpc-isa205-32l.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/powerpc-isa205-altivec32l.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/powerpc-isa205-vsx32l.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/power-altivec.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/power-vsx.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/power-core.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/power-linux.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/power-fpu.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/power-fpu-isa205.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/powerpc-e500l.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/power-spe.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/powerpc-64l.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/powerpc-altivec64l.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/powerpc-vsx64l.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/powerpc-isa205-64l.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/powerpc-isa205-altivec64l.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/powerpc-isa205-vsx64l.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/power64-core.xml"
|
|
srv_xmlfiles="${srv_xmlfiles} rs6000/power64-linux.xml"
|
|
srv_linux_usrregs=yes
|
|
srv_linux_regsets=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
s390*-*-linux*) srv_regobj="reg-s390.o reg-s390x.o"
|
|
srv_tgtobj="linux-low.o linux-s390-low.o"
|
|
srv_linux_usrregs=yes
|
|
srv_linux_regsets=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
sh*-*-linux*) srv_regobj=reg-sh.o
|
|
srv_tgtobj="linux-low.o linux-sh-low.o"
|
|
srv_linux_usrregs=yes
|
|
srv_linux_regsets=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
sparc*-*-linux*) srv_regobj=reg-sparc64.o
|
|
srv_tgtobj="linux-low.o linux-sparc-low.o"
|
|
srv_linux_regsets=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
spu*-*-*) srv_regobj=reg-spu.o
|
|
srv_tgtobj="spu-low.o"
|
|
;;
|
|
x86_64-*-linux*) srv_regobj="reg-x86-64-linux.o reg-i386-linux.o"
|
|
srv_tgtobj="linux-low.o linux-x86-low.o i386-low.o i387-fp.o"
|
|
srv_linux_usrregs=yes # This is for i386 progs.
|
|
srv_linux_regsets=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
xscale*-*-linux*) srv_regobj=reg-arm.o
|
|
srv_tgtobj="linux-low.o linux-arm-low.o"
|
|
srv_linux_usrregs=yes
|
|
srv_linux_thread_db=yes
|
|
;;
|
|
xtensa*-*-linux*) srv_regobj=reg-xtensa.o
|
|
srv_tgtobj="linux-low.o linux-xtensa-low.o"
|
|
srv_linux_regsets=yes
|
|
;;
|
|
*) echo "Error: target not supported by gdbserver."
|
|
exit 1
|
|
;;
|
|
esac
|