* Makefile.in (SPARC64_OBJS): Add dev64.o.

(CPU_OBJS): New variable.
	(SIM_OBJS): Add sparc-desc.o.
	(SIM_EXTRA_DEPS): Replace cpu-opc.h with sparc-desc.h.
	(sim-core.o): Add dev64.h dependency.
	(dev64.o): Add rule.
	(stamp-arch,stamp-cpu32): Update FLAGS variable, option syntax changed.
	(stamp-cpu64): Ditto.
	(stamp-desc): New rule.
	* configure.in (sim_link_files,sim_link_links): Delete.
	Set cpu_objs to one of SPARC32_OBJS,SPARC64_OBJS.
	* configure: Rebuild.
	* acconfig.h: Rebuild.
	* config.in: Rebuild.
	* dev64.c: New file.
	* dev64.h: New file.
	* sparc64.c: New file.
	* trap64.h: New file.
	* arch.c,arch.h,cpuall.h: Rebuild.
	* cpu32.c,decode32.c,decode32.h,model32.c,sem32.c: Rebuild.
	* sim-if.c (sparc_disassemble_insn): New function.
	(sim_open): sparc_cgen_cpu_open renamed from sparc_cgen_opcode_open.
	Set disassembler.
	(sim_close): sparc_cgen_cpu_open renamed from sparc_cgen_opcode_open.
	* sim-main.h: Don't include cpu-opc.h,cpu-sim.h. Include
	sparc-desc.h,sparc-opc.h,sparc-sim.h.
This commit is contained in:
Doug Evans 1999-02-10 09:42:33 +00:00
parent 9aa2d8ddaf
commit c14d22a7a7
15 changed files with 14168 additions and 14 deletions

View File

@ -38,6 +38,8 @@ decode32.c
decode32.h
dev32.c
dev32.h
dev64.c
dev64.h
mloop32.in
model32.c
regs32.h
@ -47,9 +49,11 @@ sim-main.h
sparc-sim.h
sparc.c
sparc32.c
sparc64.c
tconfig.in
trap32.c
trap32.h
trap64.h
Things-to-lose:

32
sim/sparc/ChangeLog Normal file
View File

@ -0,0 +1,32 @@
1999-02-09 Doug Evans <devans@casey.cygnus.com>
* Makefile.in (SPARC64_OBJS): Add dev64.o.
(CPU_OBJS): New variable.
(SIM_OBJS): Add sparc-desc.o.
(SIM_EXTRA_DEPS): Replace cpu-opc.h with sparc-desc.h.
(sim-core.o): Add dev64.h dependency.
(dev64.o): Add rule.
(stamp-arch,stamp-cpu32): Update FLAGS variable, option syntax changed.
(stamp-cpu64): Ditto.
(stamp-desc): New rule.
* configure.in (sim_link_files,sim_link_links): Delete.
Set cpu_objs to one of SPARC32_OBJS,SPARC64_OBJS.
* configure: Rebuild.
* acconfig.h: Rebuild.
* config.in: Rebuild.
* dev64.c: New file.
* dev64.h: New file.
* sparc64.c: New file.
* trap64.h: New file.
* arch.c,arch.h,cpuall.h: Rebuild.
* cpu32.c,decode32.c,decode32.h,model32.c,sem32.c: Rebuild.
* sim-if.c (sparc_disassemble_insn): New function.
(sim_open): sparc_cgen_cpu_open renamed from sparc_cgen_opcode_open.
Set disassembler.
(sim_close): sparc_cgen_cpu_open renamed from sparc_cgen_opcode_open.
* sim-main.h: Don't include cpu-opc.h,cpu-sim.h. Include
sparc-desc.h,sparc-opc.h,sparc-sim.h.
1999-02-02 Doug Evans <devans@casey.cygnus.com>
* Directory created.

View File

@ -4,7 +4,10 @@
## COMMON_PRE_CONFIG_FRAG
SPARC32_OBJS = sparc32.o trap32.o dev32.o cpu32.o decode32.o model32.o mloop32.o sem32.o
SPARC64_OBJS = sparc64.o trap64.o cpu64.o decode64.o model64.o mloop64.o sem64.o
SPARC64_OBJS = sparc64.o trap64.o dev64.o cpu64.o decode64.o model64.o mloop64.o sem64.o
# Set to one of SPARC32_OBJS/SPARC64_OBJS.
CPU_OBJS = @cpu_objs@
SIM_OBJS = \
$(SIM_NEW_COMMON_OBJS) \
@ -15,14 +18,14 @@ SIM_OBJS = \
sim-reg.o \
cgen-utils.o cgen-trace.o cgen-scache.o \
cgen-run.o sim-reason.o sim-engine.o sim-stop.o \
sim-if.o sparc.o arch.o \
$(SPARC32_OBJS)
sim-if.o sparc.o arch.o sparc-desc.o \
$(CPU_OBJS)
# Extra headers included by sim-main.h.
# This plus sim_main_headers is used by Make-common.in for files in common.
SIM_EXTRA_DEPS = \
$(CGEN_INCLUDE_DEPS) \
arch.h cpuall.h cpu-opc.h
arch.h cpuall.h sparc-desc.h
# sparc-sim.h kept out for now (too much unnecessary recompilation)
SIM_EXTRA_CFLAGS =
@ -37,7 +40,8 @@ NL_TARGET = -DNL_TARGET_sparc
arch = sparc
sim-if.o: sim-if.c $(SIM_MAIN_DEPS) $(srcdir)/../common/sim-core.h dev32.h
sim-if.o: sim-if.c $(SIM_MAIN_DEPS) $(srcdir)/../common/sim-core.h \
dev32.h dev64.h
sparc.o: sparc.c $(SIM_MAIN_DEPS) \
$(srcdir)/../common/cgen-mem.h \
$(srcdir)/../common/cgen-ops.h
@ -81,6 +85,7 @@ SPARC64_INCLUDE_DEPS = \
sparc64.o: sparc64.c $(SPARC64_INCLUDE_DEPS)
trap64.o: trap64.c $(SPARC64_INCLUDE_DEPS)
dev64.o: dev64.c $(SPARC32_INCLUDE_DEPS) dev64.h
# FIXME: Use of `mono' is wip.
mloop64.c eng64.h: stamp-mloop64
@ -98,38 +103,50 @@ decode64.o: decode64.c $(SPARC64_INCLUDE_DEPS)
model64.o: model64.c $(SPARC64_INCLUDE_DEPS)
sparc-clean:
rm -f mloop32.c eng32.h mloop64.c eng64.h stamp-mloop32 stamp-mloop64
rm -f stamp-arch stamp-cpu32 stamp-cpu64
rm -f mloop32.c eng32.h stamp-mloop32
rm -f mloop64.c eng64.h stamp-mloop64
rm -f stamp-arch stamp-cpu32 stamp-cpu64 stamp-desc
rm -f tmp-*
# cgen support
stamp-arch: $(CGEN_MAIN_SCM) $(CGEN_ARCH_SCM) \
stamp-arch: $(CGEN_READ_SCM) $(CGEN_ARCH_SCM) \
$(srccgen)/sparc.cpu $(srccgen)/sparccom.cpu \
$(srccgen)/sparc32.cpu $(srccgen)/sparc64.cpu
$(MAKE) cgen-arch $(CGEN_FLAGS_TO_PASS) mach=sparc-v8,sparclite
$(MAKE) cgen-arch $(CGEN_FLAGS_TO_PASS) \
mach=sparc-v8,sparclite,sparc-v9 \
FLAGS="copyright=cygnus package=cygsim"
touch stamp-arch
arch.h arch.c cpuall.h: $(CGEN_MAIN) stamp-arch
@true
# Add with-scache to FLAGS when switching to -pbb.
stamp-cpu32: $(CGEN_MAIN_SCM) $(CGEN_CPU_SCM) $(CGEN_DECODE_SCM) \
stamp-cpu32: $(CGEN_READ_SCM) $(CGEN_CPU_SCM) $(CGEN_DECODE_SCM) \
$(srccgen)/sparc.cpu $(srccgen)/sparccom.cpu $(srccgen)/sparc32.cpu
$(MAKE) cgen-cpu-decode $(CGEN_FLAGS_TO_PASS) \
cpu=sparc32 mach=sparc-v8,sparclite SUFFIX=32 \
FLAGS="with-profile fn" \
FLAGS="with-profile=fn copyright=cygnus package=cygsim" \
EXTRAFILES="$(CGEN_CPU_SEM)"
touch stamp-cpu32
cpu32.h decode32.h decode32.c model32.c sem32.c sem32-switch.c: $(CGEN_MAINT) stamp-cpu32
@true
# Add with-scache to FLAGS when switching to -pbb.
stamp-cpu64: $(CGEN_MAIN_SCM) $(CGEN_CPU_SCM) $(CGEN_DECODE_SCM) \
stamp-cpu64: $(CGEN_READ_SCM) $(CGEN_CPU_SCM) $(CGEN_DECODE_SCM) \
$(srccgen)/sparc.cpu $(srccgen)/sparccom.cpu $(srccgen)/sparc64.cpu
$(MAKE) cgen-cpu-decode $(CGEN_FLAGS_TO_PASS) \
cpu=sparc64 mach=sparc-v9,sparc-v9a SUFFIX=64 \
FLAGS="with-profile fn" \
cpu=sparc64 mach=sparc-v9 SUFFIX=64 \
FLAGS="with-profile=fn copyright=cygnus package=cygsim" \
EXTRAFILES="$(CGEN_CPU_SEM)"
touch stamp-cpu64
cpu64.h decode64.h decode64.c model64.c sem64.c sem64-switch.c: $(CGEN_MAINT) stamp-cpu64
@true
stamp-desc: $(CGEN_READ_SCM) $(CGEN_DESC_SCM) \
$(srccgen)/sparc.cpu $(srccgen)/sparccom.cpu $(srccgen)/sparc32.cpu $(srccgen)/sparc64.cpu
$(MAKE) cgen-desc $(CGEN_FLAGS_TO_PASS) \
cpu=sparc mach=all \
FLAGS="copyright=cygnus package=cygsim"
touch stamp-desc
sparc-desc.c sparc-desc.h sparc-opc: $(CGEN_MAINT) stamp-desc
@true

View File

@ -13,3 +13,6 @@
/* Define if your locale.h file contains LC_MESSAGES. */
#undef HAVE_LC_MESSAGES
/* Define if sparc64 target. */
#undef SPARC64_P

2428
sim/sparc/arch.c Normal file

File diff suppressed because it is too large Load Diff

149
sim/sparc/arch.h Normal file
View File

@ -0,0 +1,149 @@
/* Simulator header for sparc.
THIS FILE IS MACHINE GENERATED WITH CGEN.
Copyright (C) 1999 Cygnus Solutions, Inc.
This file is part of the Cygnus Simulators.
*/
#ifndef SPARC_ARCH_H
#define SPARC_ARCH_H
#define TARGET_BIG_ENDIAN 1
/* Cover fns for register access. */
USI a_sparc_h_pc_get (SIM_CPU *);
void a_sparc_h_pc_set (SIM_CPU *, USI);
SI a_sparc_h_npc_get (SIM_CPU *);
void a_sparc_h_npc_set (SIM_CPU *, SI);
SI a_sparc_h_gr_get (SIM_CPU *, UINT);
void a_sparc_h_gr_set (SIM_CPU *, UINT, SI);
BI a_sparc_h_icc_c_get (SIM_CPU *);
void a_sparc_h_icc_c_set (SIM_CPU *, BI);
BI a_sparc_h_icc_n_get (SIM_CPU *);
void a_sparc_h_icc_n_set (SIM_CPU *, BI);
BI a_sparc_h_icc_v_get (SIM_CPU *);
void a_sparc_h_icc_v_set (SIM_CPU *, BI);
BI a_sparc_h_icc_z_get (SIM_CPU *);
void a_sparc_h_icc_z_set (SIM_CPU *, BI);
BI a_sparc_h_xcc_c_get (SIM_CPU *);
void a_sparc_h_xcc_c_set (SIM_CPU *, BI);
BI a_sparc_h_xcc_n_get (SIM_CPU *);
void a_sparc_h_xcc_n_set (SIM_CPU *, BI);
BI a_sparc_h_xcc_v_get (SIM_CPU *);
void a_sparc_h_xcc_v_set (SIM_CPU *, BI);
BI a_sparc_h_xcc_z_get (SIM_CPU *);
void a_sparc_h_xcc_z_set (SIM_CPU *, BI);
SI a_sparc_h_y_get (SIM_CPU *);
void a_sparc_h_y_set (SIM_CPU *, SI);
SI a_sparc_h_asr_get (SIM_CPU *, UINT);
void a_sparc_h_asr_set (SIM_CPU *, UINT, SI);
BI a_sparc_h_annul_p_get (SIM_CPU *);
void a_sparc_h_annul_p_set (SIM_CPU *, BI);
SF a_sparc_h_fr_get (SIM_CPU *, UINT);
void a_sparc_h_fr_set (SIM_CPU *, UINT, SF);
USI a_sparc_h_psr_get (SIM_CPU *);
void a_sparc_h_psr_set (SIM_CPU *, USI);
BI a_sparc_h_s_get (SIM_CPU *);
void a_sparc_h_s_set (SIM_CPU *, BI);
BI a_sparc_h_ps_get (SIM_CPU *);
void a_sparc_h_ps_set (SIM_CPU *, BI);
UQI a_sparc_h_pil_get (SIM_CPU *);
void a_sparc_h_pil_set (SIM_CPU *, UQI);
BI a_sparc_h_et_get (SIM_CPU *);
void a_sparc_h_et_set (SIM_CPU *, BI);
SI a_sparc_h_tbr_get (SIM_CPU *);
void a_sparc_h_tbr_set (SIM_CPU *, SI);
UQI a_sparc_h_cwp_get (SIM_CPU *);
void a_sparc_h_cwp_set (SIM_CPU *, UQI);
USI a_sparc_h_wim_get (SIM_CPU *);
void a_sparc_h_wim_set (SIM_CPU *, USI);
QI a_sparc_h_ag_get (SIM_CPU *);
void a_sparc_h_ag_set (SIM_CPU *, QI);
BI a_sparc_h_ec_get (SIM_CPU *);
void a_sparc_h_ec_set (SIM_CPU *, BI);
BI a_sparc_h_ef_get (SIM_CPU *);
void a_sparc_h_ef_set (SIM_CPU *, BI);
USI a_sparc_h_fsr_get (SIM_CPU *);
void a_sparc_h_fsr_set (SIM_CPU *, USI);
UDI a_sparc_h_ver_get (SIM_CPU *);
void a_sparc_h_ver_set (SIM_CPU *, UDI);
UDI a_sparc_h_pstate_get (SIM_CPU *);
void a_sparc_h_pstate_set (SIM_CPU *, UDI);
UDI a_sparc_h_tba_get (SIM_CPU *);
void a_sparc_h_tba_set (SIM_CPU *, UDI);
UDI a_sparc_h_tt_get (SIM_CPU *);
void a_sparc_h_tt_set (SIM_CPU *, UDI);
UQI a_sparc_h_asi_get (SIM_CPU *);
void a_sparc_h_asi_set (SIM_CPU *, UQI);
UQI a_sparc_h_tl_get (SIM_CPU *);
void a_sparc_h_tl_set (SIM_CPU *, UQI);
UDI a_sparc_h_tpc_get (SIM_CPU *);
void a_sparc_h_tpc_set (SIM_CPU *, UDI);
UDI a_sparc_h_tnpc_get (SIM_CPU *);
void a_sparc_h_tnpc_set (SIM_CPU *, UDI);
UDI a_sparc_h_tstate_get (SIM_CPU *);
void a_sparc_h_tstate_set (SIM_CPU *, UDI);
UDI a_sparc_h_tick_get (SIM_CPU *);
void a_sparc_h_tick_set (SIM_CPU *, UDI);
UDI a_sparc_h_cansave_get (SIM_CPU *);
void a_sparc_h_cansave_set (SIM_CPU *, UDI);
UDI a_sparc_h_canrestore_get (SIM_CPU *);
void a_sparc_h_canrestore_set (SIM_CPU *, UDI);
UDI a_sparc_h_otherwin_get (SIM_CPU *);
void a_sparc_h_otherwin_set (SIM_CPU *, UDI);
UDI a_sparc_h_cleanwin_get (SIM_CPU *);
void a_sparc_h_cleanwin_set (SIM_CPU *, UDI);
UDI a_sparc_h_wstate_get (SIM_CPU *);
void a_sparc_h_wstate_set (SIM_CPU *, UDI);
UQI a_sparc_h_fcc0_get (SIM_CPU *);
void a_sparc_h_fcc0_set (SIM_CPU *, UQI);
UQI a_sparc_h_fcc1_get (SIM_CPU *);
void a_sparc_h_fcc1_set (SIM_CPU *, UQI);
UQI a_sparc_h_fcc2_get (SIM_CPU *);
void a_sparc_h_fcc2_set (SIM_CPU *, UQI);
UQI a_sparc_h_fcc3_get (SIM_CPU *);
void a_sparc_h_fcc3_set (SIM_CPU *, UQI);
UQI a_sparc_h_fsr_rd_get (SIM_CPU *);
void a_sparc_h_fsr_rd_set (SIM_CPU *, UQI);
UQI a_sparc_h_fsr_tem_get (SIM_CPU *);
void a_sparc_h_fsr_tem_set (SIM_CPU *, UQI);
BI a_sparc_h_fsr_ns_get (SIM_CPU *);
void a_sparc_h_fsr_ns_set (SIM_CPU *, BI);
UQI a_sparc_h_fsr_ver_get (SIM_CPU *);
void a_sparc_h_fsr_ver_set (SIM_CPU *, UQI);
UQI a_sparc_h_fsr_ftt_get (SIM_CPU *);
void a_sparc_h_fsr_ftt_set (SIM_CPU *, UQI);
BI a_sparc_h_fsr_qne_get (SIM_CPU *);
void a_sparc_h_fsr_qne_set (SIM_CPU *, BI);
UQI a_sparc_h_fsr_aexc_get (SIM_CPU *);
void a_sparc_h_fsr_aexc_set (SIM_CPU *, UQI);
UQI a_sparc_h_fsr_cexc_get (SIM_CPU *);
void a_sparc_h_fsr_cexc_set (SIM_CPU *, UQI);
BI a_sparc_h_fpsr_fef_get (SIM_CPU *);
void a_sparc_h_fpsr_fef_set (SIM_CPU *, BI);
BI a_sparc_h_fpsr_du_get (SIM_CPU *);
void a_sparc_h_fpsr_du_set (SIM_CPU *, BI);
BI a_sparc_h_fpsr_dl_get (SIM_CPU *);
void a_sparc_h_fpsr_dl_set (SIM_CPU *, BI);
UQI a_sparc_h_fpsr_get (SIM_CPU *);
void a_sparc_h_fpsr_set (SIM_CPU *, UQI);
/* Enum declaration for model types. */
typedef enum model_type {
MODEL_SPARC32_DEF, MODEL_SPARC64_DEF, MODEL_MAX
} MODEL_TYPE;
#define MAX_MODELS ((int) MODEL_MAX)
/* Enum declaration for unit types. */
typedef enum unit_type {
UNIT_NONE, UNIT_SPARC32_DEF_U_EXEC, UNIT_SPARC64_DEF_U_EXEC, UNIT_MAX
} UNIT_TYPE;
#define MAX_UNITS (1)
#endif /* SPARC_ARCH_H */

618
sim/sparc/cpu32.h Normal file
View File

@ -0,0 +1,618 @@
/* CPU family header for sparc32.
THIS FILE IS MACHINE GENERATED WITH CGEN.
Copyright (C) 1999 Cygnus Solutions, Inc.
This file is part of the Cygnus Simulators.
*/
#ifndef CPU_SPARC32_H
#define CPU_SPARC32_H
/* Maximum number of instructions that are fetched at a time.
This is for LIW type instructions sets (e.g. m32r). */
#define MAX_LIW_INSNS 1
/* Maximum number of instructions that can be executed in parallel. */
#define MAX_PARALLEL_INSNS 1
/* CPU state information. */
typedef struct {
/* Hardware elements. */
struct {
/* program counter */
USI h_pc;
#define GET_H_PC() CPU (h_pc)
#define SET_H_PC(x) (CPU (h_pc) = (x))
/* next pc */
SI h_npc;
#define GET_H_NPC() CPU (h_npc)
#define SET_H_NPC(x) (CPU (h_npc) = (x))
/* GET_H_GR macro user-written */
/* SET_H_GR macro user-written */
/* icc carry bit */
BI h_icc_c;
#define GET_H_ICC_C() CPU (h_icc_c)
#define SET_H_ICC_C(x) (CPU (h_icc_c) = (x))
/* icc negative bit */
BI h_icc_n;
#define GET_H_ICC_N() CPU (h_icc_n)
#define SET_H_ICC_N(x) (CPU (h_icc_n) = (x))
/* icc overflow bit */
BI h_icc_v;
#define GET_H_ICC_V() CPU (h_icc_v)
#define SET_H_ICC_V(x) (CPU (h_icc_v) = (x))
/* icc zero bit */
BI h_icc_z;
#define GET_H_ICC_Z() CPU (h_icc_z)
#define SET_H_ICC_Z(x) (CPU (h_icc_z) = (x))
/* xcc carry bit */
BI h_xcc_c;
#define GET_H_XCC_C() CPU (h_xcc_c)
#define SET_H_XCC_C(x) (CPU (h_xcc_c) = (x))
/* xcc negative bit */
BI h_xcc_n;
#define GET_H_XCC_N() CPU (h_xcc_n)
#define SET_H_XCC_N(x) (CPU (h_xcc_n) = (x))
/* xcc overflow bit */
BI h_xcc_v;
#define GET_H_XCC_V() CPU (h_xcc_v)
#define SET_H_XCC_V(x) (CPU (h_xcc_v) = (x))
/* xcc zero bit */
BI h_xcc_z;
#define GET_H_XCC_Z() CPU (h_xcc_z)
#define SET_H_XCC_Z(x) (CPU (h_xcc_z) = (x))
/* GET_H_Y macro user-written */
/* SET_H_Y macro user-written */
/* ancilliary state registers */
SI h_asr[32];
#define GET_H_ASR(a1) CPU (h_asr)[a1]
#define SET_H_ASR(a1, x) (CPU (h_asr)[a1] = (x))
/* annul next insn? - assists execution */
BI h_annul_p;
#define GET_H_ANNUL_P() CPU (h_annul_p)
#define SET_H_ANNUL_P(x) (CPU (h_annul_p) = (x))
/* floating point regs */
SF h_fr[32];
#define GET_H_FR(a1) CPU (h_fr)[a1]
#define SET_H_FR(a1, x) (CPU (h_fr)[a1] = (x))
/* psr register */
USI h_psr;
/* GET_H_PSR macro user-written */
/* SET_H_PSR macro user-written */
/* supervisor bit */
BI h_s;
#define GET_H_S() CPU (h_s)
#define SET_H_S(x) (CPU (h_s) = (x))
/* previous supervisor bit */
BI h_ps;
#define GET_H_PS() CPU (h_ps)
#define SET_H_PS(x) (CPU (h_ps) = (x))
/* processor interrupt level */
UQI h_pil;
#define GET_H_PIL() CPU (h_pil)
#define SET_H_PIL(x) (CPU (h_pil) = (x))
/* enable traps bit */
BI h_et;
#define GET_H_ET() CPU (h_et)
#define SET_H_ET(x) (CPU (h_et) = (x))
/* tbr register */
SI h_tbr;
/* GET_H_TBR macro user-written */
/* SET_H_TBR macro user-written */
/* current window pointer */
UQI h_cwp;
/* GET_H_CWP macro user-written */
/* SET_H_CWP macro user-written */
/* window invalid mask */
USI h_wim;
/* GET_H_WIM macro user-written */
/* SET_H_WIM macro user-written */
/* alternate global indicator */
QI h_ag;
#define GET_H_AG() CPU (h_ag)
#define SET_H_AG(x) (CPU (h_ag) = (x))
/* enable coprocessor bit */
BI h_ec;
#define GET_H_EC() CPU (h_ec)
#define SET_H_EC(x) (CPU (h_ec) = (x))
/* enable fpu bit */
BI h_ef;
#define GET_H_EF() CPU (h_ef)
#define SET_H_EF(x) (CPU (h_ef) = (x))
/* floating point status register */
USI h_fsr;
#define GET_H_FSR() CPU (h_fsr)
#define SET_H_FSR(x) (CPU (h_fsr) = (x))
} hardware;
#define CPU_CGEN_HW(cpu) (& (cpu)->cpu_data.hardware)
} SPARC32_CPU_DATA;
/* Cover fns for register access. */
USI sparc32_h_pc_get (SIM_CPU *);
void sparc32_h_pc_set (SIM_CPU *, USI);
SI sparc32_h_npc_get (SIM_CPU *);
void sparc32_h_npc_set (SIM_CPU *, SI);
SI sparc32_h_gr_get (SIM_CPU *, UINT);
void sparc32_h_gr_set (SIM_CPU *, UINT, SI);
BI sparc32_h_icc_c_get (SIM_CPU *);
void sparc32_h_icc_c_set (SIM_CPU *, BI);
BI sparc32_h_icc_n_get (SIM_CPU *);
void sparc32_h_icc_n_set (SIM_CPU *, BI);
BI sparc32_h_icc_v_get (SIM_CPU *);
void sparc32_h_icc_v_set (SIM_CPU *, BI);
BI sparc32_h_icc_z_get (SIM_CPU *);
void sparc32_h_icc_z_set (SIM_CPU *, BI);
BI sparc32_h_xcc_c_get (SIM_CPU *);
void sparc32_h_xcc_c_set (SIM_CPU *, BI);
BI sparc32_h_xcc_n_get (SIM_CPU *);
void sparc32_h_xcc_n_set (SIM_CPU *, BI);
BI sparc32_h_xcc_v_get (SIM_CPU *);
void sparc32_h_xcc_v_set (SIM_CPU *, BI);
BI sparc32_h_xcc_z_get (SIM_CPU *);
void sparc32_h_xcc_z_set (SIM_CPU *, BI);
SI sparc32_h_y_get (SIM_CPU *);
void sparc32_h_y_set (SIM_CPU *, SI);
SI sparc32_h_asr_get (SIM_CPU *, UINT);
void sparc32_h_asr_set (SIM_CPU *, UINT, SI);
BI sparc32_h_annul_p_get (SIM_CPU *);
void sparc32_h_annul_p_set (SIM_CPU *, BI);
SF sparc32_h_fr_get (SIM_CPU *, UINT);
void sparc32_h_fr_set (SIM_CPU *, UINT, SF);
USI sparc32_h_psr_get (SIM_CPU *);
void sparc32_h_psr_set (SIM_CPU *, USI);
BI sparc32_h_s_get (SIM_CPU *);
void sparc32_h_s_set (SIM_CPU *, BI);
BI sparc32_h_ps_get (SIM_CPU *);
void sparc32_h_ps_set (SIM_CPU *, BI);
UQI sparc32_h_pil_get (SIM_CPU *);
void sparc32_h_pil_set (SIM_CPU *, UQI);
BI sparc32_h_et_get (SIM_CPU *);
void sparc32_h_et_set (SIM_CPU *, BI);
SI sparc32_h_tbr_get (SIM_CPU *);
void sparc32_h_tbr_set (SIM_CPU *, SI);
UQI sparc32_h_cwp_get (SIM_CPU *);
void sparc32_h_cwp_set (SIM_CPU *, UQI);
USI sparc32_h_wim_get (SIM_CPU *);
void sparc32_h_wim_set (SIM_CPU *, USI);
QI sparc32_h_ag_get (SIM_CPU *);
void sparc32_h_ag_set (SIM_CPU *, QI);
BI sparc32_h_ec_get (SIM_CPU *);
void sparc32_h_ec_set (SIM_CPU *, BI);
BI sparc32_h_ef_get (SIM_CPU *);
void sparc32_h_ef_set (SIM_CPU *, BI);
USI sparc32_h_fsr_get (SIM_CPU *);
void sparc32_h_fsr_set (SIM_CPU *, USI);
/* These must be hand-written. */
extern CPUREG_FETCH_FN sparc32_fetch_register;
extern CPUREG_STORE_FN sparc32_store_register;
typedef struct {
int empty;
} MODEL_SPARC32_DEF_DATA;
/* The ARGBUF struct. */
struct argbuf {
/* These are the baseclass definitions. */
IADDR addr;
const IDESC *idesc;
char trace_p;
char profile_p;
/* cpu specific data follows */
CGEN_INSN_INT insn;
int written;
};
/* A cached insn.
??? SCACHE used to contain more than just argbuf. We could delete the
type entirely and always just use ARGBUF, but for future concerns and as
a level of abstraction it is left in. */
struct scache {
struct argbuf argbuf;
};
/* Macros to simplify extraction, reading and semantic code.
These define and assign the local vars that contain the insn's fields. */
#define EXTRACT_IFMT_EMPTY_VARS \
/* Instruction fields. */ \
unsigned int length;
#define EXTRACT_IFMT_EMPTY_CODE \
length = 0; \
#define EXTRACT_IFMT_RD_ASR_VARS \
/* Instruction fields. */ \
INT f_simm13; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_RD_ASR_CODE \
length = 4; \
f_simm13 = EXTRACT_INT (insn, 32, 12, 13); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_WR_ASR_VARS \
/* Instruction fields. */ \
UINT f_rs2; \
INT f_res_asi; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_WR_ASR_CODE \
length = 4; \
f_rs2 = EXTRACT_UINT (insn, 32, 4, 5); \
f_res_asi = EXTRACT_INT (insn, 32, 12, 8); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_WR_ASR_IMM_VARS \
/* Instruction fields. */ \
INT f_simm13; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_WR_ASR_IMM_CODE \
length = 4; \
f_simm13 = EXTRACT_INT (insn, 32, 12, 13); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_RD_PSR_VARS \
/* Instruction fields. */ \
INT f_simm13; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_RD_PSR_CODE \
length = 4; \
f_simm13 = EXTRACT_INT (insn, 32, 12, 13); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_WR_PSR_VARS \
/* Instruction fields. */ \
UINT f_rs2; \
INT f_res_asi; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_WR_PSR_CODE \
length = 4; \
f_rs2 = EXTRACT_UINT (insn, 32, 4, 5); \
f_res_asi = EXTRACT_INT (insn, 32, 12, 8); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_WR_PSR_IMM_VARS \
/* Instruction fields. */ \
INT f_simm13; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_WR_PSR_IMM_CODE \
length = 4; \
f_simm13 = EXTRACT_INT (insn, 32, 12, 13); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_LDSTUB_REG_REG_VARS \
/* Instruction fields. */ \
UINT f_rs2; \
INT f_res_asi; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_LDSTUB_REG_REG_CODE \
length = 4; \
f_rs2 = EXTRACT_UINT (insn, 32, 4, 5); \
f_res_asi = EXTRACT_INT (insn, 32, 12, 8); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_LDSTUB_REG_IMM_VARS \
/* Instruction fields. */ \
INT f_simm13; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_LDSTUB_REG_IMM_CODE \
length = 4; \
f_simm13 = EXTRACT_INT (insn, 32, 12, 13); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_LDSTUB_REG_REG_ASI_VARS \
/* Instruction fields. */ \
UINT f_rs2; \
UINT f_asi; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_LDSTUB_REG_REG_ASI_CODE \
length = 4; \
f_rs2 = EXTRACT_UINT (insn, 32, 4, 5); \
f_asi = EXTRACT_UINT (insn, 32, 12, 8); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_LDD_REG_REG_VARS \
/* Instruction fields. */ \
UINT f_rs2; \
INT f_res_asi; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_LDD_REG_REG_CODE \
length = 4; \
f_rs2 = EXTRACT_UINT (insn, 32, 4, 5); \
f_res_asi = EXTRACT_INT (insn, 32, 12, 8); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_LDD_REG_IMM_VARS \
/* Instruction fields. */ \
INT f_simm13; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_LDD_REG_IMM_CODE \
length = 4; \
f_simm13 = EXTRACT_INT (insn, 32, 12, 13); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_LDD_REG_REG_ASI_VARS \
/* Instruction fields. */ \
UINT f_rs2; \
UINT f_asi; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_LDD_REG_REG_ASI_CODE \
length = 4; \
f_rs2 = EXTRACT_UINT (insn, 32, 4, 5); \
f_asi = EXTRACT_UINT (insn, 32, 12, 8); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_FP_LD_REG_REG_VARS \
/* Instruction fields. */ \
UINT f_rs2; \
INT f_res_asi; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_FP_LD_REG_REG_CODE \
length = 4; \
f_rs2 = EXTRACT_UINT (insn, 32, 4, 5); \
f_res_asi = EXTRACT_INT (insn, 32, 12, 8); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_FP_LD_REG_IMM_VARS \
/* Instruction fields. */ \
INT f_simm13; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_FP_LD_REG_IMM_CODE \
length = 4; \
f_simm13 = EXTRACT_INT (insn, 32, 12, 13); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_FP_LD_REG_REG_ASI_VARS \
/* Instruction fields. */ \
UINT f_rs2; \
UINT f_asi; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_FP_LD_REG_REG_ASI_CODE \
length = 4; \
f_rs2 = EXTRACT_UINT (insn, 32, 4, 5); \
f_asi = EXTRACT_UINT (insn, 32, 12, 8); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_SETHI_VARS \
/* Instruction fields. */ \
INT f_hi22; \
UINT f_op2; \
UINT f_rd; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_SETHI_CODE \
length = 4; \
f_hi22 = EXTRACT_INT (insn, 32, 21, 22); \
f_op2 = EXTRACT_UINT (insn, 32, 24, 3); \
f_rd = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_UNIMP_VARS \
/* Instruction fields. */ \
INT f_imm22; \
UINT f_op2; \
UINT f_rd_res; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_UNIMP_CODE \
length = 4; \
f_imm22 = EXTRACT_INT (insn, 32, 21, 22); \
f_op2 = EXTRACT_UINT (insn, 32, 24, 3); \
f_rd_res = EXTRACT_UINT (insn, 32, 29, 5); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_CALL_VARS \
/* Instruction fields. */ \
SI f_disp30; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_CALL_CODE \
length = 4; \
f_disp30 = ((((EXTRACT_INT (insn, 32, 29, 30)) << (2))) + (pc)); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_BA_VARS \
/* Instruction fields. */ \
SI f_disp22; \
UINT f_op2; \
UINT f_fmt2_cond; \
UINT f_a; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_BA_CODE \
length = 4; \
f_disp22 = ((((EXTRACT_INT (insn, 32, 21, 22)) << (2))) + (pc)); \
f_op2 = EXTRACT_UINT (insn, 32, 24, 3); \
f_fmt2_cond = EXTRACT_UINT (insn, 32, 28, 4); \
f_a = EXTRACT_UINT (insn, 32, 29, 1); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_TA_VARS \
/* Instruction fields. */ \
UINT f_rs2; \
INT f_res_asi; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_fmt2_cond; \
UINT f_a; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_TA_CODE \
length = 4; \
f_rs2 = EXTRACT_UINT (insn, 32, 4, 5); \
f_res_asi = EXTRACT_INT (insn, 32, 12, 8); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_fmt2_cond = EXTRACT_UINT (insn, 32, 28, 4); \
f_a = EXTRACT_UINT (insn, 32, 29, 1); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
#define EXTRACT_IFMT_TA_IMM_VARS \
/* Instruction fields. */ \
INT f_simm13; \
UINT f_i; \
UINT f_rs1; \
UINT f_op3; \
UINT f_fmt2_cond; \
UINT f_a; \
UINT f_op; \
unsigned int length;
#define EXTRACT_IFMT_TA_IMM_CODE \
length = 4; \
f_simm13 = EXTRACT_INT (insn, 32, 12, 13); \
f_i = EXTRACT_UINT (insn, 32, 13, 1); \
f_rs1 = EXTRACT_UINT (insn, 32, 18, 5); \
f_op3 = EXTRACT_UINT (insn, 32, 24, 6); \
f_fmt2_cond = EXTRACT_UINT (insn, 32, 28, 4); \
f_a = EXTRACT_UINT (insn, 32, 29, 1); \
f_op = EXTRACT_UINT (insn, 32, 31, 2); \
/* Collection of various things for the trace handler to use. */
typedef struct trace_record {
IADDR pc;
/* FIXME:wip */
} TRACE_RECORD;
#endif /* CPU_SPARC32_H */

1278
sim/sparc/decode32.c Normal file

File diff suppressed because it is too large Load Diff

285
sim/sparc/decode32.h Normal file
View File

@ -0,0 +1,285 @@
/* Decode header for sparc32.
THIS FILE IS MACHINE GENERATED WITH CGEN.
Copyright (C) 1999 Cygnus Solutions, Inc.
This file is part of the Cygnus Simulators.
*/
#ifndef SPARC32_DECODE_H
#define SPARC32_DECODE_H
extern const IDESC *sparc32_decode (SIM_CPU *, IADDR,
CGEN_INSN_INT, CGEN_INSN_INT,
ARGBUF *);
extern void sparc32_init_idesc_table (SIM_CPU *);
/* Enum declaration for instructions in cpu family sparc32. */
typedef enum sparc32_insn_type {
SPARC32_INSN_X_INVALID, SPARC32_INSN_X_AFTER, SPARC32_INSN_X_BEFORE, SPARC32_INSN_X_CTI_CHAIN
, SPARC32_INSN_X_CHAIN, SPARC32_INSN_X_BEGIN, SPARC32_INSN_RD_ASR, SPARC32_INSN_WR_ASR
, SPARC32_INSN_WR_ASR_IMM, SPARC32_INSN_RD_PSR, SPARC32_INSN_WR_PSR, SPARC32_INSN_WR_PSR_IMM
, SPARC32_INSN_RD_WIM, SPARC32_INSN_WR_WIM, SPARC32_INSN_WR_WIM_IMM, SPARC32_INSN_RD_TBR
, SPARC32_INSN_WR_TBR, SPARC32_INSN_WR_TBR_IMM, SPARC32_INSN_LDSTUB_REG_REG, SPARC32_INSN_LDSTUB_REG_IMM
, SPARC32_INSN_LDSTUB_REG_REG_ASI, SPARC32_INSN_SWAP_REG_REG, SPARC32_INSN_SWAP_REG_IMM, SPARC32_INSN_SWAP_REG_REG_ASI
, SPARC32_INSN_LDSB_REG_REG, SPARC32_INSN_LDSB_REG_IMM, SPARC32_INSN_LDSB_REG_REG_ASI, SPARC32_INSN_LDUB_REG_REG
, SPARC32_INSN_LDUB_REG_IMM, SPARC32_INSN_LDUB_REG_REG_ASI, SPARC32_INSN_LDSH_REG_REG, SPARC32_INSN_LDSH_REG_IMM
, SPARC32_INSN_LDSH_REG_REG_ASI, SPARC32_INSN_LDUH_REG_REG, SPARC32_INSN_LDUH_REG_IMM, SPARC32_INSN_LDUH_REG_REG_ASI
, SPARC32_INSN_LDSW_REG_REG, SPARC32_INSN_LDSW_REG_IMM, SPARC32_INSN_LDSW_REG_REG_ASI, SPARC32_INSN_LDUW_REG_REG
, SPARC32_INSN_LDUW_REG_IMM, SPARC32_INSN_LDUW_REG_REG_ASI, SPARC32_INSN_LDD_REG_REG, SPARC32_INSN_LDD_REG_IMM
, SPARC32_INSN_LDD_REG_REG_ASI, SPARC32_INSN_STB_REG_REG, SPARC32_INSN_STB_REG_IMM, SPARC32_INSN_STB_REG_REG_ASI
, SPARC32_INSN_STH_REG_REG, SPARC32_INSN_STH_REG_IMM, SPARC32_INSN_STH_REG_REG_ASI, SPARC32_INSN_ST_REG_REG
, SPARC32_INSN_ST_REG_IMM, SPARC32_INSN_ST_REG_REG_ASI, SPARC32_INSN_STD_REG_REG, SPARC32_INSN_STD_REG_IMM
, SPARC32_INSN_STD_REG_REG_ASI, SPARC32_INSN_FP_LD_REG_REG, SPARC32_INSN_FP_LD_REG_IMM, SPARC32_INSN_FP_LD_REG_REG_ASI
, SPARC32_INSN_SETHI, SPARC32_INSN_ADD, SPARC32_INSN_ADD_IMM, SPARC32_INSN_SUB
, SPARC32_INSN_SUB_IMM, SPARC32_INSN_ADDCC, SPARC32_INSN_ADDCC_IMM, SPARC32_INSN_SUBCC
, SPARC32_INSN_SUBCC_IMM, SPARC32_INSN_ADDX, SPARC32_INSN_ADDX_IMM, SPARC32_INSN_SUBX
, SPARC32_INSN_SUBX_IMM, SPARC32_INSN_ADDXCC, SPARC32_INSN_ADDXCC_IMM, SPARC32_INSN_SUBXCC
, SPARC32_INSN_SUBXCC_IMM, SPARC32_INSN_AND, SPARC32_INSN_AND_IMM, SPARC32_INSN_ANDCC
, SPARC32_INSN_ANDCC_IMM, SPARC32_INSN_OR, SPARC32_INSN_OR_IMM, SPARC32_INSN_ORCC
, SPARC32_INSN_ORCC_IMM, SPARC32_INSN_XOR, SPARC32_INSN_XOR_IMM, SPARC32_INSN_XORCC
, SPARC32_INSN_XORCC_IMM, SPARC32_INSN_ANDN, SPARC32_INSN_ANDN_IMM, SPARC32_INSN_ANDNCC
, SPARC32_INSN_ANDNCC_IMM, SPARC32_INSN_ORN, SPARC32_INSN_ORN_IMM, SPARC32_INSN_ORNCC
, SPARC32_INSN_ORNCC_IMM, SPARC32_INSN_XNOR, SPARC32_INSN_XNOR_IMM, SPARC32_INSN_XNORCC
, SPARC32_INSN_XNORCC_IMM, SPARC32_INSN_SLL, SPARC32_INSN_SLL_IMM, SPARC32_INSN_SRL
, SPARC32_INSN_SRL_IMM, SPARC32_INSN_SRA, SPARC32_INSN_SRA_IMM, SPARC32_INSN_SMUL
, SPARC32_INSN_SMUL_IMM, SPARC32_INSN_SMUL_CC, SPARC32_INSN_SMUL_CC_IMM, SPARC32_INSN_UMUL
, SPARC32_INSN_UMUL_IMM, SPARC32_INSN_UMUL_CC, SPARC32_INSN_UMUL_CC_IMM, SPARC32_INSN_SDIV
, SPARC32_INSN_SDIV_IMM, SPARC32_INSN_SDIV_CC, SPARC32_INSN_SDIV_CC_IMM, SPARC32_INSN_UDIV
, SPARC32_INSN_UDIV_IMM, SPARC32_INSN_UDIV_CC, SPARC32_INSN_UDIV_CC_IMM, SPARC32_INSN_MULSCC
, SPARC32_INSN_SAVE, SPARC32_INSN_SAVE_IMM, SPARC32_INSN_RESTORE, SPARC32_INSN_RESTORE_IMM
, SPARC32_INSN_RETT, SPARC32_INSN_RETT_IMM, SPARC32_INSN_UNIMP, SPARC32_INSN_CALL
, SPARC32_INSN_JMPL, SPARC32_INSN_JMPL_IMM, SPARC32_INSN_BA, SPARC32_INSN_TA
, SPARC32_INSN_TA_IMM, SPARC32_INSN_BN, SPARC32_INSN_TN, SPARC32_INSN_TN_IMM
, SPARC32_INSN_BNE, SPARC32_INSN_TNE, SPARC32_INSN_TNE_IMM, SPARC32_INSN_BE
, SPARC32_INSN_TE, SPARC32_INSN_TE_IMM, SPARC32_INSN_BG, SPARC32_INSN_TG
, SPARC32_INSN_TG_IMM, SPARC32_INSN_BLE, SPARC32_INSN_TLE, SPARC32_INSN_TLE_IMM
, SPARC32_INSN_BGE, SPARC32_INSN_TGE, SPARC32_INSN_TGE_IMM, SPARC32_INSN_BL
, SPARC32_INSN_TL, SPARC32_INSN_TL_IMM, SPARC32_INSN_BGU, SPARC32_INSN_TGU
, SPARC32_INSN_TGU_IMM, SPARC32_INSN_BLEU, SPARC32_INSN_TLEU, SPARC32_INSN_TLEU_IMM
, SPARC32_INSN_BCC, SPARC32_INSN_TCC, SPARC32_INSN_TCC_IMM, SPARC32_INSN_BCS
, SPARC32_INSN_TCS, SPARC32_INSN_TCS_IMM, SPARC32_INSN_BPOS, SPARC32_INSN_TPOS
, SPARC32_INSN_TPOS_IMM, SPARC32_INSN_BNEG, SPARC32_INSN_TNEG, SPARC32_INSN_TNEG_IMM
, SPARC32_INSN_BVC, SPARC32_INSN_TVC, SPARC32_INSN_TVC_IMM, SPARC32_INSN_BVS
, SPARC32_INSN_TVS, SPARC32_INSN_TVS_IMM, SPARC32_INSN_MAX
} SPARC32_INSN_TYPE;
#if ! WITH_SEM_SWITCH_FULL
#define SEMFULL(fn) extern SEMANTIC_FN CONCAT3 (sparc32,_sem_,fn);
#else
#define SEMFULL(fn)
#endif
#if ! WITH_SEM_SWITCH_FAST
#define SEMFAST(fn) extern SEMANTIC_FN CONCAT3 (sparc32,_semf_,fn);
#else
#define SEMFAST(fn)
#endif
#define SEM(fn) SEMFULL (fn) SEMFAST (fn)
/* The function version of the before/after handlers is always needed,
so we always want the SEMFULL declaration of them. */
extern SEMANTIC_FN CONCAT3 (sparc32,_sem_,x_before);
extern SEMANTIC_FN CONCAT3 (sparc32,_sem_,x_after);
SEM (x_invalid)
SEM (x_after)
SEM (x_before)
SEM (x_cti_chain)
SEM (x_chain)
SEM (x_begin)
SEM (rd_asr)
SEM (wr_asr)
SEM (wr_asr_imm)
SEM (rd_psr)
SEM (wr_psr)
SEM (wr_psr_imm)
SEM (rd_wim)
SEM (wr_wim)
SEM (wr_wim_imm)
SEM (rd_tbr)
SEM (wr_tbr)
SEM (wr_tbr_imm)
SEM (ldstub_reg_reg)
SEM (ldstub_reg_imm)
SEM (ldstub_reg_reg_asi)
SEM (swap_reg_reg)
SEM (swap_reg_imm)
SEM (swap_reg_reg_asi)
SEM (ldsb_reg_reg)
SEM (ldsb_reg_imm)
SEM (ldsb_reg_reg_asi)
SEM (ldub_reg_reg)
SEM (ldub_reg_imm)
SEM (ldub_reg_reg_asi)
SEM (ldsh_reg_reg)
SEM (ldsh_reg_imm)
SEM (ldsh_reg_reg_asi)
SEM (lduh_reg_reg)
SEM (lduh_reg_imm)
SEM (lduh_reg_reg_asi)
SEM (ldsw_reg_reg)
SEM (ldsw_reg_imm)
SEM (ldsw_reg_reg_asi)
SEM (lduw_reg_reg)
SEM (lduw_reg_imm)
SEM (lduw_reg_reg_asi)
SEM (ldd_reg_reg)
SEM (ldd_reg_imm)
SEM (ldd_reg_reg_asi)
SEM (stb_reg_reg)
SEM (stb_reg_imm)
SEM (stb_reg_reg_asi)
SEM (sth_reg_reg)
SEM (sth_reg_imm)
SEM (sth_reg_reg_asi)
SEM (st_reg_reg)
SEM (st_reg_imm)
SEM (st_reg_reg_asi)
SEM (std_reg_reg)
SEM (std_reg_imm)
SEM (std_reg_reg_asi)
SEM (fp_ld_reg_reg)
SEM (fp_ld_reg_imm)
SEM (fp_ld_reg_reg_asi)
SEM (sethi)
SEM (add)
SEM (add_imm)
SEM (sub)
SEM (sub_imm)
SEM (addcc)
SEM (addcc_imm)
SEM (subcc)
SEM (subcc_imm)
SEM (addx)
SEM (addx_imm)
SEM (subx)
SEM (subx_imm)
SEM (addxcc)
SEM (addxcc_imm)
SEM (subxcc)
SEM (subxcc_imm)
SEM (and)
SEM (and_imm)
SEM (andcc)
SEM (andcc_imm)
SEM (or)
SEM (or_imm)
SEM (orcc)
SEM (orcc_imm)
SEM (xor)
SEM (xor_imm)
SEM (xorcc)
SEM (xorcc_imm)
SEM (andn)
SEM (andn_imm)
SEM (andncc)
SEM (andncc_imm)
SEM (orn)
SEM (orn_imm)
SEM (orncc)
SEM (orncc_imm)
SEM (xnor)
SEM (xnor_imm)
SEM (xnorcc)
SEM (xnorcc_imm)
SEM (sll)
SEM (sll_imm)
SEM (srl)
SEM (srl_imm)
SEM (sra)
SEM (sra_imm)
SEM (smul)
SEM (smul_imm)
SEM (smul_cc)
SEM (smul_cc_imm)
SEM (umul)
SEM (umul_imm)
SEM (umul_cc)
SEM (umul_cc_imm)
SEM (sdiv)
SEM (sdiv_imm)
SEM (sdiv_cc)
SEM (sdiv_cc_imm)
SEM (udiv)
SEM (udiv_imm)
SEM (udiv_cc)
SEM (udiv_cc_imm)
SEM (mulscc)
SEM (save)
SEM (save_imm)
SEM (restore)
SEM (restore_imm)
SEM (rett)
SEM (rett_imm)
SEM (unimp)
SEM (call)
SEM (jmpl)
SEM (jmpl_imm)
SEM (ba)
SEM (ta)
SEM (ta_imm)
SEM (bn)
SEM (tn)
SEM (tn_imm)
SEM (bne)
SEM (tne)
SEM (tne_imm)
SEM (be)
SEM (te)
SEM (te_imm)
SEM (bg)
SEM (tg)
SEM (tg_imm)
SEM (ble)
SEM (tle)
SEM (tle_imm)
SEM (bge)
SEM (tge)
SEM (tge_imm)
SEM (bl)
SEM (tl)
SEM (tl_imm)
SEM (bgu)
SEM (tgu)
SEM (tgu_imm)
SEM (bleu)
SEM (tleu)
SEM (tleu_imm)
SEM (bcc)
SEM (tcc)
SEM (tcc_imm)
SEM (bcs)
SEM (tcs)
SEM (tcs_imm)
SEM (bpos)
SEM (tpos)
SEM (tpos_imm)
SEM (bneg)
SEM (tneg)
SEM (tneg_imm)
SEM (bvc)
SEM (tvc)
SEM (tvc_imm)
SEM (bvs)
SEM (tvs)
SEM (tvs_imm)
#undef SEMFULL
#undef SEMFAST
#undef SEM
/* Function unit handlers (user written). */
extern int sparc32_model_sparc32_def_u_exec (SIM_CPU *, const IDESC *, int /*unit_num*/, int /*referenced*/);
/* Profiling before/after handlers (user written) */
extern void sparc32_model_insn_before (SIM_CPU *, int /*first_p*/);
extern void sparc32_model_insn_after (SIM_CPU *, int /*last_p*/, int /*cycles*/);
#endif /* SPARC32_DECODE_H */

9
sim/sparc/dev64.c Normal file
View File

@ -0,0 +1,9 @@
/* sparc64 device support
Copyright (C) 1999 Cygnus Solutions. */
#include "sim-main.h"
#include "dev64.h"
#ifdef HAVE_DV_SOCKSER
#include "dv-sockser.h"
#endif

21
sim/sparc/dev64.h Normal file
View File

@ -0,0 +1,21 @@
/* sparc64 device support
Copyright (C) 1999 Cygnus Solutions. */
#ifndef DEV64_H
#define DEV64_H
/* From libgloss/sparc/erc32-io.c. */
#define ERC32_DEVICE_ADDR 0x1f80000
#define ERC32_DEVICE_LEN (0x2000000 - 0x1f80000)
#define RXADATA 0x01F800E0
#define RXBDATA 0x01F800E4
#define RXSTAT 0x01F800E8
extern device sparc_devices;
/* FIXME: Temporary, until device support ready. */
struct _device { int foo; };
#endif /* DEV64_H */

3516
sim/sparc/model32.c Normal file

File diff suppressed because it is too large Load Diff

5444
sim/sparc/sem32.c Normal file

File diff suppressed because it is too large Load Diff

264
sim/sparc/sparc64.c Normal file
View File

@ -0,0 +1,264 @@
/* sparc64 simulator support code
Copyright (C) 1999 Cygnus Solutions. */
#define WANT_CPU_SPARC64
#include "sim-main.h"
#include <signal.h>
#include "libiberty.h"
#include "bfd.h"
#include "cgen-mem.h"
#include "cgen-ops.h"
#include "targ-vals.h"
#include "trap64.h"
/* Initialize the program counter. */
void
sparc64_init_pc (SIM_CPU *current_cpu, DI pc, DI npc)
{
SET_H_PC (pc);
SET_H_NPC (npc);
}
#if WITH_PROFILE_MODEL_P
void
sparc64_model_mark_get_h_gr (SIM_CPU *cpu, SPARC64_ARGBUF *abuf)
{
if ((CPU_PROFILE_STATE (cpu)->h_gr & abuf->h_gr_get) != 0)
{
PROFILE_MODEL_LOAD_STALL_COUNT (CPU_PROFILE_DATA (cpu)) += 2;
if (TRACE_INSN_P (cpu))
cgen_trace_printf (cpu, " ; Load stall of 2 cycles.");
}
}
void
sparc64_model_mark_set_h_gr (SIM_CPU *cpu, SPARC64_ARGBUF *abuf)
{
}
void
sparc64_model_mark_busy_reg (SIM_CPU *cpu, SPARC64_ARGBUF *abuf)
{
CPU_PROFILE_STATE (cpu)->h_gr = abuf->h_gr_set;
}
void
sparc64_model_mark_unbusy_reg (SIM_CPU *cpu, SPARC64_ARGBUF *abuf)
{
CPU_PROFILE_STATE (cpu)->h_gr = 0;
}
#endif /* WITH_PROFILE_MODEL_P */
UDI
sparc64_h_gr_get (SIM_CPU *current_cpu, unsigned int regno)
{
return GET_INT_REG (cpu, regno);
}
void
sparc64_h_gr_set (SIM_CPU *current_cpu, unsigned int regno, UDI new_val)
{
SET_INT_REG (cpu, regno, new_val);
}
DI *
sparc64_h_gr_regno_get_addr (SIM_CPU *current_cpu, int regno)
{
}
DI
sparc64_h_gr_regno_get (SIM_CPU *current_cpu, int regno)
{
}
void
sparc64_h_gr_regno_set (SIM_CPU *current_cpu, int regno, DI new_val)
{
}
DI
sparc64_do_save (SIM_CPU *current_cpu, DI rs1, DI rs2_simm13)
{
DI rd;
/* If this is a user program, watch for stack overflow ... */
#if 0
if (STATE_user_prog && GET_AREG (GET_REG (REG_SP)) < mem_end)
{
if (user_prog)
fprintf (stderr, "sim: stack space exhausted!\n");
sim_signal (SIM_SIGACCESS);
return 0;
}
#endif
if (GET_CANSAVE (current_cpu) == 0)
{
return trap (TRAP_SPILL);
}
if (GET_CLEANWIN (current_cpu) - GET_CANRESTORE (current_cpu) == 0)
{
return trap (TRAP_CLEAN_WINDOW);
}
/* The calculation is done using the old window's values
[those passed in to us]. */
rd = ADDDI (rs1, rs2_simm13);
/* Switch to a new window. */
save_window ();
return rd;
}
DI
sparc64_do_restore (SIM_CPU *current_cpu, DI rs1, DI rs2_simm13)
{
DI rd;
return rd;
}
/* Initialize the register window mechanism. */
void
sparc64_alloc_register_windows (SIM_CPU *cpu, int nwindows)
{
int ag,i,r,w;
DI *(*v)[32];
cpu->greg_lookup_table = (DI *(*)[2][32]) xmalloc (nwindows * 2 * 32 * sizeof (void *));
cpu->globals = (DI (*)[][8]) zalloc (2 * 8 * sizeof (DI));
cpu->win_regs = (DI (*)[][16]) zalloc (nwindows * 16 * sizeof (DI));
v = &cpu->greg_lookup_table[0][0];
for (w = 0; w < nwindows; w++)
{
for (ag = 0; ag < 2; ag++, v++)
{
/* Initialize pointers to the global registers ... */
for (r = 0; r < 8; r++)
(*v)[r] = &cpu->globals[ag][r];
/* Initialize pointers to the output registers ... */
for (r = 0; r < 8; r++)
(*v)[r + 8] = &cpu->win_regs[(w == nwindows - 1 ? 0 : ((w + 1) * 16)) + r];
/* Initialize pointers to the local registers ... */
for (r = 0; r < 8; r++)
(*v)[r + 16] = &cpu->win_regs[(w * 16) + 8 + r];
/* Initialize pointers to the input registers ... */
for (r = 0; r < 8; r++)
(*v)[r + 24] = &cpu->win_regs[(w * 16) + r];
}
}
}
void
sparc64_free_register_windows (SIM_CPU *cpu)
{
free (cpu->win_regs);
cpu->win_regs = NULL;
free (cpu->globals);
cpu->globals = NULL;
free (cpu->greg_lookup_table);
cpu->greg_lookup_table = NULL;
}
/* Assign a new value to CWP.
The register windows are recorded in a seemingly backwards manner.
%i0-7 live at lower addresses in memory than %o0-7 (even though they
have higher register numbers). This is because the stack grows upwards
in the sense that CWP increases during a "push" operation.
FIXME: True for v9, but also for v8? */
void
sparc64_set_cwp (SIM_CPU *current_cpu, int x)
{
if (x < 0 || x >= GET_NWINDOWS (cpu))
abort ();
/* We can't use SET_CWP here because it uses us. */
cpu->cgen_cpu.cpu.h_cwp = x;
cpu->current_greg_lookup_table = &cpu->greg_lookup_table[x][GET_AG (cpu)][0];
}
/* Create a new window. We assume there is room.
WARNING: The following must always be true:
CANSAVE + CANRESTORE + OTHERWIN == NWINDOWS - 2
We only watch for this during saves. */
void
sparc64_save_window (SIM_CPU *current_cpu)
{
if (GET_CANSAVE (cpu) + GET_CANRESTORE (cpu) + GET_OTHERWIN (cpu) != GET_NWINDOWS (cpu) - 2)
abort ();
SET_CWP (cpu, ROUND_WIN (GET_CWP (cpu) + 1));
SET_CANSAVE (cpu, ROUND_WIN (GET_CANSAVE (cpu) - 1));
SET_CANRESTORE (cpu, ROUND_WIN (GET_CANRESTORE (cpu) + 1));
}
/* Pop a window. We assume no traps possible. */
void
sparc64_restore_window (SIM_CPU *current_cpu)
{
SET_CWP (cpu, ROUND_WIN (GET_CWP (cpu) - 1));
SET_CANSAVE (cpu, ROUND_WIN (GET_CANSAVE (cpu) + 1));
SET_CANRESTORE (cpu, ROUND_WIN (GET_CANRESTORE (cpu) - 1));
}
/* Flush the register windows to memory.
This is necessary, for example, when we want to walk the stack in gdb.
We use restore_window() and save_window() to traverse the register windows.
This is the cleanest and simplest thing to do. */
void
sparc64_flush_windows (SIM_CPU *cpu)
{
int i,count = GET_CANRESTORE (cpu) + 1;
/* Save the register windows, changing the current one as we go ... */
for (i = 0; i < count; i++)
{
AI sp = GET_INT_REG (cpu, REG_SP) /*+ stack_bias*/;
flush_one_window (cpu, sp, CURRENT_LREGS (cpu), CURRENT_IREGS (cpu));
if (i + 1 != count) /* don't restore window if there isn't one */
restore_window (cpu);
}
/* Restore the window state ... */
for (i = 1; i < count; i++)
save_window (cpu);
}
void
sparc64_flush_one_window (SIM_CPU *current_cpu, AI addr, DI *lregs, DI *iregs)
{
sim_core_write_buffer (CPU_STATE (cpu), cpu,
sim_core_write_map,
lregs, addr, 8 * sizeof (DI));
sim_core_write_buffer (CPU_STATE (cpu), cpu,
sim_core_write_map,
iregs, addr + 8 * sizeof (DI), 8 * sizeof (DI));
}

86
sim/sparc/trap64.h Normal file
View File

@ -0,0 +1,86 @@
/* sparc64 trap definitions
Copyright (C) 1999 Cygnus Solutions. */
#ifndef TRAP64_H
#define TRAP64_H
/* D1.2.4 page 107 */
typedef enum
{
TRAP64_POWER_ON_RESET = 1,
TRAP64_WATCHDOG_RESET = 2,
TRAP64_EXTERNALLY_INITIATED_RESET = 3,
TRAP64_SOFTWARE_INITIATED_RESET = 4,
TRAP64_RED_STATE_EXCEPTION = 5,
TRAP64_INSN_ACCESS_EXCEPTION = 8,
TRAP64_INSN_ACCESS_MMU_MISS = 9,
TRAP64_INSN_ACCESS_ERROR = 10,
TRAP64_ILLEGAL_INSN = 16,
TRAP64_PRIVILEDGED_OPCODE = 17,
TRAP64_UNIMPLEMENTED_LDD = 18,
TRAP64_UNIMPLEMENTED_STD = 19,
TRAP64_FP_DISABLED = 32,
TRAP64_FP_EXCEPTION_IEEE_754 = 33,
TRAP64_FP_EXCEPTION_OTHER = 34,
TRAP64_TAG_OVERFLOW = 35,
TRAP64_CLEAN_WINDOW = 36,
TRAP64_DIVISION_BY_ZERO = 40,
TRAP64_INTERNAL_PROCESSOR_ERROR = 41,
TRAP64_DATA_ACCESS_EXCEPTION = 48,
TRAP64_DATA_ACCESS_MMU_MISS = 49,
TRAP64_DATA_ACCESS_ERROR = 50,
TRAP64_DATA_ACCESS_PROTECTION = 51,
TRAP64_MEM_ADDRESS_NOT_ALIGNED = 52,
TRAP64_LDDF_MEM_ADDRESS_NOT_ALIGNED = 53, /* impdep # 109 */
TRAP64_STDF_MEM_ADDRESS_NOT_ALIGNED = 54, /* impdep # 110 */
TRAP64_PRIVILEDGED_ACTION = 55,
TRAP64_LDQF_MEM_ADDRESS_NOT_ALIGNED = 56, /* impdep # 111 */
TRAP64_STQF_MEM_ADDRESS_NOT_ALIGNED = 57, /* impdep # 112 */
TRAP64_ASYNC_DATA_ERROR = 64,
TRAP64_INTERRUPT_LEVEL_0 = 65, /* n = 1..15 */
TRAP64_IMPDEP_EXCEPTION_0 = 96, /* n = 0..31 */
/* IMPDEP codes used by the simulator in ENVIRONMENT_USER. */
TRAP64_SIM_UNIMPLEMENTED_OPCODE = 124,
TRAP64_SIM_RESERVED_INSN = 125,
TRAP64_SIM_SPILL = 126,
TRAP64_SIM_FILL = 127,
TRAP64_SPILL_0_NORMAL = 128, /* n = 0..7 */
TRAP64_SPILL_0_OTHER = 160, /* n = 0..7 */
TRAP64_FILL_0_NORMAL = 192, /* n = 0..7 */
TRAP64_FILL_0_OTHER = 224, /* n = 0..7 */
TRAP64_INSTRUCTION = 256, /* n = 0..127 */
TRAP64_BREAKPOINT = 257, /* convention */
TRAP64_MAX = 0x17f
} TRAP64_TYPE;
#define MAX_NUM_TRAPS 1024
#define TRAP64_TABLE_SIZE (32 * MAX_NUM_TRAPS) /* in bytes */
/* We record the fact that the cpu is in error state by setting TL to be
something greater than MAXTL, usually MAXTL+1. */
#define ERROR_STATE_P() (GET_TL () > MAXTL)
#if 0
fastint trap (trap_type_e);
int trap_priority (trap_type_e);
fastint reserved (void);
fastint deprecated (void);
fastint not_impl (void);
fastint illegal (void);
fastint priviledged (void);
fastint unimp_fpop (void);
fastint fp_disabled (void);
/* When running user level programs, we supply all the necessary trap handlers.
These handlers run on the host, not in the emulation environment. */
typedef fastint (trap_handler_t) (void);
#endif
#endif /* TRAP64_H */