diff options
| author | Evan Cheng <evan.cheng@apple.com> | 2010-01-07 00:54:06 +0000 |
|---|---|---|
| committer | Evan Cheng <evan.cheng@apple.com> | 2010-01-07 00:54:06 +0000 |
| commit | 90dc43fcf520c31e000308659440b2c300cce0f7 (patch) | |
| tree | 0afb3a689ef6b9a7223002f8c6c532c087b5d3b7 /llvm/lib/Target | |
| parent | 09470e6a4eedf2bd4aa5cc589a966f01e65f6b3d (diff) | |
| download | bcm5719-llvm-90dc43fcf520c31e000308659440b2c300cce0f7.tar.gz bcm5719-llvm-90dc43fcf520c31e000308659440b2c300cce0f7.zip | |
Fix a minor regression from my dag combiner changes. One more place which needs to look pass truncates.
llvm-svn: 92885
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/X86/X86ISelLowering.cpp | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp index 7d92fd8fad6..212478c58ab 100644 --- a/llvm/lib/Target/X86/X86ISelLowering.cpp +++ b/llvm/lib/Target/X86/X86ISelLowering.cpp @@ -5611,13 +5611,21 @@ SDValue X86TargetLowering::EmitTest(SDValue Op, unsigned X86CC, // because a TEST instruction will be better. bool NonFlagUse = false; for (SDNode::use_iterator UI = Op.getNode()->use_begin(), - UE = Op.getNode()->use_end(); UI != UE; ++UI) - if (UI->getOpcode() != ISD::BRCOND && - (UI->getOpcode() != ISD::SELECT || UI.getOperandNo() != 0) && - UI->getOpcode() != ISD::SETCC) { + UE = Op.getNode()->use_end(); UI != UE; ++UI) { + SDNode *User = *UI; + unsigned UOpNo = UI.getOperandNo(); + if (User->getOpcode() == ISD::TRUNCATE && User->hasOneUse()) { + // Look pass truncate. + UOpNo = User->use_begin().getOperandNo(); + User = *User->use_begin(); + } + if (User->getOpcode() != ISD::BRCOND && + User->getOpcode() != ISD::SETCC && + (User->getOpcode() != ISD::SELECT || UOpNo != 0)) { NonFlagUse = true; break; } + } if (!NonFlagUse) break; } |

