mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-10 22:00:58 +00:00
Fix rev 96389 by restricting the xform to mask that's either signbit or max signed value.
llvm-svn: 96990
This commit is contained in:
parent
69d643ba20
commit
d1d1755a44
@ -9092,9 +9092,10 @@ static SDValue PerformCMOVCombine(SDNode *N, SelectionDAG &DAG,
|
||||
}
|
||||
|
||||
/// PerformANDCombine - Look for SSE and instructions of this form:
|
||||
/// (and x, (build_vector c1,c2,c3,c4)). If there exists a use of a build_vector
|
||||
/// that's the bitwise complement of the mask, then transform the node to
|
||||
/// (and (xor x, (build_vector -1,-1,-1,-1)), (build_vector ~c1,~c2,~c3,~c4)).
|
||||
/// (and x, (build_vector signbit,signbit,signbit,signbit)). If there
|
||||
/// exists a use of a build_vector that's the bitwise complement of the mask,
|
||||
/// then transform the node to
|
||||
/// (and (xor x, (build_vector -1,-1,-1,-1)), (build_vector ~sb,~sb,~sb,~sb)).
|
||||
static SDValue PerformANDCombine(SDNode *N, SelectionDAG &DAG,
|
||||
TargetLowering::DAGCombinerInfo &DCI) {
|
||||
EVT VT = N->getValueType(0);
|
||||
@ -9118,7 +9119,11 @@ static SDValue PerformANDCombine(SDNode *N, SelectionDAG &DAG,
|
||||
continue;
|
||||
}
|
||||
ConstantSDNode *C = dyn_cast<ConstantSDNode>(Arg);
|
||||
if (!C) return SDValue();
|
||||
if (!C)
|
||||
return SDValue();
|
||||
if (!C->getAPIntValue().isSignBit() &&
|
||||
!C->getAPIntValue().isMaxSignedValue())
|
||||
return SDValue();
|
||||
Mask.push_back(DAG.getConstant(~C->getAPIntValue(), EltVT));
|
||||
}
|
||||
N1 = DAG.getNode(ISD::BUILD_VECTOR, N1.getDebugLoc(), VT,
|
||||
|
Loading…
x
Reference in New Issue
Block a user