//===-- VMRange.h -----------------------------------------------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #ifndef liblldb_VMRange_h_ #define liblldb_VMRange_h_ #include "lldb/lldb-private.h" #include namespace lldb_private { //---------------------------------------------------------------------- // A vm address range. These can represent offsets ranges or actual // addresses. //---------------------------------------------------------------------- class VMRange { public: typedef std::vector collection; typedef collection::iterator iterator; typedef collection::const_iterator const_iterator; VMRange() : m_base_addr(0), m_byte_size(0) { } VMRange(lldb::addr_t start_addr, lldb::addr_t end_addr) : m_base_addr(start_addr), m_byte_size(end_addr > start_addr ? end_addr - start_addr : 0) { } ~VMRange() { } void Clear () { m_base_addr = 0; m_byte_size = 0; } // Set the start and end values void Reset (lldb::addr_t start_addr, lldb::addr_t end_addr) { SetBaseAddress (start_addr); SetEndAddress (end_addr); } // Set the start value for the range, and keep the same size void SetBaseAddress (lldb::addr_t base_addr) { m_base_addr = base_addr; } void SetEndAddress (lldb::addr_t end_addr) { const lldb::addr_t base_addr = GetBaseAddress(); if (end_addr > base_addr) m_byte_size = end_addr - base_addr; else m_byte_size = 0; } lldb::addr_t GetByteSize () const { return m_byte_size; } void SetByteSize (lldb::addr_t byte_size) { m_byte_size = byte_size; } lldb::addr_t GetBaseAddress () const { return m_base_addr; } lldb::addr_t GetEndAddress () const { return GetBaseAddress() + m_byte_size; } bool IsValid() const { return m_byte_size > 0; } bool Contains (lldb::addr_t addr) const { return (GetBaseAddress() <= addr) && (addr < GetEndAddress()); } bool Contains (const VMRange& range) const { if (Contains(range.GetBaseAddress())) { lldb::addr_t range_end = range.GetEndAddress(); return (GetBaseAddress() <= range_end) && (range_end <= GetEndAddress()); } return false; } void Dump (Stream *s, lldb::addr_t base_addr = 0, uint32_t addr_width = 8) const; class ValueInRangeUnaryPredicate { public: ValueInRangeUnaryPredicate(lldb::addr_t value) : _value(value) { } bool operator()(const VMRange& range) const { return range.Contains(_value); } lldb::addr_t _value; }; class RangeInRangeUnaryPredicate { public: RangeInRangeUnaryPredicate(VMRange range) : _range(range) { } bool operator()(const VMRange& range) const { return range.Contains(_range); } const VMRange& _range; }; static bool ContainsValue(const VMRange::collection& coll, lldb::addr_t value); static bool ContainsRange(const VMRange::collection& coll, const VMRange& range); // Returns a valid index into coll when a match is found, else UINT32_MAX // is returned static size_t FindRangeIndexThatContainsValue (const VMRange::collection& coll, lldb::addr_t value); protected: lldb::addr_t m_base_addr; lldb::addr_t m_byte_size; }; bool operator== (const VMRange& lhs, const VMRange& rhs); bool operator!= (const VMRange& lhs, const VMRange& rhs); bool operator< (const VMRange& lhs, const VMRange& rhs); bool operator<= (const VMRange& lhs, const VMRange& rhs); bool operator> (const VMRange& lhs, const VMRange& rhs); bool operator>= (const VMRange& lhs, const VMRange& rhs); } // namespace lldb_private #endif // liblldb_VMRange_h_