summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen
diff options
context:
space:
mode:
authorDavid Majnemer <david.majnemer@gmail.com>2015-06-25 23:50:40 +0000
committerDavid Majnemer <david.majnemer@gmail.com>2015-06-25 23:50:40 +0000
commit41011f6706e37cecab4797e4e95a9273ca999930 (patch)
treed2b0a3abb20ca1f302c27d03261c29cc27b4f790 /clang/lib/CodeGen
parent26ffc5f7fb63dc00e68a3c7199441a396bcfbad9 (diff)
downloadbcm5719-llvm-41011f6706e37cecab4797e4e95a9273ca999930.tar.gz
bcm5719-llvm-41011f6706e37cecab4797e4e95a9273ca999930.zip
[CodeGen] Restrict isTriviallyRecursive to predefined lib functions forwarding to lib functions
isTriviallyRecursive is only supposed to guard functions part of the implementation. This fixes PR23953. llvm-svn: 240735
Diffstat (limited to 'clang/lib/CodeGen')
-rw-r--r--clang/lib/CodeGen/CodeGenModule.cpp9
1 files changed, 7 insertions, 2 deletions
diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp
index bd7b44e4133..d19d0ed886e 100644
--- a/clang/lib/CodeGen/CodeGenModule.cpp
+++ b/clang/lib/CodeGen/CodeGenModule.cpp
@@ -1425,7 +1425,7 @@ namespace {
return false;
}
unsigned BuiltinID = FD->getBuiltinID();
- if (!BuiltinID)
+ if (!BuiltinID || !BI.isLibFunction(BuiltinID))
return true;
StringRef BuiltinName = BI.GetName(BuiltinID);
if (BuiltinName.startswith("__builtin_") &&
@@ -1454,7 +1454,12 @@ CodeGenModule::isTriviallyRecursive(const FunctionDecl *FD) {
Name = FD->getName();
}
- FunctionIsDirectlyRecursive Walker(Name, Context.BuiltinInfo);
+ auto &BI = Context.BuiltinInfo;
+ unsigned BuiltinID = Context.Idents.get(Name).getBuiltinID();
+ if (!BuiltinID || !BI.isPredefinedLibFunction(BuiltinID))
+ return false;
+
+ FunctionIsDirectlyRecursive Walker(Name, BI);
Walker.TraverseFunctionDecl(const_cast<FunctionDecl*>(FD));
return Walker.Result;
}
OpenPOWER on IntegriCloud