| //===-- SBMemoryRegionInfo.h ------------------------------------*- C++ -*-===// |
| // |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef LLDB_API_SBMEMORYREGIONINFO_H |
| #define LLDB_API_SBMEMORYREGIONINFO_H |
| |
| #include "lldb/API/SBData.h" |
| #include "lldb/API/SBDefines.h" |
| |
| namespace lldb { |
| |
| class LLDB_API SBMemoryRegionInfo { |
| public: |
| SBMemoryRegionInfo(); |
| |
| SBMemoryRegionInfo(const lldb::SBMemoryRegionInfo &rhs); |
| |
| SBMemoryRegionInfo(const char *name, lldb::addr_t begin, lldb::addr_t end, |
| uint32_t permissions, bool mapped, |
| bool stack_memory = false); |
| |
| ~SBMemoryRegionInfo(); |
| |
| const lldb::SBMemoryRegionInfo & |
| operator=(const lldb::SBMemoryRegionInfo &rhs); |
| |
| void Clear(); |
| |
| /// Get the base address of this memory range. |
| /// |
| /// \return |
| /// The base address of this memory range. |
| lldb::addr_t GetRegionBase(); |
| |
| /// Get the end address of this memory range. |
| /// |
| /// \return |
| /// The base address of this memory range. |
| lldb::addr_t GetRegionEnd(); |
| |
| /// Check if this memory address is marked readable to the process. |
| /// |
| /// \return |
| /// true if this memory address is marked readable |
| bool IsReadable(); |
| |
| /// Check if this memory address is marked writable to the process. |
| /// |
| /// \return |
| /// true if this memory address is marked writable |
| bool IsWritable(); |
| |
| /// Check if this memory address is marked executable to the process. |
| /// |
| /// \return |
| /// true if this memory address is marked executable |
| bool IsExecutable(); |
| |
| /// Check if this memory address is mapped into the process address |
| /// space. |
| /// |
| /// \return |
| /// true if this memory address is in the process address space. |
| bool IsMapped(); |
| |
| /// Returns the name of the memory region mapped at the given |
| /// address. |
| /// |
| /// \return |
| /// In case of memory mapped files it is the absolute path of |
| /// the file otherwise it is a name associated with the memory |
| /// region. If no name can be determined the returns nullptr. |
| const char *GetName(); |
| |
| /// Returns whether this memory region has a list of memory pages |
| /// that have been modified -- that are dirty. |
| /// |
| /// \return |
| /// True if the dirty page list is available. |
| bool HasDirtyMemoryPageList(); |
| |
| /// Returns the number of modified pages -- dirty pages -- in this |
| /// memory region. |
| /// |
| /// \return |
| /// The number of dirty page entries will be returned. If |
| /// there are no dirty pages in this memory region, 0 will |
| /// be returned. 0 will also be returned if the dirty page |
| /// list is not available for this memory region -- you must |
| /// use HasDirtyMemoryPageList() to check for that. |
| uint32_t GetNumDirtyPages(); |
| |
| /// Returns the address of a memory page that has been modified in |
| /// this region. |
| /// |
| /// \return |
| /// Returns the address for his dirty page in the list. |
| /// If this memory region does not have a dirty page list, |
| /// LLDB_INVALID_ADDRESS is returned. |
| addr_t GetDirtyPageAddressAtIndex(uint32_t idx); |
| |
| /// Returns the size of a memory page in this region. |
| /// |
| /// \return |
| /// Returns the size of the memory pages in this region, |
| /// or 0 if this information is unavailable. |
| int GetPageSize(); |
| |
| bool operator==(const lldb::SBMemoryRegionInfo &rhs) const; |
| |
| bool operator!=(const lldb::SBMemoryRegionInfo &rhs) const; |
| |
| bool GetDescription(lldb::SBStream &description); |
| |
| private: |
| friend class SBProcess; |
| friend class SBMemoryRegionInfoList; |
| |
| friend class lldb_private::ScriptInterpreter; |
| |
| lldb_private::MemoryRegionInfo &ref(); |
| |
| const lldb_private::MemoryRegionInfo &ref() const; |
| |
| // Unused. |
| SBMemoryRegionInfo(const lldb_private::MemoryRegionInfo *lldb_object_ptr); |
| |
| lldb::MemoryRegionInfoUP m_opaque_up; |
| }; |
| |
| } // namespace lldb |
| |
| #endif // LLDB_API_SBMEMORYREGIONINFO_H |