From: Dylan Noblesmith Date: Mon, 25 Aug 2014 00:28:43 +0000 (+0000) Subject: Analysis: unique_ptr-ify DependenceAnalysis::collectCoeffInfo X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=97dc647e908223d2eda79590de451805dd16a346;p=oota-llvm.git Analysis: unique_ptr-ify DependenceAnalysis::collectCoeffInfo git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@216358 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/llvm/Analysis/DependenceAnalysis.h b/include/llvm/Analysis/DependenceAnalysis.h index a52d6a8ef2d..d032a418366 100644 --- a/include/llvm/Analysis/DependenceAnalysis.h +++ b/include/llvm/Analysis/DependenceAnalysis.h @@ -766,9 +766,10 @@ namespace llvm { /// collectCoefficientInfo - Walks through the subscript, /// collecting each coefficient, the associated loop bounds, /// and recording its positive and negative parts for later use. - CoefficientInfo *collectCoeffInfo(const SCEV *Subscript, - bool SrcFlag, - const SCEV *&Constant) const; + std::unique_ptr + collectCoeffInfo(const SCEV *Subscript, + bool SrcFlag, + const SCEV *&Constant) const; /// getPositivePart - X^+ = max(X, 0). /// diff --git a/lib/Analysis/DependenceAnalysis.cpp b/lib/Analysis/DependenceAnalysis.cpp index be4e487a149..8120736885c 100644 --- a/lib/Analysis/DependenceAnalysis.cpp +++ b/lib/Analysis/DependenceAnalysis.cpp @@ -2437,11 +2437,14 @@ bool DependenceAnalysis::banerjeeMIVtest(const SCEV *Src, ++BanerjeeApplications; DEBUG(dbgs() << " Src = " << *Src << '\n'); const SCEV *A0; - CoefficientInfo *A = collectCoeffInfo(Src, true, A0); + auto AOwner = collectCoeffInfo(Src, true, A0); + auto A = AOwner.get(); DEBUG(dbgs() << " Dst = " << *Dst << '\n'); const SCEV *B0; - CoefficientInfo *B = collectCoeffInfo(Dst, false, B0); - BoundInfo *Bound = new BoundInfo[MaxLevels + 1]; + auto BOwner = collectCoeffInfo(Dst, false, B0); + auto B = BOwner.get(); + auto BoundOwner = make_unique(MaxLevels + 1); + auto Bound = BoundOwner.get(); const SCEV *Delta = SE->getMinusSCEV(B0, A0); DEBUG(dbgs() << "\tDelta = " << *Delta << '\n'); @@ -2498,9 +2501,6 @@ bool DependenceAnalysis::banerjeeMIVtest(const SCEV *Src, ++BanerjeeIndependence; Disproved = true; } - delete [] Bound; - delete [] A; - delete [] B; return Disproved; } @@ -2818,12 +2818,12 @@ const SCEV *DependenceAnalysis::getNegativePart(const SCEV *X) const { // Walks through the subscript, // collecting each coefficient, the associated loop bounds, // and recording its positive and negative parts for later use. -DependenceAnalysis::CoefficientInfo * +std::unique_ptr DependenceAnalysis::collectCoeffInfo(const SCEV *Subscript, bool SrcFlag, const SCEV *&Constant) const { const SCEV *Zero = SE->getConstant(Subscript->getType(), 0); - CoefficientInfo *CI = new CoefficientInfo[MaxLevels + 1]; + auto CI = make_unique(MaxLevels + 1); for (unsigned K = 1; K <= MaxLevels; ++K) { CI[K].Coeff = Zero; CI[K].PosPart = Zero;