For PR1328:

Use the new parameter on Function::getIntrinsicID to identify cases where
a function is being called with an "llvm." name but it isn't actually an
intrinsic. In such cases generate an error.

llvm-svn: 36121
This commit is contained in:
Reid Spencer 2007-04-16 06:55:42 +00:00
parent 9c2eec377e
commit 94bae69764
1 changed files with 8 additions and 0 deletions

View File

@ -2821,6 +2821,14 @@ InstVal : ArithmeticOps Types ValueRef ',' ValueRef {
Value *V = getVal(PFTy, $4); // Get the function we're calling... Value *V = getVal(PFTy, $4); // Get the function we're calling...
CHECK_FOR_ERROR CHECK_FOR_ERROR
// Check for call to invalid intrinsic to avoid crashing later.
if (Function *theF = dyn_cast<Function>(V)) {
if (theF->hasName() && 0 == strncmp(theF->getName().c_str(), "llvm.", 5)&&
!theF->getIntrinsicID(true))
GEN_ERROR("Call to invalid LLVM intrinsic function '" +
theF->getName() + "'");
}
// Check the arguments // Check the arguments
ValueList Args; ValueList Args;
if ($6->empty()) { // Has no arguments? if ($6->empty()) { // Has no arguments?