diff options
author | Chris Lattner <sabre@nondot.org> | 2009-09-08 04:55:44 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-09-08 04:55:44 +0000 |
commit | ba3598cb1facb2b5aaa8ec47faf2cd07689a3b86 (patch) | |
tree | ffc896d40cc31d248813ebded64c1c366a0da83a /lib/Target | |
parent | 687bc9bfde036e201712f23955bfd2f0564cd2d4 (diff) | |
download | llvm-ba3598cb1facb2b5aaa8ec47faf2cd07689a3b86.tar.gz llvm-ba3598cb1facb2b5aaa8ec47faf2cd07689a3b86.tar.bz2 llvm-ba3598cb1facb2b5aaa8ec47faf2cd07689a3b86.tar.xz |
fix PR4767, a crash because fp stackifier visited blocks in
depth first order, so it wouldn't process unreachable blocks.
When compiling at -O0, late dead block elimination isn't done
and the bad instructions got to isel.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@81187 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target')
-rw-r--r-- | lib/Target/X86/X86FloatingPoint.cpp | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/lib/Target/X86/X86FloatingPoint.cpp b/lib/Target/X86/X86FloatingPoint.cpp index af0da6fb52..d9a05a83b9 100644 --- a/lib/Target/X86/X86FloatingPoint.cpp +++ b/lib/Target/X86/X86FloatingPoint.cpp @@ -213,6 +213,14 @@ bool FPS::runOnMachineFunction(MachineFunction &MF) { I != E; ++I) Changed |= processBasicBlock(MF, **I); + // Process any unreachable blocks in arbitrary order now. + if (MF.size() == Processed.size()) + return Changed; + + for (MachineFunction::iterator BB = MF.begin(), E = MF.end(); BB != E; ++BB) + if (Processed.insert(BB)) + Changed |= processBasicBlock(MF, *BB); + return Changed; } |