summaryrefslogtreecommitdiff
path: root/include/llvm/CodeGen/MachineBasicBlock.h
diff options
context:
space:
mode:
authorJakob Stoklund Olesen <stoklund@2pi.dk>2012-08-20 22:01:38 +0000
committerJakob Stoklund Olesen <stoklund@2pi.dk>2012-08-20 22:01:38 +0000
commit990ca5517fd6666d4049b6b8281d9df99da11637 (patch)
treeeba24e2322ff7ca69f040973f3c5654ab03f3ae0 /include/llvm/CodeGen/MachineBasicBlock.h
parente7fdef420d0c8a825555d246da259342c48bd527 (diff)
downloadllvm-990ca5517fd6666d4049b6b8281d9df99da11637.tar.gz
llvm-990ca5517fd6666d4049b6b8281d9df99da11637.tar.bz2
llvm-990ca5517fd6666d4049b6b8281d9df99da11637.tar.xz
Fix a quadratic algorithm in MachineBranchProbabilityInfo.
The getSumForBlock function was quadratic in the number of successors because getSuccWeight would perform a linear search for an already known iterator. This patch was originally committed as r161460, but reverted again because of assertion failures. Now that duplicate Machine CFG edges have been eliminated, this works properly. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@162233 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/CodeGen/MachineBasicBlock.h')
-rw-r--r--include/llvm/CodeGen/MachineBasicBlock.h2
1 files changed, 1 insertions, 1 deletions
diff --git a/include/llvm/CodeGen/MachineBasicBlock.h b/include/llvm/CodeGen/MachineBasicBlock.h
index 92d25ccf57..77ea4d03ea 100644
--- a/include/llvm/CodeGen/MachineBasicBlock.h
+++ b/include/llvm/CodeGen/MachineBasicBlock.h
@@ -574,7 +574,7 @@ private:
/// getSuccWeight - Return weight of the edge from this block to MBB. This
/// method should NOT be called directly, but by using getEdgeWeight method
/// from MachineBranchProbabilityInfo class.
- uint32_t getSuccWeight(const MachineBasicBlock *succ) const;
+ uint32_t getSuccWeight(const_succ_iterator Succ) const;
// Methods used to maintain doubly linked list of blocks...