diff options
author | Michael Eager <eager@eagercon.com> | 2009-09-23 20:01:47 +0000 |
---|---|---|
committer | Michael Eager <eager@eagercon.com> | 2009-09-23 20:01:47 +0000 |
commit | bd30e45a3430ce30c63146aa8cad0796754581b6 (patch) | |
tree | 3338988a1d4b8e77678085490cd42637081860ce /sim/microblaze/sim-main.h | |
parent | 572771db36119a9aea94d265cfe9607b6c1721b9 (diff) | |
download | gdb-bd30e45a3430ce30c63146aa8cad0796754581b6.zip gdb-bd30e45a3430ce30c63146aa8cad0796754581b6.tar.gz gdb-bd30e45a3430ce30c63146aa8cad0796754581b6.tar.bz2 |
2009-09-23 Michael Eager <eager@eagercon.com>
* configure: Add microblaze-*.* (not regenerated).
* configure.ac: Likewise.
* microblaze/config.in: New.
* microblaze/configure: Generate.
* microblaze/configure.ac: New.
* microblaze/interp.c: New.
* microblaze/Makefile.in: New.
* microblaze/microblaze.h: New.
* microblaze/microblaze.isa: New.
* microblaze/sim-main.h: New.
* microblaze/sysdep.h: New.
Diffstat (limited to 'sim/microblaze/sim-main.h')
-rw-r--r-- | sim/microblaze/sim-main.h | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/sim/microblaze/sim-main.h b/sim/microblaze/sim-main.h new file mode 100644 index 0000000..67e6fae --- /dev/null +++ b/sim/microblaze/sim-main.h @@ -0,0 +1,64 @@ +#ifndef MICROBLAZE_SIM_MAIN +#define MICROBLAZE_SIM_MAIN + +/* Copyright 2009 Free Software Foundation, Inc. + + This file is part of the Xilinx MicroBlaze simulator. + + This library 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, write to the Free Software + Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, + MA 02110-1301, USA. */ + +#include "microblaze.h" +#include "sim-basics.h" +typedef address_word sim_cia; +#include "sim-base.h" + +/* The machine state. + This state is maintained in host byte order. The + fetch/store register functions must translate between host + byte order and the target processor byte order. + Keeping this data in target byte order simplifies the register + read/write functions. Keeping this data in native order improves + the performance of the simulator. Simulation speed is deemed more + important. */ + +/* The ordering of the microblaze_regset structure is matched in the + gdb/config/microblaze/tm-microblaze.h file in the REGISTER_NAMES macro. */ + struct microblaze_regset +{ + word regs[32]; /* primary registers */ + word spregs[2]; /* pc + msr */ + int cycles; + int insts; + int exception; + unsigned long msize; + unsigned char *memory; + ubyte imm_enable; + half imm_high; +}; + +struct _sim_cpu { + struct microblaze_regset microblaze_cpu; + sim_cpu_base base; +}; + +#define MAX_NR_PROCESSORS 1 +struct sim_state { + sim_cpu cpu[MAX_NR_PROCESSORS]; +#define STATE_CPU(sd, n) (&(sd)->cpu[0]) + sim_state_base base; +}; +#endif /* MICROBLAZE_SIM_MAIN */ + |