Fix bug: BasicAA/2003-09-19-LocalArgument.ll

llvm-svn: 8615
This commit is contained in:
Chris Lattner 2003-09-20 03:08:47 +00:00
parent 066ccf8848
commit 092af3f36e
1 changed files with 22 additions and 7 deletions

View File

@ -8,6 +8,7 @@
#include "llvm/Analysis/AliasAnalysis.h" #include "llvm/Analysis/AliasAnalysis.h"
#include "llvm/Pass.h" #include "llvm/Pass.h"
#include "llvm/Argument.h"
#include "llvm/iMemory.h" #include "llvm/iMemory.h"
#include "llvm/iOther.h" #include "llvm/iOther.h"
#include "llvm/ConstantHandling.h" #include "llvm/ConstantHandling.h"
@ -54,16 +55,20 @@ void BasicAliasAnalysis::initializePass() {
// hasUniqueAddress - Return true if the // hasUniqueAddress - Return true if the specified value points to something
// with a unique, discernable, address.
static inline bool hasUniqueAddress(const Value *V) { static inline bool hasUniqueAddress(const Value *V) {
return isa<GlobalValue>(V) || isa<MallocInst>(V) || isa<AllocaInst>(V); return isa<GlobalValue>(V) || isa<AllocationInst>(V);
} }
// getUnderlyingObject - This traverses the use chain to figure out what object
// the specified value points to. If the value points to, or is derived from, a
// unique object or an argument, return it.
static const Value *getUnderlyingObject(const Value *V) { static const Value *getUnderlyingObject(const Value *V) {
if (!isa<PointerType>(V->getType())) return 0; if (!isa<PointerType>(V->getType())) return 0;
// If we are at some type of object... return it. // If we are at some type of object... return it.
if (hasUniqueAddress(V)) return V; if (hasUniqueAddress(V) || isa<Argument>(V)) return V;
// Traverse through different addressing mechanisms... // Traverse through different addressing mechanisms...
if (const Instruction *I = dyn_cast<Instruction>(V)) { if (const Instruction *I = dyn_cast<Instruction>(V)) {
@ -112,16 +117,26 @@ BasicAliasAnalysis::alias(const Value *V1, unsigned V1Size,
// Pointing at a discernible object? // Pointing at a discernible object?
if (O1 && O2) { if (O1 && O2) {
// If they are two different objects, we know that we have no alias... if (isa<Argument>(O1)) {
if (O1 != O2) return NoAlias; // Incoming argument cannot alias locally allocated object!
if (isa<AllocationInst>(O2)) return NoAlias;
// Otherwise, nothing is known...
} else if (isa<Argument>(O2)) {
// Incoming argument cannot alias locally allocated object!
if (isa<AllocationInst>(O1)) return NoAlias;
// Otherwise, nothing is known...
} else {
// If they are two different objects, we know that we have no alias...
if (O1 != O2) return NoAlias;
}
// If they are the same object, they we can look at the indexes. If they // If they are the same object, they we can look at the indexes. If they
// index off of the object is the same for both pointers, they must alias. // index off of the object is the same for both pointers, they must alias.
// If they are provably different, they must not alias. Otherwise, we can't // If they are provably different, they must not alias. Otherwise, we can't
// tell anything. // tell anything.
} else if (O1 && isa<ConstantPointerNull>(V2)) { } else if (O1 && !isa<Argument>(O1) && isa<ConstantPointerNull>(V2)) {
return NoAlias; // Unique values don't alias null return NoAlias; // Unique values don't alias null
} else if (O2 && isa<ConstantPointerNull>(V1)) { } else if (O2 && !isa<Argument>(O2) && isa<ConstantPointerNull>(V1)) {
return NoAlias; // Unique values don't alias null return NoAlias; // Unique values don't alias null
} }