[DebugInfo] Further simplify DWARFDebugAranges. No functionality change.
[oota-llvm.git] / lib / DebugInfo / DWARFDebugAranges.h
1 //===-- DWARFDebugAranges.h -------------------------------------*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9
10 #ifndef LLVM_DEBUGINFO_DWARFDEBUGARANGES_H
11 #define LLVM_DEBUGINFO_DWARFDEBUGARANGES_H
12
13 #include "DWARFDebugArangeSet.h"
14 #include "llvm/ADT/DenseSet.h"
15 #include <list>
16
17 namespace llvm {
18
19 class DWARFContext;
20
21 class DWARFDebugAranges {
22 public:
23   struct Range {
24     explicit Range(uint64_t LowPC = -1ULL, uint64_t HighPC = -1ULL,
25                    uint32_t CUOffset = -1U)
26       : LowPC(LowPC), Length(HighPC - LowPC), CUOffset(CUOffset) {}
27
28     void setHighPC(uint64_t HighPC) {
29       if (HighPC == -1ULL || HighPC <= LowPC)
30         Length = 0;
31       else
32         Length = HighPC - LowPC;
33     }
34     uint64_t HighPC() const {
35       if (Length)
36         return LowPC + Length;
37       return -1ULL;
38     }
39     bool containsAddress(uint64_t Address) const {
40       return LowPC <= Address && Address < HighPC();
41     }
42
43     bool operator <(const Range &other) const {
44       return LowPC < other.LowPC;
45     }
46
47     static bool SortedOverlapCheck(const Range &Left, const Range &Right) {
48       if (Left.CUOffset != Right.CUOffset)
49         return false;
50       return Left.HighPC() >= Right.LowPC;
51     }
52
53     void dump(raw_ostream &OS) const;
54     uint64_t LowPC; // Start of address range.
55     uint32_t Length; // End of address range (not including this address).
56     uint32_t CUOffset; // Offset of the compile unit or die.
57   };
58
59   void clear() {
60     Aranges.clear();
61     ParsedCUOffsets.clear();
62   }
63   void extract(DataExtractor DebugArangesData);
64   void generate(DWARFContext *CTX);
65
66   // Use appendRange multiple times and then call sortAndMinimize.
67   void appendRange(uint32_t CUOffset, uint64_t LowPC, uint64_t HighPC);
68   void sortAndMinimize();
69
70   void dump(raw_ostream &OS) const;
71   uint32_t findAddress(uint64_t Address) const;
72
73   typedef std::vector<Range>              RangeColl;
74   typedef RangeColl::const_iterator       RangeCollIterator;
75   typedef DenseSet<uint32_t>              ParsedCUOffsetColl;
76
77 private:
78   RangeColl Aranges;
79   ParsedCUOffsetColl ParsedCUOffsets;
80 };
81
82 }
83
84 #endif