LIEF: Library to Instrument Executable Formats Version 0.17.0
Loading...
Searching...
No Matches
MachO/Symbol.hpp
Go to the documentation of this file.
1/* Copyright 2017 - 2025 R. Thomas
2 * Copyright 2017 - 2025 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_MACHO_SYMBOL_H
17#define LIEF_MACHO_SYMBOL_H
18
19#include <ostream>
20
21#include "LIEF/visibility.h"
22
24
26
27namespace LIEF {
28namespace MachO {
29
30class BinaryParser;
31class BindingInfo;
32class ExportInfo;
33class DylibCommand;
34class Binary;
35
36namespace details {
37struct nlist_32;
38struct nlist_64;
39}
40
48
49 friend class BinaryParser;
50 friend class Binary;
51
52 public:
53 static constexpr int SELF_LIBRARY_ORD = 0x0; // Mirror SELF_LIBRARY_ORDINAL
54 static constexpr int MAIN_EXECUTABLE_ORD = 0xff; // Mirror DYNAMIC_LOOKUP_ORDINAL
55 static constexpr int DYNAMIC_LOOKUP_ORD = 0xfe; // EXECUTABLE_ORDINAL
56
69
70 enum class ORIGIN : uint32_t {
74 SYMTAB = 3,
75 };
76
77 enum class TYPE : uint32_t{
78 UNDEFINED = 0x0u,
79 ABSOLUTE_SYM = 0x2u,
80 SECTION = 0xeu,
81 PREBOUND = 0xcu,
82 INDIRECT = 0xau
83 };
84
85
87 static constexpr uint32_t TYPE_MASK = 0x0e;
88
89 Symbol() = default;
90
91 Symbol(const details::nlist_32& cmd);
92 Symbol(const details::nlist_64& cmd);
93 Symbol(uint8_t n_type, uint8_t n_sect, uint8_t n_desc, uint64_t value) :
94 type_{n_type},
95 numberof_sections_{n_sect},
96 description_{n_desc},
97 origin_{ORIGIN::SYMTAB}
98 {
99 value_ = value;
100 }
101
103 Symbol(const Symbol& other);
104 void swap(Symbol& other) noexcept;
105
106 ~Symbol() override = default;
107
108
109 static bool is_valid_index_ordinal(int idx) {
110 return idx != SELF_LIBRARY_ORD && idx != MAIN_EXECUTABLE_ORD &&
111 idx != DYNAMIC_LOOKUP_ORD;
112 }
113
114 int library_ordinal() const {
115 return (description() >> 8) & 0xff;
116 }
117
119 uint8_t raw_type() const {
120 return type_;
121 }
122
124 TYPE type() const {
125 return TYPE(type_ & TYPE_MASK);
126 }
127
130 uint8_t numberof_sections() const {
131 return numberof_sections_;
132 }
133
135 uint16_t description() const {
136 return description_;
137 }
138
141 bool has_export_info() const {
142 return export_info() != nullptr;
143 }
144
147 const ExportInfo* export_info() const {
148 return export_info_;
149 }
151 return export_info_;
152 }
153
156 bool has_binding_info() const {
157 return binding_info() != nullptr;
158 }
159
162 const BindingInfo* binding_info() const {
163 return binding_info_;
164 }
165
167 return binding_info_;
168 }
169
171 std::string demangled_name() const;
172
174 bool is_external() const {
175 return type() == TYPE::UNDEFINED;
176 }
177
180 const DylibCommand* library() const {
181 return library_;
182 }
183
185 return library_;
186 }
187
189 ORIGIN origin() const {
190 return origin_;
191 }
192
195 return category_;
196 }
197
198 void raw_type(uint8_t type) {
199 type_ = type;
200 }
201 void numberof_sections(uint8_t nbsections) {
202 numberof_sections_ = nbsections;
203 }
204 void description(uint16_t desc) {
205 description_ = desc;
206 }
207
208 void accept(Visitor& visitor) const override;
209
210 LIEF_API friend std::ostream& operator<<(std::ostream& os, const Symbol& symbol);
211
212 static const Symbol& indirect_abs();
213 static const Symbol& indirect_local();
214 static const Symbol& indirect_abs_local();
215
216 private:
217 Symbol(CATEGORY cat) :
218 category_(cat)
219 {}
220 void library(DylibCommand& library) {
221 this->library_ = &library;
222 }
223
224 uint8_t type_ = 0;
225 uint8_t numberof_sections_ = 0;
226 uint16_t description_ = 0;
227
228 BindingInfo* binding_info_ = nullptr;
229 ExportInfo* export_info_ = nullptr;
230
231 DylibCommand* library_ = nullptr;
232
233 ORIGIN origin_ = ORIGIN::UNKNOWN;
234 CATEGORY category_ = CATEGORY::NONE;
235};
236
240
241}
242}
243#endif
Class used to parse a single binary (i.e. non-FAT).
Definition BinaryParser.hpp:78
Class which represents a MachO binary.
Definition MachO/Binary.hpp:88
Class that provides an interface over a binding operation.
Definition BindingInfo.hpp:39
Class which represents a library dependency.
Definition DylibCommand.hpp:34
Class that provides an interface over the Dyld export info.
Definition ExportInfo.hpp:38
ORIGIN
Definition MachO/Symbol.hpp:70
@ SYMTAB
The symbol comes from the binding opcodes.
Definition MachO/Symbol.hpp:74
@ DYLD_BIND
Definition MachO/Symbol.hpp:73
@ UNKNOWN
Definition MachO/Symbol.hpp:71
@ DYLD_EXPORT
Definition MachO/Symbol.hpp:72
void description(uint16_t desc)
Definition MachO/Symbol.hpp:204
uint8_t numberof_sections() const
It returns the number of sections in which this symbol can be found. If the symbol can't be found in ...
Definition MachO/Symbol.hpp:130
bool is_external() const
True if the symbol is defined as an external symbol.
Definition MachO/Symbol.hpp:174
const DylibCommand * library() const
Return the library in which the symbol is defined. It returns a null pointer if the library can't be ...
Definition MachO/Symbol.hpp:180
static const Symbol & indirect_local()
std::string demangled_name() const
Try to demangle the symbol or return an empty string if it is not possible.
static constexpr int DYNAMIC_LOOKUP_ORD
Definition MachO/Symbol.hpp:55
void raw_type(uint8_t type)
Definition MachO/Symbol.hpp:198
static constexpr int MAIN_EXECUTABLE_ORD
Definition MachO/Symbol.hpp:54
static bool is_valid_index_ordinal(int idx)
Definition MachO/Symbol.hpp:109
void swap(Symbol &other) noexcept
friend class BinaryParser
Definition MachO/Symbol.hpp:49
Symbol(const details::nlist_32 &cmd)
~Symbol() override=default
void accept(Visitor &visitor) const override
CATEGORY
Category of the symbol when the symbol comes from the LC_SYMTAB command. The category is defined acco...
Definition MachO/Symbol.hpp:59
@ UNDEFINED
Definition MachO/Symbol.hpp:63
@ INDIRECT_ABS
Definition MachO/Symbol.hpp:65
@ INDIRECT_LOCAL
Definition MachO/Symbol.hpp:66
@ EXTERNAL
Definition MachO/Symbol.hpp:62
@ LOCAL
Definition MachO/Symbol.hpp:61
@ NONE
Definition MachO/Symbol.hpp:60
@ INDIRECT_ABS_LOCAL
Definition MachO/Symbol.hpp:67
uint16_t description() const
Return information about the symbol (SYMBOL_DESCRIPTIONS).
Definition MachO/Symbol.hpp:135
TYPE
Definition MachO/Symbol.hpp:77
@ UNDEFINED
The symbol is undefined. It is referenced in a different module.
Definition MachO/Symbol.hpp:78
@ PREBOUND
The symbol is undefined and the image is using a prebound value for the symbol. Set the n_sect field ...
Definition MachO/Symbol.hpp:81
@ SECTION
The symbol is defined in the section number given in nlist_base.n_sect .
Definition MachO/Symbol.hpp:80
@ INDIRECT
The symbol is defined to be the same as another symbol. The n_value field is an index into the string...
Definition MachO/Symbol.hpp:82
@ ABSOLUTE_SYM
The symbol is absolute. The linker doesn't update his value.
Definition MachO/Symbol.hpp:79
Symbol(const details::nlist_64 &cmd)
void numberof_sections(uint8_t nbsections)
Definition MachO/Symbol.hpp:201
bool has_export_info() const
True if the symbol is associated with an ExportInfo This value is set when the symbol comes from the ...
Definition MachO/Symbol.hpp:141
BindingInfo * binding_info()
Definition MachO/Symbol.hpp:166
friend std::ostream & operator<<(std::ostream &os, const Symbol &symbol)
ORIGIN origin() const
Return the origin of the symbol: from LC_SYMTAB command or from the Dyld information.
Definition MachO/Symbol.hpp:189
uint8_t raw_type() const
Raw value of nlist_xx.n_type.
Definition MachO/Symbol.hpp:119
friend class Binary
Definition MachO/Symbol.hpp:50
int library_ordinal() const
Definition MachO/Symbol.hpp:114
static const Symbol & indirect_abs()
ExportInfo * export_info()
Definition MachO/Symbol.hpp:150
Symbol & operator=(Symbol other)
static constexpr int SELF_LIBRARY_ORD
Definition MachO/Symbol.hpp:53
static const Symbol & indirect_abs_local()
CATEGORY category() const
Category of the symbol according to the LC_DYSYMTAB command.
Definition MachO/Symbol.hpp:194
Symbol(const Symbol &other)
const ExportInfo * export_info() const
Return the ExportInfo associated with this symbol (or nullptr if not present).
Definition MachO/Symbol.hpp:147
const BindingInfo * binding_info() const
Return the BindingInfo associated with this symbol (or nullptr if not present).
Definition MachO/Symbol.hpp:162
bool has_binding_info() const
True if the symbol is associated with a BindingInfo This value is set when the symbol comes from the ...
Definition MachO/Symbol.hpp:156
DylibCommand * library()
Definition MachO/Symbol.hpp:184
Symbol(uint8_t n_type, uint8_t n_sect, uint8_t n_desc, uint64_t value)
Definition MachO/Symbol.hpp:93
static constexpr uint32_t TYPE_MASK
Same as N_TYPE.
Definition MachO/Symbol.hpp:87
TYPE type() const
Type as defined by nlist_xx.n_type & N_TYPE.
Definition MachO/Symbol.hpp:124
This class represents a symbol in an executable format.
Definition Abstract/Symbol.hpp:28
virtual uint64_t value() const
Definition Abstract/Symbol.hpp:68
Definition Visitor.hpp:210
Definition endianness_support.hpp:59
Namespace related to the LIEF's Mach-O module.
Definition Abstract/Header.hpp:36
const char * to_string(BuildToolVersion::TOOLS tool)
LIEF namespace.
Definition Abstract/Binary.hpp:40
#define LIEF_API
Definition visibility.h:41