summaryrefslogtreecommitdiff
path: root/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2008-08-28 23:21:34 +0000
committerDan Gohman <gohman@apple.com>2008-08-28 23:21:34 +0000
commit99b218218c0ca3ebfdd568ddfeafa07842e9d69d (patch)
treee4205b702341cd8904cf8e126f7027a4aef2b5c5 /lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
parent327ef031ed038c55ddccb34fb922dd9c9fd735a6 (diff)
downloadllvm-99b218218c0ca3ebfdd568ddfeafa07842e9d69d.tar.gz
llvm-99b218218c0ca3ebfdd568ddfeafa07842e9d69d.tar.bz2
llvm-99b218218c0ca3ebfdd568ddfeafa07842e9d69d.tar.xz
Add a target callback for FastISel.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55512 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp')
-rw-r--r--lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp9
1 files changed, 7 insertions, 2 deletions
diff --git a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
index f2246cac2c..9b982f4fb4 100644
--- a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
+++ b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
@@ -5757,10 +5757,15 @@ void SelectionDAGISel::SelectAllBasicBlocks(Function &Fn, MachineFunction &MF) {
Begin = F->SelectInstructions(Begin, End, FuncInfo->ValueMap,
FuncInfo->MBBMap, BB);
+ // If the "fast" selector selected the entire block, we're done.
if (Begin == End)
- // The "fast" selector selected the entire block, so we're done.
break;
+ // Next, try calling the target to attempt to handle the instruction.
+ if (F->TargetSelectInstruction(Begin, FuncInfo->ValueMap,
+ FuncInfo->MBBMap, BB))
+ continue;
+
// Handle certain instructions as single-LLVM-Instruction blocks.
if (isa<CallInst>(Begin) || isa<LoadInst>(Begin) ||
isa<StoreInst>(Begin)) {
@@ -5783,7 +5788,7 @@ void SelectionDAGISel::SelectAllBasicBlocks(Function &Fn, MachineFunction &MF) {
// The "fast" selector couldn't handle something and bailed.
// For the purpose of debugging, just abort.
#ifndef NDEBUG
- Begin->dump();
+ Begin->dump();
#endif
assert(0 && "FastISel didn't select the entire block");
}