From f2de7dfd8cf1ffd6edc7ed650e709c7fa4488da1 Mon Sep 17 00:00:00 2001 From: Andrew Cagney Date: Fri, 14 Mar 1997 15:13:58 +0000 Subject: Add a number of per-simulator options: hostendian, endian, inline, warnings. Rename *-n.h files to be dos compatible --- sim/common/sim-n-core.h | 95 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 95 insertions(+) create mode 100644 sim/common/sim-n-core.h (limited to 'sim/common/sim-n-core.h') diff --git a/sim/common/sim-n-core.h b/sim/common/sim-n-core.h new file mode 100644 index 00000000000..1bcb7227bd6 --- /dev/null +++ b/sim/common/sim-n-core.h @@ -0,0 +1,95 @@ +/* This file is part of the program psim. + + Copyright (C) 1994-1997, Andrew Cagney + + 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. + + */ + + +#ifndef N +#error "N must be #defined" +#endif + +/* NOTE: see end of file for #undef of these macros */ +#define unsigned_N XCONCAT2(unsigned_,N) +#define T2H_N XCONCAT2(T2H_,N) +#define H2T_N XCONCAT2(H2T_,N) + +#define core_map_read_N XCONCAT2(core_map_read_,N) +#define core_map_write_N XCONCAT2(core_map_write_,N) + + +INLINE_SIM_CORE(unsigned_N) +core_map_read_N(engine *system, + core_maps map, + unsigned_word addr) +{ + core_mapping *mapping = core_map_find_mapping(system, map, + addr, + sizeof(unsigned_N), + 1); /*abort*/ +#if (WITH_DEVICES) + if (WITH_CALLBACK_MEMORY && mapping->device != NULL) { + unsigned_N data; + if (device_io_read_buffer(mapping->device, + &data, + mapping->space, + addr, + sizeof(unsigned_N)) != sizeof(unsigned_N)) + device_error(mapping->device, "internal error - core_read_N() - io_read_buffer should not fail"); + return T2H_N(data); + } + else +#endif + return T2H_N(*(unsigned_N*)core_translate(mapping, addr)); +} + + + +INLINE_SIM_CORE(void) +core_map_write_N(engine *system, + core_maps map, + unsigned_word addr, + unsigned_N val) +{ + core_mapping *mapping = core_map_find_mapping(system, map, + addr, + sizeof(unsigned_N), + 1); /*abort*/ +#if (WITH_DEVICES) + if (WITH_CALLBACK_MEMORY && mapping->device != NULL) { + unsigned_N data = H2T_N(val); + if (device_io_write_buffer(mapping->device, + &data, + mapping->space, + addr, + sizeof(unsigned_N), /* nr_bytes */ + processor, + cia) != sizeof(unsigned_N)) + device_error(mapping->device, "internal error - core_write_N() - io_write_buffer should not fail"); + } + else +#endif + *(unsigned_N*)core_translate(mapping, addr) = H2T_N(val); +} + + +/* NOTE: see start of file for #define of these macros */ +#undef unsigned_N +#undef T2H_N +#undef H2T_N +#undef core_map_read_N +#undef core_map_write_N -- cgit v1.2.3-65-gdbad