/Users/buildslave/jenkins/workspace/coverage/llvm-project/lldb/include/lldb/Core/AddressRange.h
Line | Count | Source (jump to first uncovered line) |
1 | | //===-- AddressRange.h ------------------------------------------*- C++ -*-===// |
2 | | // |
3 | | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
4 | | // See https://llvm.org/LICENSE.txt for license information. |
5 | | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
6 | | // |
7 | | //===----------------------------------------------------------------------===// |
8 | | |
9 | | #ifndef LLDB_CORE_ADDRESSRANGE_H |
10 | | #define LLDB_CORE_ADDRESSRANGE_H |
11 | | |
12 | | #include "lldb/Core/Address.h" |
13 | | #include "lldb/lldb-forward.h" |
14 | | #include "lldb/lldb-types.h" |
15 | | |
16 | | #include <cstddef> |
17 | | |
18 | | namespace lldb_private { |
19 | | class SectionList; |
20 | | class Stream; |
21 | | class Target; |
22 | | |
23 | | /// \class AddressRange AddressRange.h "lldb/Core/AddressRange.h" |
24 | | /// A section + offset based address range class. |
25 | | class AddressRange { |
26 | | public: |
27 | | /// Default constructor. |
28 | | /// |
29 | | /// Initialize with a invalid section (NULL), an invalid offset |
30 | | /// (LLDB_INVALID_ADDRESS), and zero byte size. |
31 | | AddressRange(); |
32 | | |
33 | | /// Construct with a section pointer, offset, and byte_size. |
34 | | /// |
35 | | /// Initialize the address with the supplied \a section, \a offset and \a |
36 | | /// byte_size. |
37 | | /// |
38 | | /// \param[in] section |
39 | | /// A section pointer to a valid lldb::Section, or NULL if the |
40 | | /// address doesn't have a section or will get resolved later. |
41 | | /// |
42 | | /// \param[in] offset |
43 | | /// The offset in bytes into \a section. |
44 | | /// |
45 | | /// \param[in] byte_size |
46 | | /// The size in bytes of the address range. |
47 | | AddressRange(const lldb::SectionSP §ion, lldb::addr_t offset, |
48 | | lldb::addr_t byte_size); |
49 | | |
50 | | /// Construct with a virtual address, section list and byte size. |
51 | | /// |
52 | | /// Initialize and resolve the address with the supplied virtual address \a |
53 | | /// file_addr, and byte size \a byte_size. |
54 | | /// |
55 | | /// \param[in] file_addr |
56 | | /// A virtual address. |
57 | | /// |
58 | | /// \param[in] byte_size |
59 | | /// The size in bytes of the address range. |
60 | | /// |
61 | | /// \param[in] section_list |
62 | | /// A list of sections, one of which may contain the \a vaddr. |
63 | | AddressRange(lldb::addr_t file_addr, lldb::addr_t byte_size, |
64 | | const SectionList *section_list = nullptr); |
65 | | |
66 | | /// Construct with a Address object address and byte size. |
67 | | /// |
68 | | /// Initialize by copying the section offset address in \a so_addr, and |
69 | | /// setting the byte size to \a byte_size. |
70 | | /// |
71 | | /// \param[in] so_addr |
72 | | /// A section offset address object. |
73 | | /// |
74 | | /// \param[in] byte_size |
75 | | /// The size in bytes of the address range. |
76 | | AddressRange(const Address &so_addr, lldb::addr_t byte_size); |
77 | | |
78 | | /// Destructor. |
79 | | /// |
80 | | /// The destructor is virtual in case this class is subclassed. |
81 | | ~AddressRange(); |
82 | | |
83 | | /// Clear the object's state. |
84 | | /// |
85 | | /// Sets the section to an invalid value (NULL), an invalid offset |
86 | | /// (LLDB_INVALID_ADDRESS) and a zero byte size. |
87 | | void Clear(); |
88 | | |
89 | | /// Check if a section offset address is contained in this range. |
90 | | /// |
91 | | /// \param[in] so_addr |
92 | | /// A section offset address object reference. |
93 | | /// |
94 | | /// \return |
95 | | /// Returns \b true if \a so_addr is contained in this range, |
96 | | /// \b false otherwise. |
97 | | bool Contains(const Address &so_addr) const; |
98 | | |
99 | | /// Check if a section offset address is contained in this range. |
100 | | /// |
101 | | /// \param[in] so_addr_ptr |
102 | | /// A section offset address object pointer. |
103 | | /// |
104 | | /// \return |
105 | | /// Returns \b true if \a so_addr is contained in this range, |
106 | | /// \b false otherwise. |
107 | | // bool |
108 | | // Contains (const Address *so_addr_ptr) const; |
109 | | |
110 | | /// Check if a section offset \a so_addr when represented as a file address |
111 | | /// is contained within this object's file address range. |
112 | | /// |
113 | | /// \param[in] so_addr |
114 | | /// A section offset address object reference. |
115 | | /// |
116 | | /// \return |
117 | | /// Returns \b true if both \a this and \a so_addr have |
118 | | /// resolvable file address values and \a so_addr is contained |
119 | | /// in the address range, \b false otherwise. |
120 | | bool ContainsFileAddress(const Address &so_addr) const; |
121 | | |
122 | | /// Check if the resolved file address \a file_addr is contained within this |
123 | | /// object's file address range. |
124 | | /// |
125 | | /// \param[in] file_addr |
126 | | /// A section offset address object reference. |
127 | | /// |
128 | | /// \return |
129 | | /// Returns \b true if both \a this has a resolvable file |
130 | | /// address value and \a so_addr is contained in the address |
131 | | /// range, \b false otherwise. |
132 | | bool ContainsFileAddress(lldb::addr_t file_addr) const; |
133 | | |
134 | | /// Check if a section offset \a so_addr when represented as a load address |
135 | | /// is contained within this object's load address range. |
136 | | /// |
137 | | /// \param[in] so_addr |
138 | | /// A section offset address object reference. |
139 | | /// |
140 | | /// \return |
141 | | /// Returns \b true if both \a this and \a so_addr have |
142 | | /// resolvable load address values and \a so_addr is contained |
143 | | /// in the address range, \b false otherwise. |
144 | | bool ContainsLoadAddress(const Address &so_addr, Target *target) const; |
145 | | |
146 | | /// Check if the resolved load address \a load_addr is contained within this |
147 | | /// object's load address range. |
148 | | /// |
149 | | /// \return |
150 | | /// Returns \b true if both \a this has a resolvable load |
151 | | /// address value and \a so_addr is contained in the address |
152 | | /// range, \b false otherwise. |
153 | | bool ContainsLoadAddress(lldb::addr_t load_addr, Target *target) const; |
154 | | |
155 | | //------------------------------------------------------------------ |
156 | | /// Extends this range with \b rhs_range if it overlaps this range on the |
157 | | /// right side. The range overlaps on the right side if the base address |
158 | | /// of \b rhs_range lies within this range or if it's contiguous on its |
159 | | /// right side. |
160 | | /// |
161 | | /// @param[in] rhs_range |
162 | | /// The range to extend at the right side. |
163 | | /// |
164 | | /// @return |
165 | | /// Returns \b true if this range was extended, \b false otherwise. |
166 | | //------------------------------------------------------------------ |
167 | | bool Extend(const AddressRange &rhs_range); |
168 | | |
169 | | /// Dump a description of this object to a Stream. |
170 | | /// |
171 | | /// Dump a description of the contents of this object to the supplied stream |
172 | | /// \a s. There are many ways to display a section offset based address |
173 | | /// range, and \a style lets the user choose how the base address gets |
174 | | /// displayed. |
175 | | /// |
176 | | /// \param[in] s |
177 | | /// The stream to which to dump the object description. |
178 | | /// |
179 | | /// \param[in] style |
180 | | /// The display style for the address. |
181 | | /// |
182 | | /// \return |
183 | | /// Returns \b true if the address was able to be displayed. |
184 | | /// File and load addresses may be unresolved and it may not be |
185 | | /// possible to display a valid value, \b false will be returned |
186 | | /// in such cases. |
187 | | /// |
188 | | /// \see Address::DumpStyle |
189 | | bool |
190 | | Dump(Stream *s, Target *target, Address::DumpStyle style, |
191 | | Address::DumpStyle fallback_style = Address::DumpStyleInvalid) const; |
192 | | |
193 | | /// Dump a debug description of this object to a Stream. |
194 | | /// |
195 | | /// Dump a debug description of the contents of this object to the supplied |
196 | | /// stream \a s. |
197 | | /// |
198 | | /// The debug description contains verbose internal state such and pointer |
199 | | /// values, reference counts, etc. |
200 | | /// |
201 | | /// \param[in] s |
202 | | /// The stream to which to dump the object description. |
203 | | void DumpDebug(Stream *s) const; |
204 | | |
205 | | /// Get accessor for the base address of the range. |
206 | | /// |
207 | | /// \return |
208 | | /// A reference to the base address object. |
209 | 277M | Address &GetBaseAddress() { return m_base_addr; } |
210 | | |
211 | | /// Get const accessor for the base address of the range. |
212 | | /// |
213 | | /// \return |
214 | | /// A const reference to the base address object. |
215 | 601M | const Address &GetBaseAddress() const { return m_base_addr; } |
216 | | |
217 | | /// Get accessor for the byte size of this range. |
218 | | /// |
219 | | /// \return |
220 | | /// The size in bytes of this address range. |
221 | 135M | lldb::addr_t GetByteSize() const { return m_byte_size; } |
222 | | |
223 | | /// Get the memory cost of this object. |
224 | | /// |
225 | | /// \return |
226 | | /// The number of bytes that this object occupies in memory. |
227 | 0 | size_t MemorySize() const { |
228 | 0 | // Noting special for the memory size of a single AddressRange object, it |
229 | 0 | // is just the size of itself. |
230 | 0 | return sizeof(AddressRange); |
231 | 0 | } |
232 | | |
233 | | /// Set accessor for the byte size of this range. |
234 | | /// |
235 | | /// \param[in] byte_size |
236 | | /// The new size in bytes of this address range. |
237 | 132M | void SetByteSize(lldb::addr_t byte_size) { m_byte_size = byte_size; } |
238 | | |
239 | | protected: |
240 | | // Member variables |
241 | | Address m_base_addr; ///< The section offset base address of this range. |
242 | | lldb::addr_t m_byte_size = 0; ///< The size in bytes of this address range. |
243 | | }; |
244 | | |
245 | | } // namespace lldb_private |
246 | | |
247 | | #endif // LLDB_CORE_ADDRESSRANGE_H |