diff options
author | Tim Northover <tnorthover@apple.com> | 2016-08-02 23:12:36 +0000 |
---|---|---|
committer | Tim Northover <tnorthover@apple.com> | 2016-08-02 23:12:36 +0000 |
commit | 765777ce67e87365be0c0df178b85a877accb6a1 (patch) | |
tree | 4b83e080c53ddb5a401b4cf245ee6dda11920dfc /llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp | |
parent | 395cc09444b114bfb0f860bcd5c3d0365e7ca18c (diff) | |
download | bcm5719-llvm-765777ce67e87365be0c0df178b85a877accb6a1.tar.gz bcm5719-llvm-765777ce67e87365be0c0df178b85a877accb6a1.zip |
ARM: only form SMMLS when SUBE flags unused.
In this particular example we wouldn't want the smmls anyway (the value is
actually unused), but in general smmls does not provide the required flags
register so if that SUBE result is used we can't replace it.
llvm-svn: 277541
Diffstat (limited to 'llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp')
-rw-r--r-- | llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp b/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp index ab20e4dee7b..d11de555fa3 100644 --- a/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp +++ b/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp @@ -3047,7 +3047,8 @@ void ARMDAGToDAGISel::Select(SDNode *N) { // Look for a pattern to match SMMLS // (sube a, (smul_loHi a, b), (subc 0, (smul_LOhi(a, b)))) if (N->getOperand(1).getOpcode() != ISD::SMUL_LOHI || - N->getOperand(2).getOpcode() != ARMISD::SUBC) + N->getOperand(2).getOpcode() != ARMISD::SUBC || + !SDValue(N, 1).use_empty()) break; if (Subtarget->isThumb()) |