diff options
author | Jakub Staszak <jstaszak@apple.com> | 2011-06-17 18:00:21 +0000 |
---|---|---|
committer | Jakub Staszak <jstaszak@apple.com> | 2011-06-17 18:00:21 +0000 |
commit | 981d82674c59b0e6415d3a30b2f9da625e438852 (patch) | |
tree | 5ac758b4b519cd1ee562622b25c8bf8ba90bfa51 /lib/CodeGen/MachineBasicBlock.cpp | |
parent | 799a58a55e91c2d0154daf85f8150c6bf17012ac (diff) |
getSuccWeight returns now default 0 if Weights vector is empty.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@133271 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/MachineBasicBlock.cpp')
-rw-r--r-- | lib/CodeGen/MachineBasicBlock.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/lib/CodeGen/MachineBasicBlock.cpp b/lib/CodeGen/MachineBasicBlock.cpp index 7d7bfb1fc3..c0f71d24a3 100644 --- a/lib/CodeGen/MachineBasicBlock.cpp +++ b/lib/CodeGen/MachineBasicBlock.cpp @@ -768,6 +768,9 @@ MachineBasicBlock::findDebugLoc(MachineBasicBlock::iterator &MBBI) { /// getSuccWeight - Return weight of the edge from this block to MBB. /// uint32_t MachineBasicBlock::getSuccWeight(MachineBasicBlock *succ) { + if (Weights.empty()) + return 0; + succ_iterator I = std::find(Successors.begin(), Successors.end(), succ); return *getWeightIterator(I); } @@ -776,8 +779,7 @@ uint32_t MachineBasicBlock::getSuccWeight(MachineBasicBlock *succ) { /// iterator MachineBasicBlock::weight_iterator MachineBasicBlock:: getWeightIterator(MachineBasicBlock::succ_iterator I) { - assert((Weights.size() == Successors.size() || Weights.empty()) && - "Async weight list!"); + assert(Weights.size() == Successors.size() && "Async weight list!"); size_t index = std::distance(Successors.begin(), I); assert(index < Weights.size() && "Not a current successor!"); return Weights.begin() + index; |