LIEF: Library to Instrument Executable Formats Version 1.0.0
Loading...
Searching...
No Matches
ELF/Binary.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_BINARY_H
17#define LIEF_ELF_BINARY_H
18
19#include <vector>
20#include <memory>
21
22#include "LIEF/visibility.h"
23#include "LIEF/errors.hpp"
24#include "LIEF/iterators.hpp"
25
27
28#include "LIEF/ELF/Note.hpp"
30#include "LIEF/ELF/Header.hpp"
31#include "LIEF/ELF/Section.hpp"
32#include "LIEF/ELF/Segment.hpp"
33#include "LIEF/ELF/Builder.hpp"
34
35namespace LIEF {
37namespace ELF {
38namespace DataHandler {
39class Handler;
40}
41
42class ExeLayout;
43class GnuHash;
44class Layout;
45class ObjectFileLayout;
46class Parser;
47class Relocation;
48class Section;
49class Segment;
50class Symbol;
51class SymbolVersion;
55class SysvHash;
56struct sizing_info_t;
57
60 friend class Parser;
61 friend class Builder;
62 friend class ExeLayout;
63 friend class Layout;
64 friend class ObjectFileLayout;
65
66 public:
67 using string_list_t = std::vector<std::string>;
68
70 using notes_t = std::vector<std::unique_ptr<Note>>;
71
74
77
80 std::vector<std::unique_ptr<SymbolVersionRequirement>>;
81
85
90
93 std::vector<std::unique_ptr<SymbolVersionDefinition>>;
94
98
103
105 using segments_t = std::vector<std::unique_ptr<Segment>>;
106
109
112
114 using dynamic_entries_t = std::vector<std::unique_ptr<DynamicEntry>>;
115
118
122
124 using symbols_version_t = std::vector<std::unique_ptr<SymbolVersion>>;
125
128
132
134 using relocations_t = std::vector<std::unique_ptr<Relocation>>;
135
138
142
146
151
154
158
161
165
167 using symbols_t = std::vector<std::unique_ptr<Symbol>>;
168
171
175
178
182
185
188
191
194
197
200
202 using sections_t = std::vector<std::unique_ptr<Section>>;
203
206
209
210 public:
243
246 enum class SEC_INSERT_POS {
248 AUTO = 0,
249
255 POST_SEGMENT,
256
260 POST_SECTION,
261 };
262
263 public:
264 Binary& operator=(const Binary&) = delete;
265 Binary(const Binary& copy) = delete;
266
269 return type_;
270 }
271
274 return header_;
275 }
276
278 return header_;
279 }
280
283 uint64_t last_offset_section() const;
284
287 uint64_t last_offset_segment() const;
288
290 uint64_t next_virtual_address() const;
291
294 return sections_;
295 }
296
298 return sections_;
299 }
300
302 uint64_t entrypoint() const override {
303 return header_.entrypoint();
304 }
305
308 return segments_;
309 }
310
312 return segments_;
313 }
314
317 return dynamic_entries_;
318 }
319
321 return dynamic_entries_;
322 }
323
326
329
331 void remove(const DynamicEntry& entry);
332
335
341 void remove(const Section& section, bool clear = false);
342
344 void remove(const Note& note);
345
348
351 void remove(const Segment& seg, bool clear = false);
352
357 void remove(Segment::TYPE type, bool clear = false);
358
362 return dynamic_symbols_;
363 }
364
366 return dynamic_symbols_;
367 }
368
372
376
379 return symtab_symbols_;
380 }
381
383 return symtab_symbols_;
384 }
385
388 return symbol_version_table_;
389 }
391 return symbol_version_table_;
392 }
393
396 return symbol_version_definition_;
397 }
398
399 it_const_symbols_version_definition
401 return symbol_version_definition_;
402 }
403
406 return symbol_version_requirements_;
407 }
408
409 it_const_symbols_version_requirement
411 return symbol_version_requirements_;
412 }
413
417
425
432
441 const Section& section);
442
446
450
453 return relocations_;
454 }
455
457 return relocations_;
458 }
459
462 const Relocation* get_relocation(uint64_t address) const LIEF_LIFETIMEBOUND;
464 return const_cast<Relocation*>(
465 static_cast<const Binary*>(this)->get_relocation(address)
466 );
467 }
468
473 return const_cast<Relocation*>(
474 static_cast<const Binary*>(this)->get_relocation(symbol)
475 );
476 }
477
480 const Relocation*
481 get_relocation(const std::string& symbol_name) const LIEF_LIFETIMEBOUND;
482 Relocation* get_relocation(const std::string& symbol_name) LIEF_LIFETIMEBOUND {
483 return const_cast<Relocation*>(
484 static_cast<const Binary*>(this)->get_relocation(symbol_name)
485 );
486 }
487
491 bool use_gnu_hash() const {
492 return gnu_hash_ != nullptr && has(DynamicEntry::TAG::GNU_HASH);
493 }
494
498 return use_gnu_hash() ? gnu_hash_.get() : nullptr;
499 }
500
504 bool use_sysv_hash() const {
505 return sysv_hash_ != nullptr && has(DynamicEntry::TAG::HASH);
506 }
507
511 return use_sysv_hash() ? sysv_hash_.get() : nullptr;
512 }
513
515 bool has_section(const std::string& name) const {
516 return get_section(name) != nullptr;
517 }
518
520 bool has_section_with_offset(uint64_t offset) const;
521
523 bool has_section_with_va(uint64_t va) const;
524
527 Section* get_section(const std::string& name) LIEF_LIFETIMEBOUND {
528 return const_cast<Section*>(
529 static_cast<const Binary*>(this)->get_section(name)
530 );
531 }
532 const Section* get_section(const std::string& name) const LIEF_LIFETIMEBOUND;
533
537 return get_section(".text");
538 }
539
543
547
551
556 uint64_t imagebase() const override;
557
559 uint64_t virtual_size() const override;
560
563 bool has_interpreter() const;
564
569 const std::string& interpreter() const {
570 return interpreter_;
571 }
572
574 void interpreter(const std::string& interpreter) {
575 interpreter_ = interpreter;
576 }
577
580 return symtab_dyn_symbols();
581 }
582
584 return symtab_dyn_symbols();
585 }
586
589
591 Symbol& export_symbol(const std::string& symbol_name,
592 uint64_t value = 0) LIEF_LIFETIMEBOUND;
593
596 bool has_dynamic_symbol(const std::string& name) const {
597 return get_dynamic_symbol(name) != nullptr;
598 }
599
602 const Symbol*
603 get_dynamic_symbol(const std::string& name) const LIEF_LIFETIMEBOUND;
604
605 Symbol* get_dynamic_symbol(const std::string& name) LIEF_LIFETIMEBOUND {
606 return const_cast<Symbol*>(
607 static_cast<const Binary*>(this)->get_dynamic_symbol(name)
608 );
609 }
610
612 bool has_symtab_symbol(const std::string& name) const {
613 return get_symtab_symbol(name) != nullptr;
614 }
615
618 const Symbol*
619 get_symtab_symbol(const std::string& name) const LIEF_LIFETIMEBOUND;
620
621 Symbol* get_symtab_symbol(const std::string& name) LIEF_LIFETIMEBOUND {
622 return const_cast<Symbol*>(
623 static_cast<const Binary*>(this)->get_symtab_symbol(name)
624 );
625 }
626
630 string_list_t strings(size_t min_size = 5) const;
631
637 void remove_symbol(const std::string& name);
638
640 void remove_symtab_symbol(const std::string& name);
642
644 void remove_dynamic_symbol(const std::string& name);
645
652
655 get_function_address(const std::string& func_name) const override;
656
658 //
661 result<uint64_t> get_function_address(const std::string& func_name,
662 bool demangled) const;
663
675 Section* add(const Section& section, bool loaded = true,
677
678 Section* extend(const Section& section, uint64_t size) LIEF_LIFETIMEBOUND;
679
682
685 nullptr) LIEF_LIFETIMEBOUND;
686
688 Symbol& add_exported_function(uint64_t address,
689 const std::string& name = "") LIEF_LIFETIMEBOUND;
690
692 DynamicEntryLibrary& add_library(const std::string& library_name);
693
695 void remove_library(const std::string& library_name);
696
700 get_library(const std::string& library_name) LIEF_LIFETIMEBOUND {
701 return const_cast<DynamicEntryLibrary*>(
702 static_cast<const Binary*>(this)->get_library(library_name)
703 );
704 }
705
709 get_library(const std::string& library_name) const LIEF_LIFETIMEBOUND;
710
712 bool has_library(const std::string& name) const {
713 return get_library(name) != nullptr;
714 }
715
723 Segment* add(const Segment& segment, uint64_t base = 0) LIEF_LIFETIMEBOUND;
724
729 Segment* replace(const Segment& new_segment, const Segment& original_segment,
730 uint64_t base = 0) LIEF_LIFETIMEBOUND;
731
732 Segment* extend(const Segment& segment, uint64_t size) LIEF_LIFETIMEBOUND;
733
734
741 void patch_address(uint64_t address, const std::vector<uint8_t>& patch_value,
742 LIEF::Binary::VA_TYPES addr_type =
743 LIEF::Binary::VA_TYPES::AUTO) override;
744
745
754 uint64_t address, uint64_t patch_value, size_t size = sizeof(uint64_t),
755 LIEF::Binary::VA_TYPES addr_type = LIEF::Binary::VA_TYPES::AUTO
756 ) override;
757
762 void patch_pltgot(const Symbol& symbol, uint64_t address);
763
764
769 void patch_pltgot(const std::string& symbol_name, uint64_t address);
770
772 void strip();
773
778 void remove_section(const std::string& name, bool clear = false) override;
779
786 void write(const std::string& filename) {
787 return write(filename, Builder::config_t{});
788 }
789
798 void write(const std::string& filename, const Builder::config_t& config);
799
806 void write(std::ostream& os) {
807 return write(os, Builder::config_t{});
808 }
809
815 void write(std::ostream& os, const Builder::config_t& config);
816
818 std::vector<uint8_t> raw();
819
821 result<uint64_t> virtual_address_to_offset(uint64_t virtual_address) const;
822
829 uint64_t slide = 0) const override;
830
835 bool is_pie() const override;
836
838 bool has_nx() const override;
839
842 int64_t dynsym_idx(const std::string& name) const;
843
844 int64_t dynsym_idx(const Symbol& sym) const;
845
847 int64_t symtab_idx(const std::string& name) const;
848
849 int64_t symtab_idx(const Symbol& sym) const;
850
857 const Section*
858 section_from_offset(uint64_t offset,
859 bool skip_nobits = true) const LIEF_LIFETIMEBOUND;
860 Section* section_from_offset(uint64_t offset,
861 bool skip_nobits = true) LIEF_LIFETIMEBOUND {
862 return const_cast<Section*>(
863 static_cast<const Binary*>(this)->section_from_offset(offset, skip_nobits)
864 );
865 }
866
873 uint64_t address, bool skip_nobits = true
874 ) const LIEF_LIFETIMEBOUND;
875 Section*
877 bool skip_nobits = true) LIEF_LIFETIMEBOUND {
878 return const_cast<Section*>(
879 static_cast<const Binary*>(this)->section_from_virtual_address(address,
880 skip_nobits)
881 );
882 }
883
886 const Segment*
889 return const_cast<Segment*>(
890 static_cast<const Binary*>(this)->segment_from_virtual_address(address)
891 );
892 }
893
894
895 const Segment*
897 uint64_t address) const LIEF_LIFETIMEBOUND;
899 uint64_t address) LIEF_LIFETIMEBOUND {
900 return const_cast<Segment*>(
901 static_cast<const Binary*>(this)->segment_from_virtual_address(type,
902 address)
903 );
904 }
905
908 const Segment* segment_from_offset(uint64_t offset) const LIEF_LIFETIMEBOUND;
910 return const_cast<Segment*>(
911 static_cast<const Binary*>(this)->segment_from_offset(offset)
912 );
913 }
914
919 return const_cast<DynamicEntry*>(static_cast<const Binary*>(this)->get(tag));
920 }
921
926 return const_cast<Segment*>(static_cast<const Binary*>(this)->get(type));
927 }
928
933 return const_cast<Note*>(static_cast<const Binary*>(this)->get(type));
934 }
935
940 return const_cast<Section*>(static_cast<const Binary*>(this)->get(type));
941 }
942
944 bool has(DynamicEntry::TAG tag) const {
945 return get(tag) != nullptr;
946 }
947
949 bool has(Segment::TYPE type) const {
950 return get(type) != nullptr;
951 }
952
954 bool has(Note::TYPE type) const {
955 return get(type) != nullptr;
956 }
957
959 bool has(Section::TYPE type) const {
960 return get(type) != nullptr;
961 }
962
965 uint64_t virtual_address, uint64_t size,
967 ) const override;
968
970 void accept(LIEF::Visitor& visitor) const override;
971
973 void permute_dynamic_symbols(const std::vector<size_t>& permutation);
974
978
982
985
987 bool has_notes() const;
988
993 return notes_;
994 }
995
997 return notes_;
998 }
999
1002 uint64_t eof_offset() const;
1003
1005 bool has_overlay() const {
1006 return !overlay_.empty();
1007 }
1008
1011 return overlay_;
1012 }
1013
1015 void overlay(std::vector<uint8_t> overlay) {
1016 overlay_ = std::move(overlay);
1017 }
1018
1028
1031 std::vector<uint64_t> get_relocated_dynamic_array(DynamicEntry::TAG tag) const;
1032
1035
1038 auto it = std::find_if(sections_.begin(), sections_.end(),
1039 [&section](const std::unique_ptr<Section>& S) {
1040 return S.get() == &section;
1041 });
1042 if (it == sections_.end()) {
1044 }
1045 return std::distance(sections_.begin(), it);
1046 }
1047
1049 result<size_t> get_section_idx(const std::string& name) const {
1050 auto it = std::find_if(sections_.begin(), sections_.end(),
1051 [name](const std::unique_ptr<Section>& S) {
1052 return S->name() == name;
1053 });
1054 if (it == sections_.end()) {
1056 }
1057 return std::distance(sections_.begin(), it);
1058 }
1059
1063 const std::string& libname
1064 ) const LIEF_LIFETIMEBOUND;
1065
1068 return const_cast<SymbolVersionRequirement*>(
1069 static_cast<const Binary*>(this)->find_version_requirement(name)
1070 );
1071 }
1072
1079 bool remove_version_requirement(const std::string& libname);
1080
1081 uint8_t ptr_size() const {
1082 switch (type()) {
1083 case Header::CLASS::ELF32: return sizeof(uint32_t);
1084 case Header::CLASS::ELF64: return sizeof(uint64_t);
1085 default: return 0;
1086 }
1087 return 0;
1088 }
1089
1090 uint64_t page_size() const override;
1091
1092 static bool classof(const LIEF::Binary* bin) {
1093 return bin->format() == Binary::FORMATS::ELF ||
1094 bin->format() == Binary::FORMATS::OAT;
1095 }
1096
1097 size_t hash(const std::string& name);
1098
1099 ~Binary() override;
1100
1101 std::ostream& print(std::ostream& os) const override;
1102
1104 add(entry);
1105 return *this;
1106 }
1107 Binary& operator+=(const Section& section) {
1108 add(section);
1109 return *this;
1110 }
1111
1112 Binary& operator+=(const Segment& segment) {
1113 add(segment);
1114 return *this;
1115 }
1116
1117 Binary& operator+=(const Note& note) {
1118 add(note);
1119 return *this;
1120 }
1121
1123 remove(entry);
1124 return *this;
1125 }
1126
1128 remove(tag);
1129 return *this;
1130 }
1131
1132 Binary& operator-=(const Note& note) {
1133 remove(note);
1134 return *this;
1135 }
1136
1138 remove(type);
1139 return *this;
1140 }
1141
1143 return get(type);
1144 }
1145
1147 return get(type);
1148 }
1149
1151 return get(tag);
1152 }
1153
1155 return get(tag);
1156 }
1157
1159 return get(type);
1160 }
1161
1163 return get(type);
1164 }
1165
1167 return get(type);
1168 }
1169
1171 return get(type);
1172 }
1173
1174 bool should_swap() const {
1175 return should_swap_;
1176 }
1177
1178 protected:
1179 struct phdr_relocation_info_t {
1180 uint64_t new_offset = 0;
1181 size_t nb_segments = 0;
1182 void clear() {
1183 new_offset = 0;
1184 nb_segments = 0;
1185 }
1186 };
1187 LIEF_LOCAL Binary();
1188
1190 LIEF_LOCAL LIEF::Binary::sections_t get_abstract_sections() override;
1191
1192 LIEF_LOCAL LIEF::Header get_abstract_header() const override {
1193 return LIEF::Header::from(*this);
1194 }
1195
1197 get_abstract_exported_functions() const override;
1199 get_abstract_imported_functions() const override;
1200 LIEF_LOCAL std::vector<std::string>
1201 get_abstract_imported_libraries() const override;
1202 LIEF_LOCAL LIEF::Binary::symbols_t get_abstract_symbols() override;
1203 LIEF_LOCAL LIEF::Binary::relocations_t get_abstract_relocations() override;
1204
1205 template<ELF::ARCH ARCH>
1206 LIEF_LOCAL void patch_relocations(uint64_t from, uint64_t shift);
1207
1208 template<class T>
1209 LIEF_LOCAL void patch_addend(Relocation& relocatio, uint64_t from,
1210 uint64_t shift);
1211
1212 LIEF_LOCAL void shift_sections(uint64_t from, uint64_t shift);
1213 LIEF_LOCAL void shift_segments(uint64_t from, uint64_t shift);
1214 LIEF_LOCAL void shift_dynamic_entries(uint64_t from, uint64_t shift);
1215 LIEF_LOCAL void shift_symbols(uint64_t from, uint64_t shift);
1216 LIEF_LOCAL void shift_relocations(uint64_t from, uint64_t shift);
1217
1218 template<class ELF_T>
1219 LIEF_LOCAL void fix_got_entries(uint64_t from, uint64_t shift);
1220
1221 LIEF_LOCAL LIEF::Binary::functions_t eh_frame_functions() const;
1222 LIEF_LOCAL LIEF::Binary::functions_t armexid_functions() const;
1223
1224 template<Header::FILE_TYPE OBJECT_TYPE, bool note = false>
1225 LIEF_LOCAL Segment* add_segment(const Segment& segment, uint64_t base);
1226
1227 LIEF_LOCAL uint64_t relocate_phdr_table_auto();
1228 LIEF_LOCAL uint64_t relocate_phdr_table_pie();
1229 LIEF_LOCAL uint64_t relocate_phdr_table_v1();
1230 LIEF_LOCAL uint64_t relocate_phdr_table_v2();
1231 LIEF_LOCAL uint64_t relocate_phdr_table_v3();
1232
1233 template<Segment::TYPE PT>
1234 LIEF_LOCAL Segment* extend_segment(const Segment& segment, uint64_t size);
1235
1236 template<bool LOADED>
1237 LIEF_LOCAL Section* add_section(const Section& section, SEC_INSERT_POS pos);
1238
1239 std::vector<Symbol*> symtab_dyn_symbols() const;
1240
1241 LIEF_LOCAL std::string shstrtab_name() const;
1242 LIEF_LOCAL Section* add_frame_section(const Section& sec);
1243 LIEF_LOCAL Section* add_section(std::unique_ptr<Section> sec);
1244
1245 LIEF_LOCAL LIEF::Binary::functions_t tor_functions(DynamicEntry::TAG tag) const;
1246
1247 Header::CLASS type_ = Header::CLASS::NONE;
1248 Header header_;
1249 sections_t sections_;
1250 segments_t segments_;
1251 dynamic_entries_t dynamic_entries_;
1252 symbols_t dynamic_symbols_;
1253 symbols_t symtab_symbols_;
1254 relocations_t relocations_;
1255 symbols_version_t symbol_version_table_;
1256 symbols_version_requirement_t symbol_version_requirements_;
1257 symbols_version_definition_t symbol_version_definition_;
1258 notes_t notes_;
1259 std::unique_ptr<GnuHash> gnu_hash_;
1260 std::unique_ptr<SysvHash> sysv_hash_;
1261 std::unique_ptr<DataHandler::Handler> datahandler_;
1262 phdr_relocation_info_t phdr_reloc_info_;
1263
1264 std::string interpreter_;
1265 std::vector<uint8_t> overlay_;
1266 std::unique_ptr<sizing_info_t> sizing_info_;
1267 uint64_t pagesize_ = 0;
1268 bool should_swap_ = false;
1269};
1270
1271}
1272}
1273#endif
Generic interface representing a binary executable.
Definition Abstract/Binary.hpp:59
std::vector< Function > functions_t
Definition Abstract/Binary.hpp:82
@ ELF
Definition Abstract/Binary.hpp:76
@ OAT
Definition Abstract/Binary.hpp:79
FORMATS format() const
Executable format (ELF, PE, Mach-O) of the underlying binary.
Definition Abstract/Binary.hpp:124
std::vector< Symbol * > symbols_t
Internal container.
Definition Abstract/Binary.hpp:94
VA_TYPES
Enumeration of virtual address types used for patching and memory access.
Definition Abstract/Binary.hpp:62
@ AUTO
Automatically determine if the address is absolute or relative (default behavior).
Definition Abstract/Binary.hpp:65
std::vector< Section * > sections_t
Internal container.
Definition Abstract/Binary.hpp:85
std::vector< Relocation * > relocations_t
Internal container.
Definition Abstract/Binary.hpp:103
friend class ObjectFileLayout
Definition ELF/Binary.hpp:64
const_ref_iterator< std::vector< Symbol * > > it_const_symbols
Iterator which outputs static and dynamic const Symbol& object.
Definition ELF/Binary.hpp:187
~Binary() override
Segment * add(const Segment &segment, uint64_t base=0)
Add a new segment in the binary.
bool use_gnu_hash() const
true if GNU hash is used
Definition ELF/Binary.hpp:491
std::vector< std::unique_ptr< SymbolVersionRequirement > > symbols_version_requirement_t
Internal container for storing SymbolVersionRequirement.
Definition ELF/Binary.hpp:79
const DynamicEntry * get(DynamicEntry::TAG tag) const
Return the first ELF::DynamicEntry associated with the given tag If the tag can't be found,...
void remove(const Segment &seg, bool clear=false)
Remove the given segment. If clear is set, the original content of the segment will be filled with ze...
void write(std::ostream &os, const Builder::config_t &config)
Reconstruct the binary object with the given config and write it in os stream.
Header::CLASS type() const
Return binary's class (ELF32 or ELF64).
Definition ELF/Binary.hpp:268
std::vector< std::unique_ptr< Symbol > > symbols_t
Internal container for storing ELF's Symbol.
Definition ELF/Binary.hpp:167
const_ref_iterator< const sections_t &, const Section * > it_const_sections
Iterator which outputs const Section& object.
Definition ELF/Binary.hpp:208
bool should_swap() const
Definition ELF/Binary.hpp:1174
result< uint64_t > virtual_address_to_offset(uint64_t virtual_address) const
Convert a virtual address to a file offset.
it_const_symbols symbols() const
Definition ELF/Binary.hpp:583
uint64_t last_offset_section() const
Return the last offset used in binary according to sections table.
SEC_INSERT_POS
This enum defines where the content of a newly added section should be inserted.
Definition ELF/Binary.hpp:246
@ AUTO
Defer the choice to LIEF.
Definition ELF/Binary.hpp:248
span< const uint8_t > get_content_from_virtual_address(uint64_t virtual_address, uint64_t size, Binary::VA_TYPES addr_type=Binary::VA_TYPES::AUTO) const override
Return the content located at virtual address.
PHDR_RELOC
Definition ELF/Binary.hpp:214
@ PIE_SHIFT
Definition ELF/Binary.hpp:225
@ AUTO
Definition ELF/Binary.hpp:218
@ BSS_END
Definition ELF/Binary.hpp:231
@ BINARY_END
Definition ELF/Binary.hpp:235
@ SEGMENT_GAP
Definition ELF/Binary.hpp:241
Header & header()
Return Elf header .
Definition ELF/Binary.hpp:273
friend class ExeLayout
Definition ELF/Binary.hpp:62
const Section * section_from_offset(uint64_t offset, bool skip_nobits=true) const
Return the ELF::Section from the given offset. Return a nullptr if a section can't be found.
it_dynamic_entries dynamic_entries()
Return binary's dynamic entries.
Definition ELF/Binary.hpp:316
it_symbols_version_requirement symbols_version_requirement()
Return Symbol version requirement.
Definition ELF/Binary.hpp:405
void remove(Segment::TYPE type, bool clear=false)
Remove all segments associated with the given type.
size_t hash(const std::string &name)
it_pltgot_relocations pltgot_relocations()
Return plt.got relocations.
ref_iterator< notes_t &, Note * > it_notes
Iterator which outputs Note& object.
Definition ELF/Binary.hpp:73
filter_iterator< relocations_t &, Relocation * > it_object_relocations
Iterator which outputs Relocation& object found in object files (.o).
Definition ELF/Binary.hpp:153
void strip()
Strip the binary by removing symtab symbols.
Note & add(const Note &note)
Add the given note and return the created entry.
Symbol & export_symbol(const std::string &symbol_name, uint64_t value=0)
Export the symbol with the given name and create it if it doesn't exist.
void remove_symtab_symbol(Symbol *symbol)
Binary & operator+=(const DynamicEntry &entry)
Definition ELF/Binary.hpp:1103
void remove(const Note &note)
Remove the given note.
const Note * operator[](Note::TYPE type) const
Definition ELF/Binary.hpp:1162
std::vector< std::unique_ptr< Relocation > > relocations_t
Internal container for storing ELF's Relocation.
Definition ELF/Binary.hpp:134
void write(const std::string &filename, const Builder::config_t &config)
Reconstruct the binary object with the given config and write it in filename.
bool has_notes() const
true if the binary embeds notes
int64_t dynsym_idx(const std::string &name) const
Symbol index in the dynamic symbol table or -1 if the symbol does not exist.
Segment * segment_from_virtual_address(uint64_t address)
Definition ELF/Binary.hpp:888
const_ref_iterator< const symbols_t &, const Symbol * > it_const_symtab_symbols
Iterator which outputs the static/debug const Symbol& object.
Definition ELF/Binary.hpp:180
const Relocation * get_relocation(const Symbol &symbol) const
Return relocation associated with the given Symbol It returns a nullptr if it is not found.
void remove_dynamic_symbol(const std::string &name)
Remove dynamic symbols with the given name.
Binary & operator-=(const Note &note)
Definition ELF/Binary.hpp:1132
const Section * section_from_virtual_address(uint64_t address, bool skip_nobits=true) const
Return the ELF::Section from the given address. Return a nullptr if a section can't be found.
const Relocation * get_relocation(const std::string &symbol_name) const
Return relocation associated with the given Symbol name It returns a nullptr if it is not found.
ref_iterator< symbols_version_definition_t &, SymbolVersionDefinition * > it_symbols_version_definition
Iterator which outputs SymbolVersionDefinition& object.
Definition ELF/Binary.hpp:96
it_symtab_symbols symtab_symbols()
Return the debug symbols from the .symtab section.
Definition ELF/Binary.hpp:378
LIEF::Binary::functions_t ctor_functions() const override
List of binary constructors (typically, the functions located in the .init_array).
uint64_t imagebase() const override
Return program image base. For instance 0x40000.
LIEF::Binary::functions_t functions() const
List of the functions found in the binary.
bool has_library(const std::string &name) const
Check if the given library name exists in the current binary.
Definition ELF/Binary.hpp:712
int64_t dynsym_idx(const Symbol &sym) const
LIEF::Binary::functions_t dtor_functions() const
List of the binary destructors (typically, the functions located in the .fini_array).
std::vector< std::unique_ptr< SymbolVersion > > symbols_version_t
Internal container for storing ELF's SymbolVersion.
Definition ELF/Binary.hpp:124
Segment * operator[](Segment::TYPE type)
Definition ELF/Binary.hpp:1142
const Symbol * get_dynamic_symbol(const std::string &name) const
Get the dynamic symbol from the given name. Return a nullptr if it can't be found.
Relocation * get_relocation(uint64_t address)
Definition ELF/Binary.hpp:463
const Segment * segment_from_virtual_address(Segment::TYPE type, uint64_t address) const
DynamicEntryLibrary * get_library(const std::string &library_name)
Get the library object (DynamicEntryLibrary) from the given name If the library can't be found,...
Definition ELF/Binary.hpp:700
bool is_pie() const override
Check if the binary has been compiled with -fpie -pie flags.
Symbol * get_symtab_symbol(const std::string &name)
Definition ELF/Binary.hpp:621
it_symbols_version symbols_version()
Return the symbol versions.
Definition ELF/Binary.hpp:387
DynamicEntryLibrary & add_library(const std::string &library_name)
Add a library as dependency.
Section * text_section()
Return the .text section. If the section can't be found, it returns a nullptr.
Definition ELF/Binary.hpp:536
filter_iterator< std::vector< Symbol * > > it_exported_symbols
Iterator which outputs exported Symbol& object.
Definition ELF/Binary.hpp:190
it_object_relocations object_relocations()
Return relocations used in an object file (*.o).
Section * get_section(const std::string &name)
Return Section with the given name. If the section can't be found, it returns a nullptr.
Definition ELF/Binary.hpp:527
it_imported_symbols imported_symbols()
Return symbols which are imported by the binary.
std::vector< std::unique_ptr< Segment > > segments_t
Internal container for storing ELF's Segment.
Definition ELF/Binary.hpp:105
it_sections sections()
Return an iterator over the binary's sections.
Definition ELF/Binary.hpp:293
it_const_notes notes() const
Return an iterator over the ELF's LIEF::ELF::Note.
Definition ELF/Binary.hpp:992
it_symbols_version_definition symbols_version_definition()
Return symbols version definition.
Definition ELF/Binary.hpp:395
const Symbol * get_symtab_symbol(const std::string &name) const
Get the symtab symbol from the given name Return a nullptr if it can't be found.
it_dynamic_relocations dynamic_relocations()
Return dynamic relocations.
void overlay(std::vector< uint8_t > overlay)
Function to set the overlay.
Definition ELF/Binary.hpp:1015
Note * get(Note::TYPE type)
Definition ELF/Binary.hpp:932
void remove_dynamic_symbol(Symbol *symbol)
Remove the given symbol from the dynamic symbols table.
const_ref_iterator< const symbols_t &, const Symbol * > it_const_dynamic_symbols
Iterator which outputs the Dynamic const Symbol& object.
Definition ELF/Binary.hpp:173
span< const uint8_t > overlay() const
Overlay data (if any).
Definition ELF/Binary.hpp:1010
const_ref_iterator< const symbols_version_definition_t &, const SymbolVersionDefinition * > it_const_symbols_version_definition
Iterator which outputs const SymbolVersionDefinition& object.
Definition ELF/Binary.hpp:100
bool has_overlay() const
True if data are present at the end of the binary.
Definition ELF/Binary.hpp:1005
const_ref_iterator< const dynamic_entries_t &, const DynamicEntry * > it_const_dynamic_entries
Iterator which outputs const DynamicEntry& object.
Definition ELF/Binary.hpp:120
bool has(Section::TYPE type) const
Check if a ELF::Section associated with the given type exists.
Definition ELF/Binary.hpp:959
std::ostream & print(std::ostream &os) const override
Relocation * get_relocation(const std::string &symbol_name)
Definition ELF/Binary.hpp:482
Symbol & add_dynamic_symbol(const Symbol &symbol, const SymbolVersion *version=nullptr)
Add a dynamic symbol with the associated SymbolVersion.
ref_iterator< segments_t &, Segment * > it_segments
Iterator which outputs Segment& object.
Definition ELF/Binary.hpp:108
std::vector< std::unique_ptr< DynamicEntry > > dynamic_entries_t
Internal container for storing ELF's DynamicEntry.
Definition ELF/Binary.hpp:114
Symbol & add_symtab_symbol(const Symbol &symbol)
Add a symtab symbol.
Binary & operator+=(const Section &section)
Definition ELF/Binary.hpp:1107
const Section * get_section(const std::string &name) const
void interpreter(const std::string &interpreter)
Change the interpreter.
Definition ELF/Binary.hpp:574
const_filter_iterator< std::vector< Symbol * > > it_const_imported_symbols
Iterator which outputs imported const Symbol& object.
Definition ELF/Binary.hpp:199
Binary(const Binary &copy)=delete
const_filter_iterator< const relocations_t &, const Relocation * > it_const_dynamic_relocations
Iterator which outputs dynamic const Relocation& object (not related to the PLT/GOT mechanism).
Definition ELF/Binary.hpp:149
int64_t symtab_idx(const Symbol &sym) const
const Segment * operator[](Segment::TYPE type) const
Definition ELF/Binary.hpp:1146
it_const_sections sections() const
Definition ELF/Binary.hpp:297
result< size_t > get_section_idx(const std::string &name) const
Find the index of the section with the name given in the first parameter.
Definition ELF/Binary.hpp:1049
Relocation * add_object_relocation(const Relocation &relocation, const Section &section)
Add relocation for object file (.o).
it_exported_symbols exported_symbols()
Return symbols which are exported by the binary.
const_ref_iterator< const relocations_t &, const Relocation * > it_const_relocations
Iterator which outputs const Relocation& object.
Definition ELF/Binary.hpp:163
const Header & header() const
Definition ELF/Binary.hpp:277
std::vector< std::string > string_list_t
Definition ELF/Binary.hpp:67
it_const_symtab_symbols symtab_symbols() const
Definition ELF/Binary.hpp:382
result< size_t > get_section_idx(const Section &section) const
Find the index of the section given in the first parameter.
Definition ELF/Binary.hpp:1037
Section * extend(const Section &section, uint64_t size)
std::vector< std::unique_ptr< Note > > notes_t
Internal container for storing notes.
Definition ELF/Binary.hpp:70
const Segment * get(Segment::TYPE type) const
Return the first ELF::Segment associated with the given type. If a segment can't be found,...
uint64_t entrypoint() const override
Return the binary's entrypoint.
Definition ELF/Binary.hpp:302
void write(const std::string &filename)
Reconstruct the binary object and write it in filename.
Definition ELF/Binary.hpp:786
friend class Builder
Definition ELF/Binary.hpp:61
bool has(Note::TYPE type) const
Check if a ELF::Note associated with the given type exists.
Definition ELF/Binary.hpp:954
Segment * segment_from_offset(uint64_t offset)
Definition ELF/Binary.hpp:909
bool has_symtab_symbol(const std::string &name) const
Check if the symbol with the given name exists in the symtab symbol table.
Definition ELF/Binary.hpp:612
bool has_dynamic_symbol(const std::string &name) const
Check if the symbol with the given name exists in the dynamic symbols table.
Definition ELF/Binary.hpp:596
DynamicEntry * operator[](DynamicEntry::TAG tag)
Definition ELF/Binary.hpp:1150
result< uint64_t > offset_to_virtual_address(uint64_t offset, uint64_t slide=0) const override
Convert the given offset into a virtual address.
ref_iterator< symbols_t &, Symbol * > it_symtab_symbols
Iterator which outputs the static/debug Symbol& object.
Definition ELF/Binary.hpp:177
const SymbolVersionRequirement * find_version_requirement(const std::string &libname) const
Try to find the SymbolVersionRequirement associated with the given library name (e....
it_const_symbols_version_definition symbols_version_definition() const
Definition ELF/Binary.hpp:400
const Section * get(Section::TYPE type) const
Return the first ELF::Section associated with the given type If a section can't be found,...
Section * hash_section()
Return the hash section. If the section can't be found, it returns a nullptr.
uint64_t next_virtual_address() const
Return the next virtual address available.
const Segment * segment_from_virtual_address(uint64_t address) const
Return the ELF::Segment from the given address. Return a nullptr if a segment can't be found.
Binary & operator-=(const DynamicEntry &entry)
Definition ELF/Binary.hpp:1122
uint64_t eof_offset() const
Return the last offset used by the ELF binary according to both: the sections table and the segments ...
void remove(DynamicEntry::TAG tag)
Remove all dynamic entries with the given tag.
uint64_t page_size() const override
Get the default memory page size according to the architecture and the format of the current binary.
it_segments segments()
Return binary's segments.
Definition ELF/Binary.hpp:307
void remove_library(const std::string &library_name)
Remove the given library from the dependencies.
result< uint64_t > get_function_address(const std::string &func_name, bool demangled) const
Return the address of the given function name.
it_dynamic_symbols dynamic_symbols()
Return an iterator over the binary's dynamic symbols The dynamic symbols are those located in the ....
Definition ELF/Binary.hpp:361
filter_iterator< std::vector< Symbol * > > it_imported_symbols
Iterator which outputs imported Symbol& object.
Definition ELF/Binary.hpp:196
const_filter_iterator< const relocations_t &, const Relocation * > it_const_object_relocations
Iterator which outputs const Relocation& object found in object files (.o).
Definition ELF/Binary.hpp:156
it_const_dynamic_entries dynamic_entries() const
Definition ELF/Binary.hpp:320
void remove_symtab_symbol(const std::string &name)
Remove symtab symbols with the given name.
Binary & operator-=(DynamicEntry::TAG tag)
Definition ELF/Binary.hpp:1127
it_relocations relocations()
Return all relocations present in the binary.
Definition ELF/Binary.hpp:452
Section * dynamic_section()
Return the .dynamic section. If the section can't be found, it returns a nullptr.
Segment * get(Segment::TYPE type)
Definition ELF/Binary.hpp:925
const DynamicEntryLibrary * get_library(const std::string &library_name) const
Get the library object (DynamicEntryLibrary) from the given name If the library can't be found,...
uint8_t ptr_size() const
Definition ELF/Binary.hpp:1081
const DynamicEntry * operator[](DynamicEntry::TAG tag) const
Definition ELF/Binary.hpp:1154
it_symbols symbols()
Return an iterator on both static and dynamic symbols.
Definition ELF/Binary.hpp:579
uint64_t relocate_phdr_table(PHDR_RELOC type)
Force relocating the segments table in a specific way.
std::vector< std::unique_ptr< Section > > sections_t
Internal container for storing ELF's Section.
Definition ELF/Binary.hpp:202
const_ref_iterator< const segments_t &, const Segment * > it_const_segments
Iterator which outputs const Segment& object.
Definition ELF/Binary.hpp:111
Segment * replace(const Segment &new_segment, const Segment &original_segment, uint64_t base=0)
Replace the segment given in 2nd parameter with the segment given in the first one and return the upd...
void remove(const Section &section, bool clear=false)
Remove the given section. The clear parameter can be used to zeroize the original content beforehand.
Symbol * get_dynamic_symbol(const std::string &name)
Definition ELF/Binary.hpp:605
Section * operator[](Section::TYPE type)
Definition ELF/Binary.hpp:1166
it_const_dynamic_symbols dynamic_symbols() const
Definition ELF/Binary.hpp:365
uint64_t virtual_size() const override
Return the size of the mapped binary.
bool has_section_with_offset(uint64_t offset) const
Check if a section that handles the given offset exists.
string_list_t strings(size_t min_size=5) const
Return list of the strings used by the ELF binary.
void remove_section(const std::string &name, bool clear=false) override
Remove a binary's section.
friend class Parser
Definition ELF/Binary.hpp:60
std::vector< uint8_t > raw()
Reconstruct the binary object and return its content as a byte vector.
const SysvHash * sysv_hash() const
Return the SysvHash object as a read-only object If the ELF binary does not use the legacy sysv hash ...
Definition ELF/Binary.hpp:510
SymbolVersionRequirement * find_version_requirement(const std::string &name)
Definition ELF/Binary.hpp:1067
bool has_section(const std::string &name) const
Check if a section with the given name exists in the binary.
Definition ELF/Binary.hpp:515
Relocation * get_relocation(const Symbol &symbol)
Definition ELF/Binary.hpp:472
Section * get(Section::TYPE type)
Definition ELF/Binary.hpp:939
static bool classof(const LIEF::Binary *bin)
Definition ELF/Binary.hpp:1092
it_const_relocations relocations() const
Definition ELF/Binary.hpp:456
Binary & operator-=(Note::TYPE type)
Definition ELF/Binary.hpp:1137
Symbol & add_exported_function(uint64_t address, const std::string &name="")
Create a symbol for the function at the given address and export it.
bool is_targeting_android() const
True if the current ELF is targeting Android.
it_const_segments segments() const
Definition ELF/Binary.hpp:311
DynamicEntry * get(DynamicEntry::TAG tag)
Definition ELF/Binary.hpp:918
Section * symtab_symbols_section()
Return section which holds the symtab symbols. If the section can't be found, it returns a nullptr.
uint64_t last_offset_segment() const
Return the last offset used in binary according to segments table.
bool use_sysv_hash() const
true if SYSV hash is used
Definition ELF/Binary.hpp:504
friend class Layout
Definition ELF/Binary.hpp:63
ref_iterator< sections_t &, Section * > it_sections
Iterator which outputs Section& object.
Definition ELF/Binary.hpp:205
void patch_pltgot(const Symbol &symbol, uint64_t address)
Patch the imported symbol with the address.
const_filter_iterator< const relocations_t &, const Relocation * > it_const_pltgot_relocations
Iterator which outputs plt/got const Relocation& object.
Definition ELF/Binary.hpp:140
filter_iterator< relocations_t &, Relocation * > it_dynamic_relocations
Iterator which outputs dynamic Relocation& object (not related to the PLT/GOT mechanism).
Definition ELF/Binary.hpp:145
ref_iterator< relocations_t &, Relocation * > it_relocations
Iterator which outputs Relocation& object.
Definition ELF/Binary.hpp:160
bool has_interpreter() const
Check if the binary uses a loader (also named linker or interpreter).
const Relocation * get_relocation(uint64_t address) const
Return relocation associated with the given address. It returns a nullptr if it is not found.
void remove_symbol(const std::string &name)
Remove symbols with the given name in both:
const Section * operator[](Section::TYPE type) const
Definition ELF/Binary.hpp:1170
const Segment * segment_from_offset(uint64_t offset) const
Return the ELF::Segment from the offset. Return a nullptr if a segment can't be found.
void remove(Note::TYPE type)
Remove all notes with the given type.
Relocation & add_dynamic_relocation(const Relocation &relocation)
Add a new dynamic relocation.
ref_iterator< symbols_t &, Symbol * > it_dynamic_symbols
Iterator which outputs the Dynamic Symbol& object.
Definition ELF/Binary.hpp:170
const std::string & interpreter() const
Return the ELF interpreter if any. (e.g. /lib64/ld-linux-x86-64.so.2) If the binary does not have an ...
Definition ELF/Binary.hpp:569
int64_t symtab_idx(const std::string &name) const
Symbol index from the .symtab section or -1 if the symbol is not present.
bool remove_version_requirement(const std::string &libname)
Deletes all required symbol versions linked to the specified library name. The function returns true ...
std::vector< uint64_t > get_relocated_dynamic_array(DynamicEntry::TAG tag) const
Return the array defined by the given tag (e.g. DynamicEntry::TAG::INIT_ARRAY) with relocations appli...
it_const_symbols_version_requirement symbols_version_requirement() const
Definition ELF/Binary.hpp:410
ref_iterator< std::vector< Symbol * > > it_symbols
Iterator which outputs static and dynamic Symbol& object.
Definition ELF/Binary.hpp:184
it_notes notes()
Definition ELF/Binary.hpp:996
std::vector< std::unique_ptr< SymbolVersionDefinition > > symbols_version_definition_t
Internal container for storing SymbolVersionDefinition.
Definition ELF/Binary.hpp:92
ref_iterator< symbols_version_t &, SymbolVersion * > it_symbols_version
Iterator which outputs SymbolVersion& object.
Definition ELF/Binary.hpp:127
void patch_address(uint64_t address, const std::vector< uint8_t > &patch_value, LIEF::Binary::VA_TYPES addr_type=LIEF::Binary::VA_TYPES::AUTO) override
Patch the content at virtual address address with patch_value.
Note * operator[](Note::TYPE type)
Definition ELF/Binary.hpp:1158
const_filter_iterator< std::vector< Symbol * > > it_const_exported_symbols
Iterator which outputs exported const Symbol& object.
Definition ELF/Binary.hpp:193
Binary & operator+=(const Segment &segment)
Definition ELF/Binary.hpp:1112
Binary & operator=(const Binary &)=delete
filter_iterator< relocations_t &, Relocation * > it_pltgot_relocations
Iterator which outputs plt/got Relocation& object.
Definition ELF/Binary.hpp:137
Section * add(const Section &section, bool loaded=true, SEC_INSERT_POS pos=SEC_INSERT_POS::AUTO)
Add a new section in the binary.
Segment * segment_from_virtual_address(Segment::TYPE type, uint64_t address)
Definition ELF/Binary.hpp:898
void permute_dynamic_symbols(const std::vector< size_t > &permutation)
Apply the given permutation on the dynamic symbols table.
const_ref_iterator< const symbols_version_t &, const SymbolVersion * > it_const_symbols_version
Iterator which outputs const SymbolVersion& object.
Definition ELF/Binary.hpp:130
bool has_section_with_va(uint64_t va) const
Check if a section that handles the given virtual address exists.
const_ref_iterator< const notes_t &, const Note * > it_const_notes
Iterator which outputs const Note& object.
Definition ELF/Binary.hpp:76
void accept(LIEF::Visitor &visitor) const override
Method associated with the visitor pattern.
const Note * get(Note::TYPE type) const
Return the first ELF::Note associated with the given type If a note can't be found,...
ref_iterator< dynamic_entries_t &, DynamicEntry * > it_dynamic_entries
Iterator which outputs DynamicEntry& object.
Definition ELF/Binary.hpp:117
Symbol & export_symbol(const Symbol &symbol)
Export the given symbol and create it if it doesn't exist.
it_const_symbols_version symbols_version() const
Definition ELF/Binary.hpp:390
Relocation & add_pltgot_relocation(const Relocation &relocation)
Add a .plt.got relocation. This kind of relocation is usually associated with a PLT stub that aims at...
Binary & operator+=(const Note &note)
Definition ELF/Binary.hpp:1117
result< uint64_t > get_function_address(const std::string &func_name) const override
Return the address of the given function name.
const GnuHash * gnu_hash() const
Return the GnuHash object in readonly If the ELF binary does not use the GNU hash table,...
Definition ELF/Binary.hpp:497
void write(std::ostream &os)
Reconstruct the binary object and write it in os stream.
Definition ELF/Binary.hpp:806
ref_iterator< symbols_version_requirement_t &, SymbolVersionRequirement * > it_symbols_version_requirement
Iterator which outputs SymbolVersionRequirement& object.
Definition ELF/Binary.hpp:83
bool has_nx() const override
Check if the binary uses the NX protection (Non executable stack).
const_ref_iterator< const symbols_version_requirement_t &, const SymbolVersionRequirement * > it_const_symbols_version_requirement
Iterator which outputs const SymbolVersionRequirement& object.
Definition ELF/Binary.hpp:87
void remove(const DynamicEntry &entry)
Remove the given dynamic entry.
DynamicEntry & add(const DynamicEntry &entry)
Add the given dynamic entry and return the new entry.
bool has(Segment::TYPE type) const
Check if ELF::Segment associated with the given type exists.
Definition ELF/Binary.hpp:949
bool has(DynamicEntry::TAG tag) const
Check if an ELF::DynamicEntry associated with the given tag exists.
Definition ELF/Binary.hpp:944
Class which represents a DT_NEEDED entry in the dynamic table.
Definition DynamicEntryLibrary.hpp:29
Class which represents an entry in the dynamic table These entries are located in the ....
Definition DynamicEntry.hpp:37
TAG
Definition DynamicEntry.hpp:48
@ HASH
Definition DynamicEntry.hpp:54
@ GNU_HASH
Definition DynamicEntry.hpp:89
Class which provides a view over the GNU Hash implementation. Most of the fields are read-only since ...
Definition GnuHash.hpp:40
Class which represents the ELF's header. This class mirrors the raw ELF Elfxx_Ehdr structure.
Definition ELF/Header.hpp:35
CLASS
Match the result of Elfxx_Ehdr.e_ident[EI_CLASS].
Definition ELF/Header.hpp:74
@ ELF64
64-bit objects
Definition ELF/Header.hpp:77
@ ELF32
32-bit objects
Definition ELF/Header.hpp:76
Class which represents an ELF note. This class can be instantiated using the static Note::create func...
Definition Note.hpp:39
TYPE
LIEF representation of the ELF NT_ values.
Definition Note.hpp:49
Class which parses and transforms an ELF file into a ELF::Binary object.
Definition ELF/Parser.hpp:45
Class that represents an ELF relocation.
Definition ELF/Relocation.hpp:40
Class which represents an ELF Section.
Definition ELF/Section.hpp:48
TYPE
Definition ELF/Section.hpp:62
Class which represents the ELF segments.
Definition Segment.hpp:48
TYPE
Definition Segment.hpp:72
Class which represents an entry defined in DT_VERDEF or .gnu.version_d.
Definition SymbolVersionDefinition.hpp:38
Class which represents an entry in the DT_VERNEED or .gnu.version_r table.
Definition SymbolVersionRequirement.hpp:40
Class which represents an entry defined in the DT_VERSYM dynamic entry.
Definition SymbolVersion.hpp:33
Class which represents an ELF symbol.
Definition ELF/Symbol.hpp:35
Class which represents the SYSV hash for the symbols resolution.
Definition SysvHash.hpp:39
Definition Abstract/Header.hpp:40
static Header from(const LIEF::ELF::Binary &elf)
Definition Visitor.hpp:212
Iterator which returns a ref on container's values given predicates.
Definition iterators.hpp:325
Iterator which returns reference on container's values.
Definition iterators.hpp:45
Wrapper that contains an Object (T) or an error.
Definition errors.hpp:77
#define LIEF_LIFETIMEBOUND
Definition compiler_attributes.hpp:72
@ not_found
Definition errors.hpp:26
tl::unexpected< lief_errors > make_error_code(lief_errors e)
Create a standard error code from lief_errors.
Definition errors.hpp:53
Definition ELF/Binary.hpp:38
Namespace related to the LIEF's ELF module.
Definition Abstract/Header.hpp:28
LIEF namespace.
Definition Abstract/Binary.hpp:40
filter_iterator< CT, U, typename decay_t< CT >::const_iterator > const_filter_iterator
Iterator which returns a const ref on container's values given predicates.
Definition iterators.hpp:591
tcb::span< ElementType, Extent > span
Definition span.hpp:22
lief_version_t version()
Return the current version.
ref_iterator< CT, U, typename decay_t< CT >::const_iterator > const_ref_iterator
Iterator which returns a const ref on container's values.
Definition iterators.hpp:318
Configuration options to tweak the building process.
Definition ELF/Builder.hpp:55
#define LIEF_API
Definition visibility.h:45
#define LIEF_LOCAL
Definition visibility.h:46