Automatic date update in version.in
[external/binutils.git] / bfd / cpu-hppa.c
1 /* BFD support for the HP Precision Architecture architecture.
2    Copyright (C) 1992-2019 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 3 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., 51 Franklin Street - Fifth Floor, Boston,
19    MA 02110-1301, USA.  */
20
21 #include "sysdep.h"
22 #include "bfd.h"
23 #include "libbfd.h"
24
25 static const bfd_arch_info_type bfd_hppa10_arch =
26 {
27   32,                           /* 32 bits in a word */
28   32,                           /* 32 bits in an address */
29   8,                            /* 8 bits in a byte */
30   bfd_arch_hppa,
31   bfd_mach_hppa10,              /* By convention PA1.0 = 10 */
32   "hppa",
33   "hppa1.0",
34   3,
35   TRUE,                         /* Unless we use 1.1 specific features */
36   bfd_default_compatible,
37   bfd_default_scan,
38   bfd_arch_default_fill,
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_arch_default_fill,
57   &bfd_hppa10_arch,
58 };
59
60 /* PA2.0 in wide mode */
61 static const bfd_arch_info_type bfd_hppa20w_arch =
62 {
63   64,                           /* 64 bits in a word */
64   64,                           /* 64 bits in an address */
65   8,                            /* 8 bits in a byte */
66   bfd_arch_hppa,
67   bfd_mach_hppa20w,             /* ??? How best to describe wide mode here?  */
68   "hppa",
69   "hppa2.0w",
70   3,
71   FALSE,                        /* Unless we use 1.1 specific features */
72   bfd_default_compatible,
73   bfd_default_scan,
74   bfd_arch_default_fill,
75   &bfd_hppa20_arch,
76 };
77
78 const bfd_arch_info_type bfd_hppa_arch =
79 {
80   32,                           /* 32 bits in a word */
81   32,                           /* 32 bits in an address */
82   8,                            /* 8 bits in a byte */
83   bfd_arch_hppa,
84   bfd_mach_hppa11,              /* By convention PA1.1 = 11 */
85   "hppa",
86   "hppa1.1",
87   3,
88   FALSE,                        /* 1.1 specific features used */
89   bfd_default_compatible,
90   bfd_default_scan,
91   bfd_arch_default_fill,
92   &bfd_hppa20w_arch,
93 };