1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
|
/* HPPA ELF support for BFD.
Copyright (C) 1993, 1994 Free Software Foundation, Inc.
This file is part of BFD, the Binary File Descriptor library.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
/* This file holds definitions specific to the HPPA ELF ABI. Note
that most of this is not actually implemented by BFD. */
#ifndef _ELF_HPPA_H
#define _ELF_HPPA_H
/* Processor specific flags for the ELF header e_flags field. */
/* Target processor IDs to be placed in the low 16 bits of the flags
field. Note these names are shared with SOM, and therefore do not
follow ELF naming conventions. */
/* PA 1.0 big endian. */
#ifndef CPU_PA_RISC1_0
#define CPU_PA_RISC1_0 0x0000020b
#endif
/* PA 1.1 big endian. */
#ifndef CPU_PA_RISC1_1
#define CPU_PA_RISC1_1 0x00000210
#endif
/* PA 1.0 little endian (unsupported) is 0x0000028b. */
/* PA 1.1 little endian (unsupported) is 0x00000290. */
/* Trap null address dereferences. */
#define ELF_PARISC_TRAPNIL 0x00010000
/* .PARISC.archext section is present. */
#define EF_PARISC_EXT 0x00020000
/* Processor specific section types. */
/* Holds the global offset table, a table of pointers to external
data. */
#define SHT_PARISC_GOT SHT_LOPROC+0
/* Nonloadable section containing information in architecture
extensions used by the code. */
#define SHT_PARISC_ARCH SHT_LOPROC+1
/* Section in which $global$ is defined. */
#define SHT_PARISC_GLOBAL SHT_LOPROC+2
/* Section holding millicode routines (mul, div, rem, dyncall, etc. */
#define SHT_PARISC_MILLI SHT_LOPROC+3
/* Section holding unwind information for use by debuggers. */
#define SHT_PARISC_UNWIND SHT_LOPROC+4
/* Section holding the procedure linkage table. */
#define SHT_PARISC_PLT SHT_LOPROC+5
/* Short initialized and uninitialized data. */
#define SHT_PARISC_SDATA SHT_LOPROC+6
#define SHT_PARISC_SBSS SHT_LOPROC+7
/* Optional section holding argument location/relocation info. */
#define SHT_PARISC_SYMEXTN SHT_LOPROC+8
/* Option section for linker stubs. */
#define SHT_PARISC_STUBS SHT_LOPROC+9
/* Processor specific section flags. */
/* This section is near the global data pointer and thus allows short
addressing modes to be used. */
#define SHF_PARISC_SHORT 0x20000000
/* Processor specific symbol types. */
/* Millicode function entry point. */
#define STT_PARISC_MILLICODE STT_LOPROC+0
/* ELF/HPPA relocation types */
#include "reloc-macros.h"
START_RELOC_NUMBERS (elf32_hppa_reloc_type)
RELOC_NUMBER (R_PARISC_NONE, 0) /* No reloc */
/* These relocation types do simple base + offset relocations. */
RELOC_NUMBER (R_PARISC_DIR32, 0x01)
RELOC_NUMBER (R_PARISC_DIR21L, 0x02)
RELOC_NUMBER (R_PARISC_DIR17R, 0x03)
RELOC_NUMBER (R_PARISC_DIR17F, 0x04)
RELOC_NUMBER (R_PARISC_DIR14R, 0x06)
/* PC-relative relocation types
Typically used for calls.
Note PCREL17C and PCREL17F differ only in overflow handling.
PCREL17C never reports a relocation error.
When supporting argument relocations, function calls must be
accompanied by parameter relocation information. This information is
carried in the ten high-order bits of the addend field. The remaining
22 bits of of the addend field are sign-extended to form the Addend.
Note the code to build argument relocations depends on the
addend being zero. A consequence of this limitation is GAS
can not perform relocation reductions for function symbols. */
RELOC_NUMBER (R_PARISC_PCREL21L, 0x0a)
RELOC_NUMBER (R_PARISC_PCREL17R, 0x0b)
RELOC_NUMBER (R_PARISC_PCREL17F, 0x0c)
RELOC_NUMBER (R_PARISC_PCREL17C, 0x0d)
RELOC_NUMBER (R_PARISC_PCREL14R, 0x0e)
RELOC_NUMBER (R_PARISC_PCREL14F, 0x0f)
/* DP-relative relocation types. */
RELOC_NUMBER (R_PARISC_DPREL21L, 0x12)
RELOC_NUMBER (R_PARISC_DPREL14R, 0x16)
RELOC_NUMBER (R_PARISC_DPREL14F, 0x17)
/* Data linkage table (DLT) relocation types
SOM DLT_REL fixup requests are used to for static data references
from position-independent code within shared libraries. They are
similar to the GOT relocation types in some SVR4 implementations. */
RELOC_NUMBER (R_PARISC_DLTREL21L, 0x1a)
RELOC_NUMBER (R_PARISC_DLTREL14R, 0x1e)
RELOC_NUMBER (R_PARISC_DLTREL14F, 0x1f)
/* DLT indirect relocation types */
RELOC_NUMBER (R_PARISC_DLTIND21L, 0x22)
RELOC_NUMBER (R_PARISC_DLTIND14R, 0x26)
RELOC_NUMBER (R_PARISC_DLTIND14F, 0x27)
/* Base relative relocation types. Ugh. These imply lots of state */
RELOC_NUMBER (R_PARISC_SETBASE, 0x28)
RELOC_NUMBER (R_PARISC_BASEREL32, 0x29)
RELOC_NUMBER (R_PARISC_BASEREL21L, 0x2a)
RELOC_NUMBER (R_PARISC_BASEREL17R, 0x2b)
RELOC_NUMBER (R_PARISC_BASEREL17F, 0x2c)
RELOC_NUMBER (R_PARISC_BASEREL14R, 0x2e)
RELOC_NUMBER (R_PARISC_BASEREL14F, 0x2f)
/* Segment relative relocation types. */
RELOC_NUMBER (R_PARISC_TEXTREL32, 0x31)
RELOC_NUMBER (R_PARISC_DATAREL32, 0x39)
/* Plabel relocation types. */
RELOC_NUMBER (R_PARISC_PLABEL32, 0x41)
RELOC_NUMBER (R_PARISC_PLABEL21L, 0x42)
RELOC_NUMBER (R_PARISC_PLABEL14R, 0x46)
/* PLT relocations. */
RELOC_NUMBER (R_PARISC_PLTIND21L, 0x82)
RELOC_NUMBER (R_PARISC_PLTIND14R, 0x86)
RELOC_NUMBER (R_PARISC_PLTIND14F, 0x87)
/* Misc relocation types. */
RELOC_NUMBER (R_PARISC_COPY, 0x88)
RELOC_NUMBER (R_PARISC_GLOB_DAT, 0x89)
RELOC_NUMBER (R_PARISC_JMP_SLOT, 0x8a)
RELOC_NUMBER (R_PARISC_RELATIVE, 0x8b)
EMPTY_RELOC (R_PARISC_UNIMPLEMENTED)
END_RELOC_NUMBERS
#ifndef RELOC_MACROS_GEN_FUNC
typedef enum elf32_hppa_reloc_type elf32_hppa_reloc_type;
#endif
#endif /* _ELF_HPPA_H */
|