Add an AArch64 simulator to GDB.

sim	* configure.tgt: Add aarch64 entry.
	* configure: Regenerate.
	* sim/aarch64/configure.ac: New configure template.
	* sim/aarch64/aclocal.m4: Generate.
	* sim/aarch64/config.in: Generate.
	* sim/aarch64/configure: Generate.
	* sim/aarch64/cpustate.c: New file - functions for accessing
	AArch64 registers.
	* sim/aarch64/cpustate.h: New header.
	* sim/aarch64/decode.h: New header.
	* sim/aarch64/interp.c: New file - interface between GDB and
	simulator.
	* sim/aarch64/Makefile.in: New makefile template.
	* sim/aarch64/memory.c: New file - functions for simulating
	aarch64 memory accesses.
	* sim/aarch64/memory.h: New header.
	* sim/aarch64/sim-main.h: New header.
	* sim/aarch64/simulator.c: New file - aarch64 simulator
	functions.
	* sim/aarch64/simulator.h: New header.

include/gdb * sim-aarch64.h: New file.

sim/test * configure: Regenerate.
	* sim/aarch64: New directory.
This commit is contained in:
Nick Clifton
2015-11-24 08:47:59 +00:00
parent 351e610191
commit 2e8cf49e13
25 changed files with 31452 additions and 4 deletions

View File

@ -1,3 +1,7 @@
2015-11-24 Nick Clifton <nickc@redhat.com>
* sim-aarch64.h: New file.
2015-11-15 Mike Frysinger <vapier@gentoo.org>
* sim-cr16.h (SIM_CR16_MEMORY_UNIFIED, SIM_CR16_MEMORY_INSN,

48
include/gdb/sim-aarch64.h Normal file
View File

@ -0,0 +1,48 @@
/* sim-aarch64.h --- interface between AArch64 simulator and GDB.
Copyright (C) 2015 Free Software Foundation, Inc.
Contributed by Red Hat.
This file is part of GDB.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>. */
#if !defined (SIM_AARCH64_H)
#define SIM_AARCH64_H
enum sim_aarch64_regnum
{
SIM_AARCH64_R0_REGNUM,
SIM_AARCH64_R1_REGNUM,
SIM_AARCH64_R2_REGNUM,
SIM_AARCH64_R3_REGNUM,
SIM_AARCH64_R4_REGNUM,
SIM_AARCH64_R5_REGNUM,
SIM_AARCH64_R6_REGNUM,
SIM_AARCH64_R7_REGNUM,
SIM_AARCH64_R8_REGNUM,
SIM_AARCH64_R9_REGNUM,
SIM_AARCH64_R10_REGNUM,
SIM_AARCH64_R11_REGNUM,
SIM_AARCH64_R12_REGNUM,
SIM_AARCH64_R13_REGNUM,
SIM_AARCH64_R14_REGNUM,
SIM_AARCH64_R15_REGNUM,
SIM_AARCH64_SP_REGNUM,
SIM_AARCH64_PC_REGNUM,
SIM_AARCH64_NUM_REGS
};
#endif