aboutsummaryrefslogtreecommitdiff
path: root/include/gdb/sim-h8300.h
diff options
context:
space:
mode:
authorAndrey Volkov <avolkov@transas.com>2002-07-23 10:30:14 +0000
committerAndrey Volkov <avolkov@transas.com>2002-07-23 10:30:14 +0000
commit88ff637d20a39762ef7fe3be2812c58713fecb74 (patch)
tree62173fe3495060b7bc0aa9ebf0bbf40c62a9fb5b /include/gdb/sim-h8300.h
parent9e12c7db7f2c50e74e2be2fae6b25d565a18ae3a (diff)
downloadgdb-88ff637d20a39762ef7fe3be2812c58713fecb74.zip
gdb-88ff637d20a39762ef7fe3be2812c58713fecb74.tar.gz
gdb-88ff637d20a39762ef7fe3be2812c58713fecb74.tar.bz2
sim-h8300.h new file
Diffstat (limited to 'include/gdb/sim-h8300.h')
-rw-r--r--include/gdb/sim-h8300.h75
1 files changed, 75 insertions, 0 deletions
diff --git a/include/gdb/sim-h8300.h b/include/gdb/sim-h8300.h
new file mode 100644
index 0000000..10ec385
--- /dev/null
+++ b/include/gdb/sim-h8300.h
@@ -0,0 +1,75 @@
+/* This file defines the interface between the h8300 simulator and gdb.
+ Copyright (C) 2002 Free Software Foundation, Inc.
+
+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 2 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, write to the Free Software
+Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
+
+#if !defined (SIM_H8300_H)
+#define SIM_H8300_H
+
+#ifdef __cplusplus
+extern "C" { //}
+#endif
+
+/* The simulator makes use of the following register information. */
+
+/* Registers common to all the H8 variants. */
+ enum sim_h8300_regs
+ {
+ H8300_R0_REGNUM = 0,
+ H8300_R1_REGNUM,
+ H8300_R2_REGNUM,
+ H8300_R3_REGNUM,
+ H8300_R4_REGNUM,
+ H8300_R5_REGNUM,
+ H8300_R6_REGNUM,
+ H8300_R7_REGNUM,
+
+ H8300_PC_REGNUM, /* Contains program counter */
+ H8300_CCR_REGNUM, /* Contains processor status */
+
+ H8300_S_EXR_REGNUM, /* Contains extended processor status */
+ H8300_S_MACL_REGNUM,/* Lower part of MAC register */
+ H8300_S_MACH_REGNUM,/* High part of MAC register */
+
+ H8300_SIM_CYCLE_REGNUM,
+ H8300_SIM_INST_REGNUM,
+ H8300_SIM_TICK_REGNUM
+ };
+
+ enum
+ {
+ ARG_FIRST_REGNUM = H8300_R0_REGNUM, /* first reg in which an arg
+ may be passed */
+ ARG_LAST_REGNUM = H8300_R3_REGNUM, /* last reg in which an arg
+ may be passed */
+ H8300_FP_REGNUM = H8300_R6_REGNUM, /* Contain address of executing
+ stack frame */
+ H8300_SP_REGNUM = H8300_R7_REGNUM /* Contains address of top of stack */
+ };
+
+ enum
+ {
+ H8300_NUM_COMMON_REGS = 10,
+ H8300_S_NUM_REGS = 13,
+ H8300_NUM_SIM_REGS = 16
+ };
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* SIM_H8300_H */