LIEF: Library to Instrument Executable Formats Version 1.0.0
Loading...
Searching...
No Matches
ELF/Parser.hpp
Go to the documentation of this file.
1/* Copyright 2017 - 2026 R. Thomas
2 * Copyright 2017 - 2026 Quarkslab
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16#ifndef LIEF_ELF_PARSER_H
17#define LIEF_ELF_PARSER_H
18#include <unordered_map>
19
20#include "LIEF/visibility.h"
21#include "LIEF/utils.hpp"
22
24#include "LIEF/errors.hpp"
25
27
28namespace LIEF {
29class BinaryStream;
30
31namespace OAT {
32class Parser;
33}
34namespace ELF {
35
36class Section;
37class Binary;
38class Segment;
39class Symbol;
40class Note;
41class Relocation;
42
45 friend class OAT::Parser;
46
47 public:
48 static constexpr uint32_t NB_MAX_SYMBOLS = 1000000;
49 static constexpr uint32_t DELTA_NB_SYMBOLS = 3000;
50 static constexpr uint32_t NB_MAX_BUCKETS = NB_MAX_SYMBOLS;
51 static constexpr uint32_t NB_MAX_CHAINS = 1000000;
52 static constexpr uint32_t NB_MAX_SEGMENTS = 10000;
53 static constexpr uint32_t NB_MAX_RELOCATIONS = 3000000;
54 static constexpr uint32_t NB_MAX_DYNAMIC_ENTRIES = 1000;
55 static constexpr uint32_t MAX_SEGMENT_SIZE = 3_GB;
56
62
72 static std::unique_ptr<Binary>
73 parse(const std::string& file,
74 const ParserConfig& conf = ParserConfig::all());
75
86 static std::unique_ptr<Binary>
87 parse(const std::vector<uint8_t>& data,
88 const ParserConfig& conf = ParserConfig::all());
89
100 static std::unique_ptr<Binary>
101 parse(std::unique_ptr<BinaryStream> stream,
102 const ParserConfig& conf = ParserConfig::all());
103
104 Parser& operator=(const Parser&) = delete;
105 Parser(const Parser&) = delete;
106
107 ~Parser() override;
108
109 protected:
111 LIEF_LOCAL Parser(std::unique_ptr<BinaryStream> stream, ParserConfig config);
112 LIEF_LOCAL Parser(const std::string& file, ParserConfig config);
113 LIEF_LOCAL Parser(const std::vector<uint8_t>& data, ParserConfig config);
114
115 LIEF_LOCAL ok_error_t init();
116
117 LIEF_LOCAL bool should_swap() const;
118
119 // map, dynamic_symbol.version <----> symbol_version
120 // symbol_version comes from symbol_version table
121 LIEF_LOCAL void link_symbol_version();
122
123 LIEF_LOCAL ok_error_t link_symbol_section(Symbol& sym);
124
125 template<typename ELF_T>
126 LIEF_LOCAL ok_error_t parse_binary();
127
128 template<typename ELF_T>
129 LIEF_LOCAL ok_error_t parse_header();
130
131 template<typename ELF_T>
132 LIEF_LOCAL ok_error_t parse_sections();
133
134 template<typename ELF_T>
135 LIEF_LOCAL ok_error_t parse_segments();
136
137 LIEF_LOCAL uint64_t
138 get_dynamic_string_table(BinaryStream* stream = nullptr) const;
139
141 get_dynamic_string_table_from_segments(BinaryStream* stream = nullptr) const;
142
143 LIEF_LOCAL uint64_t get_dynamic_string_table_from_sections() const;
144
146 template<typename ELF_T>
148 get_numberof_dynamic_symbols(ParserConfig::DYNSYM_COUNT mtd) const;
149
151 template<typename ELF_T>
152 LIEF_LOCAL result<uint32_t> nb_dynsym_hash() const;
153
155 template<typename ELF_T>
156 LIEF_LOCAL result<uint32_t> nb_dynsym_sysv_hash() const;
157
159 template<typename ELF_T>
160 LIEF_LOCAL result<uint32_t> nb_dynsym_gnu_hash() const;
161
163 template<typename ELF_T>
164 LIEF_LOCAL result<uint32_t> nb_dynsym_section() const;
165
167 template<typename ELF_T>
168 LIEF_LOCAL result<uint32_t> nb_dynsym_relocations() const;
169
170 template<typename ELF_T>
171 LIEF_LOCAL ok_error_t parse_dynamic_entries(BinaryStream& stream);
172
173 template<typename ELF_T>
174 LIEF_LOCAL ok_error_t parse_dynamic_symbols(uint64_t offset);
175
185 template<typename ELF_T>
186 LIEF_LOCAL ok_error_t parse_symtab_symbols(const Section& symtab_section,
187 const Section& string_section);
188
192 template<typename ELF_T, typename REL_T>
193 LIEF_LOCAL ok_error_t parse_dynamic_relocations(uint64_t relocations_offset,
194 uint64_t size);
195
201 template<typename ELF_T, typename REL_T>
202 LIEF_LOCAL ok_error_t parse_pltgot_relocations(uint64_t offset, uint64_t size);
203
204
206 template<typename ELF_T>
207 LIEF_LOCAL ok_error_t parse_relative_relocations(uint64_t offset, uint64_t size);
208
210 template<typename ELF_T>
211 LIEF_LOCAL ok_error_t parse_packed_relocations(uint64_t offset, uint64_t size);
212
213 template<typename ELF_T>
214 LIEF_LOCAL ok_error_t process_dynamic_table();
215
218 template<typename ELF_T, typename REL_T>
219 LIEF_LOCAL ok_error_t parse_section_relocations(const Section& section);
220
226 template<typename ELF_T>
227 LIEF_LOCAL ok_error_t parse_symbol_version_requirement(uint64_t offset,
228 uint32_t nb_entries);
229
230
236 template<typename ELF_T>
237 LIEF_LOCAL ok_error_t parse_symbol_version_definition(uint64_t offset,
238 uint32_t nb_entries);
239
240
247 LIEF_LOCAL ok_error_t parse_symbol_version(uint64_t symbol_version_offset);
248
252 template<typename ELF_T>
253 LIEF_LOCAL ok_error_t parse_symbol_gnu_hash(uint64_t offset);
254
256 LIEF_LOCAL ok_error_t parse_notes(uint64_t offset, uint64_t size);
257
258 LIEF_LOCAL std::unique_ptr<Note> get_note(uint32_t type, std::string name,
259 std::vector<uint8_t> desc_bytes);
260
262 LIEF_LOCAL ok_error_t parse_symbol_sysv_hash(uint64_t offset);
263
264 LIEF_LOCAL ok_error_t parse_overlay();
265
266 template<typename ELF_T, typename REL_T>
267 LIEF_LOCAL uint32_t max_relocation_index(uint64_t relocations_offset,
268 uint64_t size) const;
269
271 LIEF_LOCAL static bool check_section_in_segment(const Section& section,
272 const Segment& segment);
273
274 LIEF_LOCAL bool bind_symbol(Relocation& R);
275 LIEF_LOCAL Relocation& insert_relocation(std::unique_ptr<Relocation> R);
276
277 template<class ELF_T>
278 LIEF_LOCAL ok_error_t parse_dyn_table(Segment& pt_dyn);
279
280 std::unique_ptr<BinaryStream> stream_;
281 std::unique_ptr<Binary> binary_;
282 ParserConfig config_;
283 /*
284 * parse_sections() may skip some sections so that
285 * binary_->sections_ is not contiguous based on the index of the sections.
286 *
287 * On the other hand, we need these indexes to bind symbols that
288 * reference sections. That's why we have this unordered_map.
289 */
290 std::unordered_map<size_t, Section*> sections_idx_;
291};
292
293} // namespace ELF
294} // namespace LIEF
295#endif
Class that is used to a read stream of data from different sources.
Definition BinaryStream.hpp:33
Generic interface representing a binary executable.
Definition Abstract/Binary.hpp:59
static constexpr uint32_t NB_MAX_BUCKETS
Definition ELF/Parser.hpp:50
friend class OAT::Parser
Definition ELF/Parser.hpp:45
static constexpr uint32_t NB_MAX_SYMBOLS
Definition ELF/Parser.hpp:48
static std::unique_ptr< Binary > parse(std::unique_ptr< BinaryStream > stream, const ParserConfig &conf=ParserConfig::all())
Parse the ELF binary from the given stream and return a LIEF::ELF::Binary object.
static constexpr uint32_t DELTA_NB_SYMBOLS
Definition ELF/Parser.hpp:49
static constexpr uint32_t NB_MAX_RELOCATIONS
Definition ELF/Parser.hpp:53
static std::unique_ptr< Binary > parse(const std::vector< uint8_t > &data, const ParserConfig &conf=ParserConfig::all())
Parse the given raw data as an ELF binary and return a LIEF::ELF::Binary object.
static std::unique_ptr< Binary > parse(const std::string &file, const ParserConfig &conf=ParserConfig::all())
Parse an ELF file and return a LIEF::ELF::Binary object.
static constexpr uint32_t NB_MAX_CHAINS
Definition ELF/Parser.hpp:51
~Parser() override
ELF_TYPE
Definition ELF/Parser.hpp:57
@ ELF64
Definition ELF/Parser.hpp:60
@ ELF_UNKNOWN
Definition ELF/Parser.hpp:58
@ ELF32
Definition ELF/Parser.hpp:59
static constexpr uint32_t MAX_SEGMENT_SIZE
Definition ELF/Parser.hpp:55
Parser(const Parser &)=delete
Parser & operator=(const Parser &)=delete
static constexpr uint32_t NB_MAX_SEGMENTS
Definition ELF/Parser.hpp:52
static constexpr uint32_t NB_MAX_DYNAMIC_ENTRIES
Definition ELF/Parser.hpp:54
Class that represents an ELF relocation.
Definition ELF/Relocation.hpp:40
Class which represents an ELF Section.
Definition ELF/Section.hpp:48
Class which represents the ELF segments.
Definition Segment.hpp:48
Class which represents an ELF symbol.
Definition ELF/Symbol.hpp:35
Class to parse an OAT file to produce an OAT::Binary.
Definition OAT/Parser.hpp:38
Main interface to parse an executable regardless of its format.
Definition Abstract/Parser.hpp:30
Class which represents an abstracted Relocation.
Definition Abstract/Relocation.hpp:27
Class which represents an abstracted section.
Definition Abstract/Section.hpp:29
This class represents a symbol in an executable format.
Definition Abstract/Symbol.hpp:28
Opaque structure that is used by LIEF to avoid writing result<void> f(...). Instead,...
Definition errors.hpp:117
Wrapper that contains an Object (T) or an error.
Definition errors.hpp:77
Namespace related to the LIEF's ELF module.
Definition Abstract/Header.hpp:28
Definition ELF/Parser.hpp:31
LIEF namespace.
Definition Abstract/Binary.hpp:40
This structure is used to tweak the ELF Parser (ELF::Parser).
Definition ELF/ParserConfig.hpp:26
DYNSYM_COUNT
Methods that can be used by the LIEF::ELF::Parser to count the number of dynamic symbols.
Definition ELF/ParserConfig.hpp:29
static ParserConfig all()
This returns a ParserConfig object configured to process all the ELF elements.
Definition ELF/ParserConfig.hpp:45
#define LIEF_API
Definition visibility.h:45
#define LIEF_LOCAL
Definition visibility.h:46