Lines Matching refs:MVT
111 unsigned fastEmit_i(MVT Ty, MVT RetTy, unsigned Opc, uint64_t Imm) override;
140 bool isTypeLegal(Type *Ty, MVT &VT);
141 bool isLoadTypeLegal(Type *Ty, MVT &VT);
160 bool PPCEmitLoad(MVT VT, Register &ResultReg, Address &Addr,
163 bool PPCEmitStore(MVT VT, unsigned SrcReg, Address &Addr);
167 bool PPCEmitIntExt(MVT SrcVT, unsigned SrcReg, MVT DestVT,
169 unsigned PPCMaterializeFP(const ConstantFP *CFP, MVT VT);
170 unsigned PPCMaterializeGV(const GlobalValue *GV, MVT VT);
171 unsigned PPCMaterializeInt(const ConstantInt *CI, MVT VT,
177 unsigned PPCMoveToIntReg(const Instruction *I, MVT VT,
179 unsigned PPCMoveToFPReg(MVT VT, unsigned SrcReg, bool IsSigned);
185 SmallVectorImpl<MVT> &ArgVTs,
191 bool finishCall(MVT RetVT, CallLoweringInfo &CLI, unsigned &NumBytes);
269 bool PPCFastISel::isTypeLegal(Type *Ty, MVT &VT) { in isTypeLegal()
273 if (Evt == MVT::Other || !Evt.isSimple()) return false; in isTypeLegal()
283 bool PPCFastISel::isLoadTypeLegal(Type *Ty, MVT &VT) { in isLoadTypeLegal()
288 if (VT == MVT::i8 || VT == MVT::i16 || VT == MVT::i32) { in isLoadTypeLegal()
440 IndexReg = PPCMaterializeInt(Offset, MVT::i64); in PPCSimplifyAddress()
448 bool PPCFastISel::PPCEmitLoad(MVT VT, Register &ResultReg, Address &Addr, in PPCEmitLoad()
465 (VT == MVT::f64 ? (HasSPE ? &PPC::SPERCRegClass : &PPC::F8RCRegClass) : in PPCEmitLoad()
466 (VT == MVT::f32 ? (HasSPE ? &PPC::GPRCRegClass : &PPC::F4RCRegClass) : in PPCEmitLoad()
467 (VT == MVT::i64 ? &PPC::G8RC_and_G8RC_NOX0RegClass : in PPCEmitLoad()
475 case MVT::i8: in PPCEmitLoad()
478 case MVT::i16: in PPCEmitLoad()
482 case MVT::i32: in PPCEmitLoad()
488 case MVT::i64: in PPCEmitLoad()
494 case MVT::f32: in PPCEmitLoad()
497 case MVT::f64: in PPCEmitLoad()
593 MVT VT; in SelectLoad()
618 bool PPCFastISel::PPCEmitStore(MVT VT, unsigned SrcReg, Address &Addr) { in PPCEmitStore()
629 case MVT::i8: in PPCEmitStore()
632 case MVT::i16: in PPCEmitStore()
635 case MVT::i32: in PPCEmitStore()
639 case MVT::i64: in PPCEmitStore()
643 case MVT::f32: in PPCEmitStore()
646 case MVT::f64: in PPCEmitStore()
742 MVT VT; in SelectStore()
824 MVT SrcVT = SrcEVT.getSimpleVT(); in PPCEmitCmp()
826 if (SrcVT == MVT::i1 && Subtarget->useCRBits()) in PPCEmitCmp()
840 if (SrcVT == MVT::i64 || SrcVT == MVT::i32 || SrcVT == MVT::i16 || in PPCEmitCmp()
841 SrcVT == MVT::i8 || SrcVT == MVT::i1) { in PPCEmitCmp()
869 case MVT::f32: in PPCEmitCmp()
891 case MVT::f64: in PPCEmitCmp()
911 case MVT::i1: in PPCEmitCmp()
912 case MVT::i8: in PPCEmitCmp()
913 case MVT::i16: in PPCEmitCmp()
916 case MVT::i32: in PPCEmitCmp()
922 case MVT::i64: in PPCEmitCmp()
932 if (!PPCEmitIntExt(SrcVT, SrcReg1, MVT::i32, ExtReg, IsZExt)) in PPCEmitCmp()
938 if (!PPCEmitIntExt(SrcVT, SrcReg2, MVT::i32, ExtReg, IsZExt)) in PPCEmitCmp()
960 if (SrcVT != MVT::f32 || DestVT != MVT::f64) in SelectFPExt()
978 if (SrcVT != MVT::f64 || DestVT != MVT::f32) in SelectFPTrunc()
1017 unsigned PPCFastISel::PPCMoveToFPReg(MVT SrcVT, unsigned SrcReg, in PPCMoveToFPReg()
1021 if (SrcVT == MVT::i32) { in PPCMoveToFPReg()
1023 if (!PPCEmitIntExt(MVT::i32, SrcReg, MVT::i64, TmpReg, !IsSigned)) in PPCMoveToFPReg()
1034 if (!PPCEmitStore(MVT::i64, SrcReg, Addr)) in PPCMoveToFPReg()
1041 if (SrcVT == MVT::i32) { in PPCMoveToFPReg()
1053 if (!PPCEmitLoad(MVT::f64, ResultReg, Addr, RC, !IsSigned, LoadOpc)) in PPCMoveToFPReg()
1063 MVT DstVT; in SelectIToFP()
1068 if (DstVT != MVT::f32 && DstVT != MVT::f64) in SelectIToFP()
1076 MVT SrcVT = SrcEVT.getSimpleVT(); in SelectIToFP()
1078 if (SrcVT != MVT::i8 && SrcVT != MVT::i16 && in SelectIToFP()
1079 SrcVT != MVT::i32 && SrcVT != MVT::i64) in SelectIToFP()
1089 if (DstVT == MVT::f32) in SelectIToFP()
1112 if (DstVT == MVT::f32 && !Subtarget->hasFPCVT()) in SelectIToFP()
1116 if (SrcVT == MVT::i8 || SrcVT == MVT::i16) { in SelectIToFP()
1118 if (!PPCEmitIntExt(SrcVT, SrcReg, MVT::i64, TmpReg, !IsSigned)) in SelectIToFP()
1120 SrcVT = MVT::i64; in SelectIToFP()
1134 if (DstVT == MVT::f32) in SelectIToFP()
1152 unsigned PPCFastISel::PPCMoveToIntReg(const Instruction *I, MVT VT, in PPCMoveToIntReg()
1163 if (!PPCEmitStore(MVT::f64, SrcReg, Addr)) in PPCMoveToIntReg()
1168 if (VT == MVT::i32) in PPCMoveToIntReg()
1188 MVT DstVT, SrcVT; in SelectFPToI()
1193 if (DstVT != MVT::i32 && DstVT != MVT::i64) in SelectFPToI()
1197 if (DstVT == MVT::i64 && !IsSigned && !Subtarget->hasFPCVT() && in SelectFPToI()
1206 if (SrcVT != MVT::f32 && SrcVT != MVT::f64) in SelectFPToI()
1235 if (DstVT == MVT::i32) in SelectFPToI()
1241 if (DstVT == MVT::i32) in SelectFPToI()
1273 if (DestVT != MVT::i16 && DestVT != MVT::i8) in SelectBinaryIntOp()
1375 SmallVectorImpl<MVT> &ArgVTs, in processCallArgs()
1392 MVT ArgVT = ArgVTs[VA.getValNo()]; in processCallArgs()
1396 if (ArgVT.isVector() || ArgVT.getSizeInBits() > 64 || ArgVT == MVT::i1 || in processCallArgs()
1430 MVT ArgVT = ArgVTs[VA.getValNo()]; in processCallArgs()
1439 MVT DestVT = VA.getLocVT(); in processCallArgs()
1441 (DestVT == MVT::i64) ? &PPC::G8RCRegClass : &PPC::GPRCRegClass; in processCallArgs()
1451 MVT DestVT = VA.getLocVT(); in processCallArgs()
1453 (DestVT == MVT::i64) ? &PPC::G8RCRegClass : &PPC::GPRCRegClass; in processCallArgs()
1470 if (ArgVT == MVT::f32 || ArgVT == MVT::f64) { in processCallArgs()
1487 bool PPCFastISel::finishCall(MVT RetVT, CallLoweringInfo &CLI, unsigned &NumBytes) { in finishCall()
1498 if (RetVT != MVT::isVoid) { in finishCall()
1506 MVT DestVT = VA.getValVT(); in finishCall()
1507 MVT CopyVT = DestVT; in finishCall()
1511 if (RetVT == MVT::i8 || RetVT == MVT::i16 || RetVT == MVT::i32) in finishCall()
1512 CopyVT = MVT::i64; in finishCall()
1522 } else if (CopyVT == MVT::f64) { in finishCall()
1531 } else if (RetVT == MVT::i8 || RetVT == MVT::i16 || RetVT == MVT::i32) { in finishCall()
1571 MVT RetVT; in fastLowerCall()
1573 RetVT = MVT::isVoid; in fastLowerCall()
1574 else if (!isTypeLegal(RetTy, RetVT) && RetVT != MVT::i16 && in fastLowerCall()
1575 RetVT != MVT::i8) in fastLowerCall()
1577 else if (RetVT == MVT::i1 && Subtarget->useCRBits()) in fastLowerCall()
1582 if (RetVT != MVT::isVoid && RetVT != MVT::i8 && RetVT != MVT::i16 && in fastLowerCall()
1583 RetVT != MVT::i32 && RetVT != MVT::i64 && RetVT != MVT::f32 && in fastLowerCall()
1584 RetVT != MVT::f64) { in fastLowerCall()
1601 SmallVector<MVT, 8> ArgVTs; in fastLowerCall()
1619 MVT ArgVT; in fastLowerCall()
1620 if (!isTypeLegal(ArgTy, ArgVT) && ArgVT != MVT::i16 && ArgVT != MVT::i8) in fastLowerCall()
1626 if (ArgVT.isVector() || ArgVT == MVT::f128) in fastLowerCall()
1727 PPCMaterializeInt(CI, MVT::i64, VA.getLocInfo() != CCValAssign::ZExt); in SelectRet()
1751 MVT RVVT = RVEVT.getSimpleVT(); in SelectRet()
1752 MVT DestVT = VA.getLocVT(); in SelectRet()
1754 if (RVVT != DestVT && RVVT != MVT::i8 && in SelectRet()
1755 RVVT != MVT::i16 && RVVT != MVT::i32) in SelectRet()
1767 (DestVT == MVT::i64) ? &PPC::G8RCRegClass : &PPC::GPRCRegClass; in SelectRet()
1776 (DestVT == MVT::i64) ? &PPC::G8RCRegClass : &PPC::GPRCRegClass; in SelectRet()
1805 bool PPCFastISel::PPCEmitIntExt(MVT SrcVT, unsigned SrcReg, MVT DestVT, in PPCEmitIntExt()
1807 if (DestVT != MVT::i32 && DestVT != MVT::i64) in PPCEmitIntExt()
1809 if (SrcVT != MVT::i8 && SrcVT != MVT::i16 && SrcVT != MVT::i32) in PPCEmitIntExt()
1815 if (SrcVT == MVT::i8) in PPCEmitIntExt()
1816 Opc = (DestVT == MVT::i32) ? PPC::EXTSB : PPC::EXTSB8_32_64; in PPCEmitIntExt()
1817 else if (SrcVT == MVT::i16) in PPCEmitIntExt()
1818 Opc = (DestVT == MVT::i32) ? PPC::EXTSH : PPC::EXTSH8_32_64; in PPCEmitIntExt()
1820 assert(DestVT == MVT::i64 && "Signed extend from i32 to i32??"); in PPCEmitIntExt()
1827 } else if (DestVT == MVT::i32) { in PPCEmitIntExt()
1829 if (SrcVT == MVT::i8) in PPCEmitIntExt()
1832 assert(SrcVT == MVT::i16 && "Unsigned extend from i32 to i32??"); in PPCEmitIntExt()
1842 if (SrcVT == MVT::i8) in PPCEmitIntExt()
1844 else if (SrcVT == MVT::i16) in PPCEmitIntExt()
1879 if (SrcVT != MVT::i64 && SrcVT != MVT::i32 && SrcVT != MVT::i16) in SelectTrunc()
1882 if (DestVT != MVT::i32 && DestVT != MVT::i16 && DestVT != MVT::i8) in SelectTrunc()
1890 if (SrcVT == MVT::i64) in SelectTrunc()
1915 MVT SrcVT = SrcEVT.getSimpleVT(); in SelectIntExt()
1916 MVT DestVT = DestEVT.getSimpleVT(); in SelectIntExt()
1925 (DestVT == MVT::i64 ? &PPC::G8RC_and_G8RC_NOX0RegClass : in SelectIntExt()
1985 unsigned PPCFastISel::PPCMaterializeFP(const ConstantFP *CFP, MVT VT) { in PPCMaterializeFP()
1991 if (VT != MVT::f32 && VT != MVT::f64) in PPCMaterializeFP()
2000 RC = ((VT == MVT::f32) ? &PPC::GPRCRegClass : &PPC::SPERCRegClass); in PPCMaterializeFP()
2002 RC = ((VT == MVT::f32) ? &PPC::F4RCRegClass : &PPC::F8RCRegClass); in PPCMaterializeFP()
2009 MachineMemOperand::MOLoad, (VT == MVT::f32) ? 4 : 8, Alignment); in PPCMaterializeFP()
2014 Opc = ((VT == MVT::f32) ? PPC::SPELWZ : PPC::EVLDD); in PPCMaterializeFP()
2016 Opc = ((VT == MVT::f32) ? PPC::LFS : PPC::LFD); in PPCMaterializeFP()
2053 unsigned PPCFastISel::PPCMaterializeGV(const GlobalValue *GV, MVT VT) { in PPCMaterializeGV()
2058 assert(VT == MVT::i64 && "Non-address!"); in PPCMaterializeGV()
2208 unsigned PPCFastISel::PPCMaterializeInt(const ConstantInt *CI, MVT VT, in PPCMaterializeInt()
2212 if (VT == MVT::i1 && Subtarget->useCRBits()) { in PPCMaterializeInt()
2219 if (VT != MVT::i64 && VT != MVT::i32 && VT != MVT::i16 && VT != MVT::i8 && in PPCMaterializeInt()
2220 VT != MVT::i1) in PPCMaterializeInt()
2224 ((VT == MVT::i64) ? &PPC::G8RCRegClass : &PPC::GPRCRegClass); in PPCMaterializeInt()
2232 unsigned Opc = (VT == MVT::i64) ? PPC::LI8 : PPC::LI; in PPCMaterializeInt()
2240 if (VT == MVT::i64) in PPCMaterializeInt()
2242 else if (VT == MVT::i32) in PPCMaterializeInt()
2255 MVT VT = CEVT.getSimpleVT(); in fastMaterializeConstant()
2278 MVT VT; in fastMaterializeAlloca()
2305 MVT VT; in tryToFoldLoadIntoMI()
2319 if ((VT == MVT::i8 && MB <= 56) || in tryToFoldLoadIntoMI()
2320 (VT == MVT::i16 && MB <= 48) || in tryToFoldLoadIntoMI()
2321 (VT == MVT::i32 && MB <= 32)) in tryToFoldLoadIntoMI()
2330 if ((VT == MVT::i8 && MB <= 24) || in tryToFoldLoadIntoMI()
2331 (VT == MVT::i16 && MB <= 16)) in tryToFoldLoadIntoMI()
2345 if (VT != MVT::i16 && VT != MVT::i8) in tryToFoldLoadIntoMI()
2353 if (VT != MVT::i32 && VT != MVT::i16 && VT != MVT::i8) in tryToFoldLoadIntoMI()
2387 unsigned PPCFastISel::fastEmit_i(MVT Ty, MVT VT, unsigned Opc, uint64_t Imm) { in fastEmit_i()
2394 if (VT == MVT::i1 && Subtarget->useCRBits()) { in fastEmit_i()
2401 if (VT != MVT::i64 && VT != MVT::i32 && VT != MVT::i16 && VT != MVT::i8 && in fastEmit_i()
2402 VT != MVT::i1) in fastEmit_i()
2405 const TargetRegisterClass *RC = ((VT == MVT::i64) ? &PPC::G8RCRegClass : in fastEmit_i()
2407 if (VT == MVT::i64) in fastEmit_i()