mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 19:52:54 +01:00
[SelectionDAG][X86] Don't use ->getValueType(0) after a call to getOperand to get the type of the operand.
getOperand returns an SDValue that contains the node and the result number. There is no guarantee that the result number if 0. By using the -> operator we are calling SDNode::getValueType rather than SDValue::getValueType. This requires supplying a result number and we shouldn't assume it was 0. I don't have a test case. Just noticed while cleaning up some other code and saw that it occurred in other places. llvm-svn: 321397
This commit is contained in:
parent
787b28f8c8
commit
acac80b2f8
@ -10542,7 +10542,7 @@ static inline bool CanCombineFCOPYSIGN_EXTEND_ROUND(SDNode *N) {
|
||||
// value in one SSE register, but instruction selection cannot handle
|
||||
// FCOPYSIGN on SSE registers yet.
|
||||
EVT N1VT = N1->getValueType(0);
|
||||
EVT N1Op0VT = N1->getOperand(0)->getValueType(0);
|
||||
EVT N1Op0VT = N1->getOperand(0).getValueType();
|
||||
return (N1VT == N1Op0VT || N1Op0VT != MVT::f128);
|
||||
}
|
||||
return false;
|
||||
@ -15097,7 +15097,7 @@ SDValue DAGCombiner::visitCONCAT_VECTORS(SDNode *N) {
|
||||
|
||||
// Transform: concat_vectors(scalar, undef) -> scalar_to_vector(sclr).
|
||||
if (In->getOpcode() == ISD::BITCAST &&
|
||||
!In->getOperand(0)->getValueType(0).isVector()) {
|
||||
!In->getOperand(0).getValueType().isVector()) {
|
||||
SDValue Scalar = In->getOperand(0);
|
||||
|
||||
// If the bitcast type isn't legal, it might be a trunc of a legal type;
|
||||
@ -15144,7 +15144,7 @@ SDValue DAGCombiner::visitCONCAT_VECTORS(SDNode *N) {
|
||||
bool FoundMinVT = false;
|
||||
for (const SDValue &Op : N->ops())
|
||||
if (ISD::BUILD_VECTOR == Op.getOpcode()) {
|
||||
EVT OpSVT = Op.getOperand(0)->getValueType(0);
|
||||
EVT OpSVT = Op.getOperand(0).getValueType();
|
||||
MinVT = (!FoundMinVT || OpSVT.bitsLE(MinVT)) ? OpSVT : MinVT;
|
||||
FoundMinVT = true;
|
||||
}
|
||||
|
@ -1887,7 +1887,7 @@ SDValue DAGTypeLegalizer::PromoteFloatOp_STORE(SDNode *N, unsigned OpNo) {
|
||||
SDLoc DL(N);
|
||||
|
||||
SDValue Promoted = GetPromotedFloat(Val);
|
||||
EVT VT = ST->getOperand(1)->getValueType(0);
|
||||
EVT VT = ST->getOperand(1).getValueType();
|
||||
EVT IVT = EVT::getIntegerVT(*DAG.getContext(), VT.getSizeInBits());
|
||||
|
||||
SDValue NewVal;
|
||||
|
@ -331,7 +331,7 @@ SDValue DAGTypeLegalizer::ScalarizeVecRes_VSELECT(SDNode *N) {
|
||||
// At least try the common case where the boolean is generated by a
|
||||
// comparison.
|
||||
if (Cond->getOpcode() == ISD::SETCC) {
|
||||
EVT OpVT = Cond->getOperand(0)->getValueType(0);
|
||||
EVT OpVT = Cond->getOperand(0).getValueType();
|
||||
ScalarBool = TLI.getBooleanContents(OpVT.getScalarType());
|
||||
VecBool = TLI.getBooleanContents(OpVT);
|
||||
} else
|
||||
@ -1548,14 +1548,14 @@ bool DAGTypeLegalizer::SplitVectorOperand(SDNode *N, unsigned OpNo) {
|
||||
break;
|
||||
case ISD::FP_TO_SINT:
|
||||
case ISD::FP_TO_UINT:
|
||||
if (N->getValueType(0).bitsLT(N->getOperand(0)->getValueType(0)))
|
||||
if (N->getValueType(0).bitsLT(N->getOperand(0).getValueType()))
|
||||
Res = SplitVecOp_TruncateHelper(N);
|
||||
else
|
||||
Res = SplitVecOp_UnaryOp(N);
|
||||
break;
|
||||
case ISD::SINT_TO_FP:
|
||||
case ISD::UINT_TO_FP:
|
||||
if (N->getValueType(0).bitsLT(N->getOperand(0)->getValueType(0)))
|
||||
if (N->getValueType(0).bitsLT(N->getOperand(0).getValueType()))
|
||||
Res = SplitVecOp_TruncateHelper(N);
|
||||
else
|
||||
Res = SplitVecOp_UnaryOp(N);
|
||||
|
@ -21136,7 +21136,7 @@ static SDValue LowerINTRINSIC_W_CHAIN(SDValue Op, const X86Subtarget &Subtarget,
|
||||
// ADC/ADCX/SBB
|
||||
case ADX: {
|
||||
SDVTList CFVTs = DAG.getVTList(Op->getValueType(0), MVT::i32);
|
||||
SDVTList VTs = DAG.getVTList(Op.getOperand(3)->getValueType(0), MVT::i32);
|
||||
SDVTList VTs = DAG.getVTList(Op.getOperand(3).getValueType(), MVT::i32);
|
||||
SDValue GenCF = DAG.getNode(X86ISD::ADD, dl, CFVTs, Op.getOperand(2),
|
||||
DAG.getConstant(-1, dl, MVT::i8));
|
||||
SDValue Res = DAG.getNode(IntrData->Opc0, dl, VTs, Op.getOperand(3),
|
||||
@ -24941,7 +24941,7 @@ void X86TargetLowering::ReplaceNodeResults(SDNode *N,
|
||||
case ISD::BITCAST: {
|
||||
assert(Subtarget.hasSSE2() && "Requires at least SSE2!");
|
||||
EVT DstVT = N->getValueType(0);
|
||||
EVT SrcVT = N->getOperand(0)->getValueType(0);
|
||||
EVT SrcVT = N->getOperand(0).getValueType();
|
||||
|
||||
if (SrcVT != MVT::f64 ||
|
||||
(DstVT != MVT::v2i32 && DstVT != MVT::v4i16 && DstVT != MVT::v8i8))
|
||||
@ -30215,7 +30215,7 @@ static SDValue combineBitcastvxi1(SelectionDAG &DAG, SDValue BitCast,
|
||||
// For cases such as (i4 bitcast (v4i1 setcc v4i64 v1, v2))
|
||||
// sign-extend to a 256-bit operation to avoid truncation.
|
||||
if (N0->getOpcode() == ISD::SETCC && Subtarget.hasAVX() &&
|
||||
N0->getOperand(0)->getValueType(0).is256BitVector()) {
|
||||
N0->getOperand(0).getValueType().is256BitVector()) {
|
||||
SExtVT = MVT::v4i64;
|
||||
FPCastVT = MVT::v4f64;
|
||||
}
|
||||
@ -30228,8 +30228,8 @@ static SDValue combineBitcastvxi1(SelectionDAG &DAG, SDValue BitCast,
|
||||
// 256-bit because the shuffle is cheaper than sign extending the result of
|
||||
// the compare.
|
||||
if (N0->getOpcode() == ISD::SETCC && Subtarget.hasAVX() &&
|
||||
(N0->getOperand(0)->getValueType(0).is256BitVector() ||
|
||||
N0->getOperand(0)->getValueType(0).is512BitVector())) {
|
||||
(N0->getOperand(0).getValueType().is256BitVector() ||
|
||||
N0->getOperand(0).getValueType().is512BitVector())) {
|
||||
SExtVT = MVT::v8i32;
|
||||
FPCastVT = MVT::v8f32;
|
||||
}
|
||||
@ -33042,7 +33042,7 @@ static SDValue WidenMaskArithmetic(SDNode *N, SelectionDAG &DAG,
|
||||
return SDValue();
|
||||
|
||||
// The type of the truncated inputs.
|
||||
EVT WideVT = N0->getOperand(0)->getValueType(0);
|
||||
EVT WideVT = N0->getOperand(0).getValueType();
|
||||
if (WideVT != VT)
|
||||
return SDValue();
|
||||
|
||||
@ -36398,7 +36398,7 @@ static SDValue combineVectorCompareAndMaskUnaryOp(SDNode *N,
|
||||
EVT VT = N->getValueType(0);
|
||||
if (!VT.isVector() || N->getOperand(0)->getOpcode() != ISD::AND ||
|
||||
N->getOperand(0)->getOperand(0)->getOpcode() != ISD::SETCC ||
|
||||
VT.getSizeInBits() != N->getOperand(0)->getValueType(0).getSizeInBits())
|
||||
VT.getSizeInBits() != N->getOperand(0).getValueSizeInBits())
|
||||
return SDValue();
|
||||
|
||||
// Now check that the other operand of the AND is a constant. We could
|
||||
|
Loading…
Reference in New Issue
Block a user