aboutsummaryrefslogtreecommitdiff
path: root/clang/lib/CodeGen/CodeGenModule.cpp
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/CodeGenModule.cpp
parent26ffc5f7fb63dc00e68a3c7199441a396bcfbad9 (diff)
downloadllvm-41011f6706e37cecab4797e4e95a9273ca999930.zip
llvm-41011f6706e37cecab4797e4e95a9273ca999930.tar.gz
llvm-41011f6706e37cecab4797e4e95a9273ca999930.tar.bz2
[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/CodeGenModule.cpp')
-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 bd7b44e..d19d0ed 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;
}