diff options
Diffstat (limited to 'bfd/cpu-xc16x.c')
-rw-r--r-- | bfd/cpu-xc16x.c | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/bfd/cpu-xc16x.c b/bfd/cpu-xc16x.c new file mode 100644 index 0000000..1156900 --- /dev/null +++ b/bfd/cpu-xc16x.c @@ -0,0 +1,73 @@ +/* BFD support for the Infineon XC16X Microcontroller. + Copyright 2006 Free Software Foundation, Inc. + Contributed by KPIT Cummins Infosystems + + This file is part of BFD, the Binary File Descriptor library. + Contributed by Anil Paranjpe(anilp1@kpitcummins.com) + + 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 2 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, 51 Franklin Street - Fifth Floor, Boston, MA + 02110-1301, USA. */ + +#include "bfd.h" +#include "sysdep.h" +#include "libbfd.h" + +const bfd_arch_info_type xc16xs_info_struct = +{ + 16, /* Bits per word. */ + 16, /* Bits per address. */ + 8, /* Bits per byte. */ + bfd_arch_xc16x, /* Architecture. */ + bfd_mach_xc16xs, /* Machine. */ + "xc16x", /* Architecture name. */ + "xc16xs", /* Printable name. */ + 1, /* Section alignment - 16 bit. */ + TRUE, /* The default ? */ + bfd_default_compatible, /* Architecture comparison fn. */ + bfd_default_scan, /* String to architecture convert fn. */ + NULL /* Next in list. */ +}; + +const bfd_arch_info_type xc16xl_info_struct = +{ + 16, /* Bits per word. */ + 32, /* Bits per address. */ + 8, /* Bits per byte. */ + bfd_arch_xc16x, /* Architecture. */ + bfd_mach_xc16xl, /* Machine. */ + "xc16x", /* Architecture name. */ + "xc16xl", /* Printable name. */ + 1, /* Section alignment - 16 bit. */ + TRUE, /* The default ? */ + bfd_default_compatible, /* Architecture comparison fn. */ + bfd_default_scan, /* String to architecture convert fn. */ + & xc16xs_info_struct /* Next in list. */ +}; + +const bfd_arch_info_type bfd_xc16x_arch = +{ + 16, /* Bits per word. */ + 16, /* Bits per address. */ + 8, /* Bits per byte. */ + bfd_arch_xc16x, /* Architecture. */ + bfd_mach_xc16x, /* Machine. */ + "xc16x", /* Architecture name. */ + "xc16x", /* Printable name. */ + 1, /* Section alignment - 16 bit. */ + TRUE, /* The default ? */ + bfd_default_compatible, /* Architecture comparison fn. */ + bfd_default_scan, /* String to architecture convert fn. */ + & xc16xl_info_struct /* Next in list. */ +}; |