diff options
author | Owen Anderson <resistor@mac.com> | 2011-06-24 23:02:22 +0000 |
---|---|---|
committer | Owen Anderson <resistor@mac.com> | 2011-06-24 23:02:22 +0000 |
commit | 99adfec0b13153d6fbf5fc430423633c08a791e5 (patch) | |
tree | fcc72baef22c4f7544525eed48e8bf83fd66373c /llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp | |
parent | 57e34b21db38423e437e4cc97f56dbc468b583a7 (diff) | |
download | bcm5719-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.cpp | 3 |
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(); } |