mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-14 15:19:33 +00:00
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
This commit is contained in:
parent
1a73dcfbdd
commit
db0dc19c04
@ -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
|
||||
|
@ -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.
|
||||
|
@ -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())
|
||||
|
@ -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();
|
||||
|
@ -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)
|
||||
|
@ -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;
|
||||
}
|
||||
|
@ -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.
|
||||
|
@ -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.
|
||||
|
@ -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?");
|
||||
|
Loading…
Reference in New Issue
Block a user