aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorevancheng <evancheng@91177308-0d34-0410-b5e6-96231b3b80d8>2009-01-27 21:15:07 +0000
committerevancheng <evancheng@91177308-0d34-0410-b5e6-96231b3b80d8>2009-01-27 21:15:07 +0000
commitc611f1d881c25889d6343c0bd41ea73a5157ae66 (patch)
tree61bcbb8c4220806701cd15e0a356df90b78337b0
parent51bef2e7f3b8bd4bafc8b4e4e6d42d0b2ede47ee (diff)
downloadexternal_llvm-c611f1d881c25889d6343c0bd41ea73a5157ae66.zip
external_llvm-c611f1d881c25889d6343c0bd41ea73a5157ae66.tar.gz
external_llvm-c611f1d881c25889d6343c0bd41ea73a5157ae66.tar.bz2
Refine DebugLoc per review comments.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@63132 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--include/llvm/CodeGen/DebugLoc.h20
-rw-r--r--include/llvm/CodeGen/MachineFunction.h8
-rw-r--r--lib/CodeGen/MachineFunction.cpp13
3 files changed, 22 insertions, 19 deletions
diff --git a/include/llvm/CodeGen/DebugLoc.h b/include/llvm/CodeGen/DebugLoc.h
index baf6583..89c51c4 100644
--- a/include/llvm/CodeGen/DebugLoc.h
+++ b/include/llvm/CodeGen/DebugLoc.h
@@ -33,16 +33,21 @@ namespace llvm {
unsigned Idx;
public:
- DebugLoc() : Idx(~0U) {}
+ DebugLoc() : Idx(~0U) {} // Defaults to invalid.
- static DebugLoc getNoDebugLoc() { DebugLoc L; L.Idx = 0; return L; }
+ static DebugLoc getUnknownLoc() { DebugLoc L; L.Idx = 0; return L; }
static DebugLoc get(unsigned idx) { DebugLoc L; L.Idx = idx; return L; }
- bool isInvalid() { return Idx == ~0U; }
- bool isUnknown() { return Idx == 0; }
+ // isInvalid - Return true if the DebugLoc is invalid.
+ bool isInvalid() const { return Idx == ~0U; }
+
+ // isUnknown - Return true if there is no debug info for the SDNode /
+ // MachineInstr.
+ bool isUnknown() const { return Idx == 0; }
};
- struct DebugLocTupleDenseMapInfo {
+ // Partially specialize DenseMapInfo for DebugLocTyple.
+ template<> struct DenseMapInfo<DebugLocTuple> {
static inline DebugLocTuple getEmptyKey() {
return DebugLocTuple(~0U, ~0U, ~0U);
}
@@ -63,9 +68,6 @@ namespace llvm {
static bool isPod() { return true; }
};
- typedef DenseMap<DebugLocTuple, unsigned, DebugLocTupleDenseMapInfo>
- DebugIdMapType;
-
/// DebugLocTracker - This class tracks debug location information.
///
struct DebugLocTracker {
@@ -75,7 +77,7 @@ namespace llvm {
// DebugIdsMap - This maps DebugLocTuple's to indices into
// DebugLocations vector.
- DebugIdMapType DebugIdMap;
+ DenseMap<DebugLocTuple, unsigned> DebugIdMap;
DebugLocTracker() {}
diff --git a/include/llvm/CodeGen/MachineFunction.h b/include/llvm/CodeGen/MachineFunction.h
index 4fa70fc..0d5a71d 100644
--- a/include/llvm/CodeGen/MachineFunction.h
+++ b/include/llvm/CodeGen/MachineFunction.h
@@ -311,10 +311,10 @@ public:
// Debug location.
//
- /// lookUpDebugLocId - Look up the DebugLocTuple index with the given
- /// source file, line, and column. It may add a new filename and / or
- /// a new DebugLocTuple.
- unsigned lookUpDebugLocId(unsigned Src, unsigned Line, unsigned Col);
+ /// getOrCreateDebugLocID - Look up the DebugLocTuple index with the given
+ /// source file, line, and column. If none currently exists, create add a new
+ /// new DebugLocTuple and insert it into the DebugIdMap.
+ unsigned getOrCreateDebugLocID(unsigned Src, unsigned Line, unsigned Col);
};
//===--------------------------------------------------------------------===//
diff --git a/lib/CodeGen/MachineFunction.cpp b/lib/CodeGen/MachineFunction.cpp
index abd84ec..b303b1b 100644
--- a/lib/CodeGen/MachineFunction.cpp
+++ b/lib/CodeGen/MachineFunction.cpp
@@ -378,13 +378,14 @@ MachineFunction& MachineFunction::get(const Function *F)
return *mc;
}
-/// lookUpDebugLocId - Look up the DebugLocTuple index with the given
-/// source file, line, and column. It may add a new filename and / or
-/// a new DebugLocTuple.
-unsigned MachineFunction::lookUpDebugLocId(unsigned Src, unsigned Line,
- unsigned Col) {
+/// getOrCreateDebugLocID - Look up the DebugLocTuple index with the given
+/// source file, line, and column. If none currently exists, create add a new
+/// new DebugLocTuple and insert it into the DebugIdMap.
+unsigned MachineFunction::getOrCreateDebugLocID(unsigned Src, unsigned Line,
+ unsigned Col) {
struct DebugLocTuple Tuple(Src, Line, Col);
- DebugIdMapType::iterator II = DebugLocInfo.DebugIdMap.find(Tuple);
+ DenseMap<DebugLocTuple, unsigned>::iterator II
+ = DebugLocInfo.DebugIdMap.find(Tuple);
if (II != DebugLocInfo.DebugIdMap.end())
return II->second;
// Add a new tuple.