[llvm-commits] [llvm] r146492 - /llvm/trunk/lib/CodeGen/SelectionDAG/FastISel.cpp

Chad Rosier mcrosier at apple.com
Tue Dec 13 09:45:06 PST 2011


Author: mcrosier
Date: Tue Dec 13 11:45:06 2011
New Revision: 146492

URL: http://llvm.org/viewvc/llvm-project?rev=146492&view=rev
Log:
[fast-isel] Remove SelectInsertValue() as fast-isel wasn't designed to handle 
instructions that define aggregate types.

Modified:
    llvm/trunk/lib/CodeGen/SelectionDAG/FastISel.cpp

Modified: llvm/trunk/lib/CodeGen/SelectionDAG/FastISel.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/SelectionDAG/FastISel.cpp?rev=146492&r1=146491&r2=146492&view=diff
==============================================================================
--- llvm/trunk/lib/CodeGen/SelectionDAG/FastISel.cpp (original)
+++ llvm/trunk/lib/CodeGen/SelectionDAG/FastISel.cpp Tue Dec 13 11:45:06 2011
@@ -942,106 +942,6 @@
 }
 
 bool
-FastISel::SelectInsertValue(const User *U) {
-  return false;
-  const InsertValueInst *IVI = dyn_cast<InsertValueInst>(U);
-  if (!IVI)
-    return false;
-
-  // Only try to handle inserts of legal types.  But also allow i16/i8/i1 because
-  // they're easy.
-  const Value *Val = IVI->getOperand(1);
-  Type *ValTy = Val->getType();
-  EVT ValVT = TLI.getValueType(ValTy, /*AllowUnknown=*/true);
-  if (!ValVT.isSimple())
-    return false;
-  MVT VT = ValVT.getSimpleVT();
-  if (!TLI.isTypeLegal(VT) && VT != MVT::i16 && VT != MVT::i8 && VT != MVT::i1)
-    return false;
-
-  // Get the Val register.
-  unsigned ValReg = getRegForValue(Val);
-  if (ValReg == 0) return false;
-
-  const Value *Agg = IVI->getOperand(0);
-  Type *AggTy = Agg->getType();
-
-  // TODO: Is there a better way to do this?  For each insertvalue we allocate
-  // a new set of virtual registers, which results in a large number of 
-  // loads/stores from/to the stack that copies the aggregate all over the place
-  // and results in lots of spill code.  I believe this is necessary to preserve
-  // SSA form, but maybe there's something we could do to improve this.
-
-  // Get the Aggregate base register.
-  unsigned AggBaseReg;
-  DenseMap<const Value *, unsigned>::iterator I = FuncInfo.ValueMap.find(Agg);
-  if (I != FuncInfo.ValueMap.end())
-    AggBaseReg = I->second;
-  else if (isa<Instruction>(Agg))
-    AggBaseReg = FuncInfo.InitializeRegForValue(Agg);
-  else if (isa<UndefValue>(Agg))
-    // In this case we don't need to allocate a new set of register that will
-    // never be defined.  Just copy Val into the proper result registers.
-    AggBaseReg = 0;
-  else
-    return false; // fast-isel can't handle aggregate constants at the moment
-
-  // Create result register(s).
-  unsigned ResultBaseReg = FuncInfo.CreateRegs(AggTy);
-
-  // Get the actual result register, which is an offset from the base register.
-  unsigned LinearIndex = ComputeLinearIndex(Agg->getType(), IVI->getIndices());
-
-  SmallVector<EVT, 4> AggValueVTs;
-  ComputeValueVTs(TLI, AggTy, AggValueVTs);
-
-  // Copy the beginning value(s) from the original aggregate.
-  unsigned SrcReg;
-  unsigned DestReg;
-  unsigned BaseRegOff = 0;
-  unsigned i = 0;
-  for (; i != LinearIndex; ++i) {
-    unsigned NRE = TLI.getNumRegisters(FuncInfo.Fn->getContext(),
-                                       AggValueVTs[i]);
-    for (unsigned NRI = 0; NRI != NRE; NRI++) {
-      if (AggBaseReg) {
-        SrcReg = AggBaseReg + BaseRegOff + NRI;
-        DestReg = ResultBaseReg + BaseRegOff + NRI;
-        BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt, DL, TII.get(TargetOpcode::COPY),
-                DestReg).addReg(SrcReg);
-      }
-    }
-    BaseRegOff += NRE;
-  }
-
-  // FIXME: Handle aggregate inserts.  Haven't seen these in practice, but..
-  // Copy value(s) from the inserted value(s).
-  DestReg = ResultBaseReg + BaseRegOff;
-  BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt, DL, TII.get(TargetOpcode::COPY),
-          DestReg).addReg(ValReg);
-  ++BaseRegOff;
-  ++i;
-
-  // Copy remaining value(s) from the original aggregate.
-  if (AggBaseReg) {
-    for (unsigned NumAggValues = AggValueVTs.size(); i != NumAggValues; ++i) {
-      unsigned NRE = TLI.getNumRegisters(FuncInfo.Fn->getContext(),
-                                         AggValueVTs[i]);
-      for (unsigned NRI = 0; NRI != NRE; NRI++) {
-        SrcReg = AggBaseReg + BaseRegOff + NRI;
-        DestReg = ResultBaseReg + BaseRegOff + NRI;
-        BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt, DL, TII.get(TargetOpcode::COPY),
-                DestReg).addReg(SrcReg);
-        
-      }
-      BaseRegOff += NRE;
-    }
-  }
-  UpdateValueMap(IVI, ResultBaseReg);
-  return true;
-}
-
-bool
 FastISel::SelectOperator(const User *I, unsigned Opcode) {
   switch (Opcode) {
   case Instruction::Add:
@@ -1148,9 +1048,6 @@
   case Instruction::ExtractValue:
     return SelectExtractValue(I);
 
-  case Instruction::InsertValue:
-    return SelectInsertValue(I);
-
   case Instruction::PHI:
     llvm_unreachable("FastISel shouldn't visit PHI nodes!");
 





More information about the llvm-commits mailing list