Index: unittests/Transforms/Vectorize/VPlanHCFGTest.cpp =================================================================== --- unittests/Transforms/Vectorize/VPlanHCFGTest.cpp +++ unittests/Transforms/Vectorize/VPlanHCFGTest.cpp @@ -8,35 +8,14 @@ //===----------------------------------------------------------------------===// #include "../lib/Transforms/Vectorize/VPlan.h" -#include "../lib/Transforms/Vectorize/VPlanHCFGBuilder.h" #include "../lib/Transforms/Vectorize/VPlanHCFGTransforms.h" -#include "llvm/AsmParser/Parser.h" -#include "llvm/IR/Dominators.h" +#include "VPlanTestBase.h" #include "gtest/gtest.h" namespace llvm { namespace { -class VPlanHCFGTest : public testing::Test { -protected: - std::unique_ptr DT; - std::unique_ptr LI; - - VPlanHCFGTest() {} - - VPlanPtr doBuildPlan(BasicBlock *LoopHeader) { - DT.reset(new DominatorTree(*LoopHeader->getParent())); - LI.reset(new LoopInfo(*DT)); - - auto Plan = llvm::make_unique(); - VPlanHCFGBuilder HCFGBuilder(LI->getLoopFor(LoopHeader), LI.get()); - HCFGBuilder.buildHierarchicalCFG(*Plan.get()); - return Plan; - } -}; - -TEST_F(VPlanHCFGTest, testBuildHCFGInnerLoop) { - LLVMContext Ctx; +TEST_F(VPlanTestBase, testBuildHCFGInnerLoop) { const char *ModuleString = "define void @f(i32* %A, i64 %N) {\n" "entry:\n" @@ -54,10 +33,9 @@ " ret void\n" "}\n"; - SMDiagnostic Err; - std::unique_ptr M = parseAssemblyString(ModuleString, Err, Ctx); + Module &M = parseModule(ModuleString); - Function *F = M->getFunction("f"); + Function *F = M.getFunction("f"); BasicBlock *LoopHeader = F->getEntryBlock().getSingleSuccessor(); auto Plan = doBuildPlan(LoopHeader); @@ -112,8 +90,7 @@ DeadInstructions); } -TEST_F(VPlanHCFGTest, testVPInstructionToVPRecipesInner) { - LLVMContext Ctx; +TEST_F(VPlanTestBase, testVPInstructionToVPRecipesInner) { const char *ModuleString = "define void @f(i32* %A, i64 %N) {\n" "entry:\n" @@ -131,10 +108,9 @@ " ret void\n" "}\n"; - SMDiagnostic Err; - std::unique_ptr M = parseAssemblyString(ModuleString, Err, Ctx); + Module &M = parseModule(ModuleString); - Function *F = M->getFunction("f"); + Function *F = M.getFunction("f"); BasicBlock *LoopHeader = F->getEntryBlock().getSingleSuccessor(); auto Plan = doBuildPlan(LoopHeader); Index: unittests/Transforms/Vectorize/VPlanTestBase.h =================================================================== --- /dev/null +++ unittests/Transforms/Vectorize/VPlanTestBase.h @@ -0,0 +1,59 @@ +//===- llvm/unittest/Transforms/Vectorize/VPlanTestBase.h -----------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#ifndef LLVM_UNITTESTS_TRANSFORMS_VECTORIZE_VPLANTESTBASE_H +#define LLVM_UNITTESTS_TRANSFORMS_VECTORIZE_VPLANTESTBASE_H + +#include "../lib/Transforms/Vectorize/VPlan.h" +#include "../lib/Transforms/Vectorize/VPlanHCFGBuilder.h" +#include "llvm/Analysis/LoopInfo.h" +#include "llvm/AsmParser/Parser.h" +#include "llvm/IR/Dominators.h" +#include "llvm/Support/SourceMgr.h" +#include "gtest/gtest.h" + +namespace llvm { + +/// Helper class to create a module from an assembly string and create a +/// VPlan. +class VPlanTestBase : public testing::Test { +protected: + std::unique_ptr DT; + std::unique_ptr LI; + std::unique_ptr M; + LLVMContext *Ctx; + + VPlanTestBase() : Ctx(new LLVMContext) {} + ~VPlanTestBase() { + LI.release(); + DT.release(); + M.release(); + delete Ctx; + } + + Module &parseModule(const char *ModuleString) { + SMDiagnostic Err; + M = parseAssemblyString(ModuleString, Err, *Ctx); + return *M; + } + + VPlanPtr doBuildPlan(BasicBlock *LoopHeader) { + DT.reset(new DominatorTree(*LoopHeader->getParent())); + LI.reset(new LoopInfo(*DT)); + + auto Plan = llvm::make_unique(); + VPlanHCFGBuilder HCFGBuilder(LI->getLoopFor(LoopHeader), LI.get()); + HCFGBuilder.buildHierarchicalCFG(*Plan.get()); + return Plan; + } +}; + +} // namespace llvm + +#endif // LLVM_UNITTESTS_TRANSFORMS_VECTORIZE_VPLANTESTBASE_H