LLVM API Documentation
#include <AliasSetTracker.h>
Public Types | |
typedef ilist< AliasSet >::iterator | iterator |
typedef ilist< AliasSet > ::const_iterator | const_iterator |
Friends | |
class | AliasSet |
Definition at line 280 of file AliasSetTracker.h.
Definition at line 392 of file AliasSetTracker.h.
typedef ilist<AliasSet>::iterator llvm::AliasSetTracker::iterator |
Definition at line 391 of file AliasSetTracker.h.
|
inlineexplicit |
AliasSetTracker ctor - Create an empty collection of AliasSets, and use the specified alias analysis object to disambiguate load and store addresses.
Definition at line 309 of file AliasSetTracker.h.
|
inline |
Definition at line 310 of file AliasSetTracker.h.
References clear().
add methods - These methods are used to add different types of instructions to the alias sets. Adding a new instruction can result in one of three actions happening:
These methods return true if inserting the instruction resulted in the addition of a new alias set (i.e., the pointer did not alias anything).
Definition at line 292 of file AliasSetTracker.cpp.
Referenced by add().
Definition at line 299 of file AliasSetTracker.cpp.
References addUnknown(), llvm::Instruction::getMetadata(), llvm::User::getOperand(), llvm::LoadInst::getOrdering(), llvm::Value::getType(), llvm::AliasAnalysis::getTypeStoreSize(), llvm::LoadInst::isVolatile(), llvm::LLVMContext::MD_tbaa, and llvm::Monotonic.
Definition at line 311 of file AliasSetTracker.cpp.
References addUnknown(), llvm::Instruction::getMetadata(), llvm::User::getOperand(), llvm::StoreInst::getOrdering(), llvm::Value::getType(), llvm::AliasAnalysis::getTypeStoreSize(), llvm::StoreInst::isVolatile(), llvm::LLVMContext::MD_tbaa, and llvm::Monotonic.
Definition at line 324 of file AliasSetTracker.cpp.
References llvm::Instruction::getMetadata(), llvm::User::getOperand(), llvm::LLVMContext::MD_tbaa, and llvm::AliasAnalysis::UnknownSize.
bool AliasSetTracker::add | ( | Instruction * | I | ) |
Definition at line 350 of file AliasSetTracker.cpp.
References add(), addUnknown(), and LI.
void AliasSetTracker::add | ( | BasicBlock & | BB | ) |
Definition at line 361 of file AliasSetTracker.cpp.
References add(), llvm::BasicBlock::begin(), llvm::BasicBlock::end(), and I.
void AliasSetTracker::add | ( | const AliasSetTracker & | AST | ) |
Definition at line 366 of file AliasSetTracker.cpp.
References add(), llvm::AliasSet::begin(), begin(), llvm::AliasSet::end(), end(), I, llvm::AliasSet::isVolatile(), and llvm::X.
bool AliasSetTracker::addUnknown | ( | Instruction * | I | ) |
Definition at line 333 of file AliasSetTracker.cpp.
References AliasSet, and llvm::Instruction::mayReadOrWriteMemory().
Referenced by add().
|
inline |
Definition at line 394 of file AliasSetTracker.h.
Referenced by add(), containsPointer(), deleteValue(), and print().
|
inline |
Definition at line 397 of file AliasSetTracker.h.
void AliasSetTracker::clear | ( | ) |
Definition at line 201 of file AliasSetTracker.cpp.
References llvm::DenseMapBase< DerivedT, KeyT, ValueT, KeyInfoT >::begin(), llvm::DenseMapBase< DerivedT, KeyT, ValueT, KeyInfoT >::clear(), llvm::DenseMapBase< DerivedT, KeyT, ValueT, KeyInfoT >::end(), and I.
Referenced by ~AliasSetTracker().
containsPointer - Return true if the specified location is represented by this alias set, false otherwise. This does not modify the AST object or alias sets.
Definition at line 238 of file AliasSetTracker.cpp.
copyValue - This method should be used whenever a preexisting value in the program is copied or cloned, introducing a new value. Note that it is ok for clients that use this method to introduce the same value multiple times: if the tracker already knows about a value, it will ignore the request.
Definition at line 523 of file AliasSetTracker.cpp.
References llvm::AliasAnalysis::copyValue(), llvm::DenseMapBase< DerivedT, KeyT, ValueT, KeyInfoT >::end(), and llvm::DenseMapBase< DerivedT, KeyT, ValueT, KeyInfoT >::find_as().
void AliasSetTracker::deleteValue | ( | Value * | PtrVal | ) |
deleteValue method - This method is used to remove a pointer value from the AliasSetTracker entirely. It should be used when an instruction is deleted from the program to update the AST. If you don't use this, you would have dangling pointers to deleted instructions.
Definition at line 484 of file AliasSetTracker.cpp.
References begin(), llvm::AliasAnalysis::deleteValue(), llvm::DenseMapBase< DerivedT, KeyT, ValueT, KeyInfoT >::end(), end(), llvm::DenseMapBase< DerivedT, KeyT, ValueT, KeyInfoT >::erase(), llvm::DenseMapBase< DerivedT, KeyT, ValueT, KeyInfoT >::find_as(), I, and llvm::Instruction::mayReadOrWriteMemory().
Referenced by promoteSingleBlockAlloca(), and rewriteSingleStoreAlloca().
void AliasSetTracker::dump | ( | ) | const |
Definition at line 593 of file AliasSetTracker.cpp.
References llvm::dbgs(), and print().
|
inline |
Definition at line 395 of file AliasSetTracker.h.
Referenced by add(), containsPointer(), deleteValue(), and print().
|
inline |
Definition at line 398 of file AliasSetTracker.h.
|
inline |
getAliasAnalysis - Return the underlying alias analysis object used by this tracker.
Definition at line 373 of file AliasSetTracker.h.
Referenced by llvm::AliasSet::mergeSetIn().
AliasSet & AliasSetTracker::getAliasSetForPointer | ( | Value * | Pointer, |
uint64_t | Size, | ||
const MDNode * | TBAAInfo, | ||
bool * | New = 0 |
||
) |
getAliasSetForPointer - Return the alias set that the specified pointer lives in. If the New argument is non-null, this method sets the value to true if a new alias set is created to contain the pointer (because the pointer didn't alias anything).
getAliasSetForPointer - Return the alias set that the specified pointer lives in.
Definition at line 267 of file AliasSetTracker.cpp.
References AliasSet.
|
inline |
getAliasSetForPointerIfExists - Return the alias set containing the location specified if one exists, otherwise return null.
Definition at line 361 of file AliasSetTracker.h.
getAliasSets - Return the alias sets that are active.
Definition at line 349 of file AliasSetTracker.h.
void AliasSetTracker::print | ( | raw_ostream & | OS | ) | const |
Definition at line 583 of file AliasSetTracker.cpp.
References begin(), end(), I, llvm::Value::print(), and llvm::DenseMapBase< DerivedT, KeyT, ValueT, KeyInfoT >::size().
Referenced by dump(), and llvm::operator<<().
remove methods - These methods are used to remove all entries that might be aliased by the specified instruction. These methods return true if any alias sets were eliminated.
Definition at line 423 of file AliasSetTracker.cpp.
Definition at line 430 of file AliasSetTracker.cpp.
References llvm::Instruction::getMetadata(), llvm::User::getOperand(), llvm::Value::getType(), llvm::AliasAnalysis::getTypeStoreSize(), and llvm::LLVMContext::MD_tbaa.
Definition at line 439 of file AliasSetTracker.cpp.
References llvm::Instruction::getMetadata(), llvm::User::getOperand(), llvm::Value::getType(), llvm::AliasAnalysis::getTypeStoreSize(), and llvm::LLVMContext::MD_tbaa.
Definition at line 448 of file AliasSetTracker.cpp.
References llvm::Instruction::getMetadata(), llvm::User::getOperand(), llvm::LLVMContext::MD_tbaa, and llvm::AliasAnalysis::UnknownSize.
bool AliasSetTracker::remove | ( | Instruction * | I | ) |
Definition at line 467 of file AliasSetTracker.cpp.
References LI, and removeUnknown().
void AliasSetTracker::remove | ( | AliasSet & | AS | ) |
remove - Remove the specified (potentially non-empty) alias set from the tracker.
Definition at line 395 of file AliasSetTracker.cpp.
References llvm::AliasSet::empty(), llvm::DenseMapBase< DerivedT, KeyT, ValueT, KeyInfoT >::erase(), and P.
bool AliasSetTracker::removeUnknown | ( | Instruction * | I | ) |
Definition at line 457 of file AliasSetTracker.cpp.
References llvm::Instruction::mayReadOrWriteMemory().
Referenced by remove().
|
friend |
Definition at line 404 of file AliasSetTracker.h.
Referenced by addUnknown(), and getAliasSetForPointer().