merge from gcc
[platform/upstream/binutils.git] / bfd / cpu-hppa.c
1 /* BFD support for the HP Precision Architecture architecture.
2    Copyright 1992, 1995, 1998, 1999, 2000, 2002, 2003, 2005, 2007
3    Free Software Foundation, Inc.
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_hppa10_arch =
27 {
28   32,                           /* 32 bits in a word */
29   32,                           /* 32 bits in an address */
30   8,                            /* 8 bits in a byte */
31   bfd_arch_hppa,
32   bfd_mach_hppa10,              /* By convention PA1.0 = 10 */
33   "hppa",
34   "hppa1.0",
35   3,
36   TRUE,                         /* Unless we use 1.1 specific features */
37   bfd_default_compatible,
38   bfd_default_scan ,
39   0,
40 };
41
42 /* PA2.0 in narrow mode */
43 static const bfd_arch_info_type bfd_hppa20_arch =
44 {
45   32,                           /* 32 bits in a word */
46   32,                           /* 32 bits in an address */
47   8,                            /* 8 bits in a byte */
48   bfd_arch_hppa,
49   bfd_mach_hppa20,              /* By convention PA2.0 = 20 */
50   "hppa",
51   "hppa2.0",
52   3,
53   FALSE,                        /* Unless we use 1.1 specific features */
54   bfd_default_compatible,
55   bfd_default_scan ,
56   &bfd_hppa10_arch,
57 };
58
59 /* PA2.0 in wide mode */
60 static const bfd_arch_info_type bfd_hppa20w_arch =
61 {
62   64,                           /* 64 bits in a word */
63   64,                           /* 64 bits in an address */
64   8,                            /* 8 bits in a byte */
65   bfd_arch_hppa,
66   bfd_mach_hppa20w,             /* ??? How best to describe wide mode here?  */
67   "hppa",
68   "hppa2.0w",
69   3,
70   FALSE,                        /* Unless we use 1.1 specific features */
71   bfd_default_compatible,
72   bfd_default_scan ,
73   &bfd_hppa20_arch,
74 };
75
76 const bfd_arch_info_type bfd_hppa_arch =
77 {
78   32,                           /* 32 bits in a word */
79   32,                           /* 32 bits in an address */
80   8,                            /* 8 bits in a byte */
81   bfd_arch_hppa,
82   bfd_mach_hppa11,              /* By convention PA1.1 = 11 */
83   "hppa",
84   "hppa1.1",
85   3,
86   FALSE,                        /* 1.1 specific features used */
87   bfd_default_compatible,
88   bfd_default_scan ,
89   &bfd_hppa20w_arch,
90 };