LIEF: Library to Instrument Executable Formats Version 1.0.0
Loading...
Searching...
No Matches
COFF/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_COFF_SECTION_H
17#define LIEF_COFF_SECTION_H
18#include <cstdint>
19#include <memory>
20#include <ostream>
21
23#include "LIEF/visibility.h"
25#include "LIEF/PE/Section.hpp"
27#include "LIEF/iterators.hpp"
28#include "LIEF/optional.hpp"
29
30namespace LIEF {
31class BinaryStream;
32
33namespace COFF {
34class Relocation;
35class Parser;
36class Symbol;
37
38
40class LIEF_API Section : public LIEF::Section {
41 public:
42 friend class Parser;
44
46
50 Symbol* symbol = nullptr;
51 COMDAT_SELECTION kind = COMDAT_SELECTION::NONE;
52 };
53
56
58 using relocations_t = std::vector<Relocation*>;
59
62
66
69 using symbols_t = std::vector<Symbol*>;
70
73
76
78 static std::unique_ptr<Section> parse(BinaryStream& stream);
79
81 uint32_t sizeof_raw_data() const {
82 return size_;
83 }
84
86 uint32_t virtual_size() const {
87 return virtual_size_;
88 }
89
92 return content_;
93 }
94
96 uint32_t pointerto_raw_data() const {
97 return offset_;
98 }
99
101 uint32_t pointerto_relocation() const {
102 return pointer_to_relocations_;
103 }
104
110 uint32_t pointerto_line_numbers() const {
111 return pointer_to_linenumbers_;
112 }
113
119 uint16_t numberof_relocations() const {
120 return number_of_relocations_;
121 }
122
124 uint16_t numberof_line_numbers() const {
125 return number_of_linenumbers_;
126 }
127
131 uint32_t characteristics() const {
132 return characteristics_;
133 }
134
137 return (characteristics() & (uint32_t)c) > 0;
138 }
139
141 std::vector<CHARACTERISTICS> characteristics_list() const {
142 return LIEF::PE::Section::characteristics_to_list(characteristics_);
143 }
144
148 bool is_discardable() const {
149 return has_characteristic(CHARACTERISTICS::MEM_DISCARDABLE);
150 }
151
152 void clear(uint8_t c) {
153 std::fill(content_.begin(), content_.end(), c);
154 }
155
158 return relocations_;
159 }
160
162 return relocations_;
163 }
164
167 return symbols_;
168 }
169
171 return symbols_;
172 }
173
177
181 static constexpr auto MAX_RELOC = /*uint16_t::max*/ 65535;
182 return has_characteristic(CHARACTERISTICS::LNK_NRELOC_OVFL) &&
183 numberof_relocations() == MAX_RELOC;
184 }
185
186 void content(const std::vector<uint8_t>& data) override {
187 content_ = data;
188 }
189
190 void name(std::string name) override;
191
192 void virtual_size(uint32_t virtual_sz) {
193 virtual_size_ = virtual_sz;
194 }
195
196 void pointerto_raw_data(uint32_t ptr) {
197 offset(ptr);
198 }
199
200 void pointerto_relocation(uint32_t ptr) {
201 pointer_to_relocations_ = ptr;
202 }
203
204 void pointerto_line_numbers(uint32_t ptr) {
205 pointer_to_linenumbers_ = ptr;
206 }
207
208 void numberof_relocations(uint16_t nb) {
209 number_of_relocations_ = nb;
210 }
211
212 void numberof_line_numbers(uint16_t nb) {
213 number_of_linenumbers_ = nb;
214 }
215
216 void sizeof_raw_data(uint32_t size) {
217 this->size(size);
218 }
219
221 characteristics_ = characteristics;
222 }
223
229 return coff_string_;
230 }
231
232 const String* coff_string() const {
233 return coff_string_;
234 }
235
236 std::string to_string() const;
237
238 LIEF_API friend std::ostream& operator<<(std::ostream& os, const Section& sec) {
239 os << sec.to_string();
240 return os;
241 }
242
243 ~Section() override = default;
244
245 private:
246 Section() = default;
247
248 std::vector<uint8_t> content_;
249 uint32_t virtual_size_ = 0;
250 uint32_t pointer_to_relocations_ = 0;
251 uint32_t pointer_to_linenumbers_ = 0;
252 uint16_t number_of_relocations_ = 0;
253 uint16_t number_of_linenumbers_ = 0;
254 uint32_t characteristics_ = 0;
255
256 relocations_t relocations_;
257 symbols_t symbols_;
258
259 String* coff_string_ = nullptr;
260};
261
262inline const char* to_string(Section::CHARACTERISTICS e) {
263 return LIEF::PE::to_string(e);
264}
265
266}
267}
268#endif
Class that is used to a read stream of data from different sources.
Definition BinaryStream.hpp:34
COMDAT_SELECTION
Values for the AuxiliarySectionDefinition::selection attribute.
Definition AuxiliarySectionDefinition.hpp:68
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:238
const_ref_iterator< const symbols_t &, const Symbol * > it_const_symbols
Iterator that outputs const Symbol&.
Definition COFF/Section.hpp:75
void pointerto_relocation(uint32_t ptr)
Definition COFF/Section.hpp:200
uint32_t characteristics() const
Characteristics of the section: it provides information about the permissions of the section when map...
Definition COFF/Section.hpp:131
std::vector< Symbol * > symbols_t
Container for the symbols associated with this section (owned by the Binary object).
Definition COFF/Section.hpp:69
uint16_t numberof_line_numbers() const
Number of line number entries (if any).
Definition COFF/Section.hpp:124
void name(std::string name) override
Change the section's name.
String * coff_string()
Return the COFF string associated with the section's name (or a nullptr).
Definition COFF/Section.hpp:228
std::string to_string() const
it_relocations relocations()
Iterator over the relocations associated with this section.
Definition COFF/Section.hpp:157
it_const_relocations relocations() const
Definition COFF/Section.hpp:161
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:180
void virtual_size(uint32_t virtual_sz)
Definition COFF/Section.hpp:192
const_ref_iterator< const relocations_t &, const Relocation * > it_const_relocations
Iterator that outputs const Relocation&.
Definition COFF/Section.hpp:64
void content(const std::vector< uint8_t > &data) override
Change section content.
Definition COFF/Section.hpp:186
ref_iterator< symbols_t &, Symbol * > it_symbols
Iterator that outputs Symbol&.
Definition COFF/Section.hpp:72
it_const_symbols symbols() const
Definition COFF/Section.hpp:170
uint32_t pointerto_relocation() const
Offset to the relocation table.
Definition COFF/Section.hpp:101
std::vector< Relocation * > relocations_t
Container for the relocations in this section (owned by the Binary object).
Definition COFF/Section.hpp:58
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:96
void sizeof_raw_data(uint32_t size)
Definition COFF/Section.hpp:216
const String * coff_string() const
Definition COFF/Section.hpp:232
void numberof_relocations(uint16_t nb)
Definition COFF/Section.hpp:208
span< const uint8_t > content() const override
Content wrapped by this section.
Definition COFF/Section.hpp:91
std::vector< CHARACTERISTICS > characteristics_list() const
List of the section characteristics.
Definition COFF/Section.hpp:141
void pointerto_raw_data(uint32_t ptr)
Definition COFF/Section.hpp:196
void numberof_line_numbers(uint16_t nb)
Definition COFF/Section.hpp:212
~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:110
void clear(uint8_t c)
Definition COFF/Section.hpp:152
AuxiliarySectionDefinition::COMDAT_SELECTION COMDAT_SELECTION
Definition COFF/Section.hpp:45
friend class Parser
Definition COFF/Section.hpp:42
bool has_characteristic(CHARACTERISTICS c) const
Check if the section has the given CHARACTERISTICS.
Definition COFF/Section.hpp:136
uint32_t virtual_size() const
Virtual size of the section (should be 0).
Definition COFF/Section.hpp:86
uint16_t numberof_relocations() const
Number of relocations.
Definition COFF/Section.hpp:119
ref_iterator< relocations_t &, Relocation * > it_relocations
Iterator that outputs Relocation&.
Definition COFF/Section.hpp:61
optional< ComdatInfo > comdat_info() const
Return comdat information (only if the section has the CHARACTERISTICS::LNK_COMDAT characteristic).
void characteristics(uint32_t characteristics)
Definition COFF/Section.hpp:220
LIEF::PE::Section::CHARACTERISTICS CHARACTERISTICS
Mirror Characteristics from PE.
Definition COFF/Section.hpp:55
void pointerto_line_numbers(uint32_t ptr)
Definition COFF/Section.hpp:204
uint32_t sizeof_raw_data() const
Return the size of the data in the section.
Definition COFF/Section.hpp:81
bool is_discardable() const
True if the section can be discarded as needed.
Definition COFF/Section.hpp:148
it_symbols symbols()
Iterator over the symbols associated with this section.
Definition COFF/Section.hpp:166
This class represents a string located in the COFF string table.
Definition String.hpp:34
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:57
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 optional.hpp:23
Iterator which returns reference on container's values.
Definition iterators.hpp:47
#define LIEF_LIFETIMEBOUND
Definition compiler_attributes.hpp:72
Definition AuxiliarySymbol.hpp:30
const char * to_string(AuxiliarySectionDefinition::COMDAT_SELECTION e)
const char * to_string(CODE_PAGES e)
LIEF namespace.
Definition Abstract/Binary.hpp:41
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
This structure wraps comdat information which is composed of the symbol associated with the comdat se...
Definition COFF/Section.hpp:49
COMDAT_SELECTION kind
Definition COFF/Section.hpp:51
Symbol * symbol
Definition COFF/Section.hpp:50
#define LIEF_API
Definition visibility.h:45