LIEF: Library to Instrument Executable Formats Version 1.0.0
Loading...
Searching...
No Matches
PE/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_PE_SECTION_H
17#define LIEF_PE_SECTION_H
18#include <ostream>
19#include <vector>
20#include <string>
21#include <memory>
22
23#include "LIEF/iostream.hpp"
25#include "LIEF/visibility.h"
27#include "LIEF/enums.hpp"
28
29namespace LIEF {
30class SpanStream;
31
32namespace COFF {
33class String;
34}
35
36namespace PE {
37
38class Parser;
39class Builder;
40class Binary;
41
42namespace details {
43struct pe_section;
44}
45
48
49 friend class Parser;
50 friend class Builder;
51 friend class Binary;
52
53 public:
55 static constexpr size_t MAX_SECTION_NAME = 8;
56
57 enum class CHARACTERISTICS : uint64_t {
58 TYPE_NO_PAD = 0x00000008,
59 CNT_CODE = 0x00000020,
60 CNT_INITIALIZED_DATA = 0x00000040,
61 CNT_UNINITIALIZED_DATA = 0x00000080,
62 LNK_OTHER = 0x00000100,
63 LNK_INFO = 0x00000200,
64 LNK_REMOVE = 0x00000800,
65 LNK_COMDAT = 0x00001000,
66 GPREL = 0x00008000,
67 MEM_PURGEABLE = 0x00010000,
68 MEM_16BIT = 0x00020000,
69 MEM_LOCKED = 0x00040000,
70 MEM_PRELOAD = 0x00080000,
71 ALIGN_1BYTES = 0x00100000,
72 ALIGN_2BYTES = 0x00200000,
73 ALIGN_4BYTES = 0x00300000,
74 ALIGN_8BYTES = 0x00400000,
75 ALIGN_16BYTES = 0x00500000,
76 ALIGN_32BYTES = 0x00600000,
77 ALIGN_64BYTES = 0x00700000,
78 ALIGN_128BYTES = 0x00800000,
79 ALIGN_256BYTES = 0x00900000,
80 ALIGN_512BYTES = 0x00A00000,
81 ALIGN_1024BYTES = 0x00B00000,
82 ALIGN_2048BYTES = 0x00C00000,
83 ALIGN_4096BYTES = 0x00D00000,
84 ALIGN_8192BYTES = 0x00E00000,
85 LNK_NRELOC_OVFL = 0x01000000,
86 MEM_DISCARDABLE = 0x02000000,
87 MEM_NOT_CACHED = 0x04000000,
88 MEM_NOT_PAGED = 0x08000000,
89 MEM_SHARED = 0x10000000,
90 MEM_EXECUTE = 0x20000000,
91 MEM_READ = 0x40000000,
92 MEM_WRITE = 0x80000000,
93 };
94
95 Section(const details::pe_section& header);
96 Section() = default;
97 Section(std::string name) :
98 Section::Section() {
99 name_ = std::move(name);
100 }
101
102 Section(std::string name, std::vector<uint8_t> content) :
103 Section(std::move(name)) {
104 content_ = std::move(content);
105 size_ = content_.size();
106 }
107
108 Section& operator=(const Section&) = default;
109 Section(const Section&) = default;
110 ~Section() override = default;
111
113 uint32_t sizeof_raw_data() const;
114
118 uint32_t virtual_size() const {
119 return virtual_size_;
120 }
121
124 return content_;
125 }
126
129 return padding_;
130 }
131
133 uint32_t pointerto_raw_data() const;
134
141 uint32_t pointerto_relocation() const {
142 return pointer_to_relocations_;
143 }
144
149 uint32_t pointerto_line_numbers() const {
150 return pointer_to_linenumbers_;
151 }
152
154 uint16_t numberof_relocations() const {
155 return number_of_relocations_;
156 }
157
159 uint16_t numberof_line_numbers() const {
160 return number_of_linenumbers_;
161 }
162
166 uint32_t characteristics() const {
167 return characteristics_;
168 }
169
172 return (characteristics() & (uint32_t)c) > 0;
173 }
174
176 std::vector<CHARACTERISTICS> characteristics_list() const {
177 return characteristics_to_list(characteristics_);
178 }
179
186
188 void clear(uint8_t c);
189 void content(const std::vector<uint8_t>& data) override;
190
191 void name(std::string name) override;
192
193 void virtual_size(uint32_t virtual_sz) {
194 virtual_size_ = virtual_sz;
195 }
196
197 void pointerto_raw_data(uint32_t ptr) {
198 offset(ptr);
199 }
200
201 void pointerto_relocation(uint32_t ptr) {
202 pointer_to_relocations_ = ptr;
203 }
204
205 void pointerto_line_numbers(uint32_t ptr) {
206 pointer_to_linenumbers_ = ptr;
207 }
208
209 void numberof_relocations(uint16_t nb) {
210 number_of_relocations_ = nb;
211 }
212
213 void numberof_line_numbers(uint16_t nb) {
214 number_of_linenumbers_ = nb;
215 }
216
217 void sizeof_raw_data(uint32_t size) {
218 this->size(size);
219 }
220
222 characteristics_ = characteristics;
223 }
224
230 return coff_string_;
231 }
232
233 const COFF::String* coff_string() const {
234 return coff_string_;
235 }
236
238 characteristics_ &= ~static_cast<size_t>(characteristic);
239 return *this;
240 }
241
243 characteristics_ |= static_cast<size_t>(characteristic);
244 return *this;
245 }
246
247 std::unique_ptr<SpanStream> stream() const;
248
250 LIEF_LOCAL Section& reserve(size_t size, uint8_t value = 0) {
251 content_.resize(size, value);
252 return *this;
253 }
254
257 return vector_iostream(content_);
258 }
259
261 return content_;
262 }
263
264 void accept(Visitor& visitor) const override;
265
266 LIEF_API friend std::ostream& operator<<(std::ostream& os,
267 const Section& section);
268
269 static std::vector<CHARACTERISTICS> characteristics_to_list(uint32_t value);
270
271 private:
272 std::vector<uint8_t> content_;
273 std::vector<uint8_t> padding_;
274 uint32_t virtual_size_ = 0;
275 uint32_t pointer_to_relocations_ = 0;
276 uint32_t pointer_to_linenumbers_ = 0;
277 uint16_t number_of_relocations_ = 0;
278 uint16_t number_of_linenumbers_ = 0;
279 uint32_t characteristics_ = 0;
280
281 COFF::String* coff_string_ = nullptr;
282};
283
285
286} // namespace PE
287} // namespace LIEF
288
290
291#endif
This class represents a string located in the COFF string table.
Definition String.hpp:34
Class which represents a PE binary This is the main interface to manage and modify a PE executable.
Definition PE/Binary.hpp:57
Class that is used to rebuild a raw PE binary from a PE::Binary object.
Definition PE/Builder.hpp:45
Main interface to parse PE binaries. In particular, the static Parser::parse functions should be used...
Definition PE/Parser.hpp:52
Section(const Section &)=default
uint32_t pointerto_line_numbers() const
The file pointer to the beginning of line-number entries for the section. This is set to zero if ther...
Definition PE/Section.hpp:149
void sizeof_raw_data(uint32_t size)
Definition PE/Section.hpp:217
Section(std::string name)
Definition PE/Section.hpp:97
uint32_t pointerto_relocation() const
The file pointer to the beginning of the COFF relocation entries for the section. This is set to zero...
Definition PE/Section.hpp:141
Section & remove_characteristic(CHARACTERISTICS characteristic)
Definition PE/Section.hpp:237
static std::vector< CHARACTERISTICS > characteristics_to_list(uint32_t value)
friend std::ostream & operator<<(std::ostream &os, const Section &section)
Section & operator=(const Section &)=default
bool has_characteristic(CHARACTERISTICS c) const
Check if the section has the given CHARACTERISTICS.
Definition PE/Section.hpp:171
uint16_t numberof_line_numbers() const
No longer used in recent PE binaries produced by Visual Studio.
Definition PE/Section.hpp:159
bool is_discardable() const
True if the section can be discarded as needed.
Definition PE/Section.hpp:183
~Section() override=default
CHARACTERISTICS
Definition PE/Section.hpp:57
@ MEM_DISCARDABLE
Definition PE/Section.hpp:86
const COFF::String * coff_string() const
Definition PE/Section.hpp:233
friend class Builder
Definition PE/Section.hpp:50
span< const uint8_t > content() const override
The actual content of the section.
Definition PE/Section.hpp:123
void clear(uint8_t c)
Fill the content of the section with the given char.
void pointerto_raw_data(uint32_t ptr)
Definition PE/Section.hpp:197
std::vector< CHARACTERISTICS > characteristics_list() const
List of the section characteristics.
Definition PE/Section.hpp:176
uint32_t characteristics() const
Characteristics of the section: it provides information about the permissions of the section when map...
Definition PE/Section.hpp:166
void name(std::string name) override
Change the section's name.
static constexpr size_t MAX_SECTION_NAME
Definition PE/Section.hpp:55
friend class Binary
Definition PE/Section.hpp:51
void pointerto_relocation(uint32_t ptr)
Definition PE/Section.hpp:201
uint32_t sizeof_raw_data() const
Return the size of the data in the section.
span< const uint8_t > padding() const
Content of the section's padding area.
Definition PE/Section.hpp:128
void pointerto_line_numbers(uint32_t ptr)
Definition PE/Section.hpp:205
std::unique_ptr< SpanStream > stream() const
span< uint8_t > writable_content()
Definition PE/Section.hpp:260
friend class Parser
Definition PE/Section.hpp:49
void characteristics(uint32_t characteristics)
Definition PE/Section.hpp:221
void virtual_size(uint32_t virtual_sz)
Definition PE/Section.hpp:193
void content(const std::vector< uint8_t > &data) override
Change section content.
uint32_t pointerto_raw_data() const
The offset of the section data in the PE file.
void numberof_line_numbers(uint16_t nb)
Definition PE/Section.hpp:213
Section(const details::pe_section &header)
uint16_t numberof_relocations() const
No longer used in recent PE binaries produced by Visual Studio.
Definition PE/Section.hpp:154
COFF::String * coff_string()
Return the COFF string associated with the section's name (or a nullptr).
Definition PE/Section.hpp:229
void accept(Visitor &visitor) const override
Section(std::string name, std::vector< uint8_t > content)
Definition PE/Section.hpp:102
uint32_t virtual_size() const
Return the size of the data when mapped in memory.
Definition PE/Section.hpp:118
Section & add_characteristic(CHARACTERISTICS characteristic)
Definition PE/Section.hpp:242
void numberof_relocations(uint16_t nb)
Definition PE/Section.hpp:209
Class which represents an abstracted section.
Definition Abstract/Section.hpp:30
virtual void size(uint64_t size)
Change the section size.
Definition Abstract/Section.hpp:60
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
Definition SpanStream.hpp:32
Definition Visitor.hpp:212
Definition iostream.hpp:32
#define LIEF_LIFETIMEBOUND
Definition compiler_attributes.hpp:72
#define ENABLE_BITMASK_OPERATORS(X)
Definition enums.hpp:24
Definition AuxiliarySymbol.hpp:30
Definition DataDirectory.hpp:37
Namespace related to the LIEF's PE module.
Definition Abstract/Header.hpp:32
const char * to_string(CODE_PAGES e)
LIEF namespace.
Definition Abstract/Binary.hpp:41
tcb::span< ElementType, Extent > span
Definition span.hpp:22
#define LIEF_API
Definition visibility.h:45
#define LIEF_LOCAL
Definition visibility.h:46