summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp
diff options
context:
space:
mode:
authorOwen Anderson <resistor@mac.com>2011-06-24 23:02:22 +0000
committerOwen Anderson <resistor@mac.com>2011-06-24 23:02:22 +0000
commit99adfec0b13153d6fbf5fc430423633c08a791e5 (patch)
treefcc72baef22c4f7544525eed48e8bf83fd66373c /llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp
parent57e34b21db38423e437e4cc97f56dbc468b583a7 (diff)
downloadbcm5719-llvm-99adfec0b13153d6fbf5fc430423633c08a791e5.tar.gz
bcm5719-llvm-99adfec0b13153d6fbf5fc430423633c08a791e5.zip
The scheduler needs to be aware on the existence of untyped nodes when it performs type propagation for EXTRACT_SUBREG.
llvm-svn: 133838
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp')
-rw-r--r--llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp3
1 files changed, 2 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp
index dbc623b01ea..f03bf10a48f 100644
--- a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp
+++ b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp
@@ -521,7 +521,8 @@ void ScheduleDAGSDNodes::RegDefIter::Advance() {
if (!Node->hasAnyUseOfValue(DefIdx))
continue;
if (Node->isMachineOpcode() &&
- Node->getMachineOpcode() == TargetOpcode::EXTRACT_SUBREG) {
+ Node->getMachineOpcode() == TargetOpcode::EXTRACT_SUBREG &&
+ Node->getOperand(0).getValueType() != MVT::untyped) {
// Propagate the incoming (full-register) type. I doubt it's needed.
ValueType = Node->getOperand(0).getValueType();
}
OpenPOWER on IntegriCloud