LIEF: Library to Instrument Executable Formats Version 1.0.0
Loading...
Searching...
No Matches
DyldChainedFixups.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_DYLD_CHAINED_FIXUPS_H
17#define LIEF_MACHO_DYLD_CHAINED_FIXUPS_H
18#include <memory>
19#include "LIEF/span.hpp"
20#include "LIEF/iterators.hpp"
22#include "LIEF/visibility.h"
25
26namespace LIEF {
27namespace MachO {
28
29class Binary;
30class BinaryParser;
32class Builder;
34class ChainedBindingInfoList;
36class LinkEdit;
37class SegmentCommand;
38
39namespace details {
40struct linkedit_data_command;
41struct dyld_chained_fixups_header;
42struct dyld_chained_starts_in_segment;
43}
44
51 friend class BinaryParser;
52 friend class Builder;
53 friend class LinkEdit;
54 friend class BindingInfoIterator;
55 friend class Binary;
57
58 public:
64 struct chained_starts_in_segment {
65 uint32_t offset = 0;
67 uint32_t size =
68 0;
69 uint16_t page_size = 0;
71 uint64_t segment_offset =
72 0;
75 0;
78
80 size_t page_count() const {
81 return page_start.size();
82 }
83
84 std::vector<uint16_t> page_start;
86 std::vector<uint16_t> chain_starts;
87
90
91 LIEF_API friend std::ostream&
92 operator<<(std::ostream& os, const chained_starts_in_segment& info);
93
94 static chained_starts_in_segment
96 return chained_starts_in_segment(0, segment);
97 }
98
99 private:
100 friend class BinaryParser;
102 chained_starts_in_segment(uint32_t offset, SegmentCommand& segment) :
103 offset(offset),
104 segment(segment) {}
105 chained_starts_in_segment(uint32_t offset,
106 const details::dyld_chained_starts_in_segment& info,
107 SegmentCommand& segment);
108 };
109
111 using chained_starts_in_segments_t = std::vector<chained_starts_in_segment>;
112
116
120
122 using binding_info_t = std::vector<std::unique_ptr<ChainedBindingInfo>>;
123
126
130
131
133 DyldChainedFixups(const details::linkedit_data_command& cmd);
134 std::unique_ptr<LoadCommand> clone() const override {
135 return std::unique_ptr<DyldChainedFixups>(new DyldChainedFixups(*this));
136 }
137
139
142 uint32_t data_offset() const {
143 return data_offset_;
144 }
145
147 uint32_t data_size() const {
148 return data_size_;
149 }
150
151 void data_offset(uint32_t offset) {
152 data_offset_ = offset;
153 }
154 void data_size(uint32_t size) {
155 data_size_ = size;
156 }
157
160 return content_;
161 }
162
165 return all_bindings_;
166 }
167
170 return all_bindings_;
171 }
172
175 return chained_starts_in_segment_;
176 }
177
178 it_const_chained_starts_in_segments_t
180 return chained_starts_in_segment_;
181 }
182
185 uint32_t fixups_version() const {
186 return fixups_version_;
187 }
188 void fixups_version(uint32_t version) {
189 fixups_version_ = version;
190 }
191
193 uint32_t starts_offset() const {
194 return starts_offset_;
195 }
196 void starts_offset(uint32_t offset) {
197 starts_offset_ = offset;
198 }
199
201 uint32_t imports_offset() const {
202 return imports_offset_;
203 }
204 void imports_offset(uint32_t offset) {
205 imports_offset_ = offset;
206 }
207
209 uint32_t symbols_offset() const {
210 return symbols_offset_;
211 }
212 void symbols_offset(uint32_t offset) {
213 symbols_offset_ = offset;
214 }
215
217 uint32_t imports_count() const {
218 return imports_count_;
219 }
220 void imports_count(uint32_t cnt) {
221 imports_count_ = cnt;
222 }
223
229 uint32_t symbols_format() const {
230 return symbols_format_;
231 }
232 void symbols_format(uint32_t fmt) {
233 symbols_format_ = fmt;
234 }
235
238 return imports_format_;
239 }
241 imports_format_ = fmt;
242 }
243
245 chained_starts_in_segment_.push_back(std::move(start_info));
246 return chained_starts_in_segment_.back();
247 }
248
249 void accept(Visitor& visitor) const override;
250
251 std::ostream& print(std::ostream& os) const override;
252
253 static bool classof(const LoadCommand* cmd) {
255 }
256
257 private:
258 LIEF_LOCAL void update_with(const details::dyld_chained_fixups_header& header);
259 LIEF_LOCAL DyldChainedFixups& operator=(const DyldChainedFixups& other);
261
262 uint32_t data_offset_ = 0;
263 uint32_t data_size_ = 0;
264
265 // Raw payload of the DyldChainedFixups.
266 // This payload is located in the __LINKEDIT segment
267 span<uint8_t> content_;
268
269 uint32_t fixups_version_ = 0;
270 uint32_t starts_offset_ = 0;
271 uint32_t imports_offset_ = 0;
272 uint32_t symbols_offset_ = 0;
273 uint32_t imports_count_ = 0;
274 uint32_t symbols_format_ = 0;
276
277 chained_starts_in_segments_t chained_starts_in_segment_;
278
279 std::vector<std::unique_ptr<ChainedBindingInfoList>> internal_bindings_;
280 binding_info_t all_bindings_;
281};
282
283}
284}
285#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
Definition BindingInfoIterator.hpp:32
Class used to rebuild a Mach-O file.
Definition MachO/Builder.hpp:64
This class represents a symbol binding operation associated with the LC_DYLD_CHAINED_FIXUPS command.
Definition ChainedBindingInfo.hpp:48
Definition DyldChainedFixupsCreator.hpp:41
Class that represents the LC_DYLD_CHAINED_FIXUPS command.
Definition DyldChainedFixups.hpp:50
uint32_t data_offset() const
Offset of the LC_DYLD_CHAINED_FIXUPS chained payload. This offset should point in the __LINKEDIT segm...
Definition DyldChainedFixups.hpp:142
it_const_binding_info bindings() const
Iterator over the bindings (ChainedBindingInfo) associated with this command.
Definition DyldChainedFixups.hpp:169
friend class BindingInfoIterator
Definition DyldChainedFixups.hpp:54
void imports_count(uint32_t cnt)
Definition DyldChainedFixups.hpp:220
void starts_offset(uint32_t offset)
Definition DyldChainedFixups.hpp:196
it_binding_info bindings()
Iterator over the bindings (ChainedBindingInfo) associated with this command.
Definition DyldChainedFixups.hpp:164
it_chained_starts_in_segments_t chained_starts_in_segments()
Iterator over the chained fixup metadata.
Definition DyldChainedFixups.hpp:174
it_const_chained_starts_in_segments_t chained_starts_in_segments() const
Definition DyldChainedFixups.hpp:179
friend class BinaryParser
Definition DyldChainedFixups.hpp:51
void data_size(uint32_t size)
Definition DyldChainedFixups.hpp:154
const_ref_iterator< const chained_starts_in_segments_t & > it_const_chained_starts_in_segments_t
Iterator that outputs const chained_starts_in_segment&.
Definition DyldChainedFixups.hpp:118
uint32_t data_size() const
Size of the LC_DYLD_CHAINED_FIXUPS payload.
Definition DyldChainedFixups.hpp:147
uint32_t symbols_offset() const
Offset of symbol strings in chain data.
Definition DyldChainedFixups.hpp:209
chained_starts_in_segment & add(chained_starts_in_segment start_info)
Definition DyldChainedFixups.hpp:244
void data_offset(uint32_t offset)
Definition DyldChainedFixups.hpp:151
uint32_t symbols_format() const
The compression algorithm (if any) used to store the symbols 0 means uncompressed while 1 means zlib ...
Definition DyldChainedFixups.hpp:229
friend class DyldChainedFixupsCreator
Definition DyldChainedFixups.hpp:56
ref_iterator< binding_info_t &, ChainedBindingInfo * > it_binding_info
Iterator which outputs DyldBindingInfo&.
Definition DyldChainedFixups.hpp:125
std::vector< chained_starts_in_segment > chained_starts_in_segments_t
Internal container for storing chained_starts_in_segment.
Definition DyldChainedFixups.hpp:111
span< const uint8_t > payload() const
Return the raw content of the command.
Definition DyldChainedFixups.hpp:159
friend class Builder
Definition DyldChainedFixups.hpp:52
uint32_t fixups_version() const
Chained fixups version. The loader (dyld v852.2) checks that this value is set to 0.
Definition DyldChainedFixups.hpp:185
const_ref_iterator< const binding_info_t &, ChainedBindingInfo * > it_const_binding_info
Iterator which outputs const DyldBindingInfo&.
Definition DyldChainedFixups.hpp:128
uint32_t imports_offset() const
Offset of imports table in chain data.
Definition DyldChainedFixups.hpp:201
uint32_t imports_count() const
Number of imported symbol names.
Definition DyldChainedFixups.hpp:217
friend class Binary
Definition DyldChainedFixups.hpp:55
friend class LinkEdit
Definition DyldChainedFixups.hpp:53
DYLD_CHAINED_FORMAT imports_format() const
The format of the imports (ChainedBindingInfo).
Definition DyldChainedFixups.hpp:237
void symbols_format(uint32_t fmt)
Definition DyldChainedFixups.hpp:232
void imports_format(DYLD_CHAINED_FORMAT fmt)
Definition DyldChainedFixups.hpp:240
void accept(Visitor &visitor) const override
ref_iterator< chained_starts_in_segments_t & > it_chained_starts_in_segments_t
Iterator that outputs chained_starts_in_segment&.
Definition DyldChainedFixups.hpp:114
std::unique_ptr< LoadCommand > clone() const override
Definition DyldChainedFixups.hpp:134
void imports_offset(uint32_t offset)
Definition DyldChainedFixups.hpp:204
std::ostream & print(std::ostream &os) const override
void fixups_version(uint32_t version)
Definition DyldChainedFixups.hpp:188
void symbols_offset(uint32_t offset)
Definition DyldChainedFixups.hpp:212
std::vector< std::unique_ptr< ChainedBindingInfo > > binding_info_t
Internal container for storing DyldBindingInfo.
Definition DyldChainedFixups.hpp:122
static bool classof(const LoadCommand *cmd)
Definition DyldChainedFixups.hpp:253
uint32_t starts_offset() const
offset of dyld_chained_starts_in_image in chain_data
Definition DyldChainedFixups.hpp:193
DyldChainedFixups(const details::linkedit_data_command &cmd)
Definition LinkEdit.hpp:47
uint32_t size() const
Size of the command (should be greater than sizeof(load_command)).
Definition LoadCommand.hpp:135
LoadCommand::TYPE command() const
Command type.
Definition LoadCommand.hpp:130
@ DYLD_CHAINED_FIXUPS
Definition LoadCommand.hpp:100
Class which represents a LoadCommand::TYPE::SEGMENT / LoadCommand::TYPE::SEGMENT_64 command.
Definition SegmentCommand.hpp:52
Definition Visitor.hpp:212
Iterator which returns reference on container's values.
Definition iterators.hpp:47
#define LIEF_LIFETIMEBOUND
Definition compiler_attributes.hpp:72
Definition endianness_support.hpp:60
Namespace related to the LIEF's Mach-O module.
Definition Abstract/Header.hpp:36
DYLD_CHAINED_FORMAT
Definition DyldChainedFormat.hpp:22
@ IMPORT
Definition DyldChainedFormat.hpp:23
DYLD_CHAINED_PTR_FORMAT
Definition DyldChainedFormat.hpp:29
@ NONE
Definition DyldChainedFormat.hpp:30
LIEF namespace.
Definition Abstract/Binary.hpp:41
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:320
Structure that mirrors the raw dyld_chained_starts_in_segment which aims at providing information abo...
Definition DyldChainedFixups.hpp:64
std::vector< uint16_t > chain_starts
Currently not supported.
Definition DyldChainedFixups.hpp:86
uint16_t page_size
Likely 0x1000 for x86/x86_64 architectures and 0x4000 for ARM64 architecture.
Definition DyldChainedFixups.hpp:69
uint64_t segment_offset
Offset of the segment's data from the beginning of the file (it should match SegmentCommand::file_off...
Definition DyldChainedFixups.hpp:71
friend class BinaryParser
Definition DyldChainedFixups.hpp:100
DYLD_CHAINED_PTR_FORMAT pointer_format
How pointers are encoded.
Definition DyldChainedFixups.hpp:76
friend std::ostream & operator<<(std::ostream &os, const chained_starts_in_segment &info)
friend class DyldChainedFixupsCreator
Definition DyldChainedFixups.hpp:101
uint32_t max_valid_pointer
for 32-bit OS, any value beyond this is not a pointer
Definition DyldChainedFixups.hpp:74
SegmentCommand & segment
Segment in which the rebase/bind fixups take place.
Definition DyldChainedFixups.hpp:89
std::vector< uint16_t > page_start
Offset in the SegmentCommand of the first element of the chain.
Definition DyldChainedFixups.hpp:84
static chained_starts_in_segment create_empty_chained(SegmentCommand &segment)
Definition DyldChainedFixups.hpp:95
uint32_t offset
Original offset of the structure, relative to DyldChainedFixups::starts_offset.
Definition DyldChainedFixups.hpp:65
size_t page_count() const
How many pages are in the page_start array.
Definition DyldChainedFixups.hpp:80
uint32_t size
sizeof(size) + sizeof(page_size) + ... + sizeof(pointer_format)
Definition DyldChainedFixups.hpp:67
#define LIEF_API
Definition visibility.h:45
#define LIEF_LOCAL
Definition visibility.h:46