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
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
65
68 using symbols_t = std::vector<Symbol*>;
69
72
75
77 static std::unique_ptr<Section> parse(BinaryStream& stream);
78
80 uint32_t sizeof_raw_data() const {
81 return size_;
82 }
83
85 uint32_t virtual_size() const {
86 return virtual_size_;
87 }
88
90 span<const uint8_t> content() const override {
91 return content_;
92 }
93
95 uint32_t pointerto_raw_data() const {
96 return offset_;
97 }
98
100 uint32_t pointerto_relocation() const {
101 return pointer_to_relocations_;
102 }
103
109 uint32_t pointerto_line_numbers() const {
110 return pointer_to_linenumbers_;
111 }
112
118 uint16_t numberof_relocations() const {
119 return number_of_relocations_;
120 }
121
123 uint16_t numberof_line_numbers() const {
124 return number_of_linenumbers_;
125 }
126
130 uint32_t characteristics() const {
131 return characteristics_;
132 }
133
136 return (characteristics() & (uint32_t)c) > 0;
137 }
138
140 std::vector<CHARACTERISTICS> characteristics_list() const {
141 return LIEF::PE::Section::characteristics_to_list(characteristics_);
142 }
143
147 bool is_discardable() const {
148 return has_characteristic(CHARACTERISTICS::MEM_DISCARDABLE);
149 }
150
151 void clear(uint8_t c) {
152 std::fill(content_.begin(), content_.end(), c);
153 }
154
157 return relocations_;
158 }
159
161 return relocations_;
162 }
163
166 return symbols_;
167 }
168
170 return symbols_;
171 }
172
176
180 static constexpr auto MAX_RELOC = /*uint16_t::max*/ 65535;
181 return has_characteristic(CHARACTERISTICS::LNK_NRELOC_OVFL) &&
182 numberof_relocations() == MAX_RELOC;
183 }
184
185 void content(const std::vector<uint8_t>& data) override {
186 content_ = data;
187 }
188
189 void name(std::string name) override;
190
191 void virtual_size(uint32_t virtual_sz) {
192 virtual_size_ = virtual_sz;
193 }
194
195 void pointerto_raw_data(uint32_t ptr) {
196 offset(ptr);
197 }
198
199 void pointerto_relocation(uint32_t ptr) {
200 pointer_to_relocations_ = ptr;
201 }
202
203 void pointerto_line_numbers(uint32_t ptr) {
204 pointer_to_linenumbers_ = ptr;
205 }
206
207 void numberof_relocations(uint16_t nb) {
208 number_of_relocations_ = nb;
209 }
210
211 void numberof_line_numbers(uint16_t nb) {
212 number_of_linenumbers_ = nb;
213 }
214
215 void sizeof_raw_data(uint32_t size) {
216 this->size(size);
217 }
218
220 characteristics_ = characteristics;
221 }
222
228 return coff_string_;
229 }
230
231 const String* coff_string() const {
232 return coff_string_;
233 }
234
235 std::string to_string() const;
236
237 LIEF_API friend std::ostream& operator<<(std::ostream& os, const Section& sec) {
238 os << sec.to_string();
239 return os;
240 }
241
242 ~Section() override = default;
243
244 private:
245 Section() = default;
246
247 std::vector<uint8_t> content_;
248 uint32_t virtual_size_ = 0;
249 uint32_t pointer_to_relocations_ = 0;
250 uint32_t pointer_to_linenumbers_ = 0;
251 uint16_t number_of_relocations_ = 0;
252 uint16_t number_of_linenumbers_ = 0;
253 uint32_t characteristics_ = 0;
254
255 relocations_t relocations_;
256 symbols_t symbols_;
257
258 String* coff_string_ = nullptr;
259};
260
261inline const char* to_string(Section::CHARACTERISTICS e) {
262 return LIEF::PE::to_string(e);
263}
264
265}
266}
267#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:68
Definition COFF/Parser.hpp:35
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:237
const_ref_iterator< const symbols_t &, const Symbol * > it_const_symbols
Iterator that outputs const Symbol&.
Definition COFF/Section.hpp:74
void pointerto_relocation(uint32_t ptr)
Definition COFF/Section.hpp:199
uint32_t characteristics() const
Characteristics of the section: it provides information about the permissions of the section when map...
Definition COFF/Section.hpp:130
std::vector< Symbol * > symbols_t
Container for the symbols associated with this section (owned by the Binary object).
Definition COFF/Section.hpp:68
uint16_t numberof_line_numbers() const
Number of line number entries (if any).
Definition COFF/Section.hpp:123
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:227
std::string to_string() const
it_relocations relocations()
Iterator over the relocations associated with this section.
Definition COFF/Section.hpp:156
it_const_relocations relocations() const
Definition COFF/Section.hpp:160
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:179
void virtual_size(uint32_t virtual_sz)
Definition COFF/Section.hpp:191
const_ref_iterator< const relocations_t &, const Relocation * > it_const_relocations
Iterator that outputs const Relocation&.
Definition COFF/Section.hpp:63
void content(const std::vector< uint8_t > &data) override
Change section content.
Definition COFF/Section.hpp:185
ref_iterator< symbols_t &, Symbol * > it_symbols
Iterator that outputs Symbol&.
Definition COFF/Section.hpp:71
it_const_symbols symbols() const
Definition COFF/Section.hpp:169
uint32_t pointerto_relocation() const
Offset to the relocation table.
Definition COFF/Section.hpp:100
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:95
void sizeof_raw_data(uint32_t size)
Definition COFF/Section.hpp:215
const String * coff_string() const
Definition COFF/Section.hpp:231
void numberof_relocations(uint16_t nb)
Definition COFF/Section.hpp:207
span< const uint8_t > content() const override
Content wrapped by this section.
Definition COFF/Section.hpp:90
std::vector< CHARACTERISTICS > characteristics_list() const
List of the section characteristics.
Definition COFF/Section.hpp:140
void pointerto_raw_data(uint32_t ptr)
Definition COFF/Section.hpp:195
void numberof_line_numbers(uint16_t nb)
Definition COFF/Section.hpp:211
~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:109
void clear(uint8_t c)
Definition COFF/Section.hpp:151
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:135
uint32_t virtual_size() const
Virtual size of the section (should be 0).
Definition COFF/Section.hpp:85
uint16_t numberof_relocations() const
Number of relocations.
Definition COFF/Section.hpp:118
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:219
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:203
uint32_t sizeof_raw_data() const
Return the size of the data in the section.
Definition COFF/Section.hpp:80
bool is_discardable() const
True if the section can be discarded as needed.
Definition COFF/Section.hpp:147
it_symbols symbols()
Iterator over the symbols associated with this section.
Definition COFF/Section.hpp:165
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: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:59
virtual std::string name() const
section's name
Definition Abstract/Section.hpp:43
virtual uint64_t offset() const
Offset in the binary.
Definition Abstract/Section.hpp:69
Definition optional.hpp:23
Iterator which returns reference on container's values.
Definition iterators.hpp:45
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:286
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:43