2001-06-02 H.J. Lu <hjl@gnu.org>
[platform/upstream/binutils.git] / bfd / cpu-hppa.c
1 /* BFD support for the HP Precision Architecture architecture.
2    Copyright 1992, 1995, 1998, 1999, 2000 Free Software Foundation, Inc.
3
4 This file is part of BFD, the Binary File Descriptor library.
5
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
10
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
19
20 #include "bfd.h"
21 #include "sysdep.h"
22 #include "libbfd.h"
23
24 static const bfd_arch_info_type bfd_hppa10_arch =
25 {
26   32,                           /* 32 bits in a word */
27   32,                           /* 32 bits in an address */
28   8,                            /* 8 bits in a byte */
29   bfd_arch_hppa,
30   10,                           /* By convention PA1.0 = 10 */
31   "hppa",
32   "hppa1.0",
33   3,
34   true,                         /* Unless we use 1.1 specific features */
35   bfd_default_compatible,
36   bfd_default_scan ,
37   0,
38 };
39
40 /* PA2.0 in narrow mode */
41 static const bfd_arch_info_type bfd_hppa20_arch =
42 {
43   32,                           /* 32 bits in a word */
44   32,                           /* 32 bits in an address */
45   8,                            /* 8 bits in a byte */
46   bfd_arch_hppa,
47   20,                           /* By convention PA1.0 = 10 */
48   "hppa",
49   "hppa2.0",
50   3,
51   false,                        /* Unless we use 1.1 specific features */
52   bfd_default_compatible,
53   bfd_default_scan ,
54   &bfd_hppa10_arch,
55 };
56
57 /* PA2.0 in wide mode */
58 static const bfd_arch_info_type bfd_hppa20w_arch =
59 {
60   64,                           /* 32 bits in a word */
61   64,                           /* 32 bits in an address */
62   8,                            /* 8 bits in a byte */
63   bfd_arch_hppa,
64   25,                           /* ??? How best to describe wide mode here?  */
65   "hppa",
66   "hppa2.0w",
67   3,
68   false,                        /* Unless we use 1.1 specific features */
69   bfd_default_compatible,
70   bfd_default_scan ,
71   &bfd_hppa20_arch,
72 };
73
74 const bfd_arch_info_type bfd_hppa_arch =
75 {
76   32,                           /* 32 bits in a word */
77   32,                           /* 32 bits in an address */
78   8,                            /* 8 bits in a byte */
79   bfd_arch_hppa,
80   11,                           /* By convention PA1.1 = 11 */
81   "hppa",
82   "hppa1.1",
83   3,
84   false,                        /* 1.1 specific features used */
85   bfd_default_compatible,
86   bfd_default_scan ,
87   &bfd_hppa20w_arch,
88 };