diff options
author | Chris Lattner <sabre@nondot.org> | 2009-11-23 16:46:41 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-11-23 16:46:41 +0000 |
commit | 403ac2ece33046c58b66fffa105184f44fa4527e (patch) | |
tree | 0e443831ae8d644474da473c22b16f5fd0b29d41 /lib/Analysis/BasicAliasAnalysis.cpp | |
parent | 5d56b2d47d324ecf2d1cc1551a28cce49d16ab01 (diff) | |
download | external_llvm-403ac2ece33046c58b66fffa105184f44fa4527e.zip external_llvm-403ac2ece33046c58b66fffa105184f44fa4527e.tar.gz external_llvm-403ac2ece33046c58b66fffa105184f44fa4527e.tar.bz2 |
use the new isNoAlias method to simplify some code, only do an escaping check if
we have a non-constant pointer. Constant pointers can't be local.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@89665 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/BasicAliasAnalysis.cpp')
-rw-r--r-- | lib/Analysis/BasicAliasAnalysis.cpp | 23 |
1 files changed, 13 insertions, 10 deletions
diff --git a/lib/Analysis/BasicAliasAnalysis.cpp b/lib/Analysis/BasicAliasAnalysis.cpp index f80b162..32ca911 100644 --- a/lib/Analysis/BasicAliasAnalysis.cpp +++ b/lib/Analysis/BasicAliasAnalysis.cpp @@ -290,7 +290,8 @@ BasicAliasAnalysis::getModRefInfo(CallSite CS, Value *P, unsigned Size) { // If the pointer is to a locally allocated object that does not escape, // then the call can not mod/ref the pointer unless the call takes the pointer // as an argument, and itself doesn't capture it. - if (isNonEscapingLocalObject(Object) && CS.getInstruction() != Object) { + if (!isa<Constant>(Object) && CS.getInstruction() != Object && + isNonEscapingLocalObject(Object)) { bool PassedAsArg = false; unsigned ArgNo = 0; for (CallSite::arg_iterator CI = CS.arg_begin(), CE = CS.arg_end(); @@ -304,7 +305,7 @@ BasicAliasAnalysis::getModRefInfo(CallSite CS, Value *P, unsigned Size) { // is impossible to alias the pointer we're checking. If not, we have to // assume that the call could touch the pointer, even though it doesn't // escape. - if (alias(cast<Value>(CI), ~0U, P, ~0U) != NoAlias) { + if (!isNoAlias(cast<Value>(CI), ~0U, P, ~0U)) { PassedAsArg = true; break; } @@ -328,18 +329,20 @@ BasicAliasAnalysis::getModRefInfo(CallSite CS, Value *P, unsigned Size) { Len = LenCI->getZExtValue(); Value *Dest = II->getOperand(1); Value *Src = II->getOperand(2); - if (alias(Dest, Len, P, Size) == NoAlias) { - if (alias(Src, Len, P, Size) == NoAlias) + if (isNoAlias(Dest, Len, P, Size)) { + if (isNoAlias(Src, Len, P, Size)) return NoModRef; return Ref; } break; } case Intrinsic::memset: + // Since memset is 'accesses arguments' only, the AliasAnalysis base class + // will handle it for the variable length case. if (ConstantInt *LenCI = dyn_cast<ConstantInt>(II->getOperand(3))) { unsigned Len = LenCI->getZExtValue(); Value *Dest = II->getOperand(1); - if (alias(Dest, Len, P, Size) == NoAlias) + if (isNoAlias(Dest, Len, P, Size)) return NoModRef; } break; @@ -358,7 +361,7 @@ BasicAliasAnalysis::getModRefInfo(CallSite CS, Value *P, unsigned Size) { if (TD) { Value *Op1 = II->getOperand(1); unsigned Op1Size = TD->getTypeStoreSize(Op1->getType()); - if (alias(Op1, Op1Size, P, Size) == NoAlias) + if (isNoAlias(Op1, Op1Size, P, Size)) return NoModRef; } break; @@ -366,13 +369,13 @@ BasicAliasAnalysis::getModRefInfo(CallSite CS, Value *P, unsigned Size) { case Intrinsic::lifetime_end: case Intrinsic::invariant_start: { unsigned PtrSize = cast<ConstantInt>(II->getOperand(1))->getZExtValue(); - if (alias(II->getOperand(2), PtrSize, P, Size) == NoAlias) + if (isNoAlias(II->getOperand(2), PtrSize, P, Size)) return NoModRef; break; } case Intrinsic::invariant_end: { unsigned PtrSize = cast<ConstantInt>(II->getOperand(2))->getZExtValue(); - if (alias(II->getOperand(3), PtrSize, P, Size) == NoAlias) + if (isNoAlias(II->getOperand(3), PtrSize, P, Size)) return NoModRef; break; } @@ -701,11 +704,11 @@ BasicAliasAnalysis::aliasCheck(const Value *V1, unsigned V1Size, // passes true for the StoreCaptures argument to PointerMayBeCaptured). if (O1 != O2) { if ((isa<CallInst>(O1) || isa<InvokeInst>(O1) || isa<LoadInst>(O1) || - isa<Argument(O1)) && + isa<Argument>(O1)) && isNonEscapingLocalObject(O2)) return NoAlias; if ((isa<CallInst>(O2) || isa<InvokeInst>(O2) || isa<LoadInst>(O2) || - isa<Argument(O2)) && + isa<Argument>(O2)) && isNonEscapingLocalObject(O1)) return NoAlias; } |