xref: /netbsd-src/external/gpl3/binutils/dist/bfd/cpu-d10v.c (revision cb63e24e8d6aae7ddac1859a9015f48b1d8bd90e)
1 /* BFD support for the D10V processor
2    Copyright (C) 1996-2024 Free Software Foundation, Inc.
3    Contributed by Martin Hunt (hunt@cygnus.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 #define N(NUMBER, PRINT, DEFAULT, NEXT)			\
27   {							\
28     16,         /* Bits in a word.  */			\
29     18,         /* Bits in an address.  */		\
30     8,	        /* Bits in a byte.  */			\
31     bfd_arch_d10v,					\
32     NUMBER,						\
33     "d10v",						\
34     PRINT,						\
35     4,		/* Section alignment power.  */		\
36     DEFAULT,						\
37     bfd_default_compatible,				\
38     bfd_default_scan,					\
39     bfd_arch_default_fill,				\
40     NEXT,						\
41     0 /* Maximum offset of a reloc from the start of an insn.  */ \
42   }
43 
44 static const bfd_arch_info_type d10v_ts3_info =
45   N (bfd_mach_d10v_ts3, "d10v:ts3", false, NULL);
46 
47 static const bfd_arch_info_type d10v_ts2_info =
48   N (bfd_mach_d10v_ts2, "d10v:ts2", false, & d10v_ts3_info);
49 
50 const bfd_arch_info_type bfd_d10v_arch =
51   N (bfd_mach_d10v, "d10v", true, & d10v_ts2_info);
52