aboutsummaryrefslogtreecommitdiff
path: root/sim/fr30/traps.c
diff options
context:
space:
mode:
authorAndrew Cagney <cagney@redhat.com>2002-07-16 14:30:14 +0000
committerAndrew Cagney <cagney@redhat.com>2002-07-16 14:30:14 +0000
commit7a3085c168dec67f00ccc68ea4623666fa930736 (patch)
tree016c785340babe5ff06a9e605ef044cbe43e07a7 /sim/fr30/traps.c
parent25d3fb587f2c199aa9d84925188ab8924bf410a4 (diff)
downloadgdb-7a3085c168dec67f00ccc68ea4623666fa930736.zip
gdb-7a3085c168dec67f00ccc68ea4623666fa930736.tar.gz
gdb-7a3085c168dec67f00ccc68ea4623666fa930736.tar.bz2
Obsolete fr30.
Diffstat (limited to 'sim/fr30/traps.c')
-rw-r--r--sim/fr30/traps.c436
1 files changed, 218 insertions, 218 deletions
diff --git a/sim/fr30/traps.c b/sim/fr30/traps.c
index 25cd7b9..6852359 100644
--- a/sim/fr30/traps.c
+++ b/sim/fr30/traps.c
@@ -1,218 +1,218 @@
-/* fr30 exception, interrupt, and trap (EIT) support
- Copyright (C) 1998, 1999 Free Software Foundation, Inc.
- Contributed by Cygnus Solutions.
-
-This file is part of the GNU simulators.
-
-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, 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. */
-
-#include "sim-main.h"
-#include "targ-vals.h"
-#include "cgen-engine.h"
-
-/* The semantic code invokes this for invalid (unrecognized) instructions. */
-
-SEM_PC
-sim_engine_invalid_insn (SIM_CPU *current_cpu, IADDR cia, SEM_PC vpc)
-{
- SIM_DESC sd = CPU_STATE (current_cpu);
-
-#if 0
- if (STATE_ENVIRONMENT (sd) == OPERATING_ENVIRONMENT)
- {
- h_bsm_set (current_cpu, h_sm_get (current_cpu));
- h_bie_set (current_cpu, h_ie_get (current_cpu));
- h_bcond_set (current_cpu, h_cond_get (current_cpu));
- /* sm not changed */
- h_ie_set (current_cpu, 0);
- h_cond_set (current_cpu, 0);
-
- h_bpc_set (current_cpu, cia);
-
- sim_engine_restart (CPU_STATE (current_cpu), current_cpu, NULL,
- EIT_RSVD_INSN_ADDR);
- }
- else
-#endif
- sim_engine_halt (sd, current_cpu, NULL, cia, sim_stopped, SIM_SIGILL);
- return vpc;
-}
-
-/* Process an address exception. */
-
-void
-fr30_core_signal (SIM_DESC sd, SIM_CPU *current_cpu, sim_cia cia,
- unsigned int map, int nr_bytes, address_word addr,
- transfer_type transfer, sim_core_signals sig)
-{
-#if 0
- if (STATE_ENVIRONMENT (sd) == OPERATING_ENVIRONMENT)
- {
- h_bsm_set (current_cpu, h_sm_get (current_cpu));
- h_bie_set (current_cpu, h_ie_get (current_cpu));
- h_bcond_set (current_cpu, h_cond_get (current_cpu));
- /* sm not changed */
- h_ie_set (current_cpu, 0);
- h_cond_set (current_cpu, 0);
-
- h_bpc_set (current_cpu, cia);
-
- sim_engine_restart (CPU_STATE (current_cpu), current_cpu, NULL,
- EIT_ADDR_EXCP_ADDR);
- }
- else
-#endif
- sim_core_signal (sd, current_cpu, cia, map, nr_bytes, addr,
- transfer, sig);
-}
-
-/* Read/write functions for system call interface. */
-
-static int
-syscall_read_mem (host_callback *cb, struct cb_syscall *sc,
- unsigned long taddr, char *buf, int bytes)
-{
- SIM_DESC sd = (SIM_DESC) sc->p1;
- SIM_CPU *cpu = (SIM_CPU *) sc->p2;
-
- return sim_core_read_buffer (sd, cpu, read_map, buf, taddr, bytes);
-}
-
-static int
-syscall_write_mem (host_callback *cb, struct cb_syscall *sc,
- unsigned long taddr, const char *buf, int bytes)
-{
- SIM_DESC sd = (SIM_DESC) sc->p1;
- SIM_CPU *cpu = (SIM_CPU *) sc->p2;
-
- return sim_core_write_buffer (sd, cpu, write_map, buf, taddr, bytes);
-}
-
-/* Subroutine of fr30_int to save the PS and PC and setup for INT and INTE. */
-
-static void
-setup_int (SIM_CPU *current_cpu, PCADDR pc)
-{
- USI ssp = fr30bf_h_dr_get (current_cpu, H_DR_SSP);
- USI ps = fr30bf_h_ps_get (current_cpu);
-
- ssp -= 4;
- SETMEMSI (current_cpu, pc, ssp, ps);
- ssp -= 4;
- SETMEMSI (current_cpu, pc, ssp, pc + 2);
- fr30bf_h_dr_set (current_cpu, H_DR_SSP, ssp);
- fr30bf_h_sbit_set (current_cpu, 0);
-}
-
-/* Trap support.
- The result is the pc address to continue at.
- Preprocessing like saving the various registers has already been done. */
-
-USI
-fr30_int (SIM_CPU *current_cpu, PCADDR pc, int num)
-{
- SIM_DESC sd = CPU_STATE (current_cpu);
- host_callback *cb = STATE_CALLBACK (sd);
-
-#ifdef SIM_HAVE_BREAKPOINTS
- /* Check for breakpoints "owned" by the simulator first, regardless
- of --environment. */
- if (num == TRAP_BREAKPOINT)
- {
- /* First try sim-break.c. If it's a breakpoint the simulator "owns"
- it doesn't return. Otherwise it returns and let's us try. */
- sim_handle_breakpoint (sd, current_cpu, pc);
- /* Fall through. */
- }
-#endif
-
- if (STATE_ENVIRONMENT (sd) == OPERATING_ENVIRONMENT)
- {
- /* The new pc is the trap vector entry.
- We assume there's a branch there to some handler. */
- USI new_pc;
- setup_int (current_cpu, pc);
- fr30bf_h_ibit_set (current_cpu, 0);
- new_pc = GETMEMSI (current_cpu, pc,
- fr30bf_h_dr_get (current_cpu, H_DR_TBR)
- + 1024 - ((num + 1) * 4));
- return new_pc;
- }
-
- switch (num)
- {
- case TRAP_SYSCALL :
- {
- /* TODO: find out what the ABI for this is */
- CB_SYSCALL s;
-
- CB_SYSCALL_INIT (&s);
- s.func = fr30bf_h_gr_get (current_cpu, 0);
- s.arg1 = fr30bf_h_gr_get (current_cpu, 4);
- s.arg2 = fr30bf_h_gr_get (current_cpu, 5);
- s.arg3 = fr30bf_h_gr_get (current_cpu, 6);
-
- if (s.func == TARGET_SYS_exit)
- {
- sim_engine_halt (sd, current_cpu, NULL, pc, sim_exited, s.arg1);
- }
-
- s.p1 = (PTR) sd;
- s.p2 = (PTR) current_cpu;
- s.read_mem = syscall_read_mem;
- s.write_mem = syscall_write_mem;
- cb_syscall (cb, &s);
- fr30bf_h_gr_set (current_cpu, 2, s.errcode); /* TODO: check this one */
- fr30bf_h_gr_set (current_cpu, 4, s.result);
- fr30bf_h_gr_set (current_cpu, 1, s.result2); /* TODO: check this one */
- break;
- }
-
- case TRAP_BREAKPOINT:
- sim_engine_halt (sd, current_cpu, NULL, pc,
- sim_stopped, SIM_SIGTRAP);
- break;
-
- default :
- {
- USI new_pc;
- setup_int (current_cpu, pc);
- fr30bf_h_ibit_set (current_cpu, 0);
- new_pc = GETMEMSI (current_cpu, pc,
- fr30bf_h_dr_get (current_cpu, H_DR_TBR)
- + 1024 - ((num + 1) * 4));
- return new_pc;
- }
- }
-
- /* Fake an "reti" insn.
- Since we didn't push anything to stack, all we need to do is
- update pc. */
- return pc + 2;
-}
-
-USI
-fr30_inte (SIM_CPU *current_cpu, PCADDR pc, int num)
-{
- /* The new pc is the trap #9 vector entry.
- We assume there's a branch there to some handler. */
- USI new_pc;
- setup_int (current_cpu, pc);
- fr30bf_h_ilm_set (current_cpu, 4);
- new_pc = GETMEMSI (current_cpu, pc,
- fr30bf_h_dr_get (current_cpu, H_DR_TBR)
- + 1024 - ((9 + 1) * 4));
- return new_pc;
-}
+// OBSOLETE /* fr30 exception, interrupt, and trap (EIT) support
+// OBSOLETE Copyright (C) 1998, 1999 Free Software Foundation, Inc.
+// OBSOLETE Contributed by Cygnus Solutions.
+// OBSOLETE
+// OBSOLETE This file is part of the GNU simulators.
+// OBSOLETE
+// OBSOLETE This program is free software; you can redistribute it and/or modify
+// OBSOLETE it under the terms of the GNU General Public License as published by
+// OBSOLETE the Free Software Foundation; either version 2, or (at your option)
+// OBSOLETE any later version.
+// OBSOLETE
+// OBSOLETE This program is distributed in the hope that it will be useful,
+// OBSOLETE but WITHOUT ANY WARRANTY; without even the implied warranty of
+// OBSOLETE MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// OBSOLETE GNU General Public License for more details.
+// OBSOLETE
+// OBSOLETE You should have received a copy of the GNU General Public License along
+// OBSOLETE with this program; if not, write to the Free Software Foundation, Inc.,
+// OBSOLETE 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
+// OBSOLETE
+// OBSOLETE #include "sim-main.h"
+// OBSOLETE #include "targ-vals.h"
+// OBSOLETE #include "cgen-engine.h"
+// OBSOLETE
+// OBSOLETE /* The semantic code invokes this for invalid (unrecognized) instructions. */
+// OBSOLETE
+// OBSOLETE SEM_PC
+// OBSOLETE sim_engine_invalid_insn (SIM_CPU *current_cpu, IADDR cia, SEM_PC vpc)
+// OBSOLETE {
+// OBSOLETE SIM_DESC sd = CPU_STATE (current_cpu);
+// OBSOLETE
+// OBSOLETE #if 0
+// OBSOLETE if (STATE_ENVIRONMENT (sd) == OPERATING_ENVIRONMENT)
+// OBSOLETE {
+// OBSOLETE h_bsm_set (current_cpu, h_sm_get (current_cpu));
+// OBSOLETE h_bie_set (current_cpu, h_ie_get (current_cpu));
+// OBSOLETE h_bcond_set (current_cpu, h_cond_get (current_cpu));
+// OBSOLETE /* sm not changed */
+// OBSOLETE h_ie_set (current_cpu, 0);
+// OBSOLETE h_cond_set (current_cpu, 0);
+// OBSOLETE
+// OBSOLETE h_bpc_set (current_cpu, cia);
+// OBSOLETE
+// OBSOLETE sim_engine_restart (CPU_STATE (current_cpu), current_cpu, NULL,
+// OBSOLETE EIT_RSVD_INSN_ADDR);
+// OBSOLETE }
+// OBSOLETE else
+// OBSOLETE #endif
+// OBSOLETE sim_engine_halt (sd, current_cpu, NULL, cia, sim_stopped, SIM_SIGILL);
+// OBSOLETE return vpc;
+// OBSOLETE }
+// OBSOLETE
+// OBSOLETE /* Process an address exception. */
+// OBSOLETE
+// OBSOLETE void
+// OBSOLETE fr30_core_signal (SIM_DESC sd, SIM_CPU *current_cpu, sim_cia cia,
+// OBSOLETE unsigned int map, int nr_bytes, address_word addr,
+// OBSOLETE transfer_type transfer, sim_core_signals sig)
+// OBSOLETE {
+// OBSOLETE #if 0
+// OBSOLETE if (STATE_ENVIRONMENT (sd) == OPERATING_ENVIRONMENT)
+// OBSOLETE {
+// OBSOLETE h_bsm_set (current_cpu, h_sm_get (current_cpu));
+// OBSOLETE h_bie_set (current_cpu, h_ie_get (current_cpu));
+// OBSOLETE h_bcond_set (current_cpu, h_cond_get (current_cpu));
+// OBSOLETE /* sm not changed */
+// OBSOLETE h_ie_set (current_cpu, 0);
+// OBSOLETE h_cond_set (current_cpu, 0);
+// OBSOLETE
+// OBSOLETE h_bpc_set (current_cpu, cia);
+// OBSOLETE
+// OBSOLETE sim_engine_restart (CPU_STATE (current_cpu), current_cpu, NULL,
+// OBSOLETE EIT_ADDR_EXCP_ADDR);
+// OBSOLETE }
+// OBSOLETE else
+// OBSOLETE #endif
+// OBSOLETE sim_core_signal (sd, current_cpu, cia, map, nr_bytes, addr,
+// OBSOLETE transfer, sig);
+// OBSOLETE }
+// OBSOLETE
+// OBSOLETE /* Read/write functions for system call interface. */
+// OBSOLETE
+// OBSOLETE static int
+// OBSOLETE syscall_read_mem (host_callback *cb, struct cb_syscall *sc,
+// OBSOLETE unsigned long taddr, char *buf, int bytes)
+// OBSOLETE {
+// OBSOLETE SIM_DESC sd = (SIM_DESC) sc->p1;
+// OBSOLETE SIM_CPU *cpu = (SIM_CPU *) sc->p2;
+// OBSOLETE
+// OBSOLETE return sim_core_read_buffer (sd, cpu, read_map, buf, taddr, bytes);
+// OBSOLETE }
+// OBSOLETE
+// OBSOLETE static int
+// OBSOLETE syscall_write_mem (host_callback *cb, struct cb_syscall *sc,
+// OBSOLETE unsigned long taddr, const char *buf, int bytes)
+// OBSOLETE {
+// OBSOLETE SIM_DESC sd = (SIM_DESC) sc->p1;
+// OBSOLETE SIM_CPU *cpu = (SIM_CPU *) sc->p2;
+// OBSOLETE
+// OBSOLETE return sim_core_write_buffer (sd, cpu, write_map, buf, taddr, bytes);
+// OBSOLETE }
+// OBSOLETE
+// OBSOLETE /* Subroutine of fr30_int to save the PS and PC and setup for INT and INTE. */
+// OBSOLETE
+// OBSOLETE static void
+// OBSOLETE setup_int (SIM_CPU *current_cpu, PCADDR pc)
+// OBSOLETE {
+// OBSOLETE USI ssp = fr30bf_h_dr_get (current_cpu, H_DR_SSP);
+// OBSOLETE USI ps = fr30bf_h_ps_get (current_cpu);
+// OBSOLETE
+// OBSOLETE ssp -= 4;
+// OBSOLETE SETMEMSI (current_cpu, pc, ssp, ps);
+// OBSOLETE ssp -= 4;
+// OBSOLETE SETMEMSI (current_cpu, pc, ssp, pc + 2);
+// OBSOLETE fr30bf_h_dr_set (current_cpu, H_DR_SSP, ssp);
+// OBSOLETE fr30bf_h_sbit_set (current_cpu, 0);
+// OBSOLETE }
+// OBSOLETE
+// OBSOLETE /* Trap support.
+// OBSOLETE The result is the pc address to continue at.
+// OBSOLETE Preprocessing like saving the various registers has already been done. */
+// OBSOLETE
+// OBSOLETE USI
+// OBSOLETE fr30_int (SIM_CPU *current_cpu, PCADDR pc, int num)
+// OBSOLETE {
+// OBSOLETE SIM_DESC sd = CPU_STATE (current_cpu);
+// OBSOLETE host_callback *cb = STATE_CALLBACK (sd);
+// OBSOLETE
+// OBSOLETE #ifdef SIM_HAVE_BREAKPOINTS
+// OBSOLETE /* Check for breakpoints "owned" by the simulator first, regardless
+// OBSOLETE of --environment. */
+// OBSOLETE if (num == TRAP_BREAKPOINT)
+// OBSOLETE {
+// OBSOLETE /* First try sim-break.c. If it's a breakpoint the simulator "owns"
+// OBSOLETE it doesn't return. Otherwise it returns and let's us try. */
+// OBSOLETE sim_handle_breakpoint (sd, current_cpu, pc);
+// OBSOLETE /* Fall through. */
+// OBSOLETE }
+// OBSOLETE #endif
+// OBSOLETE
+// OBSOLETE if (STATE_ENVIRONMENT (sd) == OPERATING_ENVIRONMENT)
+// OBSOLETE {
+// OBSOLETE /* The new pc is the trap vector entry.
+// OBSOLETE We assume there's a branch there to some handler. */
+// OBSOLETE USI new_pc;
+// OBSOLETE setup_int (current_cpu, pc);
+// OBSOLETE fr30bf_h_ibit_set (current_cpu, 0);
+// OBSOLETE new_pc = GETMEMSI (current_cpu, pc,
+// OBSOLETE fr30bf_h_dr_get (current_cpu, H_DR_TBR)
+// OBSOLETE + 1024 - ((num + 1) * 4));
+// OBSOLETE return new_pc;
+// OBSOLETE }
+// OBSOLETE
+// OBSOLETE switch (num)
+// OBSOLETE {
+// OBSOLETE case TRAP_SYSCALL :
+// OBSOLETE {
+// OBSOLETE /* TODO: find out what the ABI for this is */
+// OBSOLETE CB_SYSCALL s;
+// OBSOLETE
+// OBSOLETE CB_SYSCALL_INIT (&s);
+// OBSOLETE s.func = fr30bf_h_gr_get (current_cpu, 0);
+// OBSOLETE s.arg1 = fr30bf_h_gr_get (current_cpu, 4);
+// OBSOLETE s.arg2 = fr30bf_h_gr_get (current_cpu, 5);
+// OBSOLETE s.arg3 = fr30bf_h_gr_get (current_cpu, 6);
+// OBSOLETE
+// OBSOLETE if (s.func == TARGET_SYS_exit)
+// OBSOLETE {
+// OBSOLETE sim_engine_halt (sd, current_cpu, NULL, pc, sim_exited, s.arg1);
+// OBSOLETE }
+// OBSOLETE
+// OBSOLETE s.p1 = (PTR) sd;
+// OBSOLETE s.p2 = (PTR) current_cpu;
+// OBSOLETE s.read_mem = syscall_read_mem;
+// OBSOLETE s.write_mem = syscall_write_mem;
+// OBSOLETE cb_syscall (cb, &s);
+// OBSOLETE fr30bf_h_gr_set (current_cpu, 2, s.errcode); /* TODO: check this one */
+// OBSOLETE fr30bf_h_gr_set (current_cpu, 4, s.result);
+// OBSOLETE fr30bf_h_gr_set (current_cpu, 1, s.result2); /* TODO: check this one */
+// OBSOLETE break;
+// OBSOLETE }
+// OBSOLETE
+// OBSOLETE case TRAP_BREAKPOINT:
+// OBSOLETE sim_engine_halt (sd, current_cpu, NULL, pc,
+// OBSOLETE sim_stopped, SIM_SIGTRAP);
+// OBSOLETE break;
+// OBSOLETE
+// OBSOLETE default :
+// OBSOLETE {
+// OBSOLETE USI new_pc;
+// OBSOLETE setup_int (current_cpu, pc);
+// OBSOLETE fr30bf_h_ibit_set (current_cpu, 0);
+// OBSOLETE new_pc = GETMEMSI (current_cpu, pc,
+// OBSOLETE fr30bf_h_dr_get (current_cpu, H_DR_TBR)
+// OBSOLETE + 1024 - ((num + 1) * 4));
+// OBSOLETE return new_pc;
+// OBSOLETE }
+// OBSOLETE }
+// OBSOLETE
+// OBSOLETE /* Fake an "reti" insn.
+// OBSOLETE Since we didn't push anything to stack, all we need to do is
+// OBSOLETE update pc. */
+// OBSOLETE return pc + 2;
+// OBSOLETE }
+// OBSOLETE
+// OBSOLETE USI
+// OBSOLETE fr30_inte (SIM_CPU *current_cpu, PCADDR pc, int num)
+// OBSOLETE {
+// OBSOLETE /* The new pc is the trap #9 vector entry.
+// OBSOLETE We assume there's a branch there to some handler. */
+// OBSOLETE USI new_pc;
+// OBSOLETE setup_int (current_cpu, pc);
+// OBSOLETE fr30bf_h_ilm_set (current_cpu, 4);
+// OBSOLETE new_pc = GETMEMSI (current_cpu, pc,
+// OBSOLETE fr30bf_h_dr_get (current_cpu, H_DR_TBR)
+// OBSOLETE + 1024 - ((9 + 1) * 4));
+// OBSOLETE return new_pc;
+// OBSOLETE }