From 73247d2edc860c4c4ca6f2d5b3fef38d6ac0f68a Mon Sep 17 00:00:00 2001 From: Duncan Sands Date: Sat, 14 Feb 2009 10:56:35 +0000 Subject: Generalize some alias analysis logic from atomic intrinsics to any IntrWriteArgMem intrinsics. llvm-svn: 64551 --- llvm/lib/Analysis/BasicAliasAnalysis.cpp | 51 -------------------------------- 1 file changed, 51 deletions(-) (limited to 'llvm/lib/Analysis/BasicAliasAnalysis.cpp') diff --git a/llvm/lib/Analysis/BasicAliasAnalysis.cpp b/llvm/lib/Analysis/BasicAliasAnalysis.cpp index ef918507b77..fe71f04098b 100644 --- a/llvm/lib/Analysis/BasicAliasAnalysis.cpp +++ b/llvm/lib/Analysis/BasicAliasAnalysis.cpp @@ -201,13 +201,7 @@ namespace { ModRefResult getModRefInfo(CallSite CS, Value *P, unsigned Size); ModRefResult getModRefInfo(CallSite CS1, CallSite CS2); - - virtual ModRefBehavior getModRefBehavior(CallSite CS, - std::vector *Info = 0); - virtual ModRefBehavior getModRefBehavior(Function *F, - std::vector *Info = 0); - /// hasNoModRefInfoForCalls - We can provide mod/ref information against /// non-escaping allocations. virtual bool hasNoModRefInfoForCalls() const { return false; } @@ -251,51 +245,6 @@ bool BasicAliasAnalysis::pointsToConstantMemory(const Value *P) { } -static bool isAtomicRMW(Function* F) { - if (!F) return false; - if (F->isIntrinsic()) { - switch (F->getIntrinsicID()) { - case Intrinsic::atomic_cmp_swap: - case Intrinsic::atomic_load_add: - case Intrinsic::atomic_load_and: - case Intrinsic::atomic_load_max: - case Intrinsic::atomic_load_min: - case Intrinsic::atomic_load_nand: - case Intrinsic::atomic_load_or: - case Intrinsic::atomic_load_sub: - case Intrinsic::atomic_load_umax: - case Intrinsic::atomic_load_umin: - case Intrinsic::atomic_load_xor: - case Intrinsic::atomic_swap: - return true; - default: - return false; - } - } - - return false; -} - -AliasAnalysis::ModRefBehavior -BasicAliasAnalysis::getModRefBehavior(CallSite CS, - std::vector *Info) { - if (isAtomicRMW(CS.getCalledFunction())) - // CAS and related intrinsics only access their arguments. - return AliasAnalysis::AccessesArguments; - - return AliasAnalysis::getModRefBehavior(CS, Info); -} - -AliasAnalysis::ModRefBehavior -BasicAliasAnalysis::getModRefBehavior(Function *F, - std::vector *Info) { - if (isAtomicRMW(F)) - // CAS and related intrinsics only access their arguments. - return AliasAnalysis::AccessesArguments; - - return AliasAnalysis::getModRefBehavior(F, Info); -} - // getModRefInfo - Check to see if the specified callsite can clobber the // specified memory object. Since we only look at local properties of this // function, we really can't say much about this query. We do, however, use -- cgit v1.2.3