xref: /netbsd-src/external/gpl3/binutils.old/dist/bfd/cpu-epiphany.c (revision e992f068c547fd6e84b3f104dc2340adcc955732)
175fd0b74Schristos /* BFD support for the Adapteva EPIPHANY processor.
2*e992f068Schristos    Copyright (C) 2009-2022 Free Software Foundation, Inc.
375fd0b74Schristos    Contributed by Embecosm on behalf of Adapteva, Inc.
475fd0b74Schristos 
575fd0b74Schristos    This file is part of BFD, the Binary File Descriptor library.
675fd0b74Schristos 
775fd0b74Schristos    This program is free software; you can redistribute it and/or modify
875fd0b74Schristos    it under the terms of the GNU General Public License as published by
975fd0b74Schristos    the Free Software Foundation; either version 3 of the License, or
1075fd0b74Schristos    (at your option) any later version.
1175fd0b74Schristos 
1275fd0b74Schristos    This program is distributed in the hope that it will be useful,
1375fd0b74Schristos    but WITHOUT ANY WARRANTY; without even the implied warranty of
1475fd0b74Schristos    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
1575fd0b74Schristos    GNU General Public License for more details.
1675fd0b74Schristos 
1775fd0b74Schristos    You should have received a copy of the GNU General Public License
1875fd0b74Schristos    along with this program; if not, write to the Free Software
1975fd0b74Schristos    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
2075fd0b74Schristos    MA 02110-1301, USA.  */
2175fd0b74Schristos 
2275fd0b74Schristos #include "sysdep.h"
2375fd0b74Schristos #include "bfd.h"
2475fd0b74Schristos #include "libbfd.h"
2575fd0b74Schristos 
26012573ebSchristos #define N(NUMBER, PRINT, ALIGN, DEFAULT, NEXT)		\
27012573ebSchristos   {							\
28012573ebSchristos     32,         /* Bits in a word.  */			\
29012573ebSchristos     32,         /* Bits in an address.  */		\
30012573ebSchristos     8,	        /* Bits in a byte.  */			\
31012573ebSchristos     bfd_arch_epiphany,					\
32012573ebSchristos     NUMBER,						\
33012573ebSchristos     "epiphany",						\
34012573ebSchristos     PRINT,						\
35012573ebSchristos     ALIGN,	/* Section alignment power.  */		\
36012573ebSchristos     DEFAULT,						\
37012573ebSchristos     bfd_default_compatible,				\
38012573ebSchristos     bfd_default_scan,					\
39012573ebSchristos     bfd_arch_default_fill,				\
40012573ebSchristos     NEXT,						\
41012573ebSchristos     0 /* Maximum offset of a reloc from the start of an insn.  */ \
42012573ebSchristos   }
43012573ebSchristos 
4475fd0b74Schristos const bfd_arch_info_type bfd_epiphany16_arch =
45*e992f068Schristos   N (bfd_mach_epiphany16, "epiphany16", 1, false, NULL);
4675fd0b74Schristos 
4775fd0b74Schristos const bfd_arch_info_type bfd_epiphany_arch =
48*e992f068Schristos   N (bfd_mach_epiphany32, "epiphany32", 2, true, &bfd_epiphany16_arch);
49