[llvm-dev] Objects of MemoryLocation class are created for ‘llvm.memset.*‘ intrinsics
    Hal Finkel via llvm-dev 
    llvm-dev at lists.llvm.org
       
    Fri Dec 11 10:44:40 PST 2015
    
    
  
Hi Roman,
The MemoryLocation objects are involved in findAliasSetForUnknownInst, but none are created there for the memset intrinsic. MemoryLocation objects are only involved for the regular memory accesses being compared to the unknown instruction. See AliasSet::aliasesUnknownInst in lib/Analysis/AliasSetTracker.cpp.
We do know how to create MemoryLocation objects for memsets, see MemoryLocation::getForDest, but we don't do so in the AliasSetTracker. We're taking advantage here of the fast that AA's getModRefInfo understands (or should understand) enough about memset to accurately answer the queries.
 -Hal
----- Original Message -----
> From: "Roman Gareev via llvm-dev" <llvm-dev at lists.llvm.org>
> To: llvm-dev at lists.llvm.org
> Cc: "Tobias Grosser" <tobias at grosser.es>
> Sent: Sunday, December 6, 2015 4:24:06 AM
> Subject: [llvm-dev] Objects of MemoryLocation class are created for ‘llvm.memset.*‘ intrinsics
> 
> Dear llvm contributors,
> 
> Could you please advise me where objects of MemoryLocation class are
> created for ‘llvm.memset.*‘ intrinsics?
> 
> In the Bug 23077 (https://llvm.org/bugs/show_bug.cgi?id=23077) the
> AliasSetTracker constructs 128 alias sets for 0 pointer values, which
> contain only unknown instructions. In this case, all unknown
> instructions, which are added to new alias sets in the
> AliasSetTracker::addUnknown, have the following form:
> 
> call void @llvm.memset.p0i8.i64(i8* %scevgep..., i8 0, i64 256, i32
> 8, i1 false)
> 
> Furthermore, in this case, there aren’t any unknown instructions,
> which are added by AliasSetTracker::addUnknown to alias sets that are
> found by findAliasSetForUnknownInst. That’s why I would like to check
> objects of MemoryLocation class that are created  for ‘llvm.memset.*‘
> intrinsics. If I’m not mistaken, objects of MemoryLocation class are
> involved in alias analysis and, in particular, in work of
> findAliasSetForUnknownInst.
> 
> Thank you for the attention!
> 
> --
>                                     Cheers, Roman Gareev.
> _______________________________________________
> LLVM Developers mailing list
> llvm-dev at lists.llvm.org
> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev
> 
-- 
Hal Finkel
Assistant Computational Scientist
Leadership Computing Facility
Argonne National Laboratory
    
    
More information about the llvm-dev
mailing list