LIEF: Library to Instrument Executable Formats Version 1.0.0
Loading...
Searching...
No Matches
MachO/Section.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_MACHO_SECTION_H
17#define LIEF_MACHO_SECTION_H
18#include <cstdint>
19#include <string>
20#include <vector>
21#include <ostream>
22#include <memory>
23
25#include "LIEF/visibility.h"
26
28#include "LIEF/enums.hpp"
29
30#include "LIEF/iterators.hpp"
31
32namespace LIEF {
33class SpanStream;
34
35namespace MachO {
36
37class BinaryParser;
38class SegmentCommand;
39class Binary;
40class Relocation;
41
42namespace details {
43struct section_32;
44struct section_64;
45}
46
49
50 friend class BinaryParser;
51 friend class Binary;
52 friend class SegmentCommand;
53
54 public:
55 using content_t = std::vector<uint8_t>;
56
58 using relocations_t = std::vector<std::unique_ptr<Relocation>>;
59
62
66
67 static constexpr auto FLAGS_MASK = uint32_t(0xffffff00u);
68 static constexpr auto TYPE_MASK = uint32_t(0xff);
69
70 enum class TYPE : uint64_t {
72 REGULAR = 0x00u,
74 ZEROFILL = 0x01u,
76 CSTRING_LITERALS = 0x02u,
78 IS_4BYTE_LITERALS = 0x03u,
80 IS_8BYTE_LITERALS = 0x04u,
82 LITERAL_POINTERS = 0x05u,
84 NON_LAZY_SYMBOL_POINTERS = 0x06u,
86 LAZY_SYMBOL_POINTERS = 0x07u,
88 SYMBOL_STUBS = 0x08u,
90 MOD_INIT_FUNC_POINTERS = 0x09u,
92 MOD_TERM_FUNC_POINTERS = 0x0au,
94 COALESCED = 0x0bu,
96 GB_ZEROFILL = 0x0cu,
98 INTERPOSING = 0x0du,
100 IS_16BYTE_LITERALS = 0x0eu,
102 DTRACE_DOF = 0x0fu,
104 LAZY_DYLIB_SYMBOL_POINTERS = 0x10u,
106 THREAD_LOCAL_REGULAR = 0x11u,
108 THREAD_LOCAL_ZEROFILL = 0x12u,
110 THREAD_LOCAL_VARIABLES = 0x13u,
112 THREAD_LOCAL_VARIABLE_POINTERS = 0x14u,
114 THREAD_LOCAL_INIT_FUNCTION_POINTERS = 0x15u,
116 INIT_FUNC_OFFSETS = 0x16u,
117 };
118
119 enum class FLAGS : uint64_t {
121 PURE_INSTRUCTIONS = 0x80000000u,
124 NO_TOC = 0x40000000u,
127 STRIP_STATIC_SYMS = 0x20000000u,
129 NO_DEAD_STRIP = 0x10000000u,
131 LIVE_SUPPORT = 0x08000000u,
133 SELF_MODIFYING_CODE = 0x04000000u,
135 DEBUG_INFO = 0x02000000u,
137 SOME_INSTRUCTIONS = 0x00000400u,
139 EXT_RELOC = 0x00000200u,
141 LOC_RELOC = 0x00000100u,
142 };
143
144 public:
145 static std::unique_ptr<Section> create(const details::section_32& sec);
146 static std::unique_ptr<Section> create(const details::section_64& sec);
147
148 static std::unique_ptr<Section> create(std::string name,
149 const content_t& content,
151
152
153 static std::unique_ptr<Section> create(std::string name,
155 return create(std::move(name), /*content=*/{}, type);
156 }
157
158 Section(const details::section_32& sec);
159 Section(const details::section_64& sec);
160
163
164 ~Section() override;
165
166 virtual std::unique_ptr<Section> clone() const {
167 return std::unique_ptr<Section>(new Section(*this));
168 }
169
171
173 return as_writable(static_cast<const Section*>(this)->content());
174 }
175
177 void content(const content_t& data) override;
178
180 const std::string& segment_name() const;
181
183 uint64_t address() const {
184 return virtual_address();
185 }
186
188 uint32_t alignment() const {
189 return align_;
190 }
191
200 uint32_t relocation_offset() const {
201 return relocations_offset_;
202 }
203
205 uint32_t numberof_relocations() const {
206 return nbof_relocations_;
207 }
208
212 FLAGS flags() const {
213 return FLAGS(flags_ & FLAGS_MASK);
214 }
215
218 TYPE type() const {
219 return TYPE(flags_ & TYPE_MASK);
220 }
221
224 uint32_t reserved1() const {
225 return reserved1_;
226 }
227
230 uint32_t reserved2() const {
231 return reserved2_;
232 }
233
236 uint32_t reserved3() const {
237 return reserved3_;
238 }
239
242 std::vector<FLAGS> flags_list() const;
243
245 uint32_t raw_flags() const {
246 return flags_;
247 }
248
250 bool has_segment() const {
251 return segment() != nullptr;
252 }
253
257 return segment_;
258 }
260 return segment_;
261 }
262
264 std::unique_ptr<SpanStream> stream() const;
265
268 void clear(uint8_t v) {
269 span<uint8_t> write_content = content();
270 std::fill(write_content.begin(), write_content.end(), v);
271 }
272
278 return relocations_;
279 }
281 return relocations_;
282 }
283
284 void segment_name(const std::string& name);
285 void address(uint64_t address) {
287 }
288 void alignment(uint32_t align) {
289 align_ = align;
290 }
291 void relocation_offset(uint32_t offset) {
292 relocations_offset_ = offset;
293 }
294 void numberof_relocations(uint32_t nb_reloc) {
295 nbof_relocations_ = nb_reloc;
296 }
297 void flags(uint32_t flags) {
298 flags_ = flags_ | flags;
299 }
300 void flags(std::vector<FLAGS> flags);
301 void type(TYPE type) {
302 flags_ = (flags_ & FLAGS_MASK) | uint8_t(type);
303 }
304 void reserved1(uint32_t reserved1) {
305 reserved1_ = reserved1;
306 }
307 void reserved2(uint32_t reserved2) {
308 reserved2_ = reserved2;
309 }
310 void reserved3(uint32_t reserved3) {
311 reserved3_ = reserved3;
312 }
313
315 bool has(FLAGS flag) const;
316
318 void add(FLAGS flag);
319
321 void remove(FLAGS flag);
322
324 add(flag);
325 return *this;
326 }
328 remove(flag);
329 return *this;
330 }
331
332 template<class T>
333 const T* cast() const {
334 static_assert(std::is_base_of<Section, T>::value,
335 "Require Section inheritance");
336 if (T::classof(this)) {
337 return static_cast<const T*>(this);
338 }
339 return nullptr;
340 }
341
342 template<class T>
343 T* cast() {
344 return const_cast<T*>(static_cast<const Section*>(this)->cast<T>());
345 }
346
347 void accept(Visitor& visitor) const override;
348
349 LIEF_API friend std::ostream& operator<<(std::ostream& os,
350 const Section& section);
351
352 protected:
353 Section();
354
355 Section& operator=(const Section& copy);
356 Section(const Section& copy);
357
358 std::string segment_name_;
359 uint64_t original_size_ = 0;
360 uint32_t align_ = 0;
361 uint32_t relocations_offset_ = 0;
362 uint32_t nbof_relocations_ = 0;
363 uint32_t flags_ = 0;
364 uint32_t reserved1_ = 0;
365 uint32_t reserved2_ = 0;
366 uint32_t reserved3_ = 0;
367 content_t content_;
368 SegmentCommand* segment_ = nullptr;
369 relocations_t relocations_;
370};
371
374
375}
376}
377
379
380#endif
Class used to parse a single binary (i.e. non-FAT).
Definition BinaryParser.hpp:79
Class which represents a MachO binary.
Definition MachO/Binary.hpp:91
Class that represents a Mach-O relocation.
Definition MachO/Relocation.hpp:40
span< const uint8_t > content() const override
Section's content.
void relocation_offset(uint32_t offset)
Definition MachO/Section.hpp:291
Section(const details::section_32 &sec)
uint32_t reserved1() const
According to the official loader.h file, this value is reserved for offset or index.
Definition MachO/Section.hpp:224
void address(uint64_t address)
Definition MachO/Section.hpp:285
ref_iterator< relocations_t &, Relocation * > it_relocations
Iterator which outputs Relocation&.
Definition MachO/Section.hpp:61
std::vector< FLAGS > flags_list() const
Return the Section::flags as a list of Section::FLAGS.
Section & operator+=(FLAGS flag)
Definition MachO/Section.hpp:323
const T * cast() const
Definition MachO/Section.hpp:333
void add(FLAGS flag)
Append a Section::FLAGS to the current section.
static std::unique_ptr< Section > create(const details::section_64 &sec)
void alignment(uint32_t align)
Definition MachO/Section.hpp:288
it_const_relocations relocations() const
Definition MachO/Section.hpp:280
static std::unique_ptr< Section > create(std::string name, const content_t &content, TYPE type=TYPE::REGULAR)
const_ref_iterator< const relocations_t &, const Relocation * > it_const_relocations
Iterator which outputs const Relocation&.
Definition MachO/Section.hpp:64
std::vector< std::unique_ptr< Relocation > > relocations_t
Internal container for storing Mach-O Relocation.
Definition MachO/Section.hpp:58
uint32_t raw_flags() const
Section flags without applying the SECTION_FLAGS_MASK mask.
Definition MachO/Section.hpp:245
T * cast()
Definition MachO/Section.hpp:343
SegmentCommand * segment()
The segment associated with this section or a nullptr if not present.
Definition MachO/Section.hpp:256
void type(TYPE type)
Definition MachO/Section.hpp:301
friend class BinaryParser
Definition MachO/Section.hpp:50
friend std::ostream & operator<<(std::ostream &os, const Section &section)
void flags(std::vector< FLAGS > flags)
static std::unique_ptr< Section > create(std::string name, TYPE type=TYPE::REGULAR)
Definition MachO/Section.hpp:153
std::vector< uint8_t > content_t
Definition MachO/Section.hpp:55
uint32_t relocation_offset() const
Offset of the relocation table. This value should be 0 for executable and libraries as the relocation...
Definition MachO/Section.hpp:200
const std::string & segment_name() const
Return the name of the segment linked to this section.
friend class SegmentCommand
Definition MachO/Section.hpp:52
void clear(uint8_t v)
Clear the content of this section by filling its values with the byte provided in parameter.
Definition MachO/Section.hpp:268
uint64_t address() const
Virtual base address of the section.
Definition MachO/Section.hpp:183
bool has_segment() const
Check if this section is correctly linked with a MachO::SegmentCommand.
Definition MachO/Section.hpp:250
uint32_t reserved3() const
This value is only present for 64 bits Mach-O files. In that case, the value is reserved.
Definition MachO/Section.hpp:236
std::unique_ptr< SpanStream > stream() const
Return a stream over the content of this section.
void remove(FLAGS flag)
Remove a Section::FLAGS to the current section.
friend class Binary
Definition MachO/Section.hpp:51
void content(const content_t &data) override
Update the content of the section.
FLAGS
Definition MachO/Section.hpp:119
Section & operator=(Section &&)
static std::unique_ptr< Section > create(const details::section_32 &sec)
void reserved3(uint32_t reserved3)
Definition MachO/Section.hpp:310
void reserved1(uint32_t reserved1)
Definition MachO/Section.hpp:304
uint32_t alignment() const
Section alignment as a power of 2.
Definition MachO/Section.hpp:188
it_relocations relocations()
Return an iterator over the MachO::Relocation associated with this section.
Definition MachO/Section.hpp:277
TYPE type() const
Type of the section. This value can help to determine the purpose of the section (e....
Definition MachO/Section.hpp:218
bool has(FLAGS flag) const
Check if the section has the given Section::FLAGS flag.
uint32_t numberof_relocations() const
Number of relocations associated with this section.
Definition MachO/Section.hpp:205
virtual std::unique_ptr< Section > clone() const
Definition MachO/Section.hpp:166
TYPE
Definition MachO/Section.hpp:70
@ REGULAR
Regular section.
Definition MachO/Section.hpp:72
void numberof_relocations(uint32_t nb_reloc)
Definition MachO/Section.hpp:294
static constexpr auto TYPE_MASK
Definition MachO/Section.hpp:68
static constexpr auto FLAGS_MASK
Definition MachO/Section.hpp:67
Section & operator-=(FLAGS flag)
Definition MachO/Section.hpp:327
const SegmentCommand * segment() const
Definition MachO/Section.hpp:259
void flags(uint32_t flags)
Definition MachO/Section.hpp:297
void accept(Visitor &visitor) const override
uint32_t reserved2() const
According to the official loader.h file, this value is reserved for count or sizeof.
Definition MachO/Section.hpp:230
void reserved2(uint32_t reserved2)
Definition MachO/Section.hpp:307
Section(const details::section_64 &sec)
FLAGS flags() const
Section's flags masked with SECTION_FLAGS_MASK (see: Section::FLAGS).
Definition MachO/Section.hpp:212
void segment_name(const std::string &name)
Class which represents a LoadCommand::TYPE::SEGMENT / LoadCommand::TYPE::SEGMENT_64 command.
Definition SegmentCommand.hpp:52
Class which represents an abstracted section.
Definition Abstract/Section.hpp:30
virtual std::string name() const
Section's name.
Definition Abstract/Section.hpp:44
virtual uint64_t offset() const
Offset in the binary.
Definition Abstract/Section.hpp:70
virtual uint64_t virtual_address() const
Address where the section should be mapped.
Definition Abstract/Section.hpp:75
Definition SpanStream.hpp:32
Definition Visitor.hpp:212
Iterator which returns reference on container's values.
Definition iterators.hpp:47
#define LIEF_LIFETIMEBOUND
Definition compiler_attributes.hpp:72
#define ENABLE_BITMASK_OPERATORS(X)
Definition enums.hpp:24
Definition endianness_support.hpp:60
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:41
uint64_t align(uint64_t value, uint64_t align_on)
Definition utils.hpp:28
span< uint8_t > as_writable(span< const uint8_t > buffer)
Definition span.hpp:24
tcb::span< ElementType, Extent > span
Definition span.hpp:22
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:320
#define LIEF_API
Definition visibility.h:45