Lines Matching refs:ISD
98 bool ISD::isBuildVectorAllOnes(const SDNode *N) { in isBuildVectorAllOnes()
100 if (N->getOpcode() == ISD::BITCAST) in isBuildVectorAllOnes()
103 if (N->getOpcode() != ISD::BUILD_VECTOR) return false; in isBuildVectorAllOnes()
108 while (i != e && N->getOperand(i).getOpcode() == ISD::UNDEF) in isBuildVectorAllOnes()
138 N->getOperand(i).getOpcode() != ISD::UNDEF) in isBuildVectorAllOnes()
146 bool ISD::isBuildVectorAllZeros(const SDNode *N) { in isBuildVectorAllZeros()
148 if (N->getOpcode() == ISD::BITCAST) in isBuildVectorAllZeros()
151 if (N->getOpcode() != ISD::BUILD_VECTOR) return false; in isBuildVectorAllZeros()
156 while (i != e && N->getOperand(i).getOpcode() == ISD::UNDEF) in isBuildVectorAllZeros()
178 N->getOperand(i).getOpcode() != ISD::UNDEF) in isBuildVectorAllZeros()
186 bool ISD::isScalarToVector(const SDNode *N) { in isScalarToVector()
187 if (N->getOpcode() == ISD::SCALAR_TO_VECTOR) in isScalarToVector()
190 if (N->getOpcode() != ISD::BUILD_VECTOR) in isScalarToVector()
192 if (N->getOperand(0).getOpcode() == ISD::UNDEF) in isScalarToVector()
199 if (V.getOpcode() != ISD::UNDEF) in isScalarToVector()
207 bool ISD::allOperandsUndef(const SDNode *N) { in allOperandsUndef()
215 if (N->getOperand(i).getOpcode() != ISD::UNDEF) in allOperandsUndef()
223 ISD::CondCode ISD::getSetCCSwappedOperands(ISD::CondCode Operation) { in getSetCCSwappedOperands()
228 return ISD::CondCode((Operation & ~6) | // Keep the N, U, E bits in getSetCCSwappedOperands()
235 ISD::CondCode ISD::getSetCCInverse(ISD::CondCode Op, bool isInteger) { in getSetCCInverse()
242 if (Operation > ISD::SETTRUE2) in getSetCCInverse()
245 return ISD::CondCode(Operation); in getSetCCInverse()
252 static int isSignedOp(ISD::CondCode Opcode) { in isSignedOp()
255 case ISD::SETEQ: in isSignedOp()
256 case ISD::SETNE: return 0; in isSignedOp()
257 case ISD::SETLT: in isSignedOp()
258 case ISD::SETLE: in isSignedOp()
259 case ISD::SETGT: in isSignedOp()
260 case ISD::SETGE: return 1; in isSignedOp()
261 case ISD::SETULT: in isSignedOp()
262 case ISD::SETULE: in isSignedOp()
263 case ISD::SETUGT: in isSignedOp()
264 case ISD::SETUGE: return 2; in isSignedOp()
272 ISD::CondCode ISD::getSetCCOrOperation(ISD::CondCode Op1, ISD::CondCode Op2, in getSetCCOrOperation()
276 return ISD::SETCC_INVALID; in getSetCCOrOperation()
282 if (Op > ISD::SETTRUE2) in getSetCCOrOperation()
286 if (isInteger && Op == ISD::SETUNE) // e.g. SETUGT | SETULT in getSetCCOrOperation()
287 Op = ISD::SETNE; in getSetCCOrOperation()
289 return ISD::CondCode(Op); in getSetCCOrOperation()
296 ISD::CondCode ISD::getSetCCAndOperation(ISD::CondCode Op1, ISD::CondCode Op2, in getSetCCAndOperation()
300 return ISD::SETCC_INVALID; in getSetCCAndOperation()
303 ISD::CondCode Result = ISD::CondCode(Op1 & Op2); in getSetCCAndOperation()
309 case ISD::SETUO : Result = ISD::SETFALSE; break; // SETUGT & SETULT in getSetCCAndOperation()
310 case ISD::SETOEQ: // SETEQ & SETU[LG]E in getSetCCAndOperation()
311 case ISD::SETUEQ: Result = ISD::SETEQ ; break; // SETUGE & SETULE in getSetCCAndOperation()
312 case ISD::SETOLT: Result = ISD::SETULT ; break; // SETULT & SETNE in getSetCCAndOperation()
313 case ISD::SETOGT: Result = ISD::SETUGT ; break; // SETUGT & SETNE in getSetCCAndOperation()
368 case ISD::TargetExternalSymbol: in AddNodeIDCustom()
369 case ISD::ExternalSymbol: in AddNodeIDCustom()
372 case ISD::TargetConstant: in AddNodeIDCustom()
373 case ISD::Constant: in AddNodeIDCustom()
376 case ISD::TargetConstantFP: in AddNodeIDCustom()
377 case ISD::ConstantFP: { in AddNodeIDCustom()
381 case ISD::TargetGlobalAddress: in AddNodeIDCustom()
382 case ISD::GlobalAddress: in AddNodeIDCustom()
383 case ISD::TargetGlobalTLSAddress: in AddNodeIDCustom()
384 case ISD::GlobalTLSAddress: { in AddNodeIDCustom()
392 case ISD::BasicBlock: in AddNodeIDCustom()
395 case ISD::Register: in AddNodeIDCustom()
398 case ISD::RegisterMask: in AddNodeIDCustom()
401 case ISD::SRCVALUE: in AddNodeIDCustom()
404 case ISD::FrameIndex: in AddNodeIDCustom()
405 case ISD::TargetFrameIndex: in AddNodeIDCustom()
408 case ISD::JumpTable: in AddNodeIDCustom()
409 case ISD::TargetJumpTable: in AddNodeIDCustom()
413 case ISD::ConstantPool: in AddNodeIDCustom()
414 case ISD::TargetConstantPool: { in AddNodeIDCustom()
425 case ISD::TargetIndex: { in AddNodeIDCustom()
432 case ISD::LOAD: { in AddNodeIDCustom()
439 case ISD::STORE: { in AddNodeIDCustom()
446 case ISD::ATOMIC_CMP_SWAP: in AddNodeIDCustom()
447 case ISD::ATOMIC_SWAP: in AddNodeIDCustom()
448 case ISD::ATOMIC_LOAD_ADD: in AddNodeIDCustom()
449 case ISD::ATOMIC_LOAD_SUB: in AddNodeIDCustom()
450 case ISD::ATOMIC_LOAD_AND: in AddNodeIDCustom()
451 case ISD::ATOMIC_LOAD_OR: in AddNodeIDCustom()
452 case ISD::ATOMIC_LOAD_XOR: in AddNodeIDCustom()
453 case ISD::ATOMIC_LOAD_NAND: in AddNodeIDCustom()
454 case ISD::ATOMIC_LOAD_MIN: in AddNodeIDCustom()
455 case ISD::ATOMIC_LOAD_MAX: in AddNodeIDCustom()
456 case ISD::ATOMIC_LOAD_UMIN: in AddNodeIDCustom()
457 case ISD::ATOMIC_LOAD_UMAX: in AddNodeIDCustom()
458 case ISD::ATOMIC_LOAD: in AddNodeIDCustom()
459 case ISD::ATOMIC_STORE: { in AddNodeIDCustom()
466 case ISD::PREFETCH: { in AddNodeIDCustom()
471 case ISD::VECTOR_SHUFFLE: { in AddNodeIDCustom()
478 case ISD::TargetBlockAddress: in AddNodeIDCustom()
479 case ISD::BlockAddress: { in AddNodeIDCustom()
511 encodeMemSDNodeFlags(int ConvType, ISD::MemIndexedMode AM, bool isVolatile, in encodeMemSDNodeFlags()
535 case ISD::HANDLENODE: in doNotCSE()
536 case ISD::EH_LABEL: in doNotCSE()
635 N->NodeType = ISD::DELETED_NODE; in DeallocateNode()
655 case ISD::HANDLENODE: return false; // noop. in RemoveNodeFromCSEMaps()
656 case ISD::CONDCODE: in RemoveNodeFromCSEMaps()
662 case ISD::ExternalSymbol: in RemoveNodeFromCSEMaps()
665 case ISD::TargetExternalSymbol: { in RemoveNodeFromCSEMaps()
672 case ISD::VALUETYPE: { in RemoveNodeFromCSEMaps()
684 assert(N->getOpcode() != ISD::DELETED_NODE && "DELETED_NODE in CSEMap!"); in RemoveNodeFromCSEMaps()
685 assert(N->getOpcode() != ISD::EntryToken && "EntryToken in CSEMap!"); in RemoveNodeFromCSEMaps()
792 case ISD::BUILD_PAIR: { in VerifyNodeCommon()
806 case ISD::BUILD_VECTOR: { in VerifyNodeCommon()
877 TTI(0), OptLevel(OL), EntryNode(ISD::EntryToken, DebugLoc(), in SelectionDAG()
927 getNode(ISD::ANY_EXTEND, DL, VT, Op) : in getAnyExtOrTrunc()
928 getNode(ISD::TRUNCATE, DL, VT, Op); in getAnyExtOrTrunc()
933 getNode(ISD::SIGN_EXTEND, DL, VT, Op) : in getSExtOrTrunc()
934 getNode(ISD::TRUNCATE, DL, VT, Op); in getSExtOrTrunc()
939 getNode(ISD::ZERO_EXTEND, DL, VT, Op) : in getZExtOrTrunc()
940 getNode(ISD::TRUNCATE, DL, VT, Op); in getZExtOrTrunc()
951 return getNode(ISD::AND, DL, Op.getValueType(), Op, in getZeroExtendInReg()
961 return getNode(ISD::XOR, DL, VT, Val, NegOne); in getNOT()
995 unsigned Opc = isT ? ISD::TargetConstant : ISD::Constant; in getConstant()
1015 Result = getNode(ISD::BUILD_VECTOR, DebugLoc(), VT, &Ops[0], Ops.size()); in getConstant()
1037 unsigned Opc = isTarget ? ISD::TargetConstantFP : ISD::ConstantFP; in getConstantFP()
1058 Result = getNode(ISD::BUILD_VECTOR, DebugLoc(), VT, &Ops[0], Ops.size()); in getConstantFP()
1101 Opc = isTargetGA ? ISD::TargetGlobalTLSAddress : ISD::GlobalTLSAddress; in getGlobalAddress()
1103 Opc = isTargetGA ? ISD::TargetGlobalAddress : ISD::GlobalAddress; in getGlobalAddress()
1123 unsigned Opc = isTarget ? ISD::TargetFrameIndex : ISD::FrameIndex; in getFrameIndex()
1141 unsigned Opc = isTarget ? ISD::TargetJumpTable : ISD::JumpTable; in getJumpTable()
1165 unsigned Opc = isTarget ? ISD::TargetConstantPool : ISD::ConstantPool; in getConstantPool()
1192 unsigned Opc = isTarget ? ISD::TargetConstantPool : ISD::ConstantPool; in getConstantPool()
1213 AddNodeIDNode(ID, ISD::TargetIndex, getVTList(VT), 0, 0); in getTargetIndex()
1230 AddNodeIDNode(ID, ISD::BasicBlock, getVTList(MVT::Other), 0, 0); in getBasicBlock()
1275 SDValue SelectionDAG::getCondCode(ISD::CondCode Cond) { in getCondCode()
1311 if (N1.getOpcode() == ISD::UNDEF && N2.getOpcode() == ISD::UNDEF) in getVectorShuffle()
1331 if (N1.getOpcode() == ISD::UNDEF) in getVectorShuffle()
1337 bool N2Undef = N2.getOpcode() == ISD::UNDEF; in getVectorShuffle()
1371 AddNodeIDNode(ID, ISD::VECTOR_SHUFFLE, getVTList(VT), Ops, 2); in getVectorShuffle()
1395 ISD::CvtCode Code) { in getConvertRndSat()
1399 (Code == ISD::CVT_UU || Code == ISD::CVT_SS || Code == ISD::CVT_FF)) in getConvertRndSat()
1404 AddNodeIDNode(ID, ISD::CONVERT_RNDSAT, getVTList(VT), &Ops[0], 5); in getConvertRndSat()
1418 AddNodeIDNode(ID, ISD::Register, getVTList(VT), 0, 0); in getRegister()
1432 AddNodeIDNode(ID, ISD::RegisterMask, getVTList(MVT::Untyped), 0, 0); in getRegisterMask()
1447 AddNodeIDNode(ID, ISD::EH_LABEL, getVTList(MVT::Other), &Ops[0], 1); in getEHLabel()
1464 unsigned Opc = isTarget ? ISD::TargetBlockAddress : ISD::BlockAddress; in getBlockAddress()
1487 AddNodeIDNode(ID, ISD::SRCVALUE, getVTList(MVT::Other), 0, 0); in getSrcValue()
1503 AddNodeIDNode(ID, ISD::MDNODE_SDNODE, getVTList(MVT::Other), 0, 0); in getMDNode()
1524 ISD::NodeType Opcode = OpTy.bitsGT(ShTy) ? ISD::TRUNCATE : ISD::ZERO_EXTEND; in getShiftAmountOperand()
1558 SDValue N2, ISD::CondCode Cond, DebugLoc dl) { in FoldSetCC()
1562 case ISD::SETFALSE: in FoldSetCC()
1563 case ISD::SETFALSE2: return getConstant(0, VT); in FoldSetCC()
1564 case ISD::SETTRUE: in FoldSetCC()
1565 case ISD::SETTRUE2: return getConstant(1, VT); in FoldSetCC()
1567 case ISD::SETOEQ: in FoldSetCC()
1568 case ISD::SETOGT: in FoldSetCC()
1569 case ISD::SETOGE: in FoldSetCC()
1570 case ISD::SETOLT: in FoldSetCC()
1571 case ISD::SETOLE: in FoldSetCC()
1572 case ISD::SETONE: in FoldSetCC()
1573 case ISD::SETO: in FoldSetCC()
1574 case ISD::SETUO: in FoldSetCC()
1575 case ISD::SETUEQ: in FoldSetCC()
1576 case ISD::SETUNE: in FoldSetCC()
1588 case ISD::SETEQ: return getConstant(C1 == C2, VT); in FoldSetCC()
1589 case ISD::SETNE: return getConstant(C1 != C2, VT); in FoldSetCC()
1590 case ISD::SETULT: return getConstant(C1.ult(C2), VT); in FoldSetCC()
1591 case ISD::SETUGT: return getConstant(C1.ugt(C2), VT); in FoldSetCC()
1592 case ISD::SETULE: return getConstant(C1.ule(C2), VT); in FoldSetCC()
1593 case ISD::SETUGE: return getConstant(C1.uge(C2), VT); in FoldSetCC()
1594 case ISD::SETLT: return getConstant(C1.slt(C2), VT); in FoldSetCC()
1595 case ISD::SETGT: return getConstant(C1.sgt(C2), VT); in FoldSetCC()
1596 case ISD::SETLE: return getConstant(C1.sle(C2), VT); in FoldSetCC()
1597 case ISD::SETGE: return getConstant(C1.sge(C2), VT); in FoldSetCC()
1606 case ISD::SETEQ: if (R==APFloat::cmpUnordered) in FoldSetCC()
1609 case ISD::SETOEQ: return getConstant(R==APFloat::cmpEqual, VT); in FoldSetCC()
1610 case ISD::SETNE: if (R==APFloat::cmpUnordered) in FoldSetCC()
1613 case ISD::SETONE: return getConstant(R==APFloat::cmpGreaterThan || in FoldSetCC()
1615 case ISD::SETLT: if (R==APFloat::cmpUnordered) in FoldSetCC()
1618 case ISD::SETOLT: return getConstant(R==APFloat::cmpLessThan, VT); in FoldSetCC()
1619 case ISD::SETGT: if (R==APFloat::cmpUnordered) in FoldSetCC()
1622 case ISD::SETOGT: return getConstant(R==APFloat::cmpGreaterThan, VT); in FoldSetCC()
1623 case ISD::SETLE: if (R==APFloat::cmpUnordered) in FoldSetCC()
1626 case ISD::SETOLE: return getConstant(R==APFloat::cmpLessThan || in FoldSetCC()
1628 case ISD::SETGE: if (R==APFloat::cmpUnordered) in FoldSetCC()
1631 case ISD::SETOGE: return getConstant(R==APFloat::cmpGreaterThan || in FoldSetCC()
1633 case ISD::SETO: return getConstant(R!=APFloat::cmpUnordered, VT); in FoldSetCC()
1634 case ISD::SETUO: return getConstant(R==APFloat::cmpUnordered, VT); in FoldSetCC()
1635 case ISD::SETUEQ: return getConstant(R==APFloat::cmpUnordered || in FoldSetCC()
1637 case ISD::SETUNE: return getConstant(R!=APFloat::cmpEqual, VT); in FoldSetCC()
1638 case ISD::SETULT: return getConstant(R==APFloat::cmpUnordered || in FoldSetCC()
1640 case ISD::SETUGT: return getConstant(R==APFloat::cmpGreaterThan || in FoldSetCC()
1642 case ISD::SETULE: return getConstant(R!=APFloat::cmpGreaterThan, VT); in FoldSetCC()
1643 case ISD::SETUGE: return getConstant(R!=APFloat::cmpLessThan, VT); in FoldSetCC()
1647 return getSetCC(dl, VT, N2, N1, ISD::getSetCCSwappedOperands(Cond)); in FoldSetCC()
1692 case ISD::Constant: in ComputeMaskedBits()
1697 case ISD::AND: in ComputeMaskedBits()
1709 case ISD::OR: in ComputeMaskedBits()
1720 case ISD::XOR: { in ComputeMaskedBits()
1733 case ISD::MUL: { in ComputeMaskedBits()
1756 case ISD::UDIV: { in ComputeMaskedBits()
1774 case ISD::SELECT: in ComputeMaskedBits()
1784 case ISD::SELECT_CC: in ComputeMaskedBits()
1794 case ISD::SADDO: in ComputeMaskedBits()
1795 case ISD::UADDO: in ComputeMaskedBits()
1796 case ISD::SSUBO: in ComputeMaskedBits()
1797 case ISD::USUBO: in ComputeMaskedBits()
1798 case ISD::SMULO: in ComputeMaskedBits()
1799 case ISD::UMULO: in ComputeMaskedBits()
1803 case ISD::SETCC: in ComputeMaskedBits()
1809 case ISD::SHL: in ComputeMaskedBits()
1826 case ISD::SRL: in ComputeMaskedBits()
1844 case ISD::SRA: in ComputeMaskedBits()
1872 case ISD::SIGN_EXTEND_INREG: { in ComputeMaskedBits()
1908 case ISD::CTTZ: in ComputeMaskedBits()
1909 case ISD::CTTZ_ZERO_UNDEF: in ComputeMaskedBits()
1910 case ISD::CTLZ: in ComputeMaskedBits()
1911 case ISD::CTLZ_ZERO_UNDEF: in ComputeMaskedBits()
1912 case ISD::CTPOP: { in ComputeMaskedBits()
1918 case ISD::LOAD: { in ComputeMaskedBits()
1920 if (ISD::isZEXTLoad(Op.getNode())) { in ComputeMaskedBits()
1929 case ISD::ZERO_EXTEND: { in ComputeMaskedBits()
1941 case ISD::SIGN_EXTEND: { in ComputeMaskedBits()
1967 case ISD::ANY_EXTEND: { in ComputeMaskedBits()
1977 case ISD::TRUNCATE: { in ComputeMaskedBits()
1988 case ISD::AssertZext: { in ComputeMaskedBits()
1996 case ISD::FGETSIGN: in ComputeMaskedBits()
2001 case ISD::SUB: { in ComputeMaskedBits()
2024 case ISD::ADD: in ComputeMaskedBits()
2025 case ISD::ADDE: { in ComputeMaskedBits()
2038 if (Op.getOpcode() == ISD::ADD) { in ComputeMaskedBits()
2051 case ISD::SREM: in ComputeMaskedBits()
2076 case ISD::UREM: { in ComputeMaskedBits()
2099 case ISD::FrameIndex: in ComputeMaskedBits()
2100 case ISD::TargetFrameIndex: in ComputeMaskedBits()
2109 if (Op.getOpcode() < ISD::BUILTIN_OP_END) in ComputeMaskedBits()
2112 case ISD::INTRINSIC_WO_CHAIN: in ComputeMaskedBits()
2113 case ISD::INTRINSIC_W_CHAIN: in ComputeMaskedBits()
2114 case ISD::INTRINSIC_VOID: in ComputeMaskedBits()
2138 case ISD::AssertSext: in ComputeNumSignBits()
2141 case ISD::AssertZext: in ComputeNumSignBits()
2145 case ISD::Constant: { in ComputeNumSignBits()
2150 case ISD::SIGN_EXTEND: in ComputeNumSignBits()
2154 case ISD::SIGN_EXTEND_INREG: in ComputeNumSignBits()
2163 case ISD::SRA: in ComputeNumSignBits()
2171 case ISD::SHL: in ComputeNumSignBits()
2180 case ISD::AND: in ComputeNumSignBits()
2181 case ISD::OR: in ComputeNumSignBits()
2182 case ISD::XOR: // NOT is handled here. in ComputeNumSignBits()
2194 case ISD::SELECT: in ComputeNumSignBits()
2200 case ISD::SADDO: in ComputeNumSignBits()
2201 case ISD::UADDO: in ComputeNumSignBits()
2202 case ISD::SSUBO: in ComputeNumSignBits()
2203 case ISD::USUBO: in ComputeNumSignBits()
2204 case ISD::SMULO: in ComputeNumSignBits()
2205 case ISD::UMULO: in ComputeNumSignBits()
2209 case ISD::SETCC: in ComputeNumSignBits()
2215 case ISD::ROTL: in ComputeNumSignBits()
2216 case ISD::ROTR: in ComputeNumSignBits()
2221 if (Op.getOpcode() == ISD::ROTR) in ComputeNumSignBits()
2230 case ISD::ADD: in ComputeNumSignBits()
2257 case ISD::SUB: in ComputeNumSignBits()
2284 case ISD::TRUNCATE: in ComputeNumSignBits()
2295 case ISD::SEXTLOAD: // '17' bits known in ComputeNumSignBits()
2298 case ISD::ZEXTLOAD: // '16' bits known in ComputeNumSignBits()
2305 if (Op.getOpcode() >= ISD::BUILTIN_OP_END || in ComputeNumSignBits()
2306 Op.getOpcode() == ISD::INTRINSIC_WO_CHAIN || in ComputeNumSignBits()
2307 Op.getOpcode() == ISD::INTRINSIC_W_CHAIN || in ComputeNumSignBits()
2308 Op.getOpcode() == ISD::INTRINSIC_VOID) { in ComputeNumSignBits()
2343 if ((Op.getOpcode() != ISD::ADD && Op.getOpcode() != ISD::OR) || in isBaseWithConstantOffset()
2347 if (Op.getOpcode() == ISD::OR && in isBaseWithConstantOffset()
2378 case ISD::OR: in isKnownNeverZero()
2426 case ISD::SIGN_EXTEND: in getNode()
2428 case ISD::ANY_EXTEND: in getNode()
2429 case ISD::ZERO_EXTEND: in getNode()
2430 case ISD::TRUNCATE: in getNode()
2432 case ISD::UINT_TO_FP: in getNode()
2433 case ISD::SINT_TO_FP: { in getNode()
2437 Opcode==ISD::SINT_TO_FP, in getNode()
2441 case ISD::BITCAST: in getNode()
2447 case ISD::BSWAP: in getNode()
2449 case ISD::CTPOP: in getNode()
2451 case ISD::CTLZ: in getNode()
2452 case ISD::CTLZ_ZERO_UNDEF: in getNode()
2454 case ISD::CTTZ: in getNode()
2455 case ISD::CTTZ_ZERO_UNDEF: in getNode()
2464 case ISD::FNEG: in getNode()
2467 case ISD::FABS: in getNode()
2470 case ISD::FCEIL: { in getNode()
2476 case ISD::FTRUNC: { in getNode()
2482 case ISD::FFLOOR: { in getNode()
2488 case ISD::FP_EXTEND: { in getNode()
2496 case ISD::FP_TO_SINT: in getNode()
2497 case ISD::FP_TO_UINT: { in getNode()
2503 Opcode==ISD::FP_TO_SINT, in getNode()
2510 case ISD::BITCAST: in getNode()
2521 case ISD::TokenFactor: in getNode()
2522 case ISD::MERGE_VALUES: in getNode()
2523 case ISD::CONCAT_VECTORS: in getNode()
2525 case ISD::FP_ROUND: llvm_unreachable("Invalid method to make FP_ROUND node"); in getNode()
2526 case ISD::FP_EXTEND: in getNode()
2534 if (Operand.getOpcode() == ISD::UNDEF) in getNode()
2537 case ISD::SIGN_EXTEND: in getNode()
2547 if (OpOpcode == ISD::SIGN_EXTEND || OpOpcode == ISD::ZERO_EXTEND) in getNode()
2549 else if (OpOpcode == ISD::UNDEF) in getNode()
2553 case ISD::ZERO_EXTEND: in getNode()
2563 if (OpOpcode == ISD::ZERO_EXTEND) // (zext (zext x)) -> (zext x) in getNode()
2564 return getNode(ISD::ZERO_EXTEND, DL, VT, in getNode()
2566 else if (OpOpcode == ISD::UNDEF) in getNode()
2570 case ISD::ANY_EXTEND: in getNode()
2581 if (OpOpcode == ISD::ZERO_EXTEND || OpOpcode == ISD::SIGN_EXTEND || in getNode()
2582 OpOpcode == ISD::ANY_EXTEND) in getNode()
2585 else if (OpOpcode == ISD::UNDEF) in getNode()
2589 if (OpOpcode == ISD::TRUNCATE) { in getNode()
2595 case ISD::TRUNCATE: in getNode()
2605 if (OpOpcode == ISD::TRUNCATE) in getNode()
2606 return getNode(ISD::TRUNCATE, DL, VT, Operand.getNode()->getOperand(0)); in getNode()
2607 if (OpOpcode == ISD::ZERO_EXTEND || OpOpcode == ISD::SIGN_EXTEND || in getNode()
2608 OpOpcode == ISD::ANY_EXTEND) { in getNode()
2614 return getNode(ISD::TRUNCATE, DL, VT, Operand.getNode()->getOperand(0)); in getNode()
2617 if (OpOpcode == ISD::UNDEF) in getNode()
2620 case ISD::BITCAST: in getNode()
2625 if (OpOpcode == ISD::BITCAST) // bitconv(bitconv(x)) -> bitconv(x) in getNode()
2626 return getNode(ISD::BITCAST, DL, VT, Operand.getOperand(0)); in getNode()
2627 if (OpOpcode == ISD::UNDEF) in getNode()
2630 case ISD::SCALAR_TO_VECTOR: in getNode()
2637 if (OpOpcode == ISD::UNDEF) in getNode()
2640 if (OpOpcode == ISD::EXTRACT_VECTOR_ELT && in getNode()
2646 case ISD::FNEG: in getNode()
2648 if (getTarget().Options.UnsafeFPMath && OpOpcode == ISD::FSUB) in getNode()
2649 return getNode(ISD::FSUB, DL, VT, Operand.getNode()->getOperand(1), in getNode()
2651 if (OpOpcode == ISD::FNEG) // --X -> X in getNode()
2654 case ISD::FABS: in getNode()
2655 if (OpOpcode == ISD::FNEG) // abs(-X) -> abs(X) in getNode()
2656 return getNode(ISD::FABS, DL, VT, Operand.getNode()->getOperand(0)); in getNode()
2725 case ISD::ADD: in FoldConstantArithmetic()
2728 case ISD::SUB: in FoldConstantArithmetic()
2731 case ISD::MUL: in FoldConstantArithmetic()
2734 case ISD::UDIV: in FoldConstantArithmetic()
2739 case ISD::UREM: in FoldConstantArithmetic()
2744 case ISD::SDIV: in FoldConstantArithmetic()
2749 case ISD::SREM: in FoldConstantArithmetic()
2754 case ISD::AND: in FoldConstantArithmetic()
2757 case ISD::OR: in FoldConstantArithmetic()
2760 case ISD::XOR: in FoldConstantArithmetic()
2763 case ISD::SHL: in FoldConstantArithmetic()
2766 case ISD::SRL: in FoldConstantArithmetic()
2769 case ISD::SRA: in FoldConstantArithmetic()
2772 case ISD::ROTL: in FoldConstantArithmetic()
2775 case ISD::ROTR: in FoldConstantArithmetic()
2788 return getNode(ISD::BUILD_VECTOR, DebugLoc(), VT, Outputs.data(), in FoldConstantArithmetic()
2798 case ISD::TokenFactor: in getNode()
2802 if (N1.getOpcode() == ISD::EntryToken) return N2; in getNode()
2803 if (N2.getOpcode() == ISD::EntryToken) return N1; in getNode()
2806 case ISD::CONCAT_VECTORS: in getNode()
2808 if (N1.getOpcode() == ISD::UNDEF && in getNode()
2809 N2.getOpcode() == ISD::UNDEF) in getNode()
2814 if (N1.getOpcode() == ISD::BUILD_VECTOR && in getNode()
2815 N2.getOpcode() == ISD::BUILD_VECTOR) { in getNode()
2819 return getNode(ISD::BUILD_VECTOR, DL, VT, &Elts[0], Elts.size()); in getNode()
2822 case ISD::AND: in getNode()
2833 case ISD::OR: in getNode()
2834 case ISD::XOR: in getNode()
2835 case ISD::ADD: in getNode()
2836 case ISD::SUB: in getNode()
2845 case ISD::UDIV: in getNode()
2846 case ISD::UREM: in getNode()
2847 case ISD::MULHU: in getNode()
2848 case ISD::MULHS: in getNode()
2849 case ISD::MUL: in getNode()
2850 case ISD::SDIV: in getNode()
2851 case ISD::SREM: in getNode()
2856 case ISD::FADD: in getNode()
2857 case ISD::FSUB: in getNode()
2858 case ISD::FMUL: in getNode()
2859 case ISD::FDIV: in getNode()
2860 case ISD::FREM: in getNode()
2862 if (Opcode == ISD::FADD) { in getNode()
2871 } else if (Opcode == ISD::FSUB) { in getNode()
2876 } else if (Opcode == ISD::FMUL) { in getNode()
2900 case ISD::FCOPYSIGN: // N1 and result must match. N1/N2 need not match. in getNode()
2906 case ISD::SHL: in getNode()
2907 case ISD::SRA: in getNode()
2908 case ISD::SRL: in getNode()
2909 case ISD::ROTL: in getNode()
2910 case ISD::ROTR: in getNode()
2933 case ISD::FP_ROUND_INREG: { in getNode()
2949 case ISD::FP_ROUND: in getNode()
2956 case ISD::AssertSext: in getNode()
2957 case ISD::AssertZext: { in getNode()
2969 case ISD::SIGN_EXTEND_INREG: { in getNode()
2992 case ISD::EXTRACT_VECTOR_ELT: in getNode()
2994 if (N1.getOpcode() == ISD::UNDEF) in getNode()
3000 N1.getOpcode() == ISD::CONCAT_VECTORS && in getNode()
3004 return getNode(ISD::EXTRACT_VECTOR_ELT, DL, VT, in getNode()
3012 if (N2C && N1.getOpcode() == ISD::BUILD_VECTOR) { in getNode()
3026 if (N1.getOpcode() == ISD::INSERT_VECTOR_ELT) { in getNode()
3041 return getNode(ISD::EXTRACT_VECTOR_ELT, DL, VT, N1.getOperand(0), N2); in getNode()
3045 case ISD::EXTRACT_ELEMENT: in getNode()
3055 if (N1.getOpcode() == ISD::BUILD_PAIR) in getNode()
3066 case ISD::EXTRACT_SUBVECTOR: { in getNode()
3113 case ISD::FADD: in getNode()
3118 case ISD::FSUB: in getNode()
3123 case ISD::FMUL: in getNode()
3128 case ISD::FDIV: in getNode()
3133 case ISD::FREM : in getNode()
3138 case ISD::FCOPYSIGN: in getNode()
3145 if (Opcode == ISD::FP_ROUND) { in getNode()
3157 if (N1.getOpcode() == ISD::UNDEF) { in getNode()
3162 case ISD::FP_ROUND_INREG: in getNode()
3163 case ISD::SIGN_EXTEND_INREG: in getNode()
3164 case ISD::SUB: in getNode()
3165 case ISD::FSUB: in getNode()
3166 case ISD::FDIV: in getNode()
3167 case ISD::FREM: in getNode()
3168 case ISD::SRA: in getNode()
3170 case ISD::UDIV: in getNode()
3171 case ISD::SDIV: in getNode()
3172 case ISD::UREM: in getNode()
3173 case ISD::SREM: in getNode()
3174 case ISD::SRL: in getNode()
3175 case ISD::SHL: in getNode()
3186 if (N2.getOpcode() == ISD::UNDEF) { in getNode()
3188 case ISD::XOR: in getNode()
3189 if (N1.getOpcode() == ISD::UNDEF) in getNode()
3194 case ISD::ADD: in getNode()
3195 case ISD::ADDC: in getNode()
3196 case ISD::ADDE: in getNode()
3197 case ISD::SUB: in getNode()
3198 case ISD::UDIV: in getNode()
3199 case ISD::SDIV: in getNode()
3200 case ISD::UREM: in getNode()
3201 case ISD::SREM: in getNode()
3203 case ISD::FADD: in getNode()
3204 case ISD::FSUB: in getNode()
3205 case ISD::FMUL: in getNode()
3206 case ISD::FDIV: in getNode()
3207 case ISD::FREM: in getNode()
3211 case ISD::MUL: in getNode()
3212 case ISD::AND: in getNode()
3213 case ISD::SRL: in getNode()
3214 case ISD::SHL: in getNode()
3220 case ISD::OR: in getNode()
3226 case ISD::SRA: in getNode()
3260 case ISD::CONCAT_VECTORS: in getNode()
3263 if (N1.getOpcode() == ISD::BUILD_VECTOR && in getNode()
3264 N2.getOpcode() == ISD::BUILD_VECTOR && in getNode()
3265 N3.getOpcode() == ISD::BUILD_VECTOR) { in getNode()
3270 return getNode(ISD::BUILD_VECTOR, DL, VT, &Elts[0], Elts.size()); in getNode()
3273 case ISD::SETCC: { in getNode()
3279 case ISD::SELECT: in getNode()
3288 case ISD::VECTOR_SHUFFLE: in getNode()
3290 case ISD::INSERT_SUBVECTOR: { in getNode()
3314 case ISD::BITCAST: in getNode()
3378 return getNode(ISD::TokenFactor, Chain.getDebugLoc(), MVT::Other, in getStackArgumentTokenFactor()
3386 assert(Value.getOpcode() != ISD::UNDEF); in getMemsetValue()
3397 Value = DAG.getNode(ISD::ZERO_EXTEND, dl, VT, Value); in getMemsetValue()
3402 Value = DAG.getNode(ISD::MUL, dl, VT, Value, DAG.getConstant(Magic, VT)); in getMemsetValue()
3422 return DAG.getNode(ISD::BITCAST, dl, VT, in getMemsetStringVal()
3456 return DAG.getNode(ISD::ADD, Base.getDebugLoc(), in getMemBasePlusOffset()
3465 if (Src.getOpcode() == ISD::GlobalAddress) in isMemSrcFromString()
3467 else if (Src.getOpcode() == ISD::ADD && in isMemSrcFromString()
3468 Src.getOperand(0).getOpcode() == ISD::GlobalAddress && in isMemSrcFromString()
3469 Src.getOperand(1).getOpcode() == ISD::Constant) { in isMemSrcFromString()
3538 if (TLI.isOperationLegalOrCustom(ISD::STORE, NewVT) && in FindOptimalMemOpLowering()
3542 TLI.isOperationLegalOrCustom(ISD::STORE, MVT::f64) && in FindOptimalMemOpLowering()
3592 if (Src.getOpcode() == ISD::UNDEF) in getMemcpyLoadsAndStores()
3683 Value = DAG.getExtLoad(ISD::EXTLOAD, dl, NVT, Chain, in getMemcpyLoadsAndStores()
3698 return DAG.getNode(ISD::TokenFactor, dl, MVT::Other, in getMemcpyLoadsAndStores()
3710 if (Src.getOpcode() == ISD::UNDEF) in getMemmoveLoadsAndStores()
3764 Chain = DAG.getNode(ISD::TokenFactor, dl, MVT::Other, in getMemmoveLoadsAndStores()
3779 return DAG.getNode(ISD::TokenFactor, dl, MVT::Other, in getMemmoveLoadsAndStores()
3789 if (Src.getOpcode() == ISD::UNDEF) in getMemsetStores()
3849 Value = DAG.getNode(ISD::TRUNCATE, dl, VT, MemSetValue); in getMemsetStores()
3863 return DAG.getNode(ISD::TokenFactor, dl, MVT::Other, in getMemsetStores()
4029 Src = getNode(ISD::TRUNCATE, dl, MVT::i32, Src); in getMemset()
4031 Src = getNode(ISD::ZERO_EXTEND, dl, MVT::i32, Src); in getMemset()
4071 if (Opcode != ISD::ATOMIC_STORE) in getAtomic()
4073 if (Opcode != ISD::ATOMIC_LOAD) in getAtomic()
4089 assert(Opcode == ISD::ATOMIC_CMP_SWAP && "Invalid Atomic Op"); in getAtomic()
4131 if (Opcode != ISD::ATOMIC_STORE) in getAtomic()
4133 if (Opcode != ISD::ATOMIC_LOAD) in getAtomic()
4150 assert((Opcode == ISD::ATOMIC_LOAD_ADD || in getAtomic()
4151 Opcode == ISD::ATOMIC_LOAD_SUB || in getAtomic()
4152 Opcode == ISD::ATOMIC_LOAD_AND || in getAtomic()
4153 Opcode == ISD::ATOMIC_LOAD_OR || in getAtomic()
4154 Opcode == ISD::ATOMIC_LOAD_XOR || in getAtomic()
4155 Opcode == ISD::ATOMIC_LOAD_NAND || in getAtomic()
4156 Opcode == ISD::ATOMIC_LOAD_MIN || in getAtomic()
4157 Opcode == ISD::ATOMIC_LOAD_MAX || in getAtomic()
4158 Opcode == ISD::ATOMIC_LOAD_UMIN || in getAtomic()
4159 Opcode == ISD::ATOMIC_LOAD_UMAX || in getAtomic()
4160 Opcode == ISD::ATOMIC_SWAP || in getAtomic()
4161 Opcode == ISD::ATOMIC_STORE) && in getAtomic()
4166 SDVTList VTs = Opcode == ISD::ATOMIC_STORE ? getVTList(MVT::Other) : in getAtomic()
4204 if (Opcode != ISD::ATOMIC_STORE) in getAtomic()
4206 if (Opcode != ISD::ATOMIC_LOAD) in getAtomic()
4223 assert(Opcode == ISD::ATOMIC_LOAD && "Invalid Atomic Op"); in getAtomic()
4253 return getNode(ISD::MERGE_VALUES, dl, getVTList(&VTs[0], NumOps), in getMergeValues()
4296 assert((Opcode == ISD::INTRINSIC_VOID || in getMemIntrinsicNode()
4297 Opcode == ISD::INTRINSIC_W_CHAIN || in getMemIntrinsicNode()
4298 Opcode == ISD::PREFETCH || in getMemIntrinsicNode()
4299 Opcode == ISD::LIFETIME_START || in getMemIntrinsicNode()
4300 Opcode == ISD::LIFETIME_END || in getMemIntrinsicNode()
4302 (int)Opcode >= ISD::FIRST_TARGET_MEMORY_OPCODE)) && in getMemIntrinsicNode()
4338 if (Ptr.getOpcode() != ISD::ADD || in InferPointerInfo()
4356 if (OffsetOp.getOpcode() == ISD::UNDEF) in InferPointerInfo()
4363 SelectionDAG::getLoad(ISD::MemIndexedMode AM, ISD::LoadExtType ExtType, in getLoad()
4396 SelectionDAG::getLoad(ISD::MemIndexedMode AM, ISD::LoadExtType ExtType, in getLoad()
4401 ExtType = ISD::NON_EXTLOAD; in getLoad()
4402 } else if (ExtType == ISD::NON_EXTLOAD) { in getLoad()
4417 bool Indexed = AM != ISD::UNINDEXED; in getLoad()
4418 assert((Indexed || Offset.getOpcode() == ISD::UNDEF) && in getLoad()
4425 AddNodeIDNode(ID, ISD::LOAD, VTs, Ops, 3); in getLoad()
4451 return getLoad(ISD::UNINDEXED, ISD::NON_EXTLOAD, VT, dl, Chain, Ptr, Undef, in getLoad()
4456 SDValue SelectionDAG::getExtLoad(ISD::LoadExtType ExtType, DebugLoc dl, EVT VT, in getExtLoad()
4462 return getLoad(ISD::UNINDEXED, ExtType, VT, dl, Chain, Ptr, Undef, in getExtLoad()
4470 SDValue Offset, ISD::MemIndexedMode AM) { in getIndexedLoad()
4472 assert(LD->getOffset().getOpcode() == ISD::UNDEF && in getIndexedLoad()
4516 AddNodeIDNode(ID, ISD::STORE, VTs, Ops, 4); in getStore()
4518 ID.AddInteger(encodeMemSDNodeFlags(false, ISD::UNINDEXED, MMO->isVolatile(), in getStore()
4526 SDNode *N = new (NodeAllocator) StoreSDNode(Ops, dl, VTs, ISD::UNINDEXED, in getStore()
4584 AddNodeIDNode(ID, ISD::STORE, VTs, Ops, 4); in getTruncStore()
4586 ID.AddInteger(encodeMemSDNodeFlags(true, ISD::UNINDEXED, MMO->isVolatile(), in getTruncStore()
4594 SDNode *N = new (NodeAllocator) StoreSDNode(Ops, dl, VTs, ISD::UNINDEXED, in getTruncStore()
4603 SDValue Offset, ISD::MemIndexedMode AM) { in getIndexedStore()
4605 assert(ST->getOffset().getOpcode() == ISD::UNDEF && in getIndexedStore()
4610 AddNodeIDNode(ID, ISD::STORE, VTs, Ops, 4); in getIndexedStore()
4632 return getNode(ISD::VAARG, dl, getVTList(VT, MVT::Other), Ops, 4); in getVAArg()
4663 case ISD::SELECT_CC: { in getNode()
4673 case ISD::BR_CC: { in getNode()
4731 case ISD::SRA_PARTS: in getNode()
4732 case ISD::SRL_PARTS: in getNode()
4733 case ISD::SHL_PARTS: in getNode()
4734 if (N3.getOpcode() == ISD::SIGN_EXTEND_INREG && in getNode()
4737 else if (N3.getOpcode() == ISD::AND) in getNode()
5828 assert(AllNodes.front().getOpcode() == ISD::EntryToken && in AssignTopologicalOrder()
5903 SubclassData = encodeMemSDNodeFlags(0, ISD::UNINDEXED, MMO->isVolatile(), in MemSDNode()
5916 SubclassData = encodeMemSDNodeFlags(0, ISD::UNINDEXED, MMO->isVolatile(), in MemSDNode()
6036 if (getOpcode() == ISD::TokenFactor) { in reachesChainWithoutSideEffects()
6119 Operands[j] = getNode(ISD::EXTRACT_VECTOR_ELT, dl, in UnrollVectorOp()
6134 case ISD::VSELECT: in UnrollVectorOp()
6135 Scalars.push_back(getNode(ISD::SELECT, dl, EltVT, in UnrollVectorOp()
6138 case ISD::SHL: in UnrollVectorOp()
6139 case ISD::SRA: in UnrollVectorOp()
6140 case ISD::SRL: in UnrollVectorOp()
6141 case ISD::ROTL: in UnrollVectorOp()
6142 case ISD::ROTR: in UnrollVectorOp()
6147 case ISD::SIGN_EXTEND_INREG: in UnrollVectorOp()
6148 case ISD::FP_ROUND_INREG: { in UnrollVectorOp()
6160 return getNode(ISD::BUILD_VECTOR, dl, in UnrollVectorOp()
6179 if (Loc.getOpcode() == ISD::FrameIndex) { in isConsecutiveLoad()
6180 if (BaseLoc.getOpcode() != ISD::FrameIndex) in isConsecutiveLoad()
6288 if (OpVal.getOpcode() == ISD::UNDEF) in isConstantSplat()