[objc-arc] Move the before optimization statistics gathering phase out of OptimizeIndividualCalls.

This makes the statistics gathering completely independent of the actual
optimization occuring, preventing any sort of bleeding over from occuring.

Additionally, it simplifies a switch statement in the non-statistic gathering case.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@181719 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Michael Gottesman 2013-05-13 18:29:07 +00:00
parent 42f562a169
commit fa709768b9

View File

@ -1440,11 +1440,7 @@ void ObjCARCOpt::OptimizeIndividualCalls(Function &F) {
case IC_RetainBlock: case IC_RetainBlock:
// If we strength reduce an objc_retainBlock to an objc_retain, continue // If we strength reduce an objc_retainBlock to an objc_retain, continue
// onto the objc_retain peephole optimizations. Otherwise break. // onto the objc_retain peephole optimizations. Otherwise break.
if (!OptimizeRetainBlockCall(F, Inst, Class)) OptimizeRetainBlockCall(F, Inst, Class);
break;
// FALLTHROUGH
case IC_Retain:
++NumRetainsBeforeOpt;
break; break;
case IC_RetainRV: case IC_RetainRV:
if (OptimizeRetainRVCall(F, Inst)) if (OptimizeRetainRVCall(F, Inst))
@ -1453,9 +1449,6 @@ void ObjCARCOpt::OptimizeIndividualCalls(Function &F) {
case IC_AutoreleaseRV: case IC_AutoreleaseRV:
OptimizeAutoreleaseRVCall(F, Inst, Class); OptimizeAutoreleaseRVCall(F, Inst, Class);
break; break;
case IC_Release:
++NumReleasesBeforeOpt;
break;
} }
// objc_autorelease(x) -> objc_release(x) if x is otherwise unused. // objc_autorelease(x) -> objc_release(x) if x is otherwise unused.
@ -3050,6 +3043,12 @@ bool ObjCARCOpt::runOnFunction(Function &F) {
PA.setAA(&getAnalysis<AliasAnalysis>()); PA.setAA(&getAnalysis<AliasAnalysis>());
#ifndef NDEBUG
if (AreStatisticsEnabled()) {
GatherStatistics(F, false);
}
#endif
// This pass performs several distinct transformations. As a compile-time aid // This pass performs several distinct transformations. As a compile-time aid
// when compiling code that isn't ObjC, skip these if the relevant ObjC // when compiling code that isn't ObjC, skip these if the relevant ObjC
// library functions aren't declared. // library functions aren't declared.