aboutsummaryrefslogtreecommitdiff
path: root/include/elf/hppa.h
blob: 2952e2398d290076cf4b5678d2767d53de551a18 (plain)
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 */