diff options
| author | Jay Foad <jay.foad@gmail.com> | 2011-07-19 15:07:52 +0000 | 
|---|---|---|
| committer | Jay Foad <jay.foad@gmail.com> | 2011-07-19 15:07:52 +0000 | 
| commit | b9b54ebfed02f0654897d37e8a4448d3f8087558 (patch) | |
| tree | 8bdb4816b8fc391e63610f245c48ff9baa93459f /lib | |
| parent | ca12a2139e7ed8b5f30df9927494dd7aae929a7c (diff) | |
| download | external_llvm-b9b54ebfed02f0654897d37e8a4448d3f8087558.zip external_llvm-b9b54ebfed02f0654897d37e8a4448d3f8087558.tar.gz external_llvm-b9b54ebfed02f0654897d37e8a4448d3f8087558.tar.bz2  | |
Convert SimplifyGEPInst to use ArrayRef.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@135482 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/Analysis/InstructionSimplify.cpp | 17 | ||||
| -rw-r--r-- | lib/Analysis/PHITransAddr.cpp | 2 | ||||
| -rw-r--r-- | lib/Transforms/InstCombine/InstructionCombining.cpp | 2 | 
3 files changed, 11 insertions, 10 deletions
diff --git a/lib/Analysis/InstructionSimplify.cpp b/lib/Analysis/InstructionSimplify.cpp index 5080106..740351c 100644 --- a/lib/Analysis/InstructionSimplify.cpp +++ b/lib/Analysis/InstructionSimplify.cpp @@ -2219,24 +2219,24 @@ Value *llvm::SimplifySelectInst(Value *CondVal, Value *TrueVal, Value *FalseVal,  /// SimplifyGEPInst - Given operands for an GetElementPtrInst, see if we can  /// fold the result.  If not, this returns null. -Value *llvm::SimplifyGEPInst(Value *const *Ops, unsigned NumOps, +Value *llvm::SimplifyGEPInst(ArrayRef<Value *> Ops,                               const TargetData *TD, const DominatorTree *) {    // The type of the GEP pointer operand.    PointerType *PtrTy = cast<PointerType>(Ops[0]->getType());    // getelementptr P -> P. -  if (NumOps == 1) +  if (Ops.size() == 1)      return Ops[0];    if (isa<UndefValue>(Ops[0])) {      // Compute the (pointer) type returned by the GEP instruction. -    Type *LastType = GetElementPtrInst::getIndexedType(PtrTy, &Ops[1], -                                                             NumOps-1); +    Type *LastType = GetElementPtrInst::getIndexedType(PtrTy, Ops.data() + 1, +                                                       Ops.size() - 1);      Type *GEPTy = PointerType::get(LastType, PtrTy->getAddressSpace());      return UndefValue::get(GEPTy);    } -  if (NumOps == 2) { +  if (Ops.size() == 2) {      // getelementptr P, 0 -> P.      if (ConstantInt *C = dyn_cast<ConstantInt>(Ops[1]))        if (C->isZero()) @@ -2250,12 +2250,13 @@ Value *llvm::SimplifyGEPInst(Value *const *Ops, unsigned NumOps,    }    // Check to see if this is constant foldable. -  for (unsigned i = 0; i != NumOps; ++i) +  for (unsigned i = 0, e = Ops.size(); i != e; ++i)      if (!isa<Constant>(Ops[i]))        return 0;    return ConstantExpr::getGetElementPtr(cast<Constant>(Ops[0]), -                                        (Constant *const*)Ops+1, NumOps-1); +                                        (Constant *const*)Ops.data() + 1, +                                        Ops.size() - 1);  }  /// SimplifyPHINode - See if we can fold the given phi.  If not, returns null. @@ -2456,7 +2457,7 @@ Value *llvm::SimplifyInstruction(Instruction *I, const TargetData *TD,      break;    case Instruction::GetElementPtr: {      SmallVector<Value*, 8> Ops(I->op_begin(), I->op_end()); -    Result = SimplifyGEPInst(&Ops[0], Ops.size(), TD, DT); +    Result = SimplifyGEPInst(Ops, TD, DT);      break;    }    case Instruction::PHI: diff --git a/lib/Analysis/PHITransAddr.cpp b/lib/Analysis/PHITransAddr.cpp index 70dcd0d..0547611 100644 --- a/lib/Analysis/PHITransAddr.cpp +++ b/lib/Analysis/PHITransAddr.cpp @@ -228,7 +228,7 @@ Value *PHITransAddr::PHITranslateSubExpr(Value *V, BasicBlock *CurBB,        return GEP;      // Simplify the GEP to handle 'gep x, 0' -> x etc. -    if (Value *V = SimplifyGEPInst(&GEPOps[0], GEPOps.size(), TD, DT)) { +    if (Value *V = SimplifyGEPInst(GEPOps, TD, DT)) {        for (unsigned i = 0, e = GEPOps.size(); i != e; ++i)          RemoveInstInputs(GEPOps[i], InstInputs); diff --git a/lib/Transforms/InstCombine/InstructionCombining.cpp b/lib/Transforms/InstCombine/InstructionCombining.cpp index 34f5531..021ca13 100644 --- a/lib/Transforms/InstCombine/InstructionCombining.cpp +++ b/lib/Transforms/InstCombine/InstructionCombining.cpp @@ -742,7 +742,7 @@ Type *InstCombiner::FindElementAtOffset(Type *Ty, int64_t Offset,  Instruction *InstCombiner::visitGetElementPtrInst(GetElementPtrInst &GEP) {    SmallVector<Value*, 8> Ops(GEP.op_begin(), GEP.op_end()); -  if (Value *V = SimplifyGEPInst(&Ops[0], Ops.size(), TD)) +  if (Value *V = SimplifyGEPInst(Ops, TD))      return ReplaceInstUsesWith(GEP, V);    Value *PtrOp = GEP.getOperand(0);  | 
