xref: /netbsd-src/external/gpl3/binutils.old/dist/bfd/cpu-nfp.c (revision c42dbd0ed2e61fe6eda8590caa852ccf34719964)
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 
26 static const bfd_arch_info_type *
bfd_nfp_compatible(const bfd_arch_info_type * a,const bfd_arch_info_type * b)27 bfd_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 
57 static const bfd_arch_info_type arch_info_struct =
58   N (bfd_mach_nfp3200, "NFP-32xx", false, NULL);
59 
60 const bfd_arch_info_type bfd_nfp_arch =
61   N (bfd_mach_nfp6000, "NFP-6xxx", true, &arch_info_struct);
62