diff options
author | Mike Frysinger <vapier@gentoo.org> | 2015-06-15 21:09:21 +0545 |
---|---|---|
committer | Mike Frysinger <vapier@gentoo.org> | 2015-06-17 13:19:51 -0400 |
commit | 61a0c964e611eaf72489c3049ba206b2f91ea4a9 (patch) | |
tree | 386585a4f8d371d56225e968649dba301ec27801 /sim/common | |
parent | 6362a3f8757bfce133b724df2077573433823ad4 (diff) | |
download | gdb-61a0c964e611eaf72489c3049ba206b2f91ea4a9.zip gdb-61a0c964e611eaf72489c3049ba206b2f91ea4a9.tar.gz gdb-61a0c964e611eaf72489c3049ba206b2f91ea4a9.tar.bz2 |
sim: syscall: unify memory helpers
Almost every port implements these two callbacks in the same way, so
unify them in the common layer.
Diffstat (limited to 'sim/common')
-rw-r--r-- | sim/common/ChangeLog | 6 | ||||
-rw-r--r-- | sim/common/Make-common.in | 1 | ||||
-rw-r--r-- | sim/common/sim-syscall.c | 49 | ||||
-rw-r--r-- | sim/common/sim-syscall.h | 30 |
4 files changed, 86 insertions, 0 deletions
diff --git a/sim/common/ChangeLog b/sim/common/ChangeLog index 0478f2c..2c67e49 100644 --- a/sim/common/ChangeLog +++ b/sim/common/ChangeLog @@ -1,5 +1,11 @@ 2015-06-17 Mike Frysinger <vapier@gentoo.org> + * Make-common.in (SIM_NEW_COMMON_OBJS): Add sim-syscall.o. + * sim-syscall.c: New file. + * sim-syscall.h: New file. + +2015-06-17 Mike Frysinger <vapier@gentoo.org> + * callback.c (cb_target_map_entry, cb_host_map_entry): Define. (cb_target_to_host_syscall): Rewrite to use cb_target_map_entry. (cb_host_to_target_errno): Rewrite to use cb_host_map_entry. diff --git a/sim/common/Make-common.in b/sim/common/Make-common.in index 2d1bb8a..2f5ad89 100644 --- a/sim/common/Make-common.in +++ b/sim/common/Make-common.in @@ -190,6 +190,7 @@ SIM_NEW_COMMON_OBJS = \ sim-options.o \ sim-profile.o \ sim-signal.o \ + sim-syscall.o \ sim-trace.o \ sim-utils.o \ sim-watch.o \ diff --git a/sim/common/sim-syscall.c b/sim/common/sim-syscall.c new file mode 100644 index 0000000..76812d3 --- /dev/null +++ b/sim/common/sim-syscall.c @@ -0,0 +1,49 @@ +/* Simulator system call support. + + Copyright 2002-2015 Free Software Foundation, Inc. + + This file is part of 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 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/>. */ + +#include "config.h" + +#include "sim-main.h" +#include "sim-syscall.h" + +/* Read/write functions for system call interface. */ + +int +sim_syscall_read_mem (host_callback *cb ATTRIBUTE_UNUSED, 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; + + TRACE_MEMORY (cpu, "READ (syscall) %i bytes @ 0x%08lx", bytes, taddr); + + return sim_core_read_buffer (sd, cpu, read_map, buf, taddr, bytes); +} + +int +sim_syscall_write_mem (host_callback *cb ATTRIBUTE_UNUSED, 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; + + TRACE_MEMORY (cpu, "WRITE (syscall) %i bytes @ 0x%08lx", bytes, taddr); + + return sim_core_write_buffer (sd, cpu, write_map, buf, taddr, bytes); +} diff --git a/sim/common/sim-syscall.h b/sim/common/sim-syscall.h new file mode 100644 index 0000000..3f231fe --- /dev/null +++ b/sim/common/sim-syscall.h @@ -0,0 +1,30 @@ +/* Simulator system call support. + + Copyright 2002-2015 Free Software Foundation, Inc. + + This file is part of 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 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_SYSCALL_H +#define SIM_SYSCALL_H + +/* Simple memory callbacks for cb_syscall's read_mem/write_mem that assume + cb_syscall's p1 and p2 are set to the SIM_DESC and SIM_CPU respectively. */ +int sim_syscall_read_mem (host_callback *, struct cb_syscall *, unsigned long, + char *, int); +int sim_syscall_write_mem (host_callback *, struct cb_syscall *, unsigned long, + const char *, int); + +#endif |