diff options
| author | Dan Gohman <gohman@apple.com> | 2011-01-24 18:53:32 +0000 | 
|---|---|---|
| committer | Dan Gohman <gohman@apple.com> | 2011-01-24 18:53:32 +0000 | 
| commit | 0f124e1987c22d1801c23c93628d202d21bdff10 (patch) | |
| tree | d673dbf9fcc1de867343c1ee4b96382caa7e1fd6 | |
| parent | 62c31346292888357d82f42bac8e1a0e05c356fb (diff) | |
| download | bcm5719-llvm-0f124e1987c22d1801c23c93628d202d21bdff10.tar.gz bcm5719-llvm-0f124e1987c22d1801c23c93628d202d21bdff10.zip  | |
Give GetUnderlyingObject a TargetData, to keep it in sync
with BasicAA's DecomposeGEPExpression, which recently began
using a TargetData. This fixes PR8968, though the testcase
is awkward to reduce.
Also, update several off GetUnderlyingObject's users
which happen to have a TargetData handy to pass it in.
llvm-svn: 124134
| -rw-r--r-- | llvm/include/llvm/Analysis/ValueTracking.h | 8 | ||||
| -rw-r--r-- | llvm/lib/Analysis/BasicAliasAnalysis.cpp | 10 | ||||
| -rw-r--r-- | llvm/lib/Analysis/ConstantFolding.cpp | 3 | ||||
| -rw-r--r-- | llvm/lib/Analysis/Lint.cpp | 2 | ||||
| -rw-r--r-- | llvm/lib/Analysis/MemoryDependenceAnalysis.cpp | 2 | ||||
| -rw-r--r-- | llvm/lib/Analysis/ValueTracking.cpp | 7 | ||||
| -rw-r--r-- | llvm/lib/Transforms/Scalar/DeadStoreElimination.cpp | 3 | ||||
| -rw-r--r-- | llvm/lib/Transforms/Scalar/GVN.cpp | 2 | ||||
| -rw-r--r-- | llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp | 6 | 
9 files changed, 24 insertions, 19 deletions
diff --git a/llvm/include/llvm/Analysis/ValueTracking.h b/llvm/include/llvm/Analysis/ValueTracking.h index 370282d0c08..2b3176dca25 100644 --- a/llvm/include/llvm/Analysis/ValueTracking.h +++ b/llvm/include/llvm/Analysis/ValueTracking.h @@ -133,10 +133,12 @@ namespace llvm {    /// being addressed.  Note that the returned value has pointer type if the    /// specified value does.  If the MaxLookup value is non-zero, it limits the    /// number of instructions to be stripped off. -  Value *GetUnderlyingObject(Value *V, unsigned MaxLookup = 6); +  Value *GetUnderlyingObject(Value *V, const TargetData *TD = 0, +                             unsigned MaxLookup = 6);    static inline const Value * -  GetUnderlyingObject(const Value *V, unsigned MaxLookup = 6) { -    return GetUnderlyingObject(const_cast<Value *>(V), MaxLookup); +  GetUnderlyingObject(const Value *V, const TargetData *TD = 0, +                      unsigned MaxLookup = 6) { +    return GetUnderlyingObject(const_cast<Value *>(V), TD, MaxLookup);    }  } // end namespace llvm diff --git a/llvm/lib/Analysis/BasicAliasAnalysis.cpp b/llvm/lib/Analysis/BasicAliasAnalysis.cpp index f3695929d16..f7bcd9ec44d 100644 --- a/llvm/lib/Analysis/BasicAliasAnalysis.cpp +++ b/llvm/lib/Analysis/BasicAliasAnalysis.cpp @@ -554,7 +554,7 @@ BasicAliasAnalysis::pointsToConstantMemory(const Location &Loc, bool OrLocal) {    SmallVector<const Value *, 16> Worklist;    Worklist.push_back(Loc.Ptr);    do { -    const Value *V = GetUnderlyingObject(Worklist.pop_back_val()); +    const Value *V = GetUnderlyingObject(Worklist.pop_back_val(), TD);      if (!Visited.insert(V)) {        Visited.clear();        return AliasAnalysis::pointsToConstantMemory(Loc, OrLocal); @@ -659,7 +659,7 @@ BasicAliasAnalysis::getModRefInfo(ImmutableCallSite CS,    assert(notDifferentParent(CS.getInstruction(), Loc.Ptr) &&           "AliasAnalysis query involving multiple functions!"); -  const Value *Object = GetUnderlyingObject(Loc.Ptr); +  const Value *Object = GetUnderlyingObject(Loc.Ptr, TD);    // If this is a tail call and Loc.Ptr points to a stack location, we know that    // the tail call cannot access or modify the local stack. @@ -787,7 +787,7 @@ BasicAliasAnalysis::getModRefInfo(ImmutableCallSite CS,  /// aliasGEP - Provide a bunch of ad-hoc rules to disambiguate a GEP instruction  /// against another pointer.  We know that V1 is a GEP, but we don't know -/// anything about V2.  UnderlyingV1 is GetUnderlyingObject(GEP1), +/// anything about V2.  UnderlyingV1 is GetUnderlyingObject(GEP1, TD),  /// UnderlyingV2 is the same for V2.  ///  AliasAnalysis::AliasResult @@ -1070,8 +1070,8 @@ BasicAliasAnalysis::aliasCheck(const Value *V1, uint64_t V1Size,      return NoAlias;  // Scalars cannot alias each other    // Figure out what objects these things are pointing to if we can. -  const Value *O1 = GetUnderlyingObject(V1); -  const Value *O2 = GetUnderlyingObject(V2); +  const Value *O1 = GetUnderlyingObject(V1, TD); +  const Value *O2 = GetUnderlyingObject(V2, TD);    // Null values in the default address space don't point to any object, so they    // don't alias any other pointer. diff --git a/llvm/lib/Analysis/ConstantFolding.cpp b/llvm/lib/Analysis/ConstantFolding.cpp index 55a10d716b9..243611053c2 100644 --- a/llvm/lib/Analysis/ConstantFolding.cpp +++ b/llvm/lib/Analysis/ConstantFolding.cpp @@ -467,7 +467,8 @@ Constant *llvm::ConstantFoldLoadFromConstPtr(Constant *C,    // If this load comes from anywhere in a constant global, and if the global    // is all undef or zero, we know what it loads. -  if (GlobalVariable *GV = dyn_cast<GlobalVariable>(GetUnderlyingObject(CE))){ +  if (GlobalVariable *GV = +        dyn_cast<GlobalVariable>(GetUnderlyingObject(CE, TD))) {      if (GV->isConstant() && GV->hasDefinitiveInitializer()) {        const Type *ResTy = cast<PointerType>(C->getType())->getElementType();        if (GV->getInitializer()->isNullValue()) diff --git a/llvm/lib/Analysis/Lint.cpp b/llvm/lib/Analysis/Lint.cpp index d68fcd22125..fc7edc0525f 100644 --- a/llvm/lib/Analysis/Lint.cpp +++ b/llvm/lib/Analysis/Lint.cpp @@ -567,7 +567,7 @@ Value *Lint::findValueImpl(Value *V, bool OffsetOk,    // TODO: Look through eliminable cast pairs.    // TODO: Look through calls with unique return values.    // TODO: Look through vector insert/extract/shuffle. -  V = OffsetOk ? GetUnderlyingObject(V) : V->stripPointerCasts(); +  V = OffsetOk ? GetUnderlyingObject(V, TD) : V->stripPointerCasts();    if (LoadInst *L = dyn_cast<LoadInst>(V)) {      BasicBlock::iterator BBI = L;      BasicBlock *BB = L->getParent(); diff --git a/llvm/lib/Analysis/MemoryDependenceAnalysis.cpp b/llvm/lib/Analysis/MemoryDependenceAnalysis.cpp index 8ac0a374a6d..35043bddfaf 100644 --- a/llvm/lib/Analysis/MemoryDependenceAnalysis.cpp +++ b/llvm/lib/Analysis/MemoryDependenceAnalysis.cpp @@ -339,7 +339,7 @@ getPointerDependencyFrom(const AliasAnalysis::Location &MemLoc, bool isLoad,      // need to continue scanning until the malloc call.      if (isa<AllocaInst>(Inst) ||          (isa<CallInst>(Inst) && extractMallocCall(Inst))) { -      const Value *AccessPtr = GetUnderlyingObject(MemLoc.Ptr); +      const Value *AccessPtr = GetUnderlyingObject(MemLoc.Ptr, TD);        if (AccessPtr == Inst ||            AA->alias(Inst, 1, AccessPtr, 1) == AliasAnalysis::MustAlias) diff --git a/llvm/lib/Analysis/ValueTracking.cpp b/llvm/lib/Analysis/ValueTracking.cpp index e2d7e9290ab..c982e3e00de 100644 --- a/llvm/lib/Analysis/ValueTracking.cpp +++ b/llvm/lib/Analysis/ValueTracking.cpp @@ -1504,7 +1504,8 @@ uint64_t llvm::GetStringLength(Value *V) {    return Len == ~0ULL ? 1 : Len;  } -Value *llvm::GetUnderlyingObject(Value *V, unsigned MaxLookup) { +Value * +llvm::GetUnderlyingObject(Value *V, const TargetData *TD, unsigned MaxLookup) {    if (!V->getType()->isPointerTy())      return V;    for (unsigned Count = 0; MaxLookup == 0 || Count < MaxLookup; ++Count) { @@ -1519,8 +1520,8 @@ Value *llvm::GetUnderlyingObject(Value *V, unsigned MaxLookup) {      } else {        // See if InstructionSimplify knows any relevant tricks.        if (Instruction *I = dyn_cast<Instruction>(V)) -        // TODO: Aquire TargetData and DominatorTree and use them. -        if (Value *Simplified = SimplifyInstruction(I, 0, 0)) { +        // TODO: Aquire a DominatorTree and use it. +        if (Value *Simplified = SimplifyInstruction(I, TD, 0)) {            V = Simplified;            continue;          } diff --git a/llvm/lib/Transforms/Scalar/DeadStoreElimination.cpp b/llvm/lib/Transforms/Scalar/DeadStoreElimination.cpp index 5fdb885e2f6..867a06ad202 100644 --- a/llvm/lib/Transforms/Scalar/DeadStoreElimination.cpp +++ b/llvm/lib/Transforms/Scalar/DeadStoreElimination.cpp @@ -321,7 +321,8 @@ static bool isCompleteOverwrite(const AliasAnalysis::Location &Later,    // other store to the same object.    const TargetData &TD = *AA.getTargetData(); -  const Value *UO1 = GetUnderlyingObject(P1), *UO2 = GetUnderlyingObject(P2); +  const Value *UO1 = GetUnderlyingObject(P1, &TD), +              *UO2 = GetUnderlyingObject(P2, &TD);    // If we can't resolve the same pointers to the same object, then we can't    // analyze them at all. diff --git a/llvm/lib/Transforms/Scalar/GVN.cpp b/llvm/lib/Transforms/Scalar/GVN.cpp index 1fd311cf986..a0123f58981 100644 --- a/llvm/lib/Transforms/Scalar/GVN.cpp +++ b/llvm/lib/Transforms/Scalar/GVN.cpp @@ -818,7 +818,7 @@ static int AnalyzeLoadFromClobberingMemInst(const Type *LoadTy, Value *LoadPtr,    Constant *Src = dyn_cast<Constant>(MTI->getSource());    if (Src == 0) return -1; -  GlobalVariable *GV = dyn_cast<GlobalVariable>(GetUnderlyingObject(Src)); +  GlobalVariable *GV = dyn_cast<GlobalVariable>(GetUnderlyingObject(Src, &TD));    if (GV == 0 || !GV->isConstant()) return -1;    // See if the access is within the bounds of the transfer. diff --git a/llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp b/llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp index d4c953514ce..f847e358d16 100644 --- a/llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp +++ b/llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp @@ -529,9 +529,9 @@ void ConvertToScalarInfo::ConvertUsesToScalar(Value *Ptr, AllocaInst *NewAI,        // If the source and destination are both to the same alloca, then this is        // a noop copy-to-self, just delete it.  Otherwise, emit a load and store        // as appropriate. -      AllocaInst *OrigAI = cast<AllocaInst>(GetUnderlyingObject(Ptr, 0)); +      AllocaInst *OrigAI = cast<AllocaInst>(GetUnderlyingObject(Ptr, &TD, 0)); -      if (GetUnderlyingObject(MTI->getSource(), 0) != OrigAI) { +      if (GetUnderlyingObject(MTI->getSource(), &TD, 0) != OrigAI) {          // Dest must be OrigAI, change this to be a load from the original          // pointer (bitcasted), then a store to our new alloca.          assert(MTI->getRawDest() == Ptr && "Neither use is of pointer?"); @@ -547,7 +547,7 @@ void ConvertToScalarInfo::ConvertUsesToScalar(Value *Ptr, AllocaInst *NewAI,          LoadInst *SrcVal = Builder.CreateLoad(SrcPtr, "srcval");          SrcVal->setAlignment(MTI->getAlignment());          Builder.CreateStore(SrcVal, NewAI); -      } else if (GetUnderlyingObject(MTI->getDest(), 0) != OrigAI) { +      } else if (GetUnderlyingObject(MTI->getDest(), &TD, 0) != OrigAI) {          // Src must be OrigAI, change this to be a load from NewAI then a store          // through the original dest pointer (bitcasted).          assert(MTI->getRawSource() == Ptr && "Neither use is of pointer?");  | 

