Remove unnecessary elfcpp_config.h file.
[platform/upstream/binutils.git] / elfcpp / elfcpp_internal.h
1 // elfcpp_internal.h -- internals for elfcpp   -*- C++ -*-
2
3 // This is included by elfcpp.h, the external interface, but holds
4 // information which we want to keep private.
5
6 #ifndef ELFCPP_INTERNAL_H
7 #define ELFCPP_INTERNAL_H
8
9 namespace elfcpp
10 {
11
12 namespace internal
13 {
14
15 // The ELF file header.
16
17 template<int size>
18 struct Ehdr_data
19 {
20   unsigned char e_ident[EI_NIDENT];
21   Elf_Half e_type;
22   Elf_Half e_machine;
23   Elf_Word e_version;
24   typename Elf_types<size>::Elf_Addr e_entry;
25   typename Elf_types<size>::Elf_Off e_phoff;
26   typename Elf_types<size>::Elf_Off e_shoff;
27   Elf_Word e_flags;
28   Elf_Half e_ehsize;
29   Elf_Half e_phentsize;
30   Elf_Half e_phnum;
31   Elf_Half e_shentsize;
32   Elf_Half e_shnum;
33   Elf_Half e_shstrndx;
34 };
35
36 // An ELF section header.
37
38 template<int size>
39 struct Shdr_data
40 {
41   Elf_Word sh_name;
42   Elf_Word sh_type;
43   typename Elf_types<size>::Elf_WXword sh_flags;
44   typename Elf_types<size>::Elf_Addr sh_addr;
45   typename Elf_types<size>::Elf_Off sh_offset;
46   typename Elf_types<size>::Elf_WXword sh_size;
47   Elf_Word sh_link;
48   Elf_Word sh_info;
49   typename Elf_types<size>::Elf_WXword sh_addralign;
50   typename Elf_types<size>::Elf_WXword sh_entsize;
51 };
52
53 // An ELF segment header.  We use template specialization for the
54 // 32-bit and 64-bit versions because the fields are in a different
55 // order.
56
57 template<int size>
58 struct Phdr_data;
59
60 template<>
61 struct Phdr_data<32>
62 {
63   Elf_Word p_type;
64   Elf_types<32>::Elf_Off p_offset;
65   Elf_types<32>::Elf_Addr p_vaddr;
66   Elf_types<32>::Elf_Addr p_paddr;
67   Elf_Word p_filesz;
68   Elf_Word p_memsz;
69   Elf_Word p_flags;
70   Elf_Word p_align;
71 };
72
73 template<>
74 struct Phdr_data<64>
75 {
76   Elf_Word p_type;
77   Elf_Word p_flags;
78   Elf_types<64>::Elf_Off p_offset;
79   Elf_types<64>::Elf_Addr p_vaddr;
80   Elf_types<64>::Elf_Addr p_paddr;
81   Elf_Xword p_filesz;
82   Elf_Xword p_memsz;
83   Elf_Xword p_align;
84 };
85
86 // An ELF symbol table entry.  We use template specialization for the
87 // 32-bit and 64-bit versions because the fields are in a different
88 // order.
89
90 template<int size>
91 struct Sym_data;
92
93 template<>
94 struct Sym_data<32>
95 {
96   Elf_Word st_name;
97   Elf_types<32>::Elf_Addr st_value;
98   Elf_Word st_size;
99   unsigned char st_info;
100   unsigned char st_other;
101   Elf_Half st_shndx;
102 };
103
104 template<>
105 struct Sym_data<64>
106 {
107   Elf_Word st_name;
108   unsigned char st_info;
109   unsigned char st_other;
110   Elf_Half st_shndx;
111   Elf_types<64>::Elf_Addr st_value;
112   Elf_Xword st_size;
113 };
114
115 // ELF relocation table entries.
116
117 template<int size>
118 struct Rel_data
119 {
120   typename Elf_types<size>::Elf_Addr r_offset;
121   typename Elf_types<size>::Elf_WXword r_info;
122 };
123
124 template<int size>
125 struct Rela_data
126 {
127   typename Elf_types<size>::Elf_Addr r_offset;
128   typename Elf_types<size>::Elf_WXword r_info;
129   typename Elf_types<size>::Elf_Swxword r_addend;
130 };
131
132 // An entry in the ELF SHT_DYNAMIC section aka PT_DYNAMIC segment.
133
134 template<int size>
135 struct Dyn_data
136 {
137   typename Elf_types<size>::Elf_Swxword d_tag;
138   typename Elf_types<size>::Elf_WXword d_val;
139 };
140
141 // An entry in a SHT_GNU_verdef section.  This structure is the same
142 // in 32-bit and 64-bit ELF files.
143
144 struct Verdef_data
145 {
146   // Version number of structure (VER_DEF_*).
147   Elf_Half vd_version;
148   // Bit flags (VER_FLG_*).
149   Elf_Half vd_flags;
150   // Version index.
151   Elf_Half vd_ndx;
152   // Number of auxiliary Verdaux entries.
153   Elf_Half vd_cnt;
154   // Hash of name.
155   Elf_Word vd_hash;
156   // Byte offset to first Verdaux entry.
157   Elf_Word vd_aux;
158   // Byte offset to next Verdef entry.
159   Elf_Word vd_next;
160 };
161
162 // An auxiliary entry in a SHT_GNU_verdef section.  This structure is
163 // the same in 32-bit and 64-bit ELF files.
164
165 struct Verdaux_data
166 {
167   // Offset in string table of version name.
168   Elf_Word vda_name;
169   // Byte offset to next Verdaux entry.
170   Elf_Word vda_next;
171 };
172
173 // An entry in a SHT_GNU_verneed section.  This structure is the same
174 // in 32-bit and 64-bit ELF files.
175
176 struct Verneed_data
177 {
178   // Version number of structure (VER_NEED_*).
179   Elf_Half vn_version;
180   // Number of auxiliary Vernaux entries.
181   Elf_Half vn_cnt;
182   // Offset in string table of library name.
183   Elf_Word vn_file;
184   // Byte offset to first Vernaux entry.
185   Elf_Word vn_aux;
186   // Byt eoffset to next Verneed entry.
187   Elf_Word vn_next;
188 };
189
190 // An auxiliary entry in a SHT_GNU_verneed section.  This structure is
191 // the same in 32-bit and 64-bit ELF files.
192
193 struct Vernaux_data
194 {
195   // Hash of dependency name.
196   Elf_Word vna_hash;
197   // Bit flags (VER_FLG_*).
198   Elf_Half vna_flags;
199   // Version index used in SHT_GNU_versym entries.
200   Elf_Half vna_other;
201   // Offset in string table of version name.
202   Elf_Word vna_name;
203   // Byte offset to next Vernaux entry.
204   Elf_Word vna_next;
205 };
206
207 } // End namespace internal.
208
209 } // End namespace elfcpp.
210
211 #endif // !defined(ELFCPP_INTERNAL_H)