1/* BFD library support routines for the NFP.
2   Copyright (C) 2017-2022 Free Software Foundation, Inc.
3   Contributed by Francois H. Theron <francois.theron@netronome.com>
4
5   This file is part of BFD, the Binary File Descriptor library.
6
7   This program is free software; you can redistribute it and/or modify
8   it under the terms of the GNU General Public License as published by
9   the Free Software Foundation; either version 3 of the License, or
10   (at your option) any later version.
11
12   This program is distributed in the hope that it will be useful,
13   but WITHOUT ANY WARRANTY; without even the implied warranty of
14   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15   GNU General Public License for more details.
16
17   You should have received a copy of the GNU General Public License
18   along with this program; if not, write to the Free Software
19   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
20   MA 02110-1301, USA.  */
21
22#include "sysdep.h"
23#include "bfd.h"
24#include "libbfd.h"
25
26static const bfd_arch_info_type *
27bfd_nfp_compatible (const bfd_arch_info_type * a,
28		    const bfd_arch_info_type * b)
29{
30  if (a->arch != b->arch)
31    return NULL;
32
33  if (a->mach != b->mach)
34    return NULL;
35
36  return a;
37}
38
39#define N(machine, print, default, next)			\
40{								\
41  32,								\
42  64,								\
43  8,								\
44  bfd_arch_nfp,							\
45  machine,							\
46  "nfp",							\
47  print,							\
48  3,								\
49  default,							\
50  bfd_nfp_compatible,						\
51  bfd_default_scan,						\
52  bfd_arch_default_fill,					\
53  next,								\
54  0 /* Maximum offset of a reloc from the start of an insn.  */ \
55}
56
57static const bfd_arch_info_type arch_info_struct =
58  N (bfd_mach_nfp3200, "NFP-32xx", false, NULL);
59
60const bfd_arch_info_type bfd_nfp_arch =
61  N (bfd_mach_nfp6000, "NFP-6xxx", true, &arch_info_struct);
62