mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-27 06:54:30 +00:00
Add method to query for 'NoAlias' attribute on call/invoke instructions.
llvm-svn: 165208
This commit is contained in:
parent
b33809b4df
commit
f6649b4e9a
@ -1279,6 +1279,7 @@ public:
|
||||
bool paramHasStructRetAttr(unsigned i) const;
|
||||
bool paramHasNestAttr(unsigned i) const;
|
||||
bool paramHasByValAttr(unsigned i) const;
|
||||
bool paramHasNoAliasAttr(unsigned i) const;
|
||||
|
||||
/// @brief Determine whether the call or the callee has the given attribute.
|
||||
bool paramHasAttr(unsigned i, Attributes attr) const;
|
||||
@ -3049,6 +3050,7 @@ public:
|
||||
bool paramHasStructRetAttr(unsigned i) const;
|
||||
bool paramHasNestAttr(unsigned i) const;
|
||||
bool paramHasByValAttr(unsigned i) const;
|
||||
bool paramHasNoAliasAttr(unsigned i) const;
|
||||
|
||||
/// @brief Determine whether the call or the callee has the given attribute.
|
||||
bool paramHasAttr(unsigned i, Attributes attr) const;
|
||||
|
@ -208,6 +208,9 @@ public:
|
||||
bool paramHasByValAttr(unsigned i) const {
|
||||
CALLSITE_DELEGATE_GETTER(paramHasByValAttr(i));
|
||||
}
|
||||
bool paramHasNoAliasAttr(unsigned i) const {
|
||||
CALLSITE_DELEGATE_GETTER(paramHasNoAliasAttr(i));
|
||||
}
|
||||
|
||||
/// paramHasAttr - whether the call or the callee has the given attribute.
|
||||
bool paramHasAttr(uint16_t i, Attributes attr) const {
|
||||
|
@ -520,7 +520,7 @@ bool FunctionAttrs::IsFunctionMallocLike(Function *F,
|
||||
case Instruction::Call:
|
||||
case Instruction::Invoke: {
|
||||
CallSite CS(RVI);
|
||||
if (CS.paramHasAttr(0, Attribute::NoAlias))
|
||||
if (CS.paramHasNoAliasAttr(0))
|
||||
break;
|
||||
if (CS.getCalledFunction() &&
|
||||
SCCNodes.count(CS.getCalledFunction()))
|
||||
|
@ -390,6 +390,14 @@ bool CallInst::paramHasByValAttr(unsigned i) const {
|
||||
return false;
|
||||
}
|
||||
|
||||
bool CallInst::paramHasNoAliasAttr(unsigned i) const {
|
||||
if (AttributeList.getParamAttributes(i).hasNoAliasAttr())
|
||||
return true;
|
||||
if (const Function *F = getCalledFunction())
|
||||
return F->getParamAttributes(i).hasNoAliasAttr();
|
||||
return false;
|
||||
}
|
||||
|
||||
bool CallInst::paramHasAttr(unsigned i, Attributes attr) const {
|
||||
if (AttributeList.paramHasAttr(i, attr))
|
||||
return true;
|
||||
@ -658,6 +666,14 @@ bool InvokeInst::paramHasByValAttr(unsigned i) const {
|
||||
return false;
|
||||
}
|
||||
|
||||
bool InvokeInst::paramHasNoAliasAttr(unsigned i) const {
|
||||
if (AttributeList.getParamAttributes(i).hasNoAliasAttr())
|
||||
return true;
|
||||
if (const Function *F = getCalledFunction())
|
||||
return F->getParamAttributes(i).hasNoAliasAttr();
|
||||
return false;
|
||||
}
|
||||
|
||||
bool InvokeInst::paramHasAttr(unsigned i, Attributes attr) const {
|
||||
if (AttributeList.paramHasAttr(i, attr))
|
||||
return true;
|
||||
|
Loading…
x
Reference in New Issue
Block a user