mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-24 12:35:55 +08:00
4449c81a85
This patch adds support for xBPF, another ISA targetting the BPF virtual architecture. For now, the primary difference between eBPF and xBPF is that xBPF supports indirect calls through the 'call %reg' form of the call instruction. bfd/ * archures.c (bfd_mach_xbpf): Define. * bfd-in2.h: Regenerate. * cpu-bpf.c (bfd_xbpf_arch) New. (bfd_bpf_arch) Update next in list field to point to xbpf arch. cpu/ * bpf.cpu (arch bpf): Add xbpf mach and isas. (define-xbpf-isa) New pmacro. (all-isas) Add xbpfle,xbpfbe. (endian-isas): New pmacro. (mach xbpf): New. (model xbpf-def): Likewise. (h-gpr): Add xbpf mach. (f-dstle, f-srcle, dstle, srcle): Add xbpfle isa. (f-dstbe, f-srcbe, dstbe, srcbe): Add xbpfbe isa. (define-alu-insn-un): Use new endian-isas pmacro. (define-alu-insn-bin, define-alu-insn-mov): Likewise. (define-endian-insn, define-lddw): Likewise. (dlind, dxli, dxsi, dsti): Likewise. (define-cond-jump-insn, define-call-insn): Likewise. (define-atomic-insns): Likewise. gas/ * config/tc-bpf.c: Add option -mxbpf to select xbpf isa. * testsuite/gas/bpf/indcall-1.d: New file. * testsuite/gas/bpf/indcall-1.s: Likewise. * testsuite/gas/bpf/indcall-bad-1.l: Likewise. * testsuite/gas/bpf/indcall-bad-1.s: Likewise. * testsuite/gas/bpf/bpf.exp: Run new tests. opcodes/ * bpf-desc.c: Regenerate. * bpf-desc.h: Likewise. * bpf-opc.c: Likewise. * bpf-opc.h: Likewise. * disassemble.c (disassemble_init_for_target): Set bits for xBPF ISA when appropriate.
63 lines
2.2 KiB
C
63 lines
2.2 KiB
C
/* BFD support for the BPF processor.
|
|
Copyright (C) 2019-2020 Free Software Foundation, Inc.
|
|
Contributed by Oracle Inc.
|
|
|
|
This file is part of BFD, the Binary File Descriptor library.
|
|
|
|
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, write to the Free Software
|
|
Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
|
|
MA 02110-1301, USA. */
|
|
|
|
#include "sysdep.h"
|
|
#include "bfd.h"
|
|
#include "libbfd.h"
|
|
|
|
|
|
static const bfd_arch_info_type bfd_xbpf_arch =
|
|
{
|
|
64, /* Bits per word. */
|
|
64, /* Bits per address. */
|
|
8, /* Bits per byte. */
|
|
bfd_arch_bpf, /* Architecture. */
|
|
bfd_mach_xbpf, /* Machine. */
|
|
"bpf", /* Architecture name. */
|
|
"xbpf", /* Machine name. */
|
|
3, /* Section align power. */
|
|
FALSE, /* The default ? */
|
|
bfd_default_compatible, /* Architecture comparison fn. */
|
|
bfd_default_scan, /* String to architecture convert fn. */
|
|
bfd_arch_default_fill, /* Default fill. */
|
|
NULL, /* Next in list. */
|
|
0 /* Maximum offset of a reloc from the start of an insn. */
|
|
};
|
|
|
|
|
|
const bfd_arch_info_type bfd_bpf_arch =
|
|
{
|
|
64, /* Bits per word. */
|
|
64, /* Bits per address. */
|
|
8, /* Bits per byte. */
|
|
bfd_arch_bpf, /* Architecture. */
|
|
bfd_mach_bpf, /* Machine. */
|
|
"bpf", /* Architecture name. */
|
|
"bpf", /* Machine name. */
|
|
3, /* Section align power. */
|
|
TRUE, /* The default ? */
|
|
bfd_default_compatible, /* Architecture comparison fn. */
|
|
bfd_default_scan, /* String to architecture convert fn. */
|
|
bfd_arch_default_fill, /* Default fill. */
|
|
&bfd_xbpf_arch, /* Next in list. */
|
|
0 /* Maximum offset of a reloc from the start of an insn. */
|
|
};
|