diff options
author | Jose E. Marchesi <jose.marchesi@oracle.com> | 2020-08-04 18:09:16 +0200 |
---|---|---|
committer | Jose E. Marchesi <jose.marchesi@oracle.com> | 2020-08-04 18:09:16 +0200 |
commit | b26e2ae7d333d84a85daaa9ca699c8bae2bd05bc (patch) | |
tree | 73db093a038074bb84b9104e5bd1182e062e9546 /sim/bpf/decode.h | |
parent | 39791af2a2191a2f7765d7809ecedcd0442138bf (diff) | |
download | binutils-b26e2ae7d333d84a85daaa9ca699c8bae2bd05bc.zip binutils-b26e2ae7d333d84a85daaa9ca699c8bae2bd05bc.tar.gz binutils-b26e2ae7d333d84a85daaa9ca699c8bae2bd05bc.tar.bz2 |
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 <jose.marchesi@oracle.com>
* configure.tgt: Set gdb_sim for bpf-*-* targets.
sim/ChangeLog:
2020-08-04 Jose E. Marchesi <jose.marchesi@oracle.com>
David Faust <david.faust@oracle.com>
* 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 <david.faust@oracle.com>
Jose E. Marchesi <jose.marchesi@oracle.com>
* 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.
Diffstat (limited to 'sim/bpf/decode.h')
-rw-r--r-- | sim/bpf/decode.h | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/sim/bpf/decode.h b/sim/bpf/decode.h new file mode 100644 index 0000000..74d31cb --- /dev/null +++ b/sim/bpf/decode.h @@ -0,0 +1,37 @@ +/* Decode declarations. + Copyright (C) 2020 Free Software Foundation, Inc. + Contributed by Oracle, Inc. + +This file is part of the GNU 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 declarations for eBPF LE and eBPF BE ISAs. */ + +#ifndef DECODE_H +#define DECODE_H + +#undef WITH_PROFILE_MODEL_P + +#ifdef WANT_ISA_EBPFLE +#include "decode-le.h" +#include "defs-le.h" +#endif /* WANT_ISA_EBPFLE */ + +#ifdef WANT_ISA_EBPFBE +#include "decode-be.h" +#include "defs-be.h" +#endif /* WANT_ISA_EBPFBE */ + +#endif /* DECODE_H */ |