Adjust to new alias analysis interfaces

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@18957 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2004-12-15 07:22:13 +00:00
parent 248e8ebeff
commit 0af024c5d0
4 changed files with 48 additions and 57 deletions

View File

@ -57,14 +57,11 @@ bool AliasAnalysis::pointsToConstantMemory(const Value *P) {
return AA->pointsToConstantMemory(P); return AA->pointsToConstantMemory(P);
} }
bool AliasAnalysis::doesNotAccessMemory(Function *F) { AliasAnalysis::ModRefBehavior
AliasAnalysis::getModRefBehavior(Function *F, CallSite CS,
std::vector<PointerAccessInfo> *Info) {
assert(AA && "AA didn't call InitializeAliasAnalysis in its run method!"); assert(AA && "AA didn't call InitializeAliasAnalysis in its run method!");
return AA->doesNotAccessMemory(F); return AA->getModRefBehavior(F, CS, Info);
}
bool AliasAnalysis::onlyReadsMemory(Function *F) {
assert(AA && "AA didn't call InitializeAliasAnalysis in its run method!");
return doesNotAccessMemory(F) || AA->onlyReadsMemory(F);
} }
bool AliasAnalysis::hasNoModRefInfoForCalls() const { bool AliasAnalysis::hasNoModRefInfoForCalls() const {

View File

@ -113,9 +113,10 @@ void AliasSet::addCallSite(CallSite CS, AliasAnalysis &AA) {
CallSites.push_back(CS); CallSites.push_back(CS);
if (Function *F = CS.getCalledFunction()) { if (Function *F = CS.getCalledFunction()) {
if (AA.doesNotAccessMemory(F)) AliasAnalysis::ModRefBehavior Behavior = AA.getModRefBehavior(F, CS);
if (Behavior == AliasAnalysis::DoesNotAccessMemory)
return; return;
else if (AA.onlyReadsMemory(F)) { else if (Behavior == AliasAnalysis::OnlyReadsMemory) {
AliasTy = MayAlias; AliasTy = MayAlias;
AccessTy |= Refs; AccessTy |= Refs;
return; return;

View File

@ -48,10 +48,17 @@ namespace {
return MayAlias; return MayAlias;
} }
virtual ModRefBehavior getModRefBehavior(Function *F, CallSite CS) {
return UnknownModRefBehavior;
}
virtual void getArgumentAccesses(Function *F, CallSite CS,
std::vector<PointerAccessInfo> &Info) {
assert(0 && "This method may not be called on this function!");
}
virtual void getMustAliases(Value *P, std::vector<Value*> &RetVals) { } virtual void getMustAliases(Value *P, std::vector<Value*> &RetVals) { }
virtual bool pointsToConstantMemory(const Value *P) { return false; } virtual bool pointsToConstantMemory(const Value *P) { return false; }
virtual bool doesNotAccessMemory(Function *F) { return false; }
virtual bool onlyReadsMemory(Function *F) { return false; }
virtual ModRefResult getModRefInfo(CallSite CS, Value *P, unsigned Size) { virtual ModRefResult getModRefInfo(CallSite CS, Value *P, unsigned Size) {
return ModRef; return ModRef;
} }
@ -94,9 +101,9 @@ namespace {
/// global) or not. /// global) or not.
bool pointsToConstantMemory(const Value *P); bool pointsToConstantMemory(const Value *P);
virtual bool doesNotAccessMemory(Function *F); virtual ModRefBehavior getModRefBehavior(Function *F, CallSite CS,
virtual bool onlyReadsMemory(Function *F); std::vector<PointerAccessInfo> *Info);
private: private:
// CheckGEPInstructions - Check two GEP instructions with known // CheckGEPInstructions - Check two GEP instructions with known
// must-aliasing base pointers. This checks to see if the index expressions // must-aliasing base pointers. This checks to see if the index expressions
@ -683,7 +690,8 @@ namespace {
// that set errno on a domain or other error. // that set errno on a domain or other error.
static const char *DoesntAccessMemoryTable[] = { static const char *DoesntAccessMemoryTable[] = {
// LLVM intrinsics: // LLVM intrinsics:
"llvm.frameaddress", "llvm.returnaddress", "llvm.readport", "llvm.isunordered", "llvm.frameaddress", "llvm.returnaddress", "llvm.readport",
"llvm.isunordered",
"abs", "labs", "llabs", "imaxabs", "fabs", "fabsf", "fabsl", "abs", "labs", "llabs", "imaxabs", "fabs", "fabsf", "fabsl",
"trunc", "truncf", "truncl", "ldexp", "trunc", "truncf", "truncl", "ldexp",
@ -723,29 +731,6 @@ static const char *DoesntAccessMemoryTable[] = {
static const unsigned DAMTableSize = static const unsigned DAMTableSize =
sizeof(DoesntAccessMemoryTable)/sizeof(DoesntAccessMemoryTable[0]); sizeof(DoesntAccessMemoryTable)/sizeof(DoesntAccessMemoryTable[0]);
/// doesNotAccessMemory - Return true if we know that the function does not
/// access memory at all. Since basicaa does no analysis, we can only do simple
/// things here. In particular, if we have an external function with the name
/// of a standard C library function, we are allowed to assume it will be
/// resolved by libc, so we can hardcode some entries in here.
bool BasicAliasAnalysis::doesNotAccessMemory(Function *F) {
if (!F->isExternal()) return false;
static bool Initialized = false;
if (!Initialized) {
// Sort the table the first time through.
std::sort(DoesntAccessMemoryTable, DoesntAccessMemoryTable+DAMTableSize,
StringCompare());
Initialized = true;
}
const char **Ptr = std::lower_bound(DoesntAccessMemoryTable,
DoesntAccessMemoryTable+DAMTableSize,
F->getName().c_str(), StringCompare());
return Ptr != DoesntAccessMemoryTable+DAMTableSize && *Ptr == F->getName();
}
static const char *OnlyReadsMemoryTable[] = { static const char *OnlyReadsMemoryTable[] = {
"atoi", "atol", "atof", "atoll", "atoq", "a64l", "atoi", "atol", "atof", "atoll", "atoq", "a64l",
"bcmp", "memcmp", "memchr", "memrchr", "wmemcmp", "wmemchr", "bcmp", "memcmp", "memchr", "memrchr", "wmemcmp", "wmemchr",
@ -772,23 +757,33 @@ static const char *OnlyReadsMemoryTable[] = {
static const unsigned ORMTableSize = static const unsigned ORMTableSize =
sizeof(OnlyReadsMemoryTable)/sizeof(OnlyReadsMemoryTable[0]); sizeof(OnlyReadsMemoryTable)/sizeof(OnlyReadsMemoryTable[0]);
bool BasicAliasAnalysis::onlyReadsMemory(Function *F) { AliasAnalysis::ModRefBehavior
if (doesNotAccessMemory(F)) return true; BasicAliasAnalysis::getModRefBehavior(Function *F, CallSite CS,
if (!F->isExternal()) return false; std::vector<PointerAccessInfo> *Info) {
if (!F->isExternal()) return UnknownModRefBehavior;
static bool Initialized = false; static bool Initialized = false;
if (!Initialized) { if (!Initialized) {
// Sort the table the first time through. // Sort the table the first time through.
std::sort(DoesntAccessMemoryTable, DoesntAccessMemoryTable+DAMTableSize,
StringCompare());
std::sort(OnlyReadsMemoryTable, OnlyReadsMemoryTable+ORMTableSize, std::sort(OnlyReadsMemoryTable, OnlyReadsMemoryTable+ORMTableSize,
StringCompare()); StringCompare());
Initialized = true; Initialized = true;
} }
const char **Ptr = std::lower_bound(OnlyReadsMemoryTable, const char **Ptr = std::lower_bound(DoesntAccessMemoryTable,
OnlyReadsMemoryTable+ORMTableSize, DoesntAccessMemoryTable+DAMTableSize,
F->getName().c_str(), StringCompare()); F->getName().c_str(), StringCompare());
return Ptr != OnlyReadsMemoryTable+ORMTableSize && *Ptr == F->getName(); if (Ptr != DoesntAccessMemoryTable+DAMTableSize && *Ptr == F->getName())
return DoesNotAccessMemory;
Ptr = std::lower_bound(OnlyReadsMemoryTable,
OnlyReadsMemoryTable+ORMTableSize,
F->getName().c_str(), StringCompare());
if (Ptr != OnlyReadsMemoryTable+ORMTableSize && *Ptr == F->getName())
return OnlyReadsMemory;
return UnknownModRefBehavior;
} }

View File

@ -101,19 +101,17 @@ namespace {
} }
bool hasNoModRefInfoForCalls() const { return false; } bool hasNoModRefInfoForCalls() const { return false; }
bool doesNotAccessMemory(Function *F) { /// getModRefBehavior - Return the behavior of the specified function if
/// called from the specified call site. The call site may be null in which
/// case the most generic behavior of this function should be returned.
virtual ModRefBehavior getModRefBehavior(Function *F, CallSite CS) {
if (FunctionRecord *FR = getFunctionInfo(F)) if (FunctionRecord *FR = getFunctionInfo(F))
if (FR->FunctionEffect == 0) if (FR->FunctionEffect == 0)
return true; return DoesNotAccessMemory;
return AliasAnalysis::doesNotAccessMemory(F); else if ((FR->FunctionEffect & Mod) == 0)
return OnlyReadsMemory;
return AliasAnalysis::getModRefBehavior(F, CS);
} }
bool onlyReadsMemory(Function *F) {
if (FunctionRecord *FR = getFunctionInfo(F))
if ((FR->FunctionEffect & Mod) == 0)
return true;
return AliasAnalysis::onlyReadsMemory(F);
}
virtual void deleteValue(Value *V); virtual void deleteValue(Value *V);
virtual void copyValue(Value *From, Value *To); virtual void copyValue(Value *From, Value *To);