From b26e2ae7d333d84a85daaa9ca699c8bae2bd05bc Mon Sep 17 00:00:00 2001 From: "Jose E. Marchesi" Date: Tue, 4 Aug 2020 18:09:16 +0200 Subject: sim: eBPF simulator This patch introduces the basics of an instruction-simulator for eBPF. The simulator is based on CGEN. gdb/ChangeLog: 2020-08-04 Jose E. Marchesi * configure.tgt: Set gdb_sim for bpf-*-* targets. sim/ChangeLog: 2020-08-04 Jose E. Marchesi David Faust * configure.tgt (sim_arch): Add entry for bpf-*-*. * configure: Regenerate. * MAINTAINERS: Add maintainer for the BPF simulator. * bpf/Makefile.in: New file. * bpf/bpf-helpers.c: Likewise. * bpf/bpf-helpers.def: Likewise. * bpf/bpf-helpers.h: Likewise. * bpf/bpf-sim.h: Likewise. * bpf/bpf.c: Likewise. * bpf/config.in: Likewise. * bpf/configure.ac: Likewise. * bpf/decode.h: Likewise. * bpf/eng.h: Likewise. * bpf/mloop.in: Likewise. * bpf/sim-if.c: Likewise. * bpf/sim-main.h: Likewise. * bpf/traps.c: Likewise. * bpf/configure: Generate. * bpf/aclocal.m4: Likewise. sim/testsuite/ChangeLog: 2020-08-04 David Faust Jose E. Marchesi * configure: Regenerate. * sim/bpf/allinsn.exp: New file. * sim/bpf/alu.s: Likewise. * sim/bpf/alu32.s: Likewise. * sim/bpf/endbe.s: Likewise. * sim/bpf/endle.s: Likewise. * sim/bpf/jmp.s: Likewise. * sim/bpf/jmp32.s: Likewise. * sim/bpf/ldabs.s: Likewise. * sim/bpf/mem.s: Likewise. * sim/bpf/mov.s: Likewise. * sim/bpf/testutils.inc: Likewise. * sim/bpf/xadd.s: Likewise. --- sim/bpf/sim-main.h | 51 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 sim/bpf/sim-main.h (limited to 'sim/bpf/sim-main.h') diff --git a/sim/bpf/sim-main.h b/sim/bpf/sim-main.h new file mode 100644 index 0000000..fc1e69f --- /dev/null +++ b/sim/bpf/sim-main.h @@ -0,0 +1,51 @@ +/* eBPF simulator main header + Copyright (C) 2020 Free Software Foundation, Inc. + + This file is part of GDB, the GNU debugger. + + 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 . */ + +#ifndef SIM_MAIN_H +#define SIM_MAIN_H + +#include "sim-basics.h" +#include "cgen-types.h" +#include "bpf-desc.h" +#include "bpf-opc.h" +#include "arch.h" +#include "sim-base.h" +#include "cgen-sim.h" +#include "bpf-sim.h" + + +struct _sim_cpu +{ + sim_cpu_base base; + CGEN_CPU cgen_cpu; + +#if defined (WANT_CPU_BPFBF) + BPFBF_CPU_DATA cpu_data; +#endif +}; + + + +struct sim_state +{ + sim_cpu *cpu[MAX_NR_PROCESSORS]; + CGEN_STATE cgen_state; + sim_state_base base; +}; + +#endif /* ! SIM_MAIN_H */ -- cgit v1.1