LIEF: Library to Instrument Executable Formats Version 0.17.0
Loading...
Searching...
No Matches
COFF/Section.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_COFF_SECTION_H
17#define LIEF_COFF_SECTION_H
18#include <cstdint>
19#include <memory>
20#include <ostream>
21
22#include "LIEF/visibility.h"
24#include "LIEF/PE/Section.hpp"
26#include "LIEF/iterators.hpp"
27#include "LIEF/optional.hpp"
28
29namespace LIEF {
30class BinaryStream;
31
32namespace COFF {
33class Relocation;
34class Parser;
35class Symbol;
36
37
39class LIEF_API Section : public LIEF::Section {
40 public:
41 friend class Parser;
43
45
49 Symbol* symbol = nullptr;
50 COMDAT_SELECTION kind = COMDAT_SELECTION::NONE;
51 };
52
55
57 using relocations_t = std::vector<Relocation*>;
58
61
64
66 using symbols_t = std::vector<Symbol*>;
67
70
73
75 static std::unique_ptr<Section> parse(BinaryStream& stream);
76
78 uint32_t sizeof_raw_data() const {
79 return size_;
80 }
81
83 uint32_t virtual_size() const {
84 return virtual_size_;
85 }
86
88 span<const uint8_t> content() const override {
89 return content_;
90 }
91
93 uint32_t pointerto_raw_data() const {
94 return offset_;
95 }
96
98 uint32_t pointerto_relocation() const {
99 return pointer_to_relocations_;
100 }
101
107 uint32_t pointerto_line_numbers() const {
108 return pointer_to_linenumbers_;
109 }
110
116 uint16_t numberof_relocations() const {
117 return number_of_relocations_;
118 }
119
121 uint16_t numberof_line_numbers() const {
122 return number_of_linenumbers_;
123 }
124
128 uint32_t characteristics() const {
129 return characteristics_;
130 }
131
134 return (characteristics() & (uint32_t)c) > 0;
135 }
136
138 std::vector<CHARACTERISTICS> characteristics_list() const {
139 return LIEF::PE::Section::characteristics_to_list(characteristics_);
140 }
141
145 bool is_discardable() const {
146 return has_characteristic(CHARACTERISTICS::MEM_DISCARDABLE);
147 }
148
149 void clear(uint8_t c) {
150 std::fill(content_.begin(), content_.end(), c);
151 }
152
155 return relocations_;
156 }
157
159 return relocations_;
160 }
161
164 return symbols_;
165 }
166
168 return symbols_;
169 }
170
174
178 return has_characteristic(CHARACTERISTICS::LNK_NRELOC_OVFL) &&
179 numberof_relocations() == std::numeric_limits<uint16_t>::max();
180 }
181
182 void content(const std::vector<uint8_t>& data) override {
183 content_ = data;
184 }
185
186 void name(std::string name) override;
187
188 void virtual_size(uint32_t virtual_sz) {
189 virtual_size_ = virtual_sz;
190 }
191
192 void pointerto_raw_data(uint32_t ptr) {
193 offset(ptr);
194 }
195
196 void pointerto_relocation(uint32_t ptr) {
197 pointer_to_relocations_ = ptr;
198 }
199
200 void pointerto_line_numbers(uint32_t ptr) {
201 pointer_to_linenumbers_ = ptr;
202 }
203
204 void numberof_relocations(uint16_t nb) {
205 number_of_relocations_ = nb;
206 }
207
208 void numberof_line_numbers(uint16_t nb) {
209 number_of_linenumbers_ = nb;
210 }
211
212 void sizeof_raw_data(uint32_t size) {
213 this->size(size);
214 }
215
217 characteristics_ = characteristics;
218 }
219
220 std::string to_string() const;
221
222 LIEF_API friend std::ostream& operator<<(std::ostream& os, const Section& sec) {
223 os << sec.to_string();
224 return os;
225 }
226
227 ~Section() override = default;
228
229 private:
230 Section() = default;
231
232 std::vector<uint8_t> content_;
233 uint32_t virtual_size_ = 0;
234 uint32_t pointer_to_relocations_ = 0;
235 uint32_t pointer_to_linenumbers_ = 0;
236 uint16_t number_of_relocations_ = 0;
237 uint16_t number_of_linenumbers_ = 0;
238 uint32_t characteristics_ = 0;
239
240 relocations_t relocations_;
241 symbols_t symbols_;
242};
243
244inline const char* to_string(Section::CHARACTERISTICS e) {
245 return LIEF::PE::to_string(e);
246}
247
248}
249}
250#endif
Class that is used to a read stream of data from different sources.
Definition BinaryStream.hpp:33
COMDAT_SELECTION
Values for the AuxiliarySectionDefinition::selection attribute.
Definition AuxiliarySectionDefinition.hpp:66
Definition COFF/Parser.hpp:34
This class represents a COFF relocation.
Definition COFF/Relocation.hpp:34
friend std::ostream & operator<<(std::ostream &os, const Section &sec)
Definition COFF/Section.hpp:222
const_ref_iterator< const symbols_t &, const Symbol * > it_const_symbols
Iterator that outputs const Symbol&.
Definition COFF/Section.hpp:72
void pointerto_relocation(uint32_t ptr)
Definition COFF/Section.hpp:196
uint32_t characteristics() const
Characteristics of the section: it provides information about the permissions of the section when map...
Definition COFF/Section.hpp:128
std::vector< Symbol * > symbols_t
Container for the symbols associated with this section (owned by the Binary object).
Definition COFF/Section.hpp:66
uint16_t numberof_line_numbers() const
Number of line number entries (if any).
Definition COFF/Section.hpp:121
void name(std::string name) override
Change the section's name.
std::string to_string() const
it_relocations relocations()
Iterator over the relocations associated with this section.
Definition COFF/Section.hpp:154
it_const_relocations relocations() const
Definition COFF/Section.hpp:158
bool has_extended_relocations() const
Whether there is a large number of relocations whose number need to be stored in the virtual address ...
Definition COFF/Section.hpp:177
void virtual_size(uint32_t virtual_sz)
Definition COFF/Section.hpp:188
void content(const std::vector< uint8_t > &data) override
Change section content.
Definition COFF/Section.hpp:182
ref_iterator< symbols_t &, Symbol * > it_symbols
Iterator that outputs Symbol&.
Definition COFF/Section.hpp:69
it_const_symbols symbols() const
Definition COFF/Section.hpp:167
uint32_t pointerto_relocation() const
Offset to the relocation table.
Definition COFF/Section.hpp:98
std::vector< Relocation * > relocations_t
Container for the relocations in this section (owned by the Binary object).
Definition COFF/Section.hpp:57
static std::unique_ptr< Section > parse(BinaryStream &stream)
Parse a section from the given stream.
uint32_t pointerto_raw_data() const
Offset to the section's content.
Definition COFF/Section.hpp:93
void sizeof_raw_data(uint32_t size)
Definition COFF/Section.hpp:212
void numberof_relocations(uint16_t nb)
Definition COFF/Section.hpp:204
span< const uint8_t > content() const override
Content wrapped by this section.
Definition COFF/Section.hpp:88
std::vector< CHARACTERISTICS > characteristics_list() const
List of the section characteristics.
Definition COFF/Section.hpp:138
void pointerto_raw_data(uint32_t ptr)
Definition COFF/Section.hpp:192
void numberof_line_numbers(uint16_t nb)
Definition COFF/Section.hpp:208
~Section() override=default
uint32_t pointerto_line_numbers() const
The file pointer to the beginning of line-number entries for the section.
Definition COFF/Section.hpp:107
void clear(uint8_t c)
Definition COFF/Section.hpp:149
AuxiliarySectionDefinition::COMDAT_SELECTION COMDAT_SELECTION
Definition COFF/Section.hpp:44
friend class Parser
Definition COFF/Section.hpp:41
bool has_characteristic(CHARACTERISTICS c) const
Check if the section has the given CHARACTERISTICS.
Definition COFF/Section.hpp:133
uint32_t virtual_size() const
Virtual size of the section (should be 0).
Definition COFF/Section.hpp:83
uint16_t numberof_relocations() const
Number of relocations.
Definition COFF/Section.hpp:116
ref_iterator< relocations_t &, Relocation * > it_relocations
Iterator that outputs Relocation&.
Definition COFF/Section.hpp:60
optional< ComdatInfo > comdat_info() const
Return comdat infomration (only if the section has the CHARACTERISTICS::LNK_COMDAT characteristic).
void characteristics(uint32_t characteristics)
Definition COFF/Section.hpp:216
LIEF::PE::Section::CHARACTERISTICS CHARACTERISTICS
Mirror Characteristics from PE.
Definition COFF/Section.hpp:54
void pointerto_line_numbers(uint32_t ptr)
Definition COFF/Section.hpp:200
uint32_t sizeof_raw_data() const
Return the size of the data in the section.
Definition COFF/Section.hpp:78
bool is_discardable() const
True if the section can be discarded as needed.
Definition COFF/Section.hpp:145
it_symbols symbols()
Iterator over the symbols associated with this section.
Definition COFF/Section.hpp:163
const_ref_iterator< const relocations_t &, const Relocation * > it_const_relocations
Iterator that outputs const Relocation&.
Definition COFF/Section.hpp:63
This class represents a COFF symbol.
Definition COFF/Symbol.hpp:35
static std::vector< CHARACTERISTICS > characteristics_to_list(uint32_t value)
CHARACTERISTICS
Definition PE/Section.hpp:56
Class which represents an abstracted section.
Definition Abstract/Section.hpp:29
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 optional.hpp:23
Iterator which returns reference on container's values.
Definition iterators.hpp:46
Definition AuxiliarySymbol.hpp:29
const char * to_string(AuxiliarySectionDefinition::COMDAT_SELECTION e)
const char * to_string(CODE_PAGES e)
LIEF namespace.
Definition Abstract/Binary.hpp:40
tcb::span< ElementType, Extent > span
Definition span.hpp:22
ref_iterator< CT, U, typename decay_t< CT >::const_iterator > const_ref_iterator
Iterator which return const ref on container's values.
Definition iterators.hpp:257
This structure wraps comdat information which is composed of the symbol associated with the comdat se...
Definition COFF/Section.hpp:48
COMDAT_SELECTION kind
Definition COFF/Section.hpp:50
Symbol * symbol
Definition COFF/Section.hpp:49
#define LIEF_API
Definition visibility.h:41