From 5cf39339d1236639b635ffb80aa83b95e4af6e95 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Mon, 1 Mar 2004 01:12:13 +0000 Subject: Disable tail duplication in a case that breaks on Olden/tsp llvm-svn: 12021 --- llvm/lib/Transforms/Scalar/LowerInvoke.cpp | 2 +- llvm/lib/Transforms/Scalar/TailDuplication.cpp | 4 ++++ 2 files changed, 5 insertions(+), 1 deletion(-) (limited to 'llvm/lib') diff --git a/llvm/lib/Transforms/Scalar/LowerInvoke.cpp b/llvm/lib/Transforms/Scalar/LowerInvoke.cpp index d42d0533f1c..24033f4876a 100644 --- a/llvm/lib/Transforms/Scalar/LowerInvoke.cpp +++ b/llvm/lib/Transforms/Scalar/LowerInvoke.cpp @@ -42,7 +42,7 @@ using namespace llvm; namespace { Statistic<> NumLowered("lowerinvoke", "Number of invoke & unwinds replaced"); - cl::opt ExpensiveEHSupport("enable-correct-eh-support", + cl::opt ExpensiveEHSupport("enable-correct-eh-support", cl::desc("Make the -lowerinvoke pass insert expensive, but correct, EH code")); class LowerInvoke : public FunctionPass { diff --git a/llvm/lib/Transforms/Scalar/TailDuplication.cpp b/llvm/lib/Transforms/Scalar/TailDuplication.cpp index 315b90697cf..a3980b342c2 100644 --- a/llvm/lib/Transforms/Scalar/TailDuplication.cpp +++ b/llvm/lib/Transforms/Scalar/TailDuplication.cpp @@ -135,6 +135,10 @@ bool TailDup::canEliminateUnconditionalBranch(TerminatorInst *TI) { Instruction *User = cast(*UI); if (User->getParent() != Tail && User->getParent() != BB) return false; + + // The 'swap' problem foils the tail duplication rewriting code. + if (isa(User) && User->getParent() == Tail) + return false; } return true; } -- cgit v1.2.3