From: Chris Lattner Date: Sun, 21 Nov 2010 07:51:27 +0000 (+0000) Subject: add "getLocation" method to AliasAnalysis for getting the source and X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=e90c5cb747631b315350e7ee7424048c7778bdf9;p=oota-llvm.git add "getLocation" method to AliasAnalysis for getting the source and destination location of a memcpy/memmove. I'm not clear about whether TBAA works on these, so I'm leaving it out for now. Dan, please revisit this when convenient. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@119928 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/llvm/Analysis/AliasAnalysis.h b/include/llvm/Analysis/AliasAnalysis.h index 5fe9d917768..007724dd5f7 100644 --- a/include/llvm/Analysis/AliasAnalysis.h +++ b/include/llvm/Analysis/AliasAnalysis.h @@ -48,6 +48,7 @@ class VAArgInst; class TargetData; class Pass; class AnalysisUsage; +class MemTransferInst; class AliasAnalysis { protected: @@ -135,6 +136,8 @@ public: Location getLocation(const LoadInst *LI); Location getLocation(const StoreInst *SI); Location getLocation(const VAArgInst *VI); + Location getLocationForSource(const MemTransferInst *MTI); + Location getLocationForDest(const MemTransferInst *MTI); /// Alias analysis result - Either we know for sure that it does not alias, we /// know for sure it must alias, or we don't know anything: The two pointers diff --git a/lib/Analysis/AliasAnalysis.cpp b/lib/Analysis/AliasAnalysis.cpp index 94a6d41872c..f452c9e6766 100644 --- a/lib/Analysis/AliasAnalysis.cpp +++ b/lib/Analysis/AliasAnalysis.cpp @@ -212,6 +212,29 @@ AliasAnalysis::Location AliasAnalysis::getLocation(const VAArgInst *VI) { VI->getMetadata(LLVMContext::MD_tbaa)); } + +AliasAnalysis::Location +AliasAnalysis::getLocationForSource(const MemTransferInst *MTI) { + uint64_t Size = UnknownSize; + if (ConstantInt *C = dyn_cast(MTI->getLength())) + Size = C->getValue().getZExtValue(); + + // FIXME: Can memcpy/memmove have TBAA tags? + return Location(MTI->getRawSource(), Size, 0); +} + +AliasAnalysis::Location +AliasAnalysis::getLocationForDest(const MemTransferInst *MTI) { + uint64_t Size = UnknownSize; + if (ConstantInt *C = dyn_cast(MTI->getLength())) + Size = C->getValue().getZExtValue(); + + // FIXME: Can memcpy/memmove have TBAA tags? + return Location(MTI->getRawDest(), Size, 0); +} + + + AliasAnalysis::ModRefResult AliasAnalysis::getModRefInfo(const LoadInst *L, const Location &Loc) { // Be conservative in the face of volatile.