From: Tim Shen Date: Tue, 3 Oct 2017 19:39:02 +0000 (+0000) Subject: Revert r314820 "[Analyzer] More granular special casing in RetainCountChecker" X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=edf4483622df7b5207947b5af5cbcad1aa0b8ae2;p=clang Revert r314820 "[Analyzer] More granular special casing in RetainCountChecker" The test retain-release.m fails with this patch. Differential Revision: https://reviews.llvm.org/D38487 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@314831 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp b/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp index 7212d296a1..165bc04993 100644 --- a/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp +++ b/lib/StaticAnalyzer/Checkers/RetainCountChecker.cpp @@ -1062,7 +1062,6 @@ RetainSummaryManager::getFunctionSummary(const FunctionDecl *FD) { // Inspect the result type. QualType RetTy = FT->getReturnType(); - StringRef RetTyName = RetTy.getAsString(); // FIXME: This should all be refactored into a chain of "summary lookup" // filters. @@ -1082,14 +1081,12 @@ RetainSummaryManager::getFunctionSummary(const FunctionDecl *FD) { AllowAnnotations = false; } else if (FName == "CFPlugInInstanceCreate") { S = getPersistentSummary(RetEffect::MakeNoRet()); - } else if (FName == "IORegistryEntrySearchCFProperty" - || (RetTyName == "CFMutableDictionaryRef" && ( - FName == "IOBSDNameMatching" || + } else if (FName == "IOBSDNameMatching" || FName == "IOServiceMatching" || FName == "IOServiceNameMatching" || + FName == "IORegistryEntrySearchCFProperty" || FName == "IORegistryEntryIDMatching" || - FName == "IOOpenFirmwarePathMatching" - ))) { + FName == "IOOpenFirmwarePathMatching") { // Part of . (IOKit) // This should be addressed using a API table. S = getPersistentSummary(RetEffect::MakeOwned(RetEffect::CF), diff --git a/test/Analysis/retain-release.mm b/test/Analysis/retain-release.mm index ac83c1a48e..c694fd33c5 100644 --- a/test/Analysis/retain-release.mm +++ b/test/Analysis/retain-release.mm @@ -463,10 +463,3 @@ void radar13722286::PrepareBitmap() { // rdar://34210609 void _() { _(); }; // no-warning - -// Do not assume that IOBSDNameMatching increments a reference counter, -// unless return type is CFMutableDictionaryRef. -void* IOBSDNameMatching(); -void rdar33832412() { - void* x = IOBSDNameMatching(); // no-warning -}