diff options
Diffstat (limited to 'llvm/lib/VMCore/Instructions.cpp')
-rw-r--r-- | llvm/lib/VMCore/Instructions.cpp | 96 |
1 files changed, 96 insertions, 0 deletions
diff --git a/llvm/lib/VMCore/Instructions.cpp b/llvm/lib/VMCore/Instructions.cpp index d5b756dac09..b3acbc42410 100644 --- a/llvm/lib/VMCore/Instructions.cpp +++ b/llvm/lib/VMCore/Instructions.cpp @@ -342,6 +342,54 @@ void CallInst::removeAttribute(unsigned i, Attributes attr) { setAttributes(PAL); } +bool CallInst::paramHasSExtAttr(unsigned i) const { + if (AttributeList.getParamAttributes(i).hasSExtAttr()) + return true; + if (const Function *F = getCalledFunction()) + return F->getParamAttributes(i).hasSExtAttr(); + return false; +} + +bool CallInst::paramHasZExtAttr(unsigned i) const { + if (AttributeList.getParamAttributes(i).hasZExtAttr()) + return true; + if (const Function *F = getCalledFunction()) + return F->getParamAttributes(i).hasZExtAttr(); + return false; +} + +bool CallInst::paramHasInRegAttr(unsigned i) const { + if (AttributeList.getParamAttributes(i).hasInRegAttr()) + return true; + if (const Function *F = getCalledFunction()) + return F->getParamAttributes(i).hasInRegAttr(); + return false; +} + +bool CallInst::paramHasStructRetAttr(unsigned i) const { + if (AttributeList.getParamAttributes(i).hasStructRetAttr()) + return true; + if (const Function *F = getCalledFunction()) + return F->getParamAttributes(i).hasStructRetAttr(); + return false; +} + +bool CallInst::paramHasNestAttr(unsigned i) const { + if (AttributeList.getParamAttributes(i).hasNestAttr()) + return true; + if (const Function *F = getCalledFunction()) + return F->getParamAttributes(i).hasNestAttr(); + return false; +} + +bool CallInst::paramHasByValAttr(unsigned i) const { + if (AttributeList.getParamAttributes(i).hasByValAttr()) + return true; + if (const Function *F = getCalledFunction()) + return F->getParamAttributes(i).hasByValAttr(); + return false; +} + bool CallInst::paramHasAttr(unsigned i, Attributes attr) const { if (AttributeList.paramHasAttr(i, attr)) return true; @@ -562,6 +610,54 @@ void InvokeInst::setSuccessorV(unsigned idx, BasicBlock *B) { return setSuccessor(idx, B); } +bool InvokeInst::paramHasSExtAttr(unsigned i) const { + if (AttributeList.getParamAttributes(i).hasSExtAttr()) + return true; + if (const Function *F = getCalledFunction()) + return F->getParamAttributes(i).hasSExtAttr(); + return false; +} + +bool InvokeInst::paramHasZExtAttr(unsigned i) const { + if (AttributeList.getParamAttributes(i).hasZExtAttr()) + return true; + if (const Function *F = getCalledFunction()) + return F->getParamAttributes(i).hasZExtAttr(); + return false; +} + +bool InvokeInst::paramHasInRegAttr(unsigned i) const { + if (AttributeList.getParamAttributes(i).hasInRegAttr()) + return true; + if (const Function *F = getCalledFunction()) + return F->getParamAttributes(i).hasInRegAttr(); + return false; +} + +bool InvokeInst::paramHasStructRetAttr(unsigned i) const { + if (AttributeList.getParamAttributes(i).hasStructRetAttr()) + return true; + if (const Function *F = getCalledFunction()) + return F->getParamAttributes(i).hasStructRetAttr(); + return false; +} + +bool InvokeInst::paramHasNestAttr(unsigned i) const { + if (AttributeList.getParamAttributes(i).hasNestAttr()) + return true; + if (const Function *F = getCalledFunction()) + return F->getParamAttributes(i).hasNestAttr(); + return false; +} + +bool InvokeInst::paramHasByValAttr(unsigned i) const { + if (AttributeList.getParamAttributes(i).hasByValAttr()) + return true; + if (const Function *F = getCalledFunction()) + return F->getParamAttributes(i).hasByValAttr(); + return false; +} + bool InvokeInst::paramHasAttr(unsigned i, Attributes attr) const { if (AttributeList.paramHasAttr(i, attr)) return true; |