| /* The common simulator framework for GDB, the GNU Debugger. |
| |
| Copyright 2002-2021 Free Software Foundation, Inc. |
| |
| Contributed by Andrew Cagney and 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/>. */ |
| |
| |
| #ifndef SIM_BASICS_H |
| #define SIM_BASICS_H |
| |
| |
| /* Basic configuration */ |
| |
| #include "defs.h" |
| |
| /* Basic host dependant mess - hopefully <stdio.h> + <stdarg.h> will |
| bring potential conflicts out in the open */ |
| |
| #include <stdarg.h> |
| #include <stdio.h> |
| #include <setjmp.h> |
| |
| |
| #ifndef min |
| #define min(a, b) ((a) < (b) ? (a) : (b)) |
| #endif |
| #ifndef max |
| #define max(a, b) ((a) > (b) ? (a) : (b)) |
| #endif |
| |
| |
| /* Global types that code manipulates */ |
| |
| struct hw; |
| struct _sim_fpu; |
| |
| |
| /* Generic address space (maps) and access attributes */ |
| |
| enum { |
| read_map = 0, |
| write_map = 1, |
| exec_map = 2, |
| io_map = 3, |
| nr_maps = 32, /* something small */ |
| }; |
| |
| enum { |
| access_invalid = 0, |
| access_read = 1 << read_map, |
| access_write = 1 << write_map, |
| access_exec = 1 << exec_map, |
| access_io = 1 << io_map, |
| }; |
| |
| enum { |
| access_read_write = (access_read | access_write), |
| access_read_exec = (access_read | access_exec), |
| access_write_exec = (access_write | access_exec), |
| access_read_write_exec = (access_read | access_write | access_exec), |
| access_read_io = (access_read | access_io), |
| access_write_io = (access_write | access_io), |
| access_read_write_io = (access_read | access_write | access_io), |
| access_exec_io = (access_exec | access_io), |
| access_read_exec_io = (access_read | access_exec | access_io), |
| access_write_exec_io = (access_write | access_exec | access_io), |
| access_read_write_exec_io = (access_read | access_write | access_exec | access_io), |
| }; |
| |
| |
| /* disposition of an object when things are reset */ |
| |
| typedef enum { |
| permenant_object, |
| temporary_object, |
| } object_disposition; |
| |
| |
| /* Memory transfer types */ |
| |
| typedef enum _transfer_type { |
| read_transfer, |
| write_transfer, |
| } transfer_type; |
| |
| |
| /* directions */ |
| |
| typedef enum { |
| bidirect_port, |
| input_port, |
| output_port, |
| } port_direction; |
| |
| |
| |
| /* Basic definitions - ordered so that nothing calls what comes after it. */ |
| |
| #include "ansidecl.h" |
| #include "sim/sim.h" |
| |
| #include "sim-config.h" |
| |
| #include "sim-inline.h" |
| |
| #include "sim-types.h" |
| #include "sim-bits.h" |
| #include "sim-endian.h" |
| |
| #include "sim-utils.h" |
| |
| /* Note: Only the simpler interfaces are defined here. More heavy |
| weight objects, such as core and events, are defined in the more |
| serious sim-base.h header. */ |
| |
| #endif /* SIM_BASICS_H */ |