1 /* BFD library support routines for the AVR architecture. 2 Copyright 1999, 2000, 2002 Free Software Foundation, Inc. 3 Contributed by Denis Chertykov <denisc@overta.ru> 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 2 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ 20 21 #include "bfd.h" 22 #include "sysdep.h" 23 #include "libbfd.h" 24 25 static const bfd_arch_info_type *compatible 26 PARAMS ((const bfd_arch_info_type *, const bfd_arch_info_type *)); 27 28 #define N(addr_bits, machine, print, default, next) \ 29 { \ 30 8, /* 8 bits in a word */ \ 31 addr_bits, /* bits in an address */ \ 32 8, /* 8 bits in a byte */ \ 33 bfd_arch_avr, \ 34 machine, /* machine */ \ 35 "avr", /* arch_name */ \ 36 print, /* printable name */ \ 37 1, /* section align power */ \ 38 default, /* the default machine */ \ 39 compatible, \ 40 bfd_default_scan, \ 41 next \ 42 } 43 44 static const bfd_arch_info_type arch_info_struct[] = 45 { 46 /* AT90S1200, ATtiny1x, ATtiny28 */ 47 N (16, bfd_mach_avr1, "avr:1", FALSE, & arch_info_struct[1]), 48 49 /* AT90S2xxx, AT90S4xxx, AT90S8xxx, ATtiny22 */ 50 N (16, bfd_mach_avr2, "avr:2", FALSE, & arch_info_struct[2]), 51 52 /* ATmega103, ATmega603 */ 53 N (22, bfd_mach_avr3, "avr:3", FALSE, & arch_info_struct[3]), 54 55 /* ATmega83, ATmega85 */ 56 N (16, bfd_mach_avr4, "avr:4", FALSE, & arch_info_struct[4]), 57 58 /* ATmega161, ATmega163, ATmega32, AT94K */ 59 N (22, bfd_mach_avr5, "avr:5", FALSE, NULL) 60 }; 61 62 const bfd_arch_info_type bfd_avr_arch = 63 N (16, bfd_mach_avr2, "avr", TRUE, & arch_info_struct[0]); 64 65 /* This routine is provided two arch_infos and works out which AVR 66 machine which would be compatible with both and returns a pointer 67 to its info structure. */ 68 69 static const bfd_arch_info_type * 70 compatible (a,b) 71 const bfd_arch_info_type * a; 72 const bfd_arch_info_type * b; 73 { 74 /* If a & b are for different architectures we can do nothing. */ 75 if (a->arch != b->arch) 76 return NULL; 77 78 /* Special case for ATmega[16]03 (avr:3) and ATmega83 (avr:4). */ 79 if ((a->mach == bfd_mach_avr3 && b->mach == bfd_mach_avr4) 80 || (a->mach == bfd_mach_avr4 && b->mach == bfd_mach_avr3)) 81 return NULL; 82 83 /* So far all newer AVR architecture cores are supersets of previous 84 cores. */ 85 if (a->mach <= b->mach) 86 return b; 87 88 if (a->mach >= b->mach) 89 return a; 90 91 /* Never reached! */ 92 return NULL; 93 } 94