diff options
Diffstat (limited to 'unittests/Transforms/Vectorize/VPlanTestBase.h')
-rw-r--r-- | unittests/Transforms/Vectorize/VPlanTestBase.h | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/unittests/Transforms/Vectorize/VPlanTestBase.h b/unittests/Transforms/Vectorize/VPlanTestBase.h new file mode 100644 index 000000000000..da3b39f4df01 --- /dev/null +++ b/unittests/Transforms/Vectorize/VPlanTestBase.h @@ -0,0 +1,61 @@ +//===- 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. +// +//===----------------------------------------------------------------------===// +/// \file +/// This file defines a VPlanTestBase class, which provides helpers to parse +/// a LLVM IR string and create VPlans given a loop entry block. +//===----------------------------------------------------------------------===// +#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 VPlans for a +/// given loop entry block. +class VPlanTestBase : public testing::Test { +protected: + std::unique_ptr<LLVMContext> Ctx; + std::unique_ptr<Module> M; + std::unique_ptr<LoopInfo> LI; + std::unique_ptr<DominatorTree> DT; + + VPlanTestBase() : Ctx(new LLVMContext) {} + + Module &parseModule(const char *ModuleString) { + SMDiagnostic Err; + M = parseAssemblyString(ModuleString, Err, *Ctx); + EXPECT_TRUE(M); + return *M; + } + + void doAnalysis(Function &F) { + DT.reset(new DominatorTree(F)); + LI.reset(new LoopInfo(*DT)); + } + + VPlanPtr buildHCFG(BasicBlock *LoopHeader) { + doAnalysis(*LoopHeader->getParent()); + + auto Plan = llvm::make_unique<VPlan>(); + VPlanHCFGBuilder HCFGBuilder(LI->getLoopFor(LoopHeader), LI.get()); + HCFGBuilder.buildHierarchicalCFG(*Plan.get()); + return Plan; + } +}; + +} // namespace llvm + +#endif // LLVM_UNITTESTS_TRANSFORMS_VECTORIZE_VPLANTESTBASE_H |