diff options
author | David Majnemer <david.majnemer@gmail.com> | 2015-06-25 23:50:40 +0000 |
---|---|---|
committer | David Majnemer <david.majnemer@gmail.com> | 2015-06-25 23:50:40 +0000 |
commit | 41011f6706e37cecab4797e4e95a9273ca999930 (patch) | |
tree | d2b0a3abb20ca1f302c27d03261c29cc27b4f790 /clang/lib/CodeGen/CodeGenModule.cpp | |
parent | 26ffc5f7fb63dc00e68a3c7199441a396bcfbad9 (diff) | |
download | llvm-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.cpp | 9 |
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; } |