[llvm] 6c7e582 - [SelectionDAG] Don't call ComputeValueVTs for "demote register" (NFC) (#119268)
via llvm-commits
llvm-commits at lists.llvm.org
Wed Dec 11 03:46:16 PST 2024
Author: Sergei Barannikov
Date: 2024-12-11T14:46:12+03:00
New Revision: 6c7e5827eda26990e872eb7c3f0d7866ee3c3171
URL: https://github.com/llvm/llvm-project/commit/6c7e5827eda26990e872eb7c3f0d7866ee3c3171
DIFF: https://github.com/llvm/llvm-project/commit/6c7e5827eda26990e872eb7c3f0d7866ee3c3171.diff
LOG: [SelectionDAG] Don't call ComputeValueVTs for "demote register" (NFC) (#119268)
`ComputeValueVTs` only breaks down aggregate types. For pointer types it
is equivalent to calling `TargetLoweringBase::getPointerTy`.
Added:
Modified:
llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
Removed:
################################################################################
diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
index c0537c72fac4a0..2464b57187b9c8 100644
--- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
+++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
@@ -2200,14 +2200,9 @@ void SelectionDAGBuilder::visitRet(const ReturnInst &I) {
// Emit a store of the return value through the virtual register.
// Leave Outs empty so that LowerReturn won't try to load return
// registers the usual way.
- SmallVector<EVT, 1> PtrValueVTs;
- ComputeValueVTs(TLI, DL,
- PointerType::get(F->getContext(),
- DAG.getDataLayout().getAllocaAddrSpace()),
- PtrValueVTs);
-
+ MVT PtrValueVT = TLI.getPointerTy(DL, DL.getAllocaAddrSpace());
SDValue RetPtr =
- DAG.getCopyFromReg(Chain, getCurSDLoc(), DemoteReg, PtrValueVTs[0]);
+ DAG.getCopyFromReg(Chain, getCurSDLoc(), DemoteReg, PtrValueVT);
SDValue RetOp = getValue(I.getOperand(0));
SmallVector<EVT, 4> ValueVTs, MemVTs;
@@ -11310,13 +11305,7 @@ TargetLowering::LowerCallTo(TargetLowering::CallLoweringInfo &CLI) const {
if (!CanLowerReturn) {
// The instruction result is the result of loading from the
// hidden sret parameter.
- SmallVector<EVT, 1> PVTs;
- Type *PtrRetTy =
- PointerType::get(OrigRetTy->getContext(), DL.getAllocaAddrSpace());
-
- ComputeValueVTs(*this, DL, PtrRetTy, PVTs);
- assert(PVTs.size() == 1 && "Pointers should fit in one register");
- EVT PtrVT = PVTs[0];
+ MVT PtrVT = getPointerTy(DL, DL.getAllocaAddrSpace());
unsigned NumValues = RetTys.size();
ReturnValues.resize(NumValues);
@@ -11636,18 +11625,12 @@ void SelectionDAGISel::LowerArguments(const Function &F) {
if (!FuncInfo->CanLowerReturn) {
// Put in an sret pointer parameter before all the other parameters.
- SmallVector<EVT, 1> ValueVTs;
- ComputeValueVTs(*TLI, DAG.getDataLayout(),
- PointerType::get(F.getContext(),
- DAG.getDataLayout().getAllocaAddrSpace()),
- ValueVTs);
-
- // NOTE: Assuming that a pointer will never break down to more than one VT
- // or one register.
+ MVT ValueVT = TLI->getPointerTy(DL, DL.getAllocaAddrSpace());
+
ISD::ArgFlagsTy Flags;
Flags.setSRet();
- MVT RegisterVT = TLI->getRegisterType(*DAG.getContext(), ValueVTs[0]);
- ISD::InputArg RetArg(Flags, RegisterVT, ValueVTs[0], true,
+ MVT RegisterVT = TLI->getRegisterType(*DAG.getContext(), ValueVT);
+ ISD::InputArg RetArg(Flags, RegisterVT, ValueVT, true,
ISD::InputArg::NoArgIndex, 0);
Ins.push_back(RetArg);
}
@@ -11830,12 +11813,7 @@ void SelectionDAGISel::LowerArguments(const Function &F) {
if (!FuncInfo->CanLowerReturn) {
// Create a virtual register for the sret pointer, and put in a copy
// from the sret argument into it.
- SmallVector<EVT, 1> ValueVTs;
- ComputeValueVTs(*TLI, DAG.getDataLayout(),
- PointerType::get(F.getContext(),
- DAG.getDataLayout().getAllocaAddrSpace()),
- ValueVTs);
- MVT VT = ValueVTs[0].getSimpleVT();
+ MVT VT = TLI->getPointerTy(DL, DL.getAllocaAddrSpace());
MVT RegVT = TLI->getRegisterType(*CurDAG->getContext(), VT);
std::optional<ISD::NodeType> AssertOp;
SDValue ArgValue =
More information about the llvm-commits
mailing list