summaryrefslogtreecommitdiffstats
path: root/polly/lib/Support
diff options
context:
space:
mode:
Diffstat (limited to 'polly/lib/Support')
-rw-r--r--polly/lib/Support/DumpModulePass.cpp95
-rw-r--r--polly/lib/Support/RegisterPasses.cpp34
2 files changed, 129 insertions, 0 deletions
diff --git a/polly/lib/Support/DumpModulePass.cpp b/polly/lib/Support/DumpModulePass.cpp
new file mode 100644
index 00000000000..558088cf898
--- /dev/null
+++ b/polly/lib/Support/DumpModulePass.cpp
@@ -0,0 +1,95 @@
+//===------ DumpModulePass.cpp ----------------------------------*- C++ -*-===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// Write a module to a file.
+//
+//===----------------------------------------------------------------------===//
+
+#include "polly/Support/DumpModulePass.h"
+
+#include "polly/Options.h"
+#include "llvm/IR/LegacyPassManagers.h"
+#include "llvm/IR/Module.h"
+#include "llvm/Pass.h"
+#include "llvm/Support/Debug.h"
+#include "llvm/Support/FileSystem.h"
+#include "llvm/Support/Path.h"
+#include "llvm/Support/ToolOutputFile.h"
+#include <string.h>
+#define DEBUG_TYPE "polly-dump-module"
+
+using namespace llvm;
+using namespace polly;
+
+namespace {
+
+class DumpModule : public ModulePass {
+private:
+ DumpModule(const DumpModule &) = delete;
+ const DumpModule &operator=(const DumpModule &) = delete;
+
+ std::string Filename;
+ bool IsSuffix;
+
+public:
+ static char ID;
+
+ /// This constructor is used e.g. if using opt -polly-dump-module.
+ ///
+ /// Provide a default suffix to not overwrite the original file.
+ explicit DumpModule() : ModulePass(ID), Filename("-dump"), IsSuffix(true) {}
+
+ explicit DumpModule(llvm::StringRef Filename, bool IsSuffix)
+ : ModulePass(ID), Filename(Filename), IsSuffix(IsSuffix) {}
+
+ /// @name ModulePass interface
+ //@{
+ virtual void getAnalysisUsage(llvm::AnalysisUsage &AU) const override {
+ AU.setPreservesAll();
+ }
+
+ virtual bool runOnModule(llvm::Module &M) override {
+ std::string Dumpfile;
+ if (IsSuffix) {
+ auto ModuleName = M.getName();
+ auto Stem = sys::path::stem(ModuleName);
+ Dumpfile = (Twine(Stem) + Filename + ".ll").str();
+ } else {
+ Dumpfile = Filename;
+ }
+ DEBUG(dbgs() << "Dumping module to " << Dumpfile << '\n');
+
+ std::unique_ptr<tool_output_file> Out;
+ std::error_code EC;
+ Out.reset(new tool_output_file(Dumpfile, EC, sys::fs::F_None));
+ if (EC) {
+ errs() << EC.message() << '\n';
+ return false;
+ }
+
+ M.print(Out->os(), nullptr);
+ Out->keep();
+
+ return false;
+ }
+ //@}
+};
+
+char DumpModule::ID;
+} // namespace
+
+ModulePass *polly::createDumpModulePass(llvm::StringRef Filename,
+ bool IsSuffix) {
+ return new DumpModule(Filename, IsSuffix);
+}
+
+INITIALIZE_PASS_BEGIN(DumpModule, "polly-dump-module", "Polly - Dump Module",
+ false, false)
+INITIALIZE_PASS_END(DumpModule, "polly-dump-module", "Polly - Dump Module",
+ false, false)
diff --git a/polly/lib/Support/RegisterPasses.cpp b/polly/lib/Support/RegisterPasses.cpp
index 949328962f0..703cbe2ae1f 100644
--- a/polly/lib/Support/RegisterPasses.cpp
+++ b/polly/lib/Support/RegisterPasses.cpp
@@ -31,6 +31,7 @@
#include "polly/PolyhedralInfo.h"
#include "polly/ScopDetection.h"
#include "polly/ScopInfo.h"
+#include "polly/Support/DumpModulePass.h"
#include "llvm/Analysis/CFGPrinter.h"
#include "llvm/IR/LegacyPassManager.h"
#include "llvm/Transforms/IPO.h"
@@ -161,6 +162,28 @@ static cl::opt<bool>
cl::Hidden, cl::init(false), cl::cat(PollyCategory));
static cl::opt<bool>
+ DumpBefore("polly-dump-before",
+ cl::desc("Dump module before Polly transformations into a file "
+ "suffixed with \"-before\""),
+ cl::init(false), cl::cat(PollyCategory));
+
+static cl::list<std::string> DumpBeforeFile(
+ "polly-dump-before-file",
+ cl::desc("Dump module before Polly transformations to the given file"),
+ cl::cat(PollyCategory));
+
+static cl::opt<bool>
+ DumpAfter("polly-dump-after",
+ cl::desc("Dump module after Polly transformations into a file "
+ "suffixed with \"-after\""),
+ cl::init(false), cl::cat(PollyCategory));
+
+static cl::list<std::string> DumpAfterFile(
+ "polly-dump-after-file",
+ cl::desc("Dump module after Polly transformations to the given file"),
+ cl::ZeroOrMore, cl::cat(PollyCategory));
+
+static cl::opt<bool>
EnableDeLICM("polly-enable-delicm",
cl::desc("Eliminate scalar loop carried dependences"),
cl::Hidden, cl::init(false), cl::cat(PollyCategory));
@@ -188,6 +211,7 @@ void initializePollyPasses(PassRegistry &Registry) {
initializeCodegenCleanupPass(Registry);
initializeFlattenSchedulePass(Registry);
initializeDeLICMPass(Registry);
+ initializeDumpModulePass(Registry);
}
/// Register Polly passes such that they form a polyhedral optimizer.
@@ -217,6 +241,11 @@ void initializePollyPasses(PassRegistry &Registry) {
///
/// Polly supports the isl internal code generator.
void registerPollyPasses(llvm::legacy::PassManagerBase &PM) {
+ if (DumpBefore)
+ PM.add(polly::createDumpModulePass("-before", true));
+ for (auto &Filename : DumpBeforeFile)
+ PM.add(polly::createDumpModulePass(Filename, false));
+
PM.add(polly::createScopDetectionPass());
if (PollyDetectOnly)
@@ -282,6 +311,11 @@ void registerPollyPasses(llvm::legacy::PassManagerBase &PM) {
// force all analysis results to be recomputed.
PM.add(createBarrierNoopPass());
+ if (DumpAfter)
+ PM.add(polly::createDumpModulePass("-after", true));
+ for (auto &Filename : DumpAfterFile)
+ PM.add(polly::createDumpModulePass(Filename, false));
+
if (CFGPrinter)
PM.add(llvm::createCFGPrinterLegacyPassPass());
OpenPOWER on IntegriCloud