* Makefile.am ($(MKDOC)): Append $(EXEEXT_FOR_BUILD) to temp file.
[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   bfd_arch_default_fill,
40   0,
41 };
42
43 /* PA2.0 in narrow mode */
44 static const bfd_arch_info_type bfd_hppa20_arch =
45 {
46   32,                           /* 32 bits in a word */
47   32,                           /* 32 bits in an address */
48   8,                            /* 8 bits in a byte */
49   bfd_arch_hppa,
50   bfd_mach_hppa20,              /* By convention PA2.0 = 20 */
51   "hppa",
52   "hppa2.0",
53   3,
54   FALSE,                        /* Unless we use 1.1 specific features */
55   bfd_default_compatible,
56   bfd_default_scan,
57   bfd_arch_default_fill,
58   &bfd_hppa10_arch,
59 };
60
61 /* PA2.0 in wide mode */
62 static const bfd_arch_info_type bfd_hppa20w_arch =
63 {
64   64,                           /* 64 bits in a word */
65   64,                           /* 64 bits in an address */
66   8,                            /* 8 bits in a byte */
67   bfd_arch_hppa,
68   bfd_mach_hppa20w,             /* ??? How best to describe wide mode here?  */
69   "hppa",
70   "hppa2.0w",
71   3,
72   FALSE,                        /* Unless we use 1.1 specific features */
73   bfd_default_compatible,
74   bfd_default_scan,
75   bfd_arch_default_fill,
76   &bfd_hppa20_arch,
77 };
78
79 const bfd_arch_info_type bfd_hppa_arch =
80 {
81   32,                           /* 32 bits in a word */
82   32,                           /* 32 bits in an address */
83   8,                            /* 8 bits in a byte */
84   bfd_arch_hppa,
85   bfd_mach_hppa11,              /* By convention PA1.1 = 11 */
86   "hppa",
87   "hppa1.1",
88   3,
89   FALSE,                        /* 1.1 specific features used */
90   bfd_default_compatible,
91   bfd_default_scan,
92   bfd_arch_default_fill,
93   &bfd_hppa20w_arch,
94 };