2012-01-31 22:00:27 +08:00
|
|
|
//===- DeadCodeElimination.cpp - Eliminate dead iteration ----------------===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
2013-03-23 08:16:05 +08:00
|
|
|
// This is a skeleton that is meant to contain a dead code elimination pass
|
|
|
|
// later on.
|
|
|
|
//
|
|
|
|
// The idea of this pass is to loop over all statements and to remove statement
|
|
|
|
// iterations that do not calculate any value that is read later on. We need to
|
|
|
|
// make sure to forward RAR and WAR dependences.
|
|
|
|
//
|
|
|
|
// A case where this pass might be useful is
|
|
|
|
// http://llvm.org/bugs/show_bug.cgi?id=5117
|
|
|
|
//
|
2012-01-31 22:00:27 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "polly/Dependences.h"
|
2013-06-01 01:41:17 +08:00
|
|
|
#include "isl/aff_type.h"
|
2013-05-07 16:11:54 +08:00
|
|
|
#include "isl/union_map.h"
|
2012-01-31 22:00:27 +08:00
|
|
|
#include "polly/LinkAllPasses.h"
|
|
|
|
#include "polly/ScopInfo.h"
|
|
|
|
|
|
|
|
using namespace llvm;
|
|
|
|
using namespace polly;
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
2013-01-08 16:27:46 +08:00
|
|
|
class DeadCodeElim : public ScopPass {
|
2012-01-31 22:00:27 +08:00
|
|
|
|
2013-01-08 16:27:46 +08:00
|
|
|
public:
|
|
|
|
static char ID;
|
2013-03-23 08:16:05 +08:00
|
|
|
explicit DeadCodeElim() : ScopPass(ID) {}
|
2012-01-31 22:00:27 +08:00
|
|
|
|
2013-01-08 16:27:46 +08:00
|
|
|
virtual bool runOnScop(Scop &S);
|
|
|
|
void printScop(llvm::raw_ostream &OS) const;
|
|
|
|
void getAnalysisUsage(AnalysisUsage &AU) const;
|
|
|
|
};
|
2012-01-31 22:00:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
char DeadCodeElim::ID = 0;
|
|
|
|
|
|
|
|
bool DeadCodeElim::runOnScop(Scop &S) {
|
|
|
|
Dependences *D = &getAnalysis<Dependences>();
|
|
|
|
|
2013-03-23 08:16:05 +08:00
|
|
|
int Kinds =
|
|
|
|
Dependences::TYPE_RAW | Dependences::TYPE_WAR | Dependences::TYPE_WAW;
|
2012-01-31 22:00:27 +08:00
|
|
|
|
2013-01-08 16:53:58 +08:00
|
|
|
isl_union_map *Deps = D->getDependences(Kinds);
|
2012-01-31 22:00:27 +08:00
|
|
|
|
2013-01-08 16:53:58 +08:00
|
|
|
isl_union_map_free(Deps);
|
2012-01-31 22:00:27 +08:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2013-03-23 08:16:05 +08:00
|
|
|
void DeadCodeElim::printScop(raw_ostream &OS) const {}
|
2012-01-31 22:00:27 +08:00
|
|
|
|
|
|
|
void DeadCodeElim::getAnalysisUsage(AnalysisUsage &AU) const {
|
|
|
|
ScopPass::getAnalysisUsage(AU);
|
|
|
|
AU.addRequired<Dependences>();
|
|
|
|
}
|
|
|
|
|
2013-03-23 08:16:05 +08:00
|
|
|
Pass *polly::createDeadCodeElimPass() { return new DeadCodeElim(); }
|
|
|
|
|
2012-01-31 22:00:27 +08:00
|
|
|
INITIALIZE_PASS_BEGIN(DeadCodeElim, "polly-dce",
|
2013-04-10 14:55:45 +08:00
|
|
|
"Polly - Remove dead iterations", false, false)
|
|
|
|
INITIALIZE_PASS_DEPENDENCY(Dependences)
|
|
|
|
INITIALIZE_PASS_DEPENDENCY(ScopInfo)
|
2013-03-23 08:16:05 +08:00
|
|
|
INITIALIZE_PASS_END(DeadCodeElim, "polly-dce", "Polly - Remove dead iterations",
|
|
|
|
false, false)
|